@charset "UTF-8";
/**
* スタイルシート統合
*/
/**
* 変数指定用フォルダ　随時追加予定
*
* ver.20211128
*/
/** テンプレファイル
* 一括指定、すべてのページに適用するスタイルなどはここに記述
* containerの指定などは全サイト共通にするのでこのファイルを使いまわす。
*
* ver.20221222
*/
html {
  scroll-behavior: smooth;
}

body {
  position: relative;
  line-height: 2em;
  font-family: "Noto Sans JP", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "ヒラギノ角ゴ ProN", "メイリオ", "MS UI Gothic", Sans;
  color: #3e3a39;
  font-weight: 400;
}
@media only screen and (max-width: 1600px) {
  body {
    font-size: 15px;
  }
}
@media only screen and (min-width: 1601px) {
  body {
    font-size: 0.9369144285vw;
  }
}

.content-wrapper {
  width: 100%;
  overflow-x: hidden !important;
  background-color: #ffffff;
}

.scrollLock {
  position: fixed;
  left: 0;
  right: 0;
  overflow: hidden;
}

a:hover {
  opacity: 0.9;
}

.container-wrap {
  position: relative;
  width: 100%;
}

.container {
  position: relative;
  margin: auto;
  width: calc(100% - 40px);
}
@media screen and (min-width: 992px) {
  .container {
    width: calc(100% - 120px);
  }
}
@media screen and (min-width: 1401px) {
  .container {
    width: calc(100% - 240px);
  }
}
@media screen and (min-width: 1601px) {
  .container {
    width: calc(100% - 14.9906308557vw);
  }
}

.container-right {
  position: relative;
  margin: auto;
  margin-right: 0;
  width: calc(100% - 20px);
  padding-right: 20px;
}
@media screen and (min-width: 992px) {
  .container-right {
    width: calc(100% - 60px);
    padding-right: 60px;
  }
}
@media screen and (min-width: 1401px) {
  .container-right {
    width: calc(100% - 120px);
    padding-right: 120px;
  }
}
@media screen and (min-width: 1601px) {
  .container-right {
    width: calc(100% - 7.4953154279vw);
    padding-right: 7.4953154279vw;
  }
}

.container-left {
  position: relative;
  margin: auto;
  margin-left: 0;
  width: calc(100% - 20px);
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .container-left {
    width: calc(100% - 60px);
    padding-left: 60px;
  }
}
@media screen and (min-width: 1401px) {
  .container-left {
    width: calc(100% - 120px);
    padding-left: 120px;
  }
}
@media screen and (min-width: 1601px) {
  .container-left {
    width: calc(100% - 7.4953154279vw);
    padding-left: 7.4953154279vw;
  }
}

.section-separator {
  height: 90px;
  opacity: 0;
}
@media screen and (min-width: 768px) {
  .section-separator {
    height: 120px;
  }
}
@media screen and (min-width: 1601px) {
  .section-separator {
    height: 7.4953154279vw;
  }
}

h1,
h2,
h3,
h4,
h5,
strong,
b {
  line-height: 2em;
}

.fadein {
  opacity: 0;
  transform: translate(0, 10px);
  transition: 0.8s ease-out;
}

.fadein.delay {
  transition-delay: 0.6s;
}

.fadein.is-inview {
  transform: translate(0, 0);
  opacity: 1;
}

.grecaptcha-badge {
  visibility: hidden;
}

#reCaptcha {
  font-size: 13px;
  text-align: left;
  padding-top: 20px;
  border-top: 1px solid #4a9d69;
}

#reCaptcha > a {
  color: #4a9d69;
}

/**
* 使いまわすコード置き場
*
* ver.20211128
*/
/**
* .heading1
*/
.heading {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  color: #3e3a39;
  font-weight: bold;
}
@media only screen and (max-width: 1600px) {
  .heading {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width: 1601px) {
  .heading {
    margin-bottom: 3.7476577139vw;
  }
}
@media only screen and (max-width: 1600px) {
  .heading {
    font-size: 18px;
  }
}
@media only screen and (min-width: 1601px) {
  .heading {
    font-size: 1.1242973142vw;
  }
}
.heading .en {
  text-transform: uppercase;
  font-family: "Lato", sans-serif;
  color: #c1c1c1;
}
@media only screen and (max-width: 1600px) {
  .heading .en {
    font-size: 50px;
  }
}
@media only screen and (min-width: 1601px) {
  .heading .en {
    font-size: 3.1230480949vw;
  }
}
@media only screen and (max-width: 767px) {
  .heading .en {
    font-size: 40px;
  }
}
.heading .wrap {
  display: flex;
  align-items: center;
}
.heading .line {
  display: block;
  content: "";
  background-color: #3e3a39;
  width: 30px;
  height: 4px;
  margin: 0 1em;
}
@media only screen and (min-width: 1601px) {
  .heading .line {
    width: 1.873828857vw;
    height: 0.2498438476vw;
  }
}

/**
* .heading2
*/
.heading2 {
  display: flex;
  align-items: center;
  color: #c1c1c1;
}
@media only screen and (max-width: 1600px) {
  .heading2 {
    margin-bottom: 15px;
  }
}
@media only screen and (min-width: 1601px) {
  .heading2 {
    margin-bottom: 0.9369144285vw;
  }
}
.heading2 .en {
  text-transform: uppercase;
  font-family: "Lato", sans-serif;
}
@media only screen and (max-width: 1600px) {
  .heading2 .en {
    font-size: 18px;
  }
}
@media only screen and (min-width: 1601px) {
  .heading2 .en {
    font-size: 1.1242973142vw;
  }
}
.heading2 .line {
  display: block;
  content: "";
  background-color: #c1c1c1;
  width: 2em;
  height: 4px;
  margin: 0 0.5em;
}
@media only screen and (min-width: 1601px) {
  .heading2 .line {
    height: 0.2498438476vw;
  }
}

/**
* .heading3
*/
.heading3 {
  display: inline-block;
  background-color: #fff;
  text-align: center;
  padding: 10px 20px;
  border-radius: 10px;
}
.heading3 span {
  display: block;
}
.heading3 .jp {
  font-weight: bold;
}
@media only screen and (max-width: 1600px) {
  .heading3 .jp {
    font-size: 20px;
  }
}
@media only screen and (min-width: 1601px) {
  .heading3 .jp {
    font-size: 1.249219238vw;
  }
}
@media only screen and (max-width: 767px) {
  .heading3 .jp {
    font-size: 18px;
  }
}
.heading3 .en {
  text-transform: uppercase;
  font-family: "Lato", sans-serif;
  color: #c1c1c1;
}
@media only screen and (max-width: 1600px) {
  .heading3 .en {
    font-size: 16px;
  }
}
@media only screen and (min-width: 1601px) {
  .heading3 .en {
    font-size: 0.9993753904vw;
  }
}
@media only screen and (max-width: 767px) {
  .heading3 .en {
    font-size: 15px;
  }
}

/**
* .more-btn
*/
.more-btn, #about-contact .contact .mail .mail-btn, #footer .right .contact .mail .mail-btn {
  position: relative;
  display: inline-block;
  text-transform: uppercase;
  font-family: "Lato", sans-serif;
  font-weight: bold;
  width: 215px;
  text-align: center;
  padding: 0.9em 0;
  border: 4px solid #3e3a39;
  border-radius: 0.5em;
  background-color: #fff;
  transition: 0.3s;
}
@media only screen and (max-width: 1600px) {
  .more-btn, #about-contact .contact .mail .mail-btn, #footer .right .contact .mail .mail-btn {
    font-size: 18px;
  }
}
@media only screen and (min-width: 1601px) {
  .more-btn, #about-contact .contact .mail .mail-btn, #footer .right .contact .mail .mail-btn {
    font-size: 1.1242973142vw;
  }
}
@media only screen and (min-width: 1601px) {
  .more-btn, #about-contact .contact .mail .mail-btn, #footer .right .contact .mail .mail-btn {
    width: 13.4291068082vw;
    border-width: 0.2498438476vw;
  }
}
.more-btn i, #about-contact .contact .mail .mail-btn i, #footer .right .contact .mail .mail-btn i {
  margin-left: 0.5em;
}
.more-btn:hover, #about-contact .contact .mail .mail-btn:hover, #footer .right .contact .mail .mail-btn:hover {
  color: #fff;
  background-color: #3e3a39;
}

/**
* 疑似要素
* @extend .element;
*/
.element, #page-keyvisual .container-wrap .container-left .page-title .jp::after, #mainvisual .container-wrap .bg-container h2 .s::after, #header .container-header.sp .nav-container .scroll nav > ul > li a .en::after,
#header .container-header.sp .nav-container .scroll nav > ul > li .has-child .en::after, #header .container-header.pc .container .gNav ul li + li::before {
  position: absolute;
  display: block;
  content: "";
}

/**
* 背景画像 中央いっぱい連続なし
* @extend .bgFull;
*/
.bgFull, #page-company .inner .right .image, #page-solution .container-wrap, #page-works .inner .box .box-inner .image-wrap .image, #page-keyvisual .container-wrap .container-left .bg, #top-service .inner .box, #top-works .inner .box .box-inner .image-wrap .image, #top-concept .container-wrap .image-wrap .image, #mainvisual .container-wrap .bg-container .background, #footer .right .contact .bg-pc {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.flex, .flex-column, #mainvisual .container-wrap .title-side .inner .icon-wrap, #mainvisual .container-wrap .title-side .inner, #mainvisual .container-wrap .title-side .title, #mainvisual .container-wrap .title-side, #back-to-top .icon-wrap, #footer .right .container-left .title, #footer .left .title, #footer .left, #splash .logo, .flex-center, .icon-btn {
  display: flex;
}

.flex-center, .icon-btn {
  justify-content: center;
  align-items: center;
}

.flex-column, #mainvisual .container-wrap .title-side .inner .icon-wrap, #mainvisual .container-wrap .title-side .inner, #mainvisual .container-wrap .title-side .title, #mainvisual .container-wrap .title-side, #back-to-top .icon-wrap, #footer .right .container-left .title, #footer .left .title, #footer .left, #splash .logo {
  flex-direction: column;
  align-items: center;
}

.icon-btn {
  color: #fff;
  background-color: #6bb0e1;
  width: 57px;
  height: 57px;
  border-radius: 0.2em;
}
@media only screen and (max-width: 1600px) {
  .icon-btn {
    font-size: 26px;
  }
}
@media only screen and (min-width: 1601px) {
  .icon-btn {
    font-size: 1.6239850094vw;
  }
}
@media only screen and (min-width: 1601px) {
  .icon-btn {
    width: 3.5602748282vw;
    height: 3.5602748282vw;
  }
}

.section-separator.tc {
  height: 60px;
  opacity: 0;
}
@media screen and (min-width: 768px) {
  .section-separator.tc {
    height: 80px;
  }
}
@media screen and (min-width: 992px) {
  .section-separator.tc {
    height: 60px;
  }
}

.pager {
  padding: 4em 0;
}
.pager .wp-pagenavi {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
.pager .page,
.pager .current {
  margin: 0 0.5em;
  border-radius: 1em;
  padding: 1.2em 2em;
  font-weight: bold;
  background-color: #f0f0f0;
}
@media only screen and (max-width: 767px) {
  .pager .page,
  .pager .current {
    padding: 1em 1.5em;
  }
}
.pager .current {
  color: #fff;
  background-color: #3e3b3a;
}
.pager .nextpostslink,
.pager .previouspostslink {
  display: inline-block;
  width: 2em;
  margin: 0 1em;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .pager .nextpostslink,
  .pager .previouspostslink {
    width: 1.5em;
  }
}

/**
* ローディング画面用スタイルシート
*/
/* オープニングアニメーション設定*/
#splash {
  /*fixedで全面に固定*/
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 99999;
  color: #3e3a39;
  /* Loading中央配置*/
  /* カウントアップ */
  /*IE11対策用バーの線の高さ※対応しなければ削除してください*/
  /*割れる画面のアニメーション*/
  /*割れる画面二重*/
  /*上の画面*/
  /*下の画面*/
  /*クラス名がついたらスケールを0*/
}
#splash .logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 150px;
  z-index: 99999;
}
#splash .logo strong {
  writing-mode: vertical-rl;
}
@media only screen and (max-width: 1600px) {
  #splash .logo strong {
    margin-top: 40px;
  }
}
@media only screen and (min-width: 1601px) {
  #splash .logo strong {
    margin-top: 2.498438476vw;
  }
}
#splash #splash_text {
  position: relative;
  z-index: 99999;
  width: 100%;
}
@media only screen and (max-width: 1600px) {
  #splash #splash_text {
    margin-top: 90px;
  }
}
@media only screen and (min-width: 1601px) {
  #splash #splash_text {
    margin-top: 5.6214865709vw;
  }
}
#splash #splash_text .progressbar-text {
  position: absolute;
  display: block;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 50px;
  font-weight: bold;
  font-weight: "Lato", sans-serif;
  color: #3e3a39 !important;
}
#splash #splash_text .progressbar-text svg {
  display: none;
}
#splash #splash_text svg {
  height: 2px;
}
#splash .loader_cover {
  position: absolute;
  width: 100%;
  height: 100%;
  transition: all 0.4s ease-in-out;
  transform: scaleY(1);
  background-color: #fff;
}
#splash .loader_cover.delay {
  background-color: #6bb0e1;
  transition-delay: 0.3s;
}
#splash .loader_cover-up {
  left: 0;
  transform-origin: top;
}
#splash .loader_cover-down {
  position: absolute;
  right: 0;
  transform-origin: right;
}
#splash .loader_cover-down.delay {
  background-color: #4a9d69;
}
#splash .loader_cover-up.coveranime,
#splash .loader_cover-down.coveranime {
  transform: scaleY(0);
}

/**
* Header用スタイルシート
*/
#header {
  position: absolute;
  width: 100%;
  z-index: 99;
}
#header .pc,
#header .sp {
  display: none;
}
@media only screen and (min-width: 1280px) {
  #header .pc {
    display: block;
  }
}
@media only screen and (max-width: 1279px) {
  #header {
    height: 66px;
  }
  #header .sp {
    display: block;
  }
}
#header .container-header.pc .container {
  padding-top: 40px;
  justify-content: flex-end;
}
#header .container-header.pc .container .fixed-logo {
  display: none;
  position: relative;
  right: 60px;
  align-items: center;
}
@media only screen and (min-width: 1601px) {
  #header .container-header.pc .container .fixed-logo {
    right: 3.7476577139vw;
  }
}
#header .container-header.pc .container .fixed-logo > a {
  display: block;
  width: 240px;
  margin-right: 1em;
}
#header .container-header.pc .container .fixed-logo > a img {
  width: 100%;
}
@media only screen and (min-width: 1601px) {
  #header .container-header.pc .container .fixed-logo > a {
    width: 14.9906308557vw;
  }
}
@media only screen and (max-width: 1600px) {
  #header .container-header.pc .container .fixed-logo > strong {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #header .container-header.pc .container .fixed-logo > strong {
    font-size: 0.8119925047vw;
  }
}
#header .container-header.pc .container .gNav ul li a {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-weight: bold;
  color: #fff;
}
#header .container-header.pc .container .gNav ul li a .en {
  font-family: "Lato", sans-serif;
  line-height: 2em;
  text-transform: uppercase;
}
@media only screen and (max-width: 1600px) {
  #header .container-header.pc .container .gNav ul li a .en {
    font-size: 18px;
  }
}
@media only screen and (min-width: 1601px) {
  #header .container-header.pc .container .gNav ul li a .en {
    font-size: 1.1242973142vw;
  }
}
@media only screen and (max-width: 1600px) {
  #header .container-header.pc .container .gNav ul li a .jp {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #header .container-header.pc .container .gNav ul li a .jp {
    font-size: 0.8119925047vw;
  }
}
#header .container-header.pc .container .gNav ul li + li {
  position: relative;
  margin-left: 4em;
}
#header .container-header.pc .container .gNav ul li + li::before {
  background-color: #fff;
  width: 4px;
  height: 3em;
  left: -2em;
  top: 0;
  bottom: 0;
  margin: auto;
}
@media only screen and (min-width: 1601px) {
  #header .container-header.pc .container .gNav ul li + li::before {
    width: 0.2498438476vw;
  }
}
#header .container-header.sp {
  height: 100%;
}
#header .container-header.sp > .inner {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #fff;
  height: 100%;
  z-index: 99999;
}
#header .container-header.sp > .inner .title {
  width: 53px;
}
#header .container-header.sp > .inner .title img {
  width: 100%;
}
#header .container-header.sp > .inner .openbtn {
  position: absolute;
  display: inline-block;
  right: 25px;
  top: 0;
  width: 62px;
  height: 62px;
  cursor: pointer;
  z-index: 99;
}
#header .container-header.sp > .inner .openbtn .line {
  transition: 0.3s;
  position: absolute;
  width: 30px;
  height: 4px;
  right: 0;
  margin: auto;
  background-color: #3e3a39;
}
#header .container-header.sp > .inner .openbtn .line1 {
  top: 24px;
}
#header .container-header.sp > .inner .openbtn .line3 {
  top: 38px;
  width: 30px;
}
#header .container-header.sp > .inner .openbtn.is-open {
  top: 0px;
}
#header .container-header.sp > .inner .openbtn.is-open .line {
  background-color: #3e3a39;
}
#header .container-header.sp > .inner .openbtn.is-open .line1 {
  top: 28px;
  transform: rotate(45deg);
}
#header .container-header.sp > .inner .openbtn.is-open .line3 {
  top: 28px;
  transform: rotate(-45deg);
}
#header .container-header.sp .glay-pannel {
  position: fixed;
  width: 100vw;
  height: 100vh;
  background-color: #000;
  opacity: 0;
  bottom: 0;
  visibility: hidden;
  transition: 0.3s ease-in-out;
}
#header .container-header.sp .glay-pannel.is-open {
  opacity: 0.5;
  visibility: visible;
}
#header .container-header.sp .nav-container {
  position: fixed;
  top: -140%;
  left: 0;
  width: 100%;
  padding: 86px 20px 30px;
  z-index: 995;
  background: #fff;
  transition: 0.5s ease-in-out;
  overflow-y: scroll;
  max-height: 100vh;
}
#header .container-header.sp .nav-container::-webkit-scrollbar {
  display: none;
}
#header .container-header.sp .nav-container .scroll .header-logo {
  height: 100%;
  margin-bottom: 40px;
}
#header .container-header.sp .nav-container .scroll nav {
  margin-bottom: 30px;
}
#header .container-header.sp .nav-container .scroll nav > ul > li {
  position: relative;
}
#header .container-header.sp .nav-container .scroll nav > ul > li a,
#header .container-header.sp .nav-container .scroll nav > ul > li .has-child {
  position: relative;
  display: flex;
  justify-content: space-between;
  font-weight: bold;
  padding: 15px 0 10px;
  color: #3e3a39;
}
#header .container-header.sp .nav-container .scroll nav > ul > li a .en,
#header .container-header.sp .nav-container .scroll nav > ul > li .has-child .en {
  display: flex;
  align-items: center;
  font-family: "Lato", sans-serif;
  color: #c1c1c1;
  text-transform: uppercase;
}
@media only screen and (max-width: 1600px) {
  #header .container-header.sp .nav-container .scroll nav > ul > li a .en,
  #header .container-header.sp .nav-container .scroll nav > ul > li .has-child .en {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #header .container-header.sp .nav-container .scroll nav > ul > li a .en,
  #header .container-header.sp .nav-container .scroll nav > ul > li .has-child .en {
    font-size: 0.8119925047vw;
  }
}
#header .container-header.sp .nav-container .scroll nav > ul > li a .en::after,
#header .container-header.sp .nav-container .scroll nav > ul > li .has-child .en::after {
  position: relative;
  width: 30px;
  height: 4px;
  margin-left: 1em;
  background-color: #3e3a39;
}
#header .container-header.sp .nav-container .scroll nav > ul > li a::before,
#header .container-header.sp .nav-container .scroll nav > ul > li .has-child::before {
  display: inline-block;
  position: absolute;
  content: "";
  background-color: #f0f0f0;
  width: 100%;
  height: 1px;
  bottom: 0;
  right: 0;
  border-radius: 3px;
}
#header .container-header.sp .nav-container .scroll nav > ul > li .child {
  display: none;
}
#header .container-header.sp .nav-container .scroll nav > ul > li #open {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  right: 0;
  top: 20px;
  height: 21px;
  width: 21px;
  z-index: 100;
  border-radius: 50%;
  background-color: #3e3a39;
  cursor: pointer;
  transition: 0.3s;
}
#header .container-header.sp .nav-container .scroll nav > ul > li #open i {
  font-size: 12px;
  color: #138ed2;
}
#header .container-header.sp .nav-container .scroll nav > ul > li #open.rotate {
  transform: rotate(180deg);
}
#header .container-header.sp .nav-container .scroll strong {
  display: block;
  font-size: 13px;
  text-align: center;
  margin-bottom: 20px;
}
#header .container-header.sp .nav-container .scroll .inner .inner-entry {
  position: relative;
  justify-content: space-between;
}
#header .container-header.sp .nav-container .scroll .inner .inner-entry > a {
  width: 50%;
  font-size: 18px;
  text-align: center;
  font-weight: bold;
  font-family: "Lato", sans-serif;
  color: #fff;
  text-transform: uppercase;
  padding: 15px 0;
}
#header .container-header.sp .nav-container .scroll .inner .inner-entry > a span {
  display: block;
  font-size: 13px;
  font-family: "Noto Sans JP", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "ヒラギノ角ゴ ProN", "メイリオ", "MS UI Gothic", Sans;
}
#header .container-header.sp .nav-container .scroll .inner .inner-entry > a i {
  position: relative;
  right: 0.4em;
}
#header .container-header.sp .nav-container .scroll .inner .inner-entry .mail-btn {
  background-color: #6bb0e1;
}
#header .container-header.sp .nav-container .scroll .inner .inner-entry .tel-btn {
  background-color: #4a9d69;
}
#header .container-header.sp .nav-container .scroll .inner .inner-contact {
  justify-content: space-between;
}
@media only screen and (max-width: 1279px) {
  #header .container-header.sp .nav-container .scroll .inner .inner-contact {
    justify-content: space-evenly;
  }
}
@media only screen and (max-width: 767px) {
  #header .container-header.sp .nav-container .scroll .inner .inner-contact {
    flex-direction: column;
    align-items: center;
  }
}
#header .container-header.sp .nav-container .scroll .inner .inner-contact .tel {
  width: calc(50% - 15px);
  font-weight: bold;
  text-align: center;
  color: #fff;
}
@media only screen and (max-width: 1600px) {
  #header .container-header.sp .nav-container .scroll .inner .inner-contact .tel {
    font-size: 33px;
  }
}
@media only screen and (min-width: 1601px) {
  #header .container-header.sp .nav-container .scroll .inner .inner-contact .tel {
    font-size: 2.0612117427vw;
  }
}
@media only screen and (max-width: 767px) {
  #header .container-header.sp .nav-container .scroll .inner .inner-contact .tel {
    width: 100%;
    margin-bottom: 30px;
  }
}
#header .container-header.sp .nav-container .scroll .inner .inner-contact .tel .icon {
  position: relative;
  display: inline-block;
  margin-right: 7px;
  width: 0.8em;
  height: 0.8em;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
#header .container-header.sp .nav-container .scroll .inner .inner-contact .tel .small {
  margin-left: 2em;
  font-weight: normal;
}
@media only screen and (max-width: 1600px) {
  #header .container-header.sp .nav-container .scroll .inner .inner-contact .tel .small {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #header .container-header.sp .nav-container .scroll .inner .inner-contact .tel .small {
    font-size: 0.8119925047vw;
  }
}
#header .container-header.sp .nav-container.is-open {
  top: 0;
}
#header .container-header.sp .fixed {
  position: fixed;
  width: calc(100% - 10px);
  height: 74px;
  bottom: -100px;
  left: 5px;
  transition: 0.3s;
  z-index: 990;
}
#header .container-header.sp .fixed .inner {
  width: 50%;
  padding: 0;
}
@media only screen and (max-width: 575px) {
  #header .container-header.sp .fixed .inner {
    width: 65%;
  }
}
#header .container-header.sp .fixed .inner .icon {
  width: 50%;
  padding: 0 8px;
  margin: auto;
}
#header .container-header.sp .fixed .inner .icon span {
  margin-left: 1em;
  display: inline-block;
}
@media only screen and (max-width: 575px) {
  #header .container-header.sp .fixed .inner .icon span {
    display: none;
  }
}
#header .container-header.sp .fixed .inner .job::before {
  right: 0;
}
#header .container-header.sp .fixed .contact {
  width: 50%;
}
@media only screen and (max-width: 575px) {
  #header .container-header.sp .fixed .contact {
    width: 35%;
  }
}
#header .container-header.sp .fixed .contact .icon {
  width: 50%;
  flex-direction: row;
}
#header .container-header.sp .fixed .contact .icon .text {
  margin-left: 1em;
  display: inline-block;
}
@media only screen and (max-width: 575px) {
  #header .container-header.sp .fixed .contact .icon .text {
    display: none;
  }
}
#header .container-header.sp .fixed .contact .icon .icon-tel {
  display: inline-block !important;
  top: 2px;
}
#header .container-header.sp .fixed.is-show {
  bottom: 4px;
}

#header.headTop {
  animation: 0.5s topAnime ease forwards !important;
}
@keyframes topAnime {
  0% {
    top: 0%;
  }
  100% {
    top: -100%;
  }
}

#header.isNotFront {
  position: relative;
  width: 100%;
  z-index: 9999;
  background-color: #ffffff;
}
#header.isNotFront .container-header.pc .container {
  justify-content: space-between;
  padding: 20px 0;
}
#header.isNotFront .container-header.pc .container .fixed-logo {
  display: flex;
}
#header.isNotFront .container-header.pc .container .gNav a {
  color: #3e3a39;
}
#header.isNotFront .container-header.pc .container .gNav li + li::before {
  background-color: #3e3a39;
}

#header.HeightMin {
  position: fixed;
  top: 0px;
  width: 100%;
  z-index: 9999;
  background-color: #ffffff;
  animation: 0.5s fixdAnime ease;
}
@keyframes fixdAnime {
  0% {
    top: -100%;
  }
  100% {
    top: 0%;
  }
}
#header.HeightMin .container-header.pc .container {
  justify-content: space-between;
  padding: 20px 0;
}
#header.HeightMin .container-header.pc .container .fixed-logo {
  display: flex;
}
#header.HeightMin .container-header.pc .container .gNav a {
  color: #3e3a39;
}
#header.HeightMin .container-header.pc .container .gNav li + li::before {
  background-color: #3e3a39;
}

#header.is-open {
  position: fixed;
  width: 100%;
  z-index: 9999999999999;
  background-color: #ffffff;
  top: 0;
}

/**
* Footer用スタイルシート
*/
@media only screen and (max-width: 1279px) {
  #footer {
    margin-bottom: 70px;
  }
}
#footer .left {
  width: 220px;
  justify-content: space-between;
  padding: 40px 0;
}
@media only screen and (min-width: 1601px) {
  #footer .left {
    width: 13.7414116177vw;
    padding: 2.498438476vw 0;
  }
}
@media only screen and (max-width: 575px) {
  #footer .left {
    display: none;
  }
}
#footer .left .title strong {
  writing-mode: vertical-rl;
}
@media only screen and (max-width: 1600px) {
  #footer .left .title strong {
    margin-top: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .left .title strong {
    margin-top: 1.873828857vw;
  }
}
@media only screen and (max-width: 1600px) {
  #footer .left .title strong {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .left .title strong {
    font-size: 0.8119925047vw;
  }
}
#footer .left .copyright {
  color: #c1c1c1;
}
@media only screen and (max-width: 1600px) {
  #footer .left .copyright {
    margin-top: 60px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .left .copyright {
    margin-top: 3.7476577139vw;
  }
}
#footer .right {
  width: calc(100% - 220px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
@media only screen and (max-width: 575px) {
  #footer .right {
    width: 100%;
  }
}
#footer .right .contact {
  justify-content: space-between;
}
@media only screen and (max-width: 991px) {
  #footer .right .contact {
    flex-direction: column;
    max-height: 631px;
  }
}
@media only screen and (max-width: 575px) {
  #footer .right .contact {
    max-height: 451px;
  }
}
#footer .right .contact .bg-pc {
  position: absolute;
  width: 100%;
  height: 450px;
  z-index: 0;
}
@media only screen and (max-width: 991px) {
  #footer .right .contact .bg-pc {
    display: none;
  }
}
#footer .right .contact .tel,
#footer .right .contact .mail {
  position: relative;
  color: #fff;
  text-align: center;
  width: 50%;
  padding: 80px 0;
}
@media only screen and (min-width: 992px) {
  #footer .right .contact .tel,
  #footer .right .contact .mail {
    background: none !important;
  }
}
@media only screen and (max-width: 991px) {
  #footer .right .contact .tel,
  #footer .right .contact .mail {
    width: 100%;
    padding: 90px 0;
  }
}
@media only screen and (max-width: 575px) {
  #footer .right .contact .tel,
  #footer .right .contact .mail {
    padding: 40px 0;
    background-size: cover;
  }
}
#footer .right .contact .tel span,
#footer .right .contact .tel a,
#footer .right .contact .mail span,
#footer .right .contact .mail a {
  display: block;
  font-weight: bold;
}
@media only screen and (max-width: 1600px) {
  #footer .right .contact .tel span,
  #footer .right .contact .tel a,
  #footer .right .contact .mail span,
  #footer .right .contact .mail a {
    margin-bottom: 10px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .right .contact .tel span,
  #footer .right .contact .tel a,
  #footer .right .contact .mail span,
  #footer .right .contact .mail a {
    margin-bottom: 0.624609619vw;
  }
}
#footer .right .contact .tel {
  border-right: 4px solid #fff;
}
@media only screen and (max-width: 991px) {
  #footer .right .contact .tel {
    border: none;
    border-bottom: 4px solid #fff;
  }
}
@media only screen and (max-width: 1600px) {
  #footer .right .contact .tel .tel-btn {
    font-size: 40px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .right .contact .tel .tel-btn {
    font-size: 2.498438476vw;
  }
}
#footer .right .contact .tel .tel-btn i {
  position: relative;
  bottom: 0.1em;
  right: 0.4em;
}
@media only screen and (max-width: 1600px) {
  #footer .right .contact .tel .tel-btn i {
    font-size: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .right .contact .tel .tel-btn i {
    font-size: 1.873828857vw;
  }
}
@media only screen and (max-width: 1600px) {
  #footer .right .contact .tel .phone-btn {
    font-size: 22px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .right .contact .tel .phone-btn {
    font-size: 1.3741411618vw;
  }
}
#footer .right .contact .tel .phone-btn img {
  height: 22px;
  position: relative;
  bottom: 0.1em;
  right: 0.4em;
}
#footer .right .contact .mail .mail-btn {
  width: 280px;
  border-color: #fff;
  color: #3e3a39;
}
#footer .right .contact .mail .mail-btn i {
  position: relative;
  top: 0.1em;
  right: 0.4em;
}
@media only screen and (max-width: 1600px) {
  #footer .right .contact .mail .mail-btn i {
    font-size: 26px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .right .contact .mail .mail-btn i {
    font-size: 1.6239850094vw;
  }
}
#footer .right .container-left {
  border-top-right-radius: 60px;
  background-color: #fff;
  padding: 60px 40px;
  margin-bottom: 0;
  justify-content: space-between;
}
@media only screen and (max-width: 1279px) {
  #footer .right .container-left {
    flex-wrap: wrap;
    padding: 30px 0;
  }
}
@media only screen and (max-width: 575px) {
  #footer .right .container-left {
    border-top-right-radius: 30px;
  }
}
#footer .right .container-left .line {
  position: relative;
  width: 4px;
  height: 100%;
  display: inline-block;
  background-color: #3e3a39;
}
@media only screen and (max-width: 1279px) {
  #footer .right .container-left .line {
    width: 220px;
    height: 4px;
    margin: 20px 0;
    margin-left: 20px;
  }
}
@media only screen and (max-width: 575px) {
  #footer .right .container-left .line {
    display: none;
  }
}
#footer .right .container-left .inner-left {
  width: 24%;
}
@media only screen and (max-width: 1279px) {
  #footer .right .container-left .inner-left {
    width: 100%;
    padding-left: 20px;
  }
}
@media only screen and (max-width: 575px) {
  #footer .right .container-left .inner-left {
    padding-left: 30px;
    margin-bottom: 30px;
  }
}
#footer .right .container-left .title {
  display: none;
  width: 160px;
  padding: 0 30px;
}
@media only screen and (max-width: 575px) {
  #footer .right .container-left .title {
    display: flex;
  }
}
#footer .right .container-left .title a,
#footer .right .container-left .title img {
  width: 100%;
}
#footer .right .container-left .title strong {
  writing-mode: vertical-rl;
}
@media only screen and (max-width: 1600px) {
  #footer .right .container-left .title strong {
    margin-top: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .right .container-left .title strong {
    margin-top: 1.873828857vw;
  }
}
@media only screen and (max-width: 1600px) {
  #footer .right .container-left .title strong {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .right .container-left .title strong {
    font-size: 0.8119925047vw;
  }
}
#footer .right .container-left .inner-right {
  width: 71%;
}
@media only screen and (max-width: 1279px) {
  #footer .right .container-left .inner-right {
    width: 100%;
    padding-left: 20px;
  }
}
@media only screen and (max-width: 575px) {
  #footer .right .container-left .inner-right {
    width: calc(100% - 160px);
    padding-left: 0;
  }
}
@media only screen and (max-width: 1600px) {
  #footer .right .container-left .inner-right span {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .right .container-left .inner-right span {
    font-size: 0.8119925047vw;
  }
}
#footer .right .container-left .inner-right p {
  display: block;
}
@media only screen and (max-width: 1600px) {
  #footer .right .container-left .inner-right p {
    margin-bottom: 10px;
  }
}
@media only screen and (min-width: 1601px) {
  #footer .right .container-left .inner-right p {
    margin-bottom: 0.624609619vw;
  }
}
#footer .right .container-left .inner-right p:last-of-type {
  margin-bottom: none;
}
#footer .right .container-left .copyright {
  display: none;
  margin: 30px 0 10px;
  color: #c1c1c1;
  text-align: center;
}
@media only screen and (max-width: 575px) {
  #footer .right .container-left .copyright {
    display: block;
    width: 100%;
  }
}

#back-to-top {
  position: fixed;
  bottom: 20px;
  right: 12px;
  z-index: 999;
  display: none;
  text-align: center;
}
#back-to-top .icon-wrap {
  margin-bottom: 20px;
}
@media only screen and (max-width: 1279px) {
  #back-to-top .icon-wrap {
    display: none !important;
  }
}
#back-to-top .icon-wrap .mail {
  background-color: #6bb0e1;
}
@media only screen and (max-width: 1600px) {
  #back-to-top .icon-wrap .mail {
    margin-bottom: 15px;
  }
}
@media only screen and (min-width: 1601px) {
  #back-to-top .icon-wrap .mail {
    margin-bottom: 0.9369144285vw;
  }
}
#back-to-top .icon-wrap .phone {
  background-color: #4a9d69;
}

#fixed-entry {
  position: fixed;
  bottom: 0px;
  width: 100%;
  height: 70px;
  justify-content: space-between;
  z-index: 999;
}
@media only screen and (min-width: 1280px) {
  #fixed-entry {
    display: none !important;
  }
}
#fixed-entry > a {
  width: 50%;
  font-size: 18px;
  text-align: center;
  font-weight: bold;
  font-family: "Lato", sans-serif;
  color: #fff;
  text-transform: uppercase;
  padding: 5px 0;
}
#fixed-entry > a span {
  display: block;
  font-size: 13px;
  font-family: "Noto Sans JP", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "ヒラギノ角ゴ ProN", "メイリオ", "MS UI Gothic", Sans;
}
#fixed-entry > a i {
  position: relative;
  right: 0.4em;
}
#fixed-entry .mail-btn {
  background-color: #6bb0e1;
}
#fixed-entry .tel-btn {
  background-color: #4a9d69;
}

/**
* トップページ用スタイルシート
*/
#mainvisual .container-wrap {
  height: 100vh;
}
@media only screen and (max-width: 1279px) {
  #mainvisual .container-wrap {
    margin-top: 66px;
    height: 488px;
  }
}
@media only screen and (max-width: 575px) {
  #mainvisual .container-wrap {
    height: 360px;
  }
}
#mainvisual .container-wrap .title-side {
  width: 220px;
  justify-content: space-between;
  padding: 35px 30px;
}
@media only screen and (min-width: 1601px) {
  #mainvisual .container-wrap .title-side {
    width: 13.7414116177vw;
    padding: 2.1861336665vw 0;
  }
}
@media only screen and (max-width: 1399px) {
  #mainvisual .container-wrap .title-side {
    width: 175px;
  }
}
@media only screen and (max-width: 1279px) {
  #mainvisual .container-wrap .title-side {
    display: none;
  }
}
#mainvisual .container-wrap .title-side .title a,
#mainvisual .container-wrap .title-side .title img {
  width: 100%;
}
#mainvisual .container-wrap .title-side .title strong {
  writing-mode: vertical-rl;
}
@media only screen and (max-width: 1600px) {
  #mainvisual .container-wrap .title-side .title strong {
    margin-top: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #mainvisual .container-wrap .title-side .title strong {
    margin-top: 1.873828857vw;
  }
}
@media only screen and (max-width: 1600px) {
  #mainvisual .container-wrap .title-side .title strong {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #mainvisual .container-wrap .title-side .title strong {
    font-size: 0.8119925047vw;
  }
}
@media only screen and (max-width: 1600px) {
  #mainvisual .container-wrap .title-side .inner .icon-wrap {
    margin-bottom: 40px;
  }
}
@media only screen and (min-width: 1601px) {
  #mainvisual .container-wrap .title-side .inner .icon-wrap {
    margin-bottom: 2.498438476vw;
  }
}
@media only screen and (max-width: 1399px) {
  #mainvisual .container-wrap .title-side .inner .icon-wrap {
    margin-bottom: 20px;
  }
}
#mainvisual .container-wrap .title-side .inner .icon-wrap .mail {
  background-color: #6bb0e1;
}
@media only screen and (max-width: 1600px) {
  #mainvisual .container-wrap .title-side .inner .icon-wrap .mail {
    margin-bottom: 15px;
  }
}
@media only screen and (min-width: 1601px) {
  #mainvisual .container-wrap .title-side .inner .icon-wrap .mail {
    margin-bottom: 0.9369144285vw;
  }
}
#mainvisual .container-wrap .title-side .inner .icon-wrap .phone {
  background-color: #4a9d69;
}
#mainvisual .container-wrap .title-side .inner .scroll {
  display: flex;
  font-weight: bold;
  letter-spacing: -2px;
  line-height: 1em;
  font-family: "Lato", sans-serif;
  writing-mode: vertical-rl;
  text-orientation: upright;
  text-transform: uppercase;
}
@media only screen and (max-width: 1600px) {
  #mainvisual .container-wrap .title-side .inner .scroll {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #mainvisual .container-wrap .title-side .inner .scroll {
    font-size: 0.8119925047vw;
  }
}
#mainvisual .container-wrap .title-side .inner .scroll .arrow {
  animation: scrollAnime 1.4s infinite;
  transform-origin: top;
}
@media only screen and (max-width: 1600px) {
  #mainvisual .container-wrap .title-side .inner .scroll .arrow {
    margin-top: 15px;
  }
}
@media only screen and (min-width: 1601px) {
  #mainvisual .container-wrap .title-side .inner .scroll .arrow {
    margin-top: 0.9369144285vw;
  }
}
@keyframes scrollAnime {
  0% {
    opacity: 0;
    transform: translateY(-0.8em);
  }
  55% {
    opacity: 1;
    transform: translateY(0);
  }
  85% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(0.8em);
  }
}
#mainvisual .container-wrap .bg-container {
  position: relative;
  width: calc(100% - 220px);
  height: 100%;
}
@media only screen and (max-width: 1399px) {
  #mainvisual .container-wrap .bg-container {
    width: calc(100% - 175px);
  }
}
@media only screen and (max-width: 1279px) {
  #mainvisual .container-wrap .bg-container {
    width: calc(100% - 60px);
    margin-left: 60px;
  }
}
@media only screen and (max-width: 991px) {
  #mainvisual .container-wrap .bg-container {
    width: calc(100% - 20px);
    margin-left: 20px;
  }
}
#mainvisual .container-wrap .bg-container .background {
  position: absolute;
  width: 100%;
  height: 100%;
  border-bottom-left-radius: 3em;
}
@media only screen and (min-width: 576px) {
  #mainvisual .container-wrap .bg-container .sp {
    display: none;
  }
}
#mainvisual .container-wrap .bg-container h2 {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  position: absolute;
  top: 22%;
  right: 120px;
}
@media only screen and (min-width: 1601px) {
  #mainvisual .container-wrap .bg-container h2 {
    top: 13.7414116177vw;
    right: 7.4953154279vw;
  }
}
@media only screen and (max-width: 1279px) {
  #mainvisual .container-wrap .bg-container h2 {
    top: 74px;
  }
}
@media only screen and (max-width: 575px) {
  #mainvisual .container-wrap .bg-container h2 {
    top: 53px;
    right: 60px;
  }
}
#mainvisual .container-wrap .bg-container h2 span {
  display: inline-block;
  color: #fff;
  font-weight: bold;
  writing-mode: vertical-rl;
  line-height: 2em;
}
#mainvisual .container-wrap .bg-container h2 .s {
  position: relative;
  letter-spacing: 0.25em;
}
@media only screen and (max-width: 1600px) {
  #mainvisual .container-wrap .bg-container h2 .s {
    font-size: 28px;
  }
}
@media only screen and (min-width: 1601px) {
  #mainvisual .container-wrap .bg-container h2 .s {
    font-size: 1.7489069332vw;
  }
}
#mainvisual .container-wrap .bg-container h2 .s::after {
  background-color: #fff;
  width: 4px;
  height: 3em;
  top: 100%;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
@media only screen and (max-width: 1399px) {
  #mainvisual .container-wrap .bg-container h2 .s {
    font-size: 24px;
  }
}
@media only screen and (max-width: 1279px) {
  #mainvisual .container-wrap .bg-container h2 .s {
    font-size: 20px;
    letter-spacing: 0.1em;
  }
  #mainvisual .container-wrap .bg-container h2 .s::after {
    width: 2px;
    height: 2em;
  }
}
@media only screen and (max-width: 575px) {
  #mainvisual .container-wrap .bg-container h2 .s {
    font-size: 16px;
  }
  #mainvisual .container-wrap .bg-container h2 .s::after {
    height: 1.5em;
  }
}
#mainvisual .container-wrap .bg-container h2 .l {
  letter-spacing: 0.2em;
}
@media only screen and (max-width: 1600px) {
  #mainvisual .container-wrap .bg-container h2 .l {
    font-size: 40px;
  }
}
@media only screen and (min-width: 1601px) {
  #mainvisual .container-wrap .bg-container h2 .l {
    font-size: 2.498438476vw;
  }
}
@media only screen and (max-width: 1399px) {
  #mainvisual .container-wrap .bg-container h2 .l {
    font-size: 34px;
  }
}
@media only screen and (max-width: 1279px) {
  #mainvisual .container-wrap .bg-container h2 .l {
    font-size: 28px;
    letter-spacing: 0.1em;
  }
}
@media only screen and (max-width: 575px) {
  #mainvisual .container-wrap .bg-container h2 .l {
    font-size: 20px;
  }
}

#top-concept .container-right {
  position: relative;
  background-color: #fff;
  width: 50%;
  padding-top: 60px;
  padding-left: 60px;
  padding-bottom: 60px;
  top: -60px;
  border-top-left-radius: 30px;
}
@media only screen and (max-width: 1279px) {
  #top-concept .container-right {
    width: 500px;
    min-width: 0px;
    top: -40px;
    padding-top: 40px;
    padding-left: 40px;
    padding-bottom: 40px;
  }
}
@media only screen and (max-width: 767px) {
  #top-concept .container-right {
    width: calc(100% - 40px);
    top: -30px;
    padding-top: 30px;
    padding-left: 30px;
    padding-bottom: 30px;
  }
}
#top-concept .container-right strong {
  display: flex;
  align-items: center;
}
@media only screen and (max-width: 1600px) {
  #top-concept .container-right strong {
    font-size: 28px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-concept .container-right strong {
    font-size: 1.7489069332vw;
  }
}
@media only screen and (max-width: 1600px) {
  #top-concept .container-right strong {
    margin-bottom: 40px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-concept .container-right strong {
    margin-bottom: 2.498438476vw;
  }
}
@media only screen and (max-width: 767px) {
  #top-concept .container-right strong {
    font-size: 22px;
    text-align: center;
    margin-bottom: 30px;
  }
}
#top-concept .container-right strong::before, #top-concept .container-right strong::after {
  position: relative;
  display: inline-block;
  content: "";
  width: 17px;
  height: 32px;
}
#top-concept .container-right strong::before {
  align-self: flex-start;
  border-left: 6px solid #3e3a39;
  border-top: 6px solid #3e3a39;
}
#top-concept .container-right strong::after {
  align-self: flex-end;
  border-right: 6px solid #3e3a39;
  border-bottom: 6px solid #3e3a39;
}
@media only screen and (max-width: 1600px) {
  #top-concept .container-right p {
    margin-bottom: 40px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-concept .container-right p {
    margin-bottom: 2.498438476vw;
  }
}
#top-concept .container-wrap {
  position: relative;
}
#top-concept .container-wrap .image-wrap {
  position: absolute;
  left: 0;
  bottom: 60px;
  width: 50%;
}
@media only screen and (max-width: 991px) {
  #top-concept .container-wrap .image-wrap {
    bottom: 200px;
  }
}
@media only screen and (max-width: 991px) {
  #top-concept .container-wrap .image-wrap {
    width: calc(100% - 500px);
  }
}
@media only screen and (max-width: 767px) {
  #top-concept .container-wrap .image-wrap {
    position: relative;
    width: 100%;
    bottom: 30px;
  }
}
#top-concept .container-wrap .image-wrap .en {
  position: relative;
  text-transform: uppercase;
  font-family: "Lato", sans-serif;
  color: #f0f0f0;
  top: 0.12em;
}
@media only screen and (max-width: 1600px) {
  #top-concept .container-wrap .image-wrap .en {
    font-size: 70px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-concept .container-wrap .image-wrap .en {
    font-size: 4.3722673329vw;
  }
}
@media only screen and (max-width: 991px) {
  #top-concept .container-wrap .image-wrap .en {
    font-size: 45px;
  }
}
@media only screen and (max-width: 767px) {
  #top-concept .container-wrap .image-wrap .en {
    display: block;
    font-size: 34px;
    top: 0em;
    text-align: center;
  }
}
#top-concept .container-wrap .image-wrap .image {
  position: relative;
  width: 100%;
  height: 375px;
}
@media only screen and (min-width: 1601px) {
  #top-concept .container-wrap .image-wrap .image {
    height: 23.4228607121vw;
  }
}
@media only screen and (max-width: 991px) {
  #top-concept .container-wrap .image-wrap .image {
    height: 315px;
  }
}
@media only screen and (max-width: 767px) {
  #top-concept .container-wrap .image-wrap .image {
    height: 165px;
  }
}

@media only screen and (max-width: 767px) {
  #top-works .heading {
    margin-bottom: 40px;
  }
}
@media only screen and (max-width: 575px) {
  #top-works .heading {
    justify-content: center;
  }
}
@media only screen and (max-width: 991px) {
  #top-works .container.max {
    width: 100%;
  }
}
#top-works .inner {
  flex-wrap: wrap;
  border-left: 1px solid #f0f0f0;
}
@media only screen and (max-width: 1600px) {
  #top-works .inner {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-works .inner {
    margin-bottom: 3.7476577139vw;
  }
}
#top-works .inner .box {
  width: calc((100% - 0px) / 3);
  margin-right: 0px;
  border-bottom: 1px solid #f0f0f0;
  border-right: 1px solid #f0f0f0;
}
@media only screen and (min-width: 1601px) {
  #top-works .inner .box {
    width: calc((100% - 0vw) / 3);
    margin-right: 0vw;
  }
}
#top-works .inner .box:nth-of-type(3n) {
  margin-right: 0;
}
@media only screen and (max-width: 991px) {
  #top-works .inner .box {
    width: calc((100% - 0px) / 2);
  }
  #top-works .inner .box:nth-of-type(3n) {
    margin-right: 0;
  }
  #top-works .inner .box:nth-of-type(2n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 767px) {
  #top-works .inner .box {
    width: 100%;
    margin-right: 0 !important;
  }
}
#top-works .inner .box:nth-of-type(-n + 3) {
  border-top: 1px solid #f0f0f0;
}
@media only screen and (max-width: 991px) {
  #top-works .inner .box:nth-of-type(-n + 3) {
    border-top: none;
  }
}
@media only screen and (max-width: 991px) {
  #top-works .inner .box:nth-of-type(-n + 2) {
    border-top: 1px solid #f0f0f0;
  }
}
@media only screen and (max-width: 991px) and (max-width: 767px) {
  #top-works .inner .box:nth-of-type(-n + 2) {
    border-top: none;
  }
}
@media only screen and (max-width: 767px) {
  #top-works .inner .box:nth-of-type(1) {
    border-top: 1px solid #f0f0f0;
  }
}
#top-works .inner .box .box-inner {
  padding: 40px;
  display: block;
}
@media only screen and (max-width: 767px) {
  #top-works .inner .box .box-inner {
    padding: 30px;
  }
}
#top-works .inner .box .box-inner .image-wrap {
  overflow: hidden;
  border-radius: 1em;
}
@media only screen and (max-width: 1600px) {
  #top-works .inner .box .box-inner .image-wrap {
    margin-bottom: 20px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-works .inner .box .box-inner .image-wrap {
    margin-bottom: 1.249219238vw;
  }
}
#top-works .inner .box .box-inner .image-wrap .image {
  width: 100%;
  transition: 0.3s;
}
#top-works .inner .box .box-inner .image-wrap .image::before {
  display: block;
  content: "";
  padding-top: 70%;
}
@media only screen and (max-width: 1600px) {
  #top-works .inner .box .box-inner .text .date {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-works .inner .box .box-inner .text .date {
    font-size: 0.8119925047vw;
  }
}
#top-works .inner .box .box-inner .text h3 {
  font-weight: bold;
}
#top-works .inner .box .box-inner .text .category {
  color: #7e7e7e;
}
@media only screen and (max-width: 1600px) {
  #top-works .inner .box .box-inner .text .category {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-works .inner .box .box-inner .text .category {
    font-size: 0.8119925047vw;
  }
}
#top-works .inner .box .box-inner:hover .image-wrap .image {
  transform: scale(1.2);
}
#top-works .more-btn, #top-works #about-contact .contact .mail .mail-btn, #about-contact .contact .mail #top-works .mail-btn, #top-works #footer .right .contact .mail .mail-btn, #footer .right .contact .mail #top-works .mail-btn {
  display: block;
  margin: auto;
}

#top-service .heading {
  justify-content: center;
}
#top-service .inner {
  flex-wrap: wrap;
  justify-content: space-between;
}
#top-service .inner .box {
  color: #fff;
  padding: 40px;
  border-radius: 40px;
}
#top-service .inner .box:nth-of-type(-n + 2) {
  width: calc((100% - 40px) / 2);
  margin-bottom: 40px;
}
#top-service .inner .box:nth-of-type(n + 3) {
  width: calc((100% - 80px) / 3);
}
@media only screen and (min-width: 1601px) {
  #top-service .inner .box {
    padding: 2.498438476vw;
    border-radius: 2.498438476vw;
  }
}
@media only screen and (max-width: 1279px) {
  #top-service .inner .box {
    width: 100% !important;
    margin-bottom: 40px;
  }
  #top-service .inner .box:last-of-type {
    margin-bottom: 0;
  }
}
@media only screen and (max-width: 767px) {
  #top-service .inner .box {
    padding: 30px;
    border-radius: 30px;
    margin-bottom: 30px;
  }
  #top-service .inner .box:last-of-type {
    margin-bottom: 0;
  }
}
#top-service .inner .box .box-inner {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
@media only screen and (max-width: 1600px) {
  #top-service .inner .box h3 {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-service .inner .box h3 {
    margin-bottom: 3.7476577139vw;
  }
}
#top-service .inner .box h3 .en {
  text-transform: uppercase;
  font-family: "Lato", sans-serif;
  display: block;
}
@media only screen and (max-width: 1600px) {
  #top-service .inner .box h3 .en {
    font-size: 24px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-service .inner .box h3 .en {
    font-size: 1.4990630856vw;
  }
}
@media only screen and (max-width: 1600px) {
  #top-service .inner .box h3 .en {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-service .inner .box h3 .en {
    margin-bottom: 1.873828857vw;
  }
}
#top-service .inner .box h3 .jp {
  font-weight: bold;
}
@media only screen and (max-width: 1600px) {
  #top-service .inner .box h3 .jp {
    font-size: 18px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-service .inner .box h3 .jp {
    font-size: 1.1242973142vw;
  }
}

#top-news .container {
  justify-content: space-between;
}
@media only screen and (max-width: 1279px) {
  #top-news .container {
    flex-direction: column;
  }
}
#top-news .container .left {
  width: 30%;
}
@media only screen and (max-width: 1279px) {
  #top-news .container .left {
    width: 100%;
    margin-bottom: 60px;
  }
  #top-news .container .left .heading {
    justify-content: center;
  }
  #top-news .container .left .more-btn, #top-news .container .left #about-contact .contact .mail .mail-btn, #about-contact .contact .mail #top-news .container .left .mail-btn, #top-news .container .left #footer .right .contact .mail .mail-btn, #footer .right .contact .mail #top-news .container .left .mail-btn {
    display: block;
    margin: auto;
  }
}
#top-news .container .right {
  width: 70%;
}
@media only screen and (max-width: 1279px) {
  #top-news .container .right {
    width: 100%;
  }
}
#top-news .container .right .box {
  border-top: 1px solid #f0f0f0;
}
#top-news .container .right .box:last-of-type {
  border-bottom: 1px solid #f0f0f0;
}
#top-news .container .right .box .box-inner {
  display: block;
  padding: 2em;
}
@media only screen and (max-width: 991px) {
  #top-news .container .right .box .box-inner {
    padding: 2em 0;
  }
}
@media only screen and (max-width: 1600px) {
  #top-news .container .right .box .box-inner .dc {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #top-news .container .right .box .box-inner .dc {
    font-size: 0.8119925047vw;
  }
}
#top-news .container .right .box .box-inner .dc .category {
  margin-left: 0.5em;
  color: #7e7e7e;
}
#top-news .container .right .box .box-inner h3 {
  font-weight: bold;
  transition: 0.1s;
}
#top-news .container .right .box .box-inner:hover h3 {
  color: #e58001;
}

/**
* 下層ページ用スタイルシート
*/
#page-keyvisual .container-wrap {
  height: 380px;
  padding-top: 40px;
}
@media only screen and (min-width: 1601px) {
  #page-keyvisual .container-wrap {
    height: 23.7351655215vw;
    padding-top: 2.498438476vw;
  }
}
@media only screen and (max-width: 575px) {
  #page-keyvisual .container-wrap {
    height: 300px;
    padding-top: 20px;
  }
}
#page-keyvisual .container-wrap .container-left {
  display: flex;
  justify-content: flex-end;
  height: 100%;
}
#page-keyvisual .container-wrap .container-left .bg {
  position: absolute;
  display: inline-block;
  width: calc(100% - 125px);
  height: 100%;
  left: 0;
  border-bottom-right-radius: 3em;
}
@media only screen and (max-width: 575px) {
  #page-keyvisual .container-wrap .container-left .bg {
    width: calc(100% - 80px);
  }
}
#page-keyvisual .container-wrap .container-left .page-title {
  display: flex;
  align-items: flex-start;
}
#page-keyvisual .container-wrap .container-left .page-title span {
  position: relative;
  display: inline-block;
  font-weight: bold;
  writing-mode: vertical-rl;
  line-height: 1.5em;
}
#page-keyvisual .container-wrap .container-left .page-title .en {
  letter-spacing: 0.25em;
  text-transform: uppercase;
  font-family: "Lato", sans-serif;
  color: #c1c1c1;
}
@media only screen and (max-width: 1600px) {
  #page-keyvisual .container-wrap .container-left .page-title .en {
    font-size: 15px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-keyvisual .container-wrap .container-left .page-title .en {
    font-size: 0.9369144285vw;
  }
}
#page-keyvisual .container-wrap .container-left .page-title .jp {
  letter-spacing: 0.2em;
}
@media only screen and (max-width: 1600px) {
  #page-keyvisual .container-wrap .container-left .page-title .jp {
    font-size: 28px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-keyvisual .container-wrap .container-left .page-title .jp {
    font-size: 1.7489069332vw;
  }
}
@media only screen and (max-width: 575px) {
  #page-keyvisual .container-wrap .container-left .page-title .jp {
    font-size: 22px;
  }
}
#page-keyvisual .container-wrap .container-left .page-title .jp::after {
  background-color: #3e3a39;
  width: 4px;
  height: 77px;
  top: calc(100% + 0.3em);
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}

/**
* お知らせ一覧ページ
* page-news
*/
#page-news .box {
  border-top: 1px solid #f0f0f0;
}
#page-news .box:last-of-type {
  border-bottom: 1px solid #f0f0f0;
}
#page-news .box .box-inner {
  display: block;
  padding: 2em;
}
@media only screen and (max-width: 991px) {
  #page-news .box .box-inner {
    padding: 2em 0;
  }
}
@media only screen and (max-width: 1600px) {
  #page-news .box .box-inner .dc {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-news .box .box-inner .dc {
    font-size: 0.8119925047vw;
  }
}
#page-news .box .box-inner .dc .category {
  margin-left: 0.5em;
  color: #7e7e7e;
}
#page-news .box .box-inner h3 {
  font-weight: bold;
  transition: 0.1s;
}
#page-news .box .box-inner:hover h3 {
  color: #e58001;
}

/**
* 施工実績一覧ページ
* page-works
*/
#page-works .inner {
  flex-wrap: wrap;
  border-left: 1px solid #f0f0f0;
}
#page-works .inner .box {
  width: calc((100% - 0px) / 3);
  margin-right: 0px;
  border-bottom: 1px solid #f0f0f0;
  border-right: 1px solid #f0f0f0;
}
@media only screen and (min-width: 1601px) {
  #page-works .inner .box {
    width: calc((100% - 0vw) / 3);
    margin-right: 0vw;
  }
}
#page-works .inner .box:nth-of-type(3n) {
  margin-right: 0;
}
@media only screen and (max-width: 991px) {
  #page-works .inner .box {
    width: calc((100% - 0px) / 2);
  }
  #page-works .inner .box:nth-of-type(3n) {
    margin-right: 0;
  }
  #page-works .inner .box:nth-of-type(2n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 767px) {
  #page-works .inner .box {
    width: 100%;
    margin-right: 0 !important;
  }
}
#page-works .inner .box:nth-of-type(-n + 3) {
  border-top: 1px solid #f0f0f0;
}
@media only screen and (max-width: 991px) {
  #page-works .inner .box:nth-of-type(-n + 3) {
    border-top: none;
  }
}
@media only screen and (max-width: 991px) {
  #page-works .inner .box:nth-of-type(-n + 2) {
    border-top: 1px solid #f0f0f0;
  }
}
@media only screen and (max-width: 991px) and (max-width: 767px) {
  #page-works .inner .box:nth-of-type(-n + 2) {
    border-top: none;
  }
}
@media only screen and (max-width: 767px) {
  #page-works .inner .box:nth-of-type(1) {
    border-top: 1px solid #f0f0f0;
  }
}
#page-works .inner .box .box-inner {
  padding: 40px;
  display: block;
}
@media only screen and (max-width: 767px) {
  #page-works .inner .box .box-inner {
    padding: 30px;
  }
}
#page-works .inner .box .box-inner .image-wrap {
  overflow: hidden;
  border-radius: 1em;
}
@media only screen and (max-width: 1600px) {
  #page-works .inner .box .box-inner .image-wrap {
    margin-bottom: 20px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-works .inner .box .box-inner .image-wrap {
    margin-bottom: 1.249219238vw;
  }
}
#page-works .inner .box .box-inner .image-wrap .image {
  width: 100%;
  transition: 0.3s;
}
#page-works .inner .box .box-inner .image-wrap .image::before {
  display: block;
  content: "";
  padding-top: 70%;
}
@media only screen and (max-width: 1600px) {
  #page-works .inner .box .box-inner .text .date {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-works .inner .box .box-inner .text .date {
    font-size: 0.8119925047vw;
  }
}
#page-works .inner .box .box-inner .text h3 {
  font-weight: bold;
}
#page-works .inner .box .box-inner .text .category {
  color: #7e7e7e;
}
@media only screen and (max-width: 1600px) {
  #page-works .inner .box .box-inner .text .category {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-works .inner .box .box-inner .text .category {
    font-size: 0.8119925047vw;
  }
}
#page-works .inner .box .box-inner:hover .image-wrap .image {
  transform: scale(1.2);
}

/**
* 平賀工務店とはページ
* page-about
*/
#concept .container-wrap .container-left {
  align-items: flex-end;
}
@media only screen and (max-width: 991px) {
  #concept .container-wrap .container-left {
    align-items: flex-start;
  }
}
@media only screen and (max-width: 767px) {
  #concept .container-wrap .container-left {
    flex-direction: column;
  }
}
#concept .container-wrap .container-left .left {
  position: relative;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  #concept .container-wrap .container-left .left {
    width: 100%;
    padding-right: 0;
    margin-bottom: 40px;
  }
}
#concept .container-wrap .container-left .left strong {
  display: flex;
  align-items: center;
}
@media only screen and (max-width: 1600px) {
  #concept .container-wrap .container-left .left strong {
    font-size: 28px;
  }
}
@media only screen and (min-width: 1601px) {
  #concept .container-wrap .container-left .left strong {
    font-size: 1.7489069332vw;
  }
}
@media only screen and (max-width: 1600px) {
  #concept .container-wrap .container-left .left strong {
    margin-bottom: 40px;
  }
}
@media only screen and (min-width: 1601px) {
  #concept .container-wrap .container-left .left strong {
    margin-bottom: 2.498438476vw;
  }
}
@media only screen and (max-width: 767px) {
  #concept .container-wrap .container-left .left strong {
    font-size: 22px;
    text-align: center;
    margin-bottom: 30px;
  }
}
#concept .container-wrap .container-left .left strong::before, #concept .container-wrap .container-left .left strong::after {
  position: relative;
  display: inline-block;
  content: "";
  width: 17px;
  height: 32px;
}
#concept .container-wrap .container-left .left strong::before {
  align-self: flex-start;
  border-left: 6px solid #3e3a39;
  border-top: 6px solid #3e3a39;
}
#concept .container-wrap .container-left .left strong::after {
  align-self: flex-end;
  border-right: 6px solid #3e3a39;
  border-bottom: 6px solid #3e3a39;
}
#concept .container-wrap .container-left .left > p {
  display: block;
}
@media only screen and (max-width: 1600px) {
  #concept .container-wrap .container-left .left > p {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width: 1601px) {
  #concept .container-wrap .container-left .left > p {
    margin-bottom: 3.7476577139vw;
  }
}
@media only screen and (max-width: 1600px) {
  #concept .container-wrap .container-left .left > p {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #concept .container-wrap .container-left .left > p {
    margin-bottom: 1.873828857vw;
  }
}
@media only screen and (max-width: 767px) {
  #concept .container-wrap .container-left .left > p {
    margin-bottom: 40px;
  }
}
#concept .container-wrap .container-left .left > img {
  position: relative;
  width: calc(100% + 120px);
  left: -120px;
}
@media only screen and (min-width: 1601px) {
  #concept .container-wrap .container-left .left > img {
    width: calc(100% + 7.4953154279vw);
    left: -7.4953154279vw;
  }
}
@media only screen and (max-width: 1399px) {
  #concept .container-wrap .container-left .left > img {
    width: calc(100% + 60px);
    left: -60px;
  }
}
@media only screen and (max-width: 767px) {
  #concept .container-wrap .container-left .left > img {
    width: calc(100% + 40px);
    left: -20px;
  }
}
#concept .container-wrap .container-left .right {
  width: 33%;
  position: relative;
}
@media only screen and (max-width: 1279px) {
  #concept .container-wrap .container-left .right {
    width: 40%;
  }
}
@media only screen and (max-width: 767px) {
  #concept .container-wrap .container-left .right {
    width: 100%;
  }
}
#concept .container-wrap .container-left .right > .en {
  position: absolute;
  font-size: 40px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-family: "Lato", sans-serif;
  color: #f0f0f0;
  font-weight: bold;
  writing-mode: vertical-rl;
  line-height: 1em;
  left: 0;
  top: 0;
}
#concept .container-wrap .container-left .right .image-wrap {
  position: relative;
  align-items: flex-start;
}
@media only screen and (max-width: 1600px) {
  #concept .container-wrap .container-left .right .image-wrap {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #concept .container-wrap .container-left .right .image-wrap {
    margin-bottom: 1.873828857vw;
  }
}
#concept .container-wrap .container-left .right .image-wrap img:nth-of-type(1) {
  width: 8%;
}
#concept .container-wrap .container-left .right .image-wrap img:nth-of-type(2) {
  width: 92%;
}
#concept .container-wrap .container-left .name {
  font-weight: bold;
}
@media only screen and (max-width: 1600px) {
  #concept .container-wrap .container-left .name {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width: 1601px) {
  #concept .container-wrap .container-left .name {
    margin-bottom: 3.7476577139vw;
  }
}
#concept .container-wrap .container-left .name > span {
  display: block;
  color: #7e7e7e;
}
#concept .container-wrap .container-left .name > p {
  line-height: 2em;
}
@media only screen and (max-width: 1600px) {
  #concept .container-wrap .container-left .name > p {
    font-size: 22px;
  }
}
@media only screen and (min-width: 1601px) {
  #concept .container-wrap .container-left .name > p {
    font-size: 1.3741411618vw;
  }
}
#concept .container-wrap .container-left .name > p .en {
  color: #c1c1c1;
  text-transform: uppercase;
  font-family: "Lato", sans-serif;
  margin-left: 1em;
}
@media only screen and (max-width: 1600px) {
  #concept .container-wrap .container-left .name > p .en {
    font-size: 18px;
  }
}
@media only screen and (min-width: 1601px) {
  #concept .container-wrap .container-left .name > p .en {
    font-size: 1.1242973142vw;
  }
}

#service .inner-head {
  text-align: center;
}
@media only screen and (max-width: 1600px) {
  #service .inner-head {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width: 1601px) {
  #service .inner-head {
    margin-bottom: 3.7476577139vw;
  }
}
#service .inner-head .heading {
  justify-content: center;
}
#service .inner-head strong {
  display: block;
}
@media only screen and (max-width: 1600px) {
  #service .inner-head strong {
    font-size: 28px;
  }
}
@media only screen and (min-width: 1601px) {
  #service .inner-head strong {
    font-size: 1.7489069332vw;
  }
}
@media only screen and (max-width: 1600px) {
  #service .inner-head strong {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width: 1601px) {
  #service .inner-head strong {
    margin-bottom: 3.7476577139vw;
  }
}
@media only screen and (max-width: 767px) {
  #service .inner-head strong {
    font-size: 22px;
  }
}
#service .flex-wrap {
  flex-wrap: wrap;
  justify-content: space-between;
  border-left: 1px solid #f0f0f0;
}
#service .flex-wrap .flex-inner {
  position: relative;
  padding: 40px;
  border-bottom: 1px solid #f0f0f0;
  border-right: 1px solid #f0f0f0;
}
#service .flex-wrap .flex-inner:nth-of-type(-n + 2) {
  width: 50%;
}
#service .flex-wrap .flex-inner:nth-of-type(-n + 2) .text {
  padding-top: 36%;
}
#service .flex-wrap .flex-inner:nth-of-type(n + 3) {
  width: 33.3333333333%;
}
#service .flex-wrap .flex-inner:nth-of-type(n + 3) .text {
  padding-top: 59%;
}
#service .flex-wrap .flex-inner:nth-of-type(-n + 2) {
  border-top: 1px solid #f0f0f0;
}
@media only screen and (max-width: 991px) {
  #service .flex-wrap .flex-inner:nth-of-type(-n + 2) {
    border-top: none;
  }
}
@media only screen and (min-width: 1601px) {
  #service .flex-wrap .flex-inner {
    padding: 2.498438476vw;
  }
}
@media only screen and (max-width: 991px) {
  #service .flex-wrap .flex-inner {
    width: 100% !important;
  }
  #service .flex-wrap .flex-inner .text {
    padding-top: 64% !important;
  }
}
@media only screen and (max-width: 767px) {
  #service .flex-wrap .flex-inner {
    padding: 30px;
  }
  #service .flex-wrap .flex-inner .text {
    padding-top: 61% !important;
  }
}
#service .flex-wrap .flex-inner img {
  position: absolute;
  width: calc(100% - 80px);
}
@media only screen and (min-width: 1601px) {
  #service .flex-wrap .flex-inner img {
    width: calc(100% - 4.9968769519vw);
  }
}
@media only screen and (max-width: 767px) {
  #service .flex-wrap .flex-inner img {
    width: calc(100% - 60px);
  }
}
#service .flex-wrap .flex-inner .text {
  position: relative;
  text-align: center;
}
@media only screen and (max-width: 1600px) {
  #service .flex-wrap .flex-inner .text .heading3 {
    margin-bottom: 20px;
  }
}
@media only screen and (min-width: 1601px) {
  #service .flex-wrap .flex-inner .text .heading3 {
    margin-bottom: 1.249219238vw;
  }
}
#service .flex-wrap .flex-inner .text strong {
  display: block;
}
@media only screen and (max-width: 1600px) {
  #service .flex-wrap .flex-inner .text strong {
    font-size: 18px;
  }
}
@media only screen and (min-width: 1601px) {
  #service .flex-wrap .flex-inner .text strong {
    font-size: 1.1242973142vw;
  }
}
@media only screen and (max-width: 1600px) {
  #service .flex-wrap .flex-inner .text strong {
    margin-bottom: 20px;
  }
}
@media only screen and (min-width: 1601px) {
  #service .flex-wrap .flex-inner .text strong {
    margin-bottom: 1.249219238vw;
  }
}
@media only screen and (max-width: 991px) {
  #service .flex-wrap .flex-inner .text strong {
    font-size: 15px;
  }
}
#service .flex-wrap .flex-inner .text p {
  text-align: left;
}
@media only screen and (min-width: 992px) {
  #service .flex-wrap .sp {
    display: none;
  }
}
@media only screen and (max-width: 991px) {
  #service .flex-wrap .pc {
    display: none;
  }
}
@media only screen and (max-width: 991px) {
  #service .container:last-of-type {
    width: 100%;
  }
}

#page-solution .container-wrap {
  padding: 14% 0 30px;
}
#page-solution .container-wrap .container > .heading {
  color: #fff;
  justify-content: center;
  flex-wrap: wrap;
}
#page-solution .container-wrap .container > .heading .en {
  color: #fff;
}
@media only screen and (max-width: 575px) {
  #page-solution .container-wrap .container > .heading .en {
    width: 100%;
    text-align: center;
  }
}
#page-solution .container-wrap .container > .heading .line {
  background-color: #fff;
}
#page-solution .container-wrap .container .inner {
  justify-content: space-between;
}
@media only screen and (max-width: 991px) {
  #page-solution .container-wrap .container .inner {
    flex-direction: column;
  }
}
#page-solution .container-wrap .container .inner .box {
  width: calc((100% - 40px) / 2);
  padding: 40px;
  background-color: #fff;
  border-radius: 1em;
}
@media only screen and (min-width: 1601px) {
  #page-solution .container-wrap .container .inner .box {
    width: calc((100% - 2.498438476vw) / 2);
    padding: 2.498438476vw;
  }
}
@media only screen and (max-width: 991px) {
  #page-solution .container-wrap .container .inner .box {
    width: 100%;
    padding: 30px;
  }
}
#page-solution .container-wrap .container .inner .box .heading {
  justify-content: center;
}
@media only screen and (max-width: 1600px) {
  #page-solution .container-wrap .container .inner .box .heading {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-solution .container-wrap .container .inner .box .heading {
    margin-bottom: 1.873828857vw;
  }
}
@media only screen and (max-width: 1600px) {
  #page-solution .container-wrap .container .inner .box .heading {
    font-size: 20px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-solution .container-wrap .container .inner .box .heading {
    font-size: 1.249219238vw;
  }
}
#page-solution .container-wrap .container .inner .box ul li {
  position: relative;
  font-weight: bold;
  padding-left: 1.5em;
  margin-bottom: 1em;
}
@media only screen and (max-width: 1600px) {
  #page-solution .container-wrap .container .inner .box ul li {
    font-size: 16px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-solution .container-wrap .container .inner .box ul li {
    font-size: 0.9993753904vw;
  }
}
#page-solution .container-wrap .container .inner .box ul li:last-of-type {
  margin-bottom: 0;
}
#page-solution .container-wrap .container .inner .box ul li i {
  position: absolute;
  top: 0.3em;
  left: 0;
  color: #e58001;
}
@media only screen and (max-width: 1600px) {
  #page-solution .container-wrap .container .inner .box ul li i {
    font-size: 20px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-solution .container-wrap .container .inner .box ul li i {
    font-size: 1.249219238vw;
  }
}
#page-solution .container-wrap .container .inner .arrow {
  color: #e58001;
  display: flex;
  align-self: center;
}
@media only screen and (max-width: 1600px) {
  #page-solution .container-wrap .container .inner .arrow {
    font-size: 40px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-solution .container-wrap .container .inner .arrow {
    font-size: 2.498438476vw;
  }
}
@media only screen and (max-width: 991px) {
  #page-solution .container-wrap .container .inner .arrow {
    margin: 10px 0;
  }
  #page-solution .container-wrap .container .inner .arrow i {
    transform: rotate(90deg);
  }
}

@media only screen and (max-width: 1600px) {
  #flow {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width: 1601px) {
  #flow {
    margin-bottom: 3.7476577139vw;
  }
}
#flow .heading {
  justify-content: center;
}
#flow .inner {
  background-color: #fff;
  border: 1px solid #c1c1c1;
  border-radius: 1em;
  flex-wrap: wrap;
}
#flow .inner dl {
  position: relative;
  width: 25%;
  padding: 40px;
  text-align: center;
  border-right: 1px solid #c1c1c1;
}
#flow .inner dl:last-of-type {
  border: none;
}
@media only screen and (max-width: 1279px) {
  #flow .inner dl {
    width: 50%;
    border-bottom: 1px solid #c1c1c1;
  }
  #flow .inner dl:nth-of-type(2) {
    border-right: none;
  }
  #flow .inner dl:nth-of-type(n + 3) {
    border-bottom: none;
  }
}
@media only screen and (max-width: 575px) {
  #flow .inner dl {
    width: 100%;
    border: none;
    border-bottom: 1px solid #c1c1c1;
  }
  #flow .inner dl:nth-of-type(n + 3) {
    border-bottom: 1px solid #c1c1c1;
  }
  #flow .inner dl:last-of-type {
    border: none;
  }
}
#flow .inner dl dt {
  margin-bottom: 1em;
}
@media only screen and (max-width: 1600px) {
  #flow .inner dl dt {
    font-size: 20px;
  }
}
@media only screen and (min-width: 1601px) {
  #flow .inner dl dt {
    font-size: 1.249219238vw;
  }
}
#flow .inner dl dt .num {
  color: #c1c1c1;
}
@media only screen and (max-width: 1600px) {
  #flow .inner dl dt .num {
    font-size: 16px;
  }
}
@media only screen and (min-width: 1601px) {
  #flow .inner dl dt .num {
    font-size: 0.9993753904vw;
  }
}
#flow .inner dl img {
  height: 4em;
  max-width: 6em;
  margin-bottom: 1em;
}
#flow .inner dl dd {
  text-align: left;
}
#flow .inner dl .arrow {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(-50%, -50%);
}
@media only screen and (max-width: 1600px) {
  #flow .inner dl .arrow {
    font-size: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #flow .inner dl .arrow {
    font-size: 1.873828857vw;
  }
}
@media only screen and (max-width: 575px) {
  #flow .inner dl .arrow {
    left: 50%;
    top: 0;
    transform: translate(-50%, -50%) rotate(90deg);
  }
}
@media only screen and (max-width: 1279px) and (min-width: 576px) {
  #flow .inner dl:nth-of-type(3) .arrow {
    display: none;
  }
}

#about-contact .heading {
  justify-content: center;
}
#about-contact .contact {
  justify-content: space-between;
  align-items: center;
}
@media only screen and (max-width: 767px) {
  #about-contact .contact {
    flex-direction: column;
  }
}
#about-contact .contact .line {
  display: inline-block;
  background-color: #3e3a39;
  width: 4px;
  height: 160px;
  margin: 0 2.5em;
}
@media only screen and (max-width: 767px) {
  #about-contact .contact .line {
    width: 160px;
    height: 4px;
    margin: 40px 0;
  }
}
#about-contact .contact .tel,
#about-contact .contact .mail {
  position: relative;
  color: #3e3a39;
  text-align: center;
  width: calc(50% - 2px);
}
@media only screen and (min-width: 768px) {
  #about-contact .contact .tel,
  #about-contact .contact .mail {
    background: none !important;
  }
}
@media only screen and (max-width: 767px) {
  #about-contact .contact .tel,
  #about-contact .contact .mail {
    width: 100%;
  }
}
#about-contact .contact .tel span,
#about-contact .contact .tel a,
#about-contact .contact .mail span,
#about-contact .contact .mail a {
  display: block;
  font-weight: bold;
}
@media only screen and (max-width: 1600px) {
  #about-contact .contact .tel span,
  #about-contact .contact .tel a,
  #about-contact .contact .mail span,
  #about-contact .contact .mail a {
    margin-bottom: 10px;
  }
}
@media only screen and (min-width: 1601px) {
  #about-contact .contact .tel span,
  #about-contact .contact .tel a,
  #about-contact .contact .mail span,
  #about-contact .contact .mail a {
    margin-bottom: 0.624609619vw;
  }
}
@media only screen and (max-width: 1600px) {
  #about-contact .contact .tel .tel-btn {
    font-size: 40px;
  }
}
@media only screen and (min-width: 1601px) {
  #about-contact .contact .tel .tel-btn {
    font-size: 2.498438476vw;
  }
}
#about-contact .contact .tel .tel-btn i {
  position: relative;
  bottom: 0.1em;
  right: 0.4em;
}
@media only screen and (max-width: 1600px) {
  #about-contact .contact .tel .tel-btn i {
    font-size: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #about-contact .contact .tel .tel-btn i {
    font-size: 1.873828857vw;
  }
}
@media only screen and (max-width: 1600px) {
  #about-contact .contact .tel .phone-btn {
    font-size: 22px;
  }
}
@media only screen and (min-width: 1601px) {
  #about-contact .contact .tel .phone-btn {
    font-size: 1.3741411618vw;
  }
}
#about-contact .contact .tel .phone-btn img {
  height: 22px;
  position: relative;
  bottom: 0.1em;
  right: 0.4em;
}
#about-contact .contact .mail .mail-btn {
  width: 280px;
  border-color: #3e3a39;
  color: #3e3a39;
}
#about-contact .contact .mail .mail-btn i {
  position: relative;
  top: 0.1em;
  right: 0.4em;
}
@media only screen and (max-width: 1600px) {
  #about-contact .contact .mail .mail-btn i {
    font-size: 26px;
  }
}
@media only screen and (min-width: 1601px) {
  #about-contact .contact .mail .mail-btn i {
    font-size: 1.6239850094vw;
  }
}

#page-company .inner {
  justify-content: space-between;
  flex-wrap: wrap;
}
#page-company .inner > div {
  width: calc((100% - 40px) / 2);
}
@media only screen and (max-width: 991px) {
  #page-company .inner > div {
    width: 100%;
  }
}
#page-company .inner .left {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
@media only screen and (max-width: 1600px) {
  #page-company .inner .left .table-wrap {
    margin-bottom: 40px;
  }
}
@media only screen and (min-width: 1601px) {
  #page-company .inner .left .table-wrap {
    margin-bottom: 2.498438476vw;
  }
}
#page-company .inner .left .table-wrap dl {
  display: flex;
}
#page-company .inner .left .table-wrap dl dt {
  width: 11em;
  border-bottom: 4px solid #3e3a39;
  padding: 20px 0 16px;
}
@media only screen and (max-width: 575px) {
  #page-company .inner .left .table-wrap dl dt {
    width: 6em;
  }
}
#page-company .inner .left .table-wrap dl dd {
  width: calc(100% - 11em);
  border-bottom: 4px solid #f0f0f0;
  padding: 20px 0 16px;
}
@media only screen and (max-width: 575px) {
  #page-company .inner .left .table-wrap dl dd {
    width: calc(100% - 6em);
  }
}
#page-company .inner .left iframe {
  opacity: 0;
  height: 350px;
}
@media only screen and (min-width: 1601px) {
  #page-company .inner .left iframe {
    height: 21.8613366646vw;
  }
}
@media only screen and (max-width: 991px) {
  #page-company .inner .left iframe {
    display: none;
  }
}
@media only screen and (max-width: 991px) {
  #page-company .inner .right {
    margin-top: 30px;
  }
}
#page-company .inner .right .image {
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 991px) {
  #page-company .inner .right .image {
    height: 450px;
  }
}

/*************************************
* お知らせ詳細ページ
* 
* ver.20221130
*/
#single-content .heading-single {
  position: relative;
  color: #3e3a39;
  padding-bottom: 30px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 1600px) {
  #single-content .heading-single {
    font-size: 24px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-content .heading-single {
    font-size: 1.4990630856vw;
  }
}
@media only screen and (max-width: 1600px) {
  #single-content .heading-single {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-content .heading-single {
    margin-bottom: 3.7476577139vw;
  }
}
@media only screen and (min-width: 1601px) {
  #single-content .heading-single {
    padding-bottom: 1.873828857vw;
  }
}
@media only screen and (max-width: 991px) {
  #single-content .heading-single {
    font-size: 20px;
  }
}
#single-content .heading-single::before {
  position: absolute;
  display: block;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  content: "";
  width: 50px;
  height: 5px;
  background: #3e3a39;
}
#single-content .dc {
  text-align: center;
}
@media only screen and (max-width: 1600px) {
  #single-content .dc {
    font-size: 13px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-content .dc {
    font-size: 0.8119925047vw;
  }
}
@media only screen and (max-width: 1600px) {
  #single-content .dc {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-content .dc {
    margin-bottom: 1.873828857vw;
  }
}
#single-content .dc .date {
  color: #3e3a39;
}
#single-content .dc .category {
  color: #7e7e7e;
}
#single-content .content img {
  display: block;
  margin: auto;
  width: 100%;
  max-width: 640px;
}
#single-content .content h2 {
  line-height: 2em;
  position: relative;
  font-weight: bold;
}
@media only screen and (max-width: 1600px) {
  #single-content .content h2 {
    font-size: 26px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-content .content h2 {
    font-size: 1.6239850094vw;
  }
}
@media only screen and (max-width: 1600px) {
  #single-content .content h2 {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-content .content h2 {
    margin-bottom: 1.873828857vw;
  }
}
#single-content .content h3 {
  position: relative;
  line-height: 2em;
  font-weight: bold;
}
@media only screen and (max-width: 1600px) {
  #single-content .content h3 {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-content .content h3 {
    margin-bottom: 1.873828857vw;
  }
}
@media only screen and (max-width: 1600px) {
  #single-content .content h3 {
    font-size: 20px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-content .content h3 {
    font-size: 1.249219238vw;
  }
}
@media only screen and (max-width: 991px) {
  #single-content .content h3 {
    font-size: 18px;
  }
}
@media only screen and (max-width: 767px) {
  #single-content .content h3 {
    font-size: 16px;
  }
}
#single-content .content ul {
  margin-left: 2em;
  list-style: disc;
  margin-bottom: 1em;
}
#single-content .content ul li {
  margin-bottom: 1em;
}
#single-content .content ul li::marker {
  color: #3e3a39;
}
#single-content .content ol {
  margin-left: 2em;
  list-style: auto;
  margin-bottom: 1em;
}
#single-content .content ol li {
  margin-bottom: 1em;
}
#single-content .content ol li::marker {
  color: #3e3a39;
}
#single-content .content b,
#single-content .content strong {
  font-weight: bold;
}
#single-content .content a {
  color: #e58001;
}
#single-content .content .wp-block-embed-youtube {
  position: relative;
  display: block;
}
#single-content .content .wp-block-embed-youtube::before {
  display: block;
  content: "";
  padding-top: 56.25%;
}
#single-content .content .wp-block-embed-youtube .wp-block-embed__wrapper {
  position: absolute !important;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#single-content .content .wp-block-embed-youtube iframe {
  width: 100% !important;
  height: 100% !important;
}

#single-content.news-page h2 {
  line-height: 2em;
  position: relative;
  font-weight: bold;
  padding-left: 60px;
}
@media only screen and (max-width: 1600px) {
  #single-content.news-page h2 {
    font-size: 26px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-content.news-page h2 {
    font-size: 1.6239850094vw;
  }
}
@media only screen and (max-width: 1600px) {
  #single-content.news-page h2 {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-content.news-page h2 {
    margin-bottom: 1.873828857vw;
  }
}
#single-content.news-page h2::before {
  position: absolute;
  display: block;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  width: 30px;
  height: 4px;
  background: #3e3a39;
}

#single-pager {
  background-color: #fff;
}
#single-pager .container {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  background-color: #f0f0f0;
  padding: 40px 20px;
}
@media only screen and (max-width: 575px) {
  #single-pager .container {
    flex-direction: column;
  }
}
#single-pager a {
  display: block;
  width: 10em;
  font-weight: bold;
  text-align: center;
  margin: 0 10px;
  border-radius: 0.5em;
  background-color: #fff;
  padding: 20px;
}
@media only screen and (max-width: 1600px) {
  #single-pager a {
    font-size: 18px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-pager a {
    font-size: 1.1242973142vw;
  }
}
#single-pager a:last-of-type {
  background-color: #3e3a39;
  color: #fff;
}
@media only screen and (max-width: 575px) {
  #single-pager a {
    width: 100%;
    margin: 0 0 5px;
  }
}
#single-pager a .arrowL {
  margin-right: 10px;
}
#single-pager a .arrowR {
  margin-left: 10px;
}
#single-pager a .arrowU {
  margin-left: 10px;
}
#single-pager a .arrowU i {
  transform: rotate(-90deg);
}
@media only screen and (max-width: 1600px) {
  #single-pager a i {
    font-size: 15px;
  }
}
@media only screen and (min-width: 1601px) {
  #single-pager a i {
    font-size: 0.9369144285vw;
  }
}

.slider-wrap {
  max-width: 640px;
  margin: auto;
}
@media only screen and (max-width: 1600px) {
  .slider-wrap {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width: 1601px) {
  .slider-wrap {
    margin-bottom: 3.7476577139vw;
  }
}
@media only screen and (max-width: 991px) {
  .slider-wrap {
    padding: 20px;
  }
}
.slider-wrap .single-slider .list- {
  padding: 0 10px;
}
.slider-wrap .single-slider .list- .img-wrap {
  position: relative;
  width: 100%;
  text-align: center;
}
@media only screen and (max-width: 1600px) {
  .slider-wrap .single-slider .list- .img-wrap {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 1601px) {
  .slider-wrap .single-slider .list- .img-wrap {
    margin-bottom: 1.873828857vw;
  }
}
.slider-wrap .single-slider .list- .img-wrap::before {
  display: block;
  content: "";
  padding-top: 70%;
}
.slider-wrap .single-slider .list- .img-wrap img {
  position: absolute;
  max-width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
.slider-wrap .single-slider .list- .img-wrap .tag {
  position: absolute;
  display: flex;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  background-color: rgba(255, 255, 255, 0.803);
  color: #3e3a39;
  padding: 0.7em;
  font-weight: bold;
  border-radius: 1em;
  align-items: center;
  font-family: "Lato", sans-serif;
}
@media only screen and (max-width: 1600px) {
  .slider-wrap .single-slider .list- .img-wrap .tag {
    font-size: 20px;
  }
}
@media only screen and (min-width: 1601px) {
  .slider-wrap .single-slider .list- .img-wrap .tag {
    font-size: 1.249219238vw;
  }
}
.slider-wrap .single-slider .list- .img-wrap .tag .arrow svg {
  display: block;
  margin-left: 0.6em;
}
@media only screen and (max-width: 767px) {
  .slider-wrap .single-slider .list- .img-wrap .tag {
    font-size: 18px;
    padding: 15px;
  }
  .slider-wrap .single-slider .list- .img-wrap .tag svg {
    width: 22px;
  }
}
.slider-wrap .single-slider .list- p {
  text-align: center;
  font-weight: bold;
  margin-bottom: 2em;
}
.slider-wrap .thumb-slider .thumb-wrapper {
  display: flex;
  width: 100%;
}
.slider-wrap .thumb-slider .thumb-wrapper .thumbnail-current .img-wrap {
  border: 4px solid #e58001;
}
.slider-wrap .thumb-slider .thumb-wrapper .list- {
  padding: 0 0.2em;
  width: 16.6666666667%;
}
@media only screen and (max-width: 991px) {
  .slider-wrap .thumb-slider .thumb-wrapper .list- {
    width: 25%;
  }
}
@media only screen and (max-width: 767px) {
  .slider-wrap .thumb-slider .thumb-wrapper .list- {
    width: 25%;
  }
}
.slider-wrap .thumb-slider .thumb-wrapper .list- .img-wrap {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
.slider-wrap .thumb-slider .thumb-wrapper .list- .img-wrap::before {
  display: block;
  content: "";
  padding-top: 100%;
}
.slider-wrap .thumb-slider .slide-arrow {
  position: absolute;
  z-index: 10;
  top: 50%;
  transition: 0.1s;
  cursor: pointer;
  padding: 2em 0;
}
.slider-wrap .thumb-slider .slide-arrow svg {
  display: block;
}
.slider-wrap .thumb-slider .prev-arrow {
  left: -1em;
  transform: translate(-50%, -50%);
}
.slider-wrap .thumb-slider .prev-arrow:hover {
  transform: translate(-50%, -50%) scale(1.2);
}
.slider-wrap .thumb-slider .next-arrow {
  right: -1em;
  transform: translate(50%, -50%) rotate(180deg);
}
.slider-wrap .thumb-slider .next-arrow:hover {
  transform: translate(50%, -50%) rotate(180deg) scale(1.2);
}

#modal-container {
  position: relative;
  width: 100%;
  height: 100%;
}
#modal-container .bg {
  position: fixed;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-color: #7e7e7e;
  opacity: 0.4;
  z-index: 9999;
  transform: scale(0);
}
#modal-container .bg.active {
  transform: scale(1);
}
#modal-container .modal-box {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: scale(0) translate(-50%, -50%);
  padding: 30px;
  width: -moz-fit-content;
  width: fit-content;
  height: -moz-fit-content;
  height: fit-content;
  display: inline-block;
  background-color: #fff;
  transition: 0.5s;
  transform-origin: left;
  z-index: 999999;
  max-height: 80vh;
  max-width: 960px;
  width: 100%;
}
#modal-container .modal-box .modal-close {
  position: absolute;
  right: 7px;
  top: 7px;
  font-size: 24px;
  cursor: pointer;
}
@media only screen and (max-width: 767px) {
  #modal-container .modal-box .modal-close {
    font-size: 20px;
    right: 7px;
    top: 5px;
  }
}
@media only screen and (max-width: 575px) {
  #modal-container .modal-box .modal-close {
    font-size: 16px;
    right: 6px;
    top: 3px;
  }
}
@media only screen and (max-width: 991px) {
  #modal-container .modal-box {
    width: 98%;
  }
}
@media only screen and (max-width: 575px) {
  #modal-container .modal-box {
    padding: 20px;
    width: 90%;
  }
}
#modal-container .modal-box .image-box {
  background-color: #fff;
  width: 100%;
  position: relative;
  overflow: hidden;
}
#modal-container .modal-box .image-box img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  height: 100%;
  transition: all 0.3s;
}
#modal-container .modal-box .image-box:after {
  content: "";
  display: block;
  padding-top: 70%;
  /* 高さを幅の75%に固定 */
}
#modal-container .modal-box figcaption {
  text-align: center;
  margin-top: 30px;
  font-weight: bold;
}
#modal-container .modal-box.active {
  transform: scale(1) translate(-50%, -50%);
}

/*************************************
* お問合せページ
* contact
*
* ver.20211128
*/
#contact {
  overflow-x: hidden;
  /* フォムのJS用 */
  /* 必須アイコン */
  /*# response-output */
  /*# response-output */
  /*# ラジオボタン */
}
#contact .smallfont {
  font-size: 13px;
}
#contact .inner {
  text-align: center;
}
#contact .inner > b {
  display: block;
  font-weight: bold;
  margin-bottom: 40px;
}
#contact .inner > p {
  margin-bottom: 40px;
}
@media only screen and (max-width: 767px) {
  #contact .inner > p {
    text-align: left;
  }
}
#contact .inner .small {
  margin-bottom: 120px;
  margin-top: 40px;
}
#contact .inner .small p {
  font-size: 12px;
  line-height: 24px;
  text-align: left;
  padding-left: 40px;
}
#contact .inner .small p:before {
  content: "●";
  position: absolute;
  left: 0px;
  color: #e2472a;
  display: block;
  padding: 2px 5px;
  font-size: 10px;
  margin: 0px 5px;
  background-size: 100% 100%;
  border-radius: 10px;
}
#contact .inner .small p.tel {
  font-weight: 700;
  color: #e2472a;
  font-size: 40px;
  margin-top: 40px;
  margin-bottom: 40px;
}
#contact .inner ul {
  list-style: disc;
  font-size: 13px;
}
#contact .inner ul li {
  margin-left: 1.5em;
}
#contact .inner ul li::marker {
  color: #e58001;
}
#contact .hidden {
  display: none;
}
#contact .topright:hover {
  color: red;
}
#contact .required {
  position: relative;
}
#contact .example-require {
  display: inline-block;
  padding: 0px 8px;
  font-size: 11px;
  right: 0px;
  line-height: 24px;
  margin: 0px;
  background-size: 100% 100%;
  background-color: #e58001;
  color: #fff;
  margin-right: 10px;
}
#contact .required:before {
  content: "必須";
  position: absolute;
  color: #ffffff;
  display: block;
  padding: 0px 8px;
  font-size: 11px;
  right: 0px;
  line-height: 24px;
  margin: 0px;
  background-size: 100% 100%;
  background-color: #e58001;
}
#contact span.wpcf7-form-control-wrap {
  display: block;
  width: 100%;
  text-align: left;
}
#contact span.wpcf7-form-control-wrap.your-address-prefectures {
  text-align: left;
}
#contact span.wpcf7-form-control-wrap.your-name-sei,
#contact span.wpcf7-form-control-wrap.your-name-mei,
#contact span.wpcf7-form-control-wrap.your-name-sei-kana,
#contact span.wpcf7-form-control-wrap.your-name-mei-kana {
  display: inline-block;
  width: 48%;
  box-sizing: border-box;
}
#contact #contactForm {
  margin-left: auto;
  margin-right: auto;
  padding: 64px 0 0;
}
#contact .wpcf7 form.failed .wpcf7-response-output,
#contact .wpcf7 form.invalid .wpcf7-response-output,
#contact .wpcf7 form.unaccepted .wpcf7-response-output,
#contact .wpcf7 form.payment-required .wpcf7-response-output {
  padding: 0;
  margin: 0;
  border: 4px solid #e58001 !important;
  color: #e58001 !important;
  padding: 40px;
  text-align: center;
  text-align: center;
  font-weight: bold;
}
@media only screen and (max-width: 575px) {
  #contact .wpcf7 form.failed .wpcf7-response-output,
  #contact .wpcf7 form.invalid .wpcf7-response-output,
  #contact .wpcf7 form.unaccepted .wpcf7-response-output,
  #contact .wpcf7 form.payment-required .wpcf7-response-output {
    text-align: left;
  }
}
#contact .wpcf7-not-valid-tip {
  color: #e58001 !important;
  font-size: 13px;
}
#contact .wpcf7 form.sent .wpcf7-response-output {
  border: 4px solid #7e7e7e !important;
  background: #fff !important;
  color: #3e3a39 !important;
  padding: 40px;
  text-align: center;
  font-weight: bold;
  margin-top: 90px;
}
@media only screen and (max-width: 575px) {
  #contact .wpcf7 form.sent .wpcf7-response-output {
    text-align: left;
  }
}
#contact .wpcf7-radio .wpcf7-list-item label input:checked ~ .wpcf7-list-item-label:after {
  background: #fff;
  color: #3e3a39;
  text-align: center;
  border-radius: 10px;
}
#contact form {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  /* プラグインの影響で謎の<p>が量産されているので非表示に */
  /* 入力項目幅制御 */
  /* 入力した 色 設定 */
  /* 住所系 */
  /* 市区町村、丁目番地 */
  /* 氏名系 */
  /* 数量 */
  /* placeholder 色 設定 */
  /* 入力した 色 設定 */
}
#contact form > p {
  display: none;
}
#contact form .text-center span {
  text-align: center;
}
#contact form .specified-commercebox p {
  border: 1px solid #ccc;
  border-radius: 3px;
  height: 346px;
  padding: 15px;
  margin: 0;
  line-height: 1.2em;
  text-align: justify;
  overflow: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
#contact form table {
  width: 100%;
  height: -moz-fit-content;
  height: fit-content;
  table-layout: fixed;
}
#contact form table tr > th {
  width: 280px;
  text-align: left;
  vertical-align: top;
  box-sizing: border-box;
  padding-top: 40px;
  padding-bottom: 0px;
  font-size: 15px;
  border-top: solid 1px #f0f0f0;
}
#contact form table tr > td.th-title {
  padding-left: 64px;
}
@media screen and (max-width: 960px) {
  #contact form table tr > td.th-title {
    border-top: none;
    padding-left: 0px;
  }
}
#contact form table tr > th + td {
  border-top: solid 1px #f0f0f0;
}
#contact form table tr > td {
  /* width: 70%; */
  box-sizing: border-box;
  padding-top: 40px;
  padding-bottom: 40px;
  font-size: 15px;
}
#contact form table tr > td p::-webkit-scrollbar {
  display: none;
}
@media screen and (max-width: 960px) {
  #contact form table {
    /* ブロック化 */
  }
  #contact form table tbody,
  #contact form table tr,
  #contact form table tr > th,
  #contact form table tr > td {
    display: block;
    width: 100%;
    box-sizing: border-box;
    font-size: 13.33px;
  }
  #contact form table tr > td {
    padding: 20px 0;
  }
  #contact form table tr > th {
    padding: 20px 0 0;
  }
}
#contact form input[type=date],
#contact form input[type=text],
#contact form input[type=email],
#contact form input[type=tel],
#contact form textarea {
  width: 100%;
  box-sizing: border-box;
  margin-top: 2px;
  margin-bottom: 2px;
  font-size: 13.33px;
  width: 100%;
  padding: 3px 8px;
  margin: 2px;
  vertical-align: middle;
  font-size: 13.33px;
  background: #fff;
  border: 1px solid #f0f0f0;
  box-sizing: border-box;
  border-radius: 2px;
}
@media screen and (max-width: 960px) {
  #contact form .required:before {
    position: absolute;
    right: 0;
  }
}
#contact form select {
  border: solid 1px #ccc;
  padding: 3px 8px;
  margin: 2px;
  vertical-align: middle;
  font-size: 13.33px;
  background: #fff;
  font-size: 13.33px;
  width: 100%;
  height: 180px;
}
@media screen and (max-width: 960px) {
  #contact form select {
    width: 100%;
  }
}
#contact form ::-webkit-input-placeholder,
#contact form :-moz-placeholder,
#contact form ::-moz-placeholder,
#contact form :-ms-input-placeholder,
#contact form ::placeholder {
  color: #dbdbdb !important;
  opacity: 1;
}
#contact form input:-webkit-autofill,
#contact form input:-webkit-autofill:hover,
#contact form input:-webkit-autofill:focus,
#contact form input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0px 1000px #fff inset;
}
#contact form input[type=submit]:active,
#contact form input[type=button]:active {
  /* font-size: 1rem; */
  transform: scale(1);
  /* box-shadow: 0 3px 15px -2px; */
  margin-top: 0px;
  margin-bottom: 0px;
  width: 100%;
  border: none;
  vertical-align: middle;
  background: none;
}
#contact form input[name=your-address-prefectures],
#contact form input[name=your-address-municipality] {
  margin-bottom: 5px;
}
#contact form select[name=your-address-prefectures],
#contact form input[name=your-address-municipality],
#contact form input[name=your-address-num] {
  margin-left: 5px;
}
#contact form input[name=your-name-sei],
#contact form input[name=your-name-mei],
#contact form input[name=your-name-sei-kana],
#contact form input[name=your-name-mei-kana] {
  width: 100%;
  max-width: 150px;
  max-width: none;
}
#contact form input[type=number] {
  width: 80px;
}
#contact form ::-moz-placeholder {
  color: #dbdbdb;
  opacity: 1;
  /* Firefox */
}
#contact form ::placeholder {
  color: #dbdbdb;
  opacity: 1;
  /* Firefox */
}
#contact form :-ms-input-placeholder {
  /* Internet Explorer 10-11 */
  color: #dbdbdb;
}
#contact form input:-webkit-autofill,
#contact form input:-webkit-autofill:hover,
#contact form input:-webkit-autofill:focus,
#contact form input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0px 1000px rgb(255, 255, 255) inset;
}
#contact form span.smallfont {
  font-size: 13px;
  line-height: 24px;
  letter-spacing: 1px;
}
#contact form ::-webkit-input-placeholder,
#contact form :-moz-placeholder,
#contact form ::-moz-placeholder,
#contact form :-ms-input-placeholder {
  color: #dbdbdb !important;
  opacity: 1;
}
#contact form textarea {
  width: 100%;
  height: 180px;
}
#contact form .wpcf7 .ajax-loader {
  position: absolute;
}
@media screen and (max-width: 960px) {
  #contact form .th-title {
    display: block;
    width: 100%;
  }
}
@media screen and (max-width: 960px) {
  #contact form span.wpcf7-form-control-wrap {
    text-align: left;
  }
}
#contact form #reCaptcha {
  border-top: solid 1px #f0f0f0;
  padding-top: 20px;
  margin-bottom: 120px;
  text-align: left;
}
#contact form #reCaptcha a {
  color: #e58001;
}
@media only screen and (max-width: 767px) {
  #contact form #reCaptcha {
    margin-bottom: 90px;
  }
}
#contact form #reCaptcha + .btn {
  padding: 20px 64px;
  font-size: 18px;
  position: relative;
}
#contact form #reCaptcha + .btn .wpcf7-spinner {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-150%, 100%);
}
#contact form .more-btn, #contact form #footer .right .contact .mail .mail-btn, #footer .right .contact .mail #contact form .mail-btn, #contact form #about-contact .contact .mail .mail-btn, #about-contact .contact .mail #contact form .mail-btn {
  width: 261px;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: auto;
  margin-bottom: 64px;
  text-align: center;
}
#contact form .more-btn input, #contact form #footer .right .contact .mail .mail-btn input, #footer .right .contact .mail #contact form .mail-btn input, #contact form #about-contact .contact .mail .mail-btn input, #about-contact .contact .mail #contact form .mail-btn input {
  padding: 15px 0;
  font-weight: bold;
}
@media only screen and (max-width: 1600px) {
  #contact form .more-btn input, #contact form #footer .right .contact .mail .mail-btn input, #footer .right .contact .mail #contact form .mail-btn input, #contact form #about-contact .contact .mail .mail-btn input, #about-contact .contact .mail #contact form .mail-btn input {
    font-size: 18px;
  }
}
@media only screen and (min-width: 1601px) {
  #contact form .more-btn input, #contact form #footer .right .contact .mail .mail-btn input, #footer .right .contact .mail #contact form .mail-btn input, #contact form #about-contact .contact .mail .mail-btn input, #about-contact .contact .mail #contact form .mail-btn input {
    font-size: 1.1242973142vw;
  }
}
#contact form .wpcf7-spinner {
  position: absolute;
  display: none;
  right: -65px;
  top: 20px;
  background-color: #4a9d69;
}
#contact .flex, #contact .flex-center, #contact .flex-column, #contact .icon-btn, #contact #splash .logo, #splash #contact .logo, #contact #footer .left, #footer #contact .left, #contact #footer .left .title, #footer .left #contact .title, #contact #footer .right .container-left .title, #footer .right .container-left #contact .title, #contact #back-to-top .icon-wrap, #back-to-top #contact .icon-wrap, #contact #mainvisual .container-wrap .title-side, #mainvisual .container-wrap #contact .title-side, #contact #mainvisual .container-wrap .title-side .title, #mainvisual .container-wrap .title-side #contact .title, #contact #mainvisual .container-wrap .title-side .inner, #mainvisual .container-wrap .title-side #contact .inner, #contact #mainvisual .container-wrap .title-side .inner .icon-wrap, #mainvisual .container-wrap .title-side .inner #contact .icon-wrap {
  display: flex;
  gap: 18px;
}
#contact .wpcf7-radio .wpcf7-list-item label {
  display: inline-block;
  position: relative;
  padding-left: 22px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  /* On mouse-over, add a grey background color */
  /* When the radio button is checked, add a blue background */
  /* Create the indicator (the dot/circle - hidden when not checked) */
  /* Show the indicator (dot/circle) when checked */
}
#contact .wpcf7-radio .wpcf7-list-item label input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}
#contact .wpcf7-radio .wpcf7-list-item label input:checked ~ .wpcf7-list-item-label:before {
  background-color: #fff;
  border: 1px solid #212a37;
  content: "";
  display: inline-block;
  position: absolute;
  border-radius: 50%;
  width: 16px;
  height: 16px;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
#contact .wpcf7-radio .wpcf7-list-item label .wpcf7-list-item-label:after {
  content: "";
  position: absolute;
  background-color: white;
  border: 1px solid #212a37;
  border-radius: 50%;
  width: 16px;
  height: 16px;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
#contact .wpcf7-radio .wpcf7-list-item label input:checked ~ .wpcf7-list-item-label:after {
  display: block;
  left: 3px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #212a37;
  border: none;
  top: 50%;
  transform: translateY(-50%);
}
#contact .wpcf7-list-item {
  margin-left: 0 !important;
  margin-right: 1em !important;
}
@media screen and (max-width: 575px) {
  #contact .wpcf7-list-item {
    display: block !important;
  }
}/*# sourceMappingURL=style.css.map */