@charset "UTF-8";
/************************************************************************
定義
*************************************************************************/
a {
  text-decoration: none;
}

.pc {
  display: none;
}

/************************************************************************
共通スタイル
*************************************************************************/
body {
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック Medium", YuGothic, YuGothicM, "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, sans-serif;
  font-feature-settings: "palt";
  background: #fff;
  color: #4a4a4a;
  line-height: 2;
  letter-spacing: 2px;
}

form input[type=text],
form input[type=tel],
form input[type=email],
form input[type=time],
form input[type=radio],
form input[type=date],
form input[type=number],
form select,
form textarea {
  cursor: pointer;
  border: 2px solid #ccc;
  width: 100%;
  border-radius: 5px;
  box-sizing: border-box;
}

#service01,
#service02,
#service03 {
  margin-top: -4rem;
  padding-top: 4rem;
}

/*********** ヘッダー ***********/
.header {
  width: 100%;
  height: 4rem;
  position: fixed;
  top: 0;
  z-index: 99;
  background: #fff;
  border-bottom: 3px solid #9d9d9d;
  box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.5019607843);
}
.header .header__inner .header-logo {
  position: fixed;
  top: 16px;
  left: 12px;
  max-width: 250px;
  height: 3rem;
}
.header .header__inner .header-logo__link {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.header .header__inner .header-logo__img {
  width: 100%;
}
.header .header__inner .sp-nav-wrap .sp-nav-toggle {
  transition: linear 1s;
  position: fixed;
  top: 0;
  right: 0;
  width: 4rem;
  height: 4rem;
  z-index: 99;
}
.header .header__inner .sp-nav-wrap .sp-nav-toggle__btn {
  position: absolute;
  top: 19px;
  right: 19px;
  width: 30px;
  height: 26px;
  display: block;
}
.header .header__inner .sp-nav-wrap .sp-nav-toggle__line {
  right: 0;
  position: absolute;
  width: 2rem;
  height: 3px;
  display: block;
  background: #9d9d9d;
  transition: all 0.3s ease-in-out;
}
.header .header__inner .sp-nav-wrap .sp-nav-toggle__line--top {
  top: 1px;
  width: 100%;
}
.header .header__inner .sp-nav-wrap .sp-nav-toggle__line--center {
  top: 12px;
  width: 77.77777%;
}
.header .header__inner .sp-nav-wrap .sp-nav-toggle__line--bottom {
  top: 23px;
  width: 44.44444%;
}
.header .header__inner .sp-nav-wrap #sp-nav-toggle-btn {
  display: none;
}
.header .header__inner .sp-nav-wrap #sp-nav-toggle-btn:checked ~ .sp-nav {
  transform: translateX(0%);
  transition: all 0.5s ease-in-out;
  right: 0;
}
.header .header__inner .sp-nav-wrap #sp-nav-toggle-btn:checked ~ .sp-nav-toggle .sp-nav-toggle__line--top {
  top: 12px !important;
  width: 100%;
  transform: rotate(45deg);
  background: #fff;
}
.header .header__inner .sp-nav-wrap #sp-nav-toggle-btn:checked ~ .sp-nav-toggle .sp-nav-toggle__line--center {
  opacity: 0;
}
.header .header__inner .sp-nav-wrap #sp-nav-toggle-btn:checked ~ .sp-nav-toggle .sp-nav-toggle__line--bottom {
  top: 12px !important;
  width: 100%;
  transform: rotate(-45deg);
  background: #fff;
}
.header .header__inner .sp-nav-wrap .sp-nav {
  transform: translateX(100%);
  transition: all 0.5s ease 0s;
  margin-left: auto;
  padding-top: 3rem;
  width: 80%;
  height: 100vh;
  background: #9d9d9d;
  position: fixed;
  right: -100%;
}
.header .header__inner .sp-nav-wrap .sp-nav__item {
  padding: 1rem;
  text-align: center;
}
.header .header__inner .sp-nav-wrap .sp-nav__link {
  color: #fff;
}

/*********** フッター ***********/
.footer__inner .footer-logo {
  margin-bottom: 3rem;
  display: flex;
  justify-content: center;
}
.footer__inner .footer-logo__link {
  width: 200px;
  max-width: 300px;
  filter: drop-shadow(0px 0px 1px #fff) drop-shadow(0px 0px 1px #fff) drop-shadow(0px 0px 2px #fff) drop-shadow(0px 0px 2px #fff);
}
.footer__inner .footer-nav {
  padding: 5rem 1rem 1rem;
}
.footer__inner .footer-nav__list {
  max-width: 600px;
  margin: auto;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.footer__inner .footer-nav__item {
  margin: 0.65rem 0;
  box-shadow: 0px 3px 8px 0px #c5c5c5;
  width: 100%;
  padding-top: 40%;
  box-sizing: border-box;
  position: relative;
  width: 100%;
}
.footer__inner .footer-nav__item--01 {
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0.1019607843) 0%, rgba(255, 255, 255, 0.1019607843) 100%), url(/img/menu/menu01.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.footer__inner .footer-nav__item--02 {
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0.1019607843) 0%, rgba(255, 255, 255, 0.1019607843) 100%), url(/img/menu/menu02.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.footer__inner .footer-nav__item--03 {
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0.1019607843) 0%, rgba(255, 255, 255, 0.1019607843) 100%), url(/img/menu/menu03.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.footer__inner .footer-nav__item--04 {
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0.1019607843) 0%, rgba(255, 255, 255, 0.1019607843) 100%), url(/img/menu/menu04.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.footer__inner .footer-nav__item--05 {
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0.1019607843) 0%, rgba(255, 255, 255, 0.1019607843) 100%), url(/img/menu/menu05.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.footer__inner .footer-nav__item--06 {
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0.1019607843) 0%, rgba(255, 255, 255, 0.1019607843) 100%), url(/img/menu/menu06.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.footer__inner .footer-nav__link {
  color: #fff;
  display: block;
  text-align: center;
  position: relative;
  padding: 0.5rem;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: calc(100% - 2.5rem);
  height: calc(100% - 2.5rem);
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
}
.footer__inner .footer-nav__link:before {
  content: "";
  display: block;
  width: 1rem;
  height: 1rem;
  transform: rotate(45deg);
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  position: absolute;
  top: 40%;
  right: 1rem;
}
.footer__inner .footer-info {
  background: #9d9d9d;
  color: #fff;
  padding: 3rem 1rem;
}
.footer__inner .footer-info__inner {
  max-width: 1025px;
  margin: auto;
}
.footer__inner .footer-info__link {
  color: #fff;
}
.footer .footer-copyright {
  text-align: center;
  background: #fff;
  display: flex;
  justify-content: center;
}

/*********** メイン ***********/
.main-contents .breadcrumb {
  max-width: 1025px;
  margin: auto;
  padding: 1rem;
  box-sizing: border-box;
}
.main-contents .breadcrumb ol {
  display: flex;
  overflow-x: auto;
  word-break: keep-all;
  white-space: nowrap;
}
.main-contents .breadcrumb ol li {
  display: flex;
}
.main-contents .breadcrumb ol li:after {
  margin: 0 10px;
  display: block;
  content: ">";
}
.main-contents .breadcrumb ol li:nth-last-of-type(1):after {
  display: none;
}
.main-contents .breadcrumb ol li a {
  text-decoration: none !important;
  color: #4c78f1;
}
.main-contents .mv {
  width: 100%;
  height: 100vh;
}
.main-contents .mv__inner {
  background: linear-gradient(to right, rgba(0, 0, 0, 0.3019607843) 0%, rgba(0, 0, 0, 0.3019607843) 100%), url(/img/mainvisual.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  height: 100%;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  flex-direction: column;
}
.main-contents .mv__logo {
  width: 50%;
  max-width: 380px;
  min-width: 300px;
  margin: auto;
  filter: drop-shadow(0px 0px 1px #fff) drop-shadow(0px 0px 1px #fff) drop-shadow(0px 0px 2px #fff) drop-shadow(0px 0px 2px #fff);
}
.main-contents .mv__heading {
  display: none;
}
.main-contents .content__inner {
  margin: 0 auto;
  max-width: 1025px;
  padding: 1rem;
  max-width: 1025px;
}
.main-contents .content__heading {
  padding: 2rem 0;
}
.main-contents .content__title {
  text-align: center;
  font-size: 2.2rem;
  line-height: 2rem;
  color: #4c78f1;
}
.main-contents .content__subtitle {
  text-align: center;
}
.main-contents .content__caption {
  margin: 1rem 0;
  font-size: 1.25rem;
  letter-spacing: 3px;
  line-height: 2;
  font-weight: bold;
}
.main-contents .content__text {
  margin: 1rem 0;
}
.main-contents .content__caption--emphasis, .main-contents .content__text--emphasis {
  color: #4c78f1;
}
.main-contents .content__caption--link, .main-contents .content__text--link {
  color: #4c78f1;
}
.main-contents .content .card-list__inner {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.main-contents .content .card-list__inner .card01 {
  width: 100%;
  margin-bottom: 1rem;
}
.main-contents .content .card-list__inner .card01__img {
  box-shadow: 0px 3px 8px 0px #c5c5c5;
  width: 100%;
  padding-top: 75%;
  position: relative;
  box-sizing: border-box;
}
.main-contents .content .card-list__inner .card01__img--01 {
  background-image: url(/img/service/service01-1.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.main-contents .content .card-list__inner .card01__img--02 {
  background-image: url(/img/service/service01-2.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.main-contents .content .card-list__inner .card01__img--03 {
  background-image: url(/img/service/service01-3.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.main-contents .content .card-list__inner .card01__img--04 {
  background-image: url(/img/service/service02-1.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.main-contents .content .card-list__inner .card01__img--05 {
  background-image: url(/img/service/service02-2.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.main-contents .content .card-list__inner .card01__img--06 {
  background-image: url(/img/service/service02-3.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.main-contents .content .card-list__inner .card01__img--07 {
  background-image: url(/img/service/service03-1.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.main-contents .content .card-list__inner .card01__img--08 {
  background-image: url(/img/service/service03-2.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.main-contents .content .card-list__inner .card01__img--09 {
  background-image: url(/img/service/service03-3.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.main-contents .content .card-list__inner .card01__img-link {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  display: block;
  width: calc(100% - 2.5rem);
  height: calc(100% - 2.5rem);
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: 1.5rem;
}
.main-contents .content .card-list__inner .card01__img-link-title {
  width: calc(100% - 2.5rem);
  height: calc(100% - 2.5rem);
  border: 1px solid #fff;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1.25rem;
  letter-spacing: 3px;
  line-height: 2;
}
.main-contents .content .card-list__inner .card01__title {
  text-align: center;
  font-size: 1.25rem;
  letter-spacing: 3px;
  line-height: 2;
  padding: 0.5rem 0;
}
.main-contents .content .card-list__inner .card01__body {
  padding: 1rem 0;
}
.main-contents .content .card-list__inner .card01__text {
  padding-left: 0.5rem;
}
.main-contents .content .works-slider {
  position: relative;
  overflow: hidden;
  box-shadow: 0px 3px 8px 0px #c5c5c5;
}
.main-contents .content .works-slider__slide {
  box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.5019607843);
}
.main-contents .content .works-slider__imgfilter:before {
  content: "";
  display: block;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.5) 30%, rgba(0, 0, 0, 0) 100%);
  width: 100%;
  height: 100%;
  position: absolute;
}
.main-contents .content .works-slider__text {
  padding: 1rem;
  background: #fff;
  text-align: center;
  position: relative;
}
.main-contents .content .works-slider__text--h3 {
  font-size: 1.25rem;
  font-weight: bold;
  letter-spacing: 5px;
  color: #fff;
  text-align: center;
  position: absolute;
  left: 0;
  bottom: 4rem;
  width: 100%;
  padding: 1rem;
  box-sizing: border-box;
}
.main-contents .content .works-slider__text--p {
  text-align: center;
}
.main-contents .content .works-slider__pagination {
  position: absolute;
  left: 50%;
  padding: 1rem 0;
  transform: translate3d(-50%, 0, 0);
}
.main-contents .content .works-slider__pagination .swiper-pagination-bullet {
  margin: 0 0.5rem;
  background: #3a3a3a;
}
.main-contents .content .works-slider__pagination .swiper-pagination-bullet .swiper-pagination-bullet-active {
  background: #1a1a1a;
}
.main-contents .content .works-slider__button--prev, .main-contents .content .works-slider__button--next {
  top: calc(50% - 32px);
}
.main-contents .content .prof-list__item {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.main-contents .content .prof-list__title {
  width: 100%;
  padding: 0.5rem;
  background-color: #e9e9e9;
  font-weight: bold;
  box-sizing: border-box;
}
.main-contents .content .prof-list__description {
  width: 100%;
  padding: 0.5rem;
  box-sizing: border-box;
}
.main-contents .content .prof-list__inner {
  border: 1px solid #ddd;
}
.main-contents .content .contact-form__inner {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  padding: 1rem 0;
}
.main-contents .content .contact-form__item {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  font-weight: bold;
  width: 100%;
}
.main-contents .content .contact-form__item--bg-gray {
  padding: 1rem 1rem 0.5rem 1rem;
  background: #e9e9e9;
}
.main-contents .content .contact-form__title {
  width: 100%;
  text-align: center;
  font-weight: bold;
  display: flex;
  align-items: center;
  font-size: 1.25rem;
}
.main-contents .content .contact-form__description {
  width: 100%;
  text-align: left;
  padding: 0 0 1rem;
  word-break: break-all;
}
.main-contents .content .contact-form__actions {
  margin-top: 1rem;
  display: flex;
  justify-content: center;
}
.main-contents .content .contact-form__button {
  background: #4c78f1;
  color: #fff;
  border: none;
  padding: 0.5rem 0;
  width: 150px;
  text-align: center;
  display: block;
  margin: auto;
  border-radius: 3px;
  cursor: pointer;
}
.main-contents .content .contact-form__error {
  color: red;
  text-align: left;
  width: 100%;
  display: block;
  font-size: 1rem;
}
.main-contents .content .contact-form__required {
  color: red;
}
.main-contents .content .map__inner {
  margin-top: 1rem;
  width: 100%;
  height: 500px;
  overflow: hidden;
}
.main-contents .content .map__inner iframe {
  width: 100%;
  height: 860px;
  margin-top: -170px;
}
.main-contents .content .privacypolicy__text {
  padding: 1.25rem 0;
}
.main-contents .content .privacypolicy__text--child {
  padding-left: 1rem;
}

/************************************************************************
下層
*************************************************************************/
body.under .main-contents .mv {
  height: 50vh;
  margin-top: calc(4rem + 3px);
}
body.under .main-contents .mv__inner {
  background: linear-gradient(to right, rgba(0, 0, 0, 0.5019607843) 0%, rgba(0, 0, 0, 0.5019607843) 100%), url(/img/mainvisual.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
body.under .main-contents .mv__logo {
  display: none;
}
body.under .main-contents .mv__heading {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
body.under .main-contents .mv__title {
  width: 100%;
  text-align: center;
  font-size: 2.2rem;
  line-height: 2rem;
  color: #4c78f1;
  color: #fff;
}
body.under .main-contents .mv__subtitle {
  color: #fff;
}
body.under .main-contents .content__heading {
  padding: 2rem 0;
}
body.under .main-contents .content__title {
  text-align: left;
  font-size: 1.5rem;
  line-height: 2rem;
  color: #4c78f1;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid #4c78f1;
}
body.under .main-contents .content .card-list__inner {
  justify-content: space-between;
}
body.under .main-contents .content .card-list__inner .card01 {
  width: 100%;
}

/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*
* タブレットサイズ
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
@media (min-width: 600px) {
  .footer .footer-logo {
    justify-content: flex-start;
  }
  .footer .footer-nav__list {
    max-width: 1025px;
    justify-content: space-between;
  }
  .footer .footer-nav__item {
    width: 32%;
    padding-top: 12.8%;
  }
  .footer .footer-nav__link {
    width: calc(100% - 1.5rem);
    height: calc(100% - 1.5rem);
    font-size: 0.85rem;
  }
}
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*
* PCサイズ
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
@media (min-width: 1025px) {
  .pc {
    display: block;
  }
  .header .header__inner .header-nav {
    display: block !important;
  }
  .header .header__inner .header-nav__list {
    display: flex;
    justify-content: right;
    margin: 0 5% 0 auto;
  }
  .header .header__inner .header-nav__item {
    padding: 1rem;
  }
  .header .header__inner .header-nav__link {
    color: #4a4a4a;
    font-weight: bold;
  }
  .header .header__inner .sp-nav-wrap {
    display: none;
  }
  .footer .footer-nav__list {
    justify-content: space-between;
  }
  .footer .footer-nav__item {
    width: 32%;
    padding-top: 12.8%;
  }
  .footer .footer-nav__link {
    width: calc(100% - 2.5rem);
    height: calc(100% - 2.5rem);
    font-size: 1rem;
  }
  .footer .footer-info__list {
    max-width: 1025px;
    margin: auto;
  }
  .main-contents .breadcrumb {
    padding: 1rem 0;
  }
  .main-contents .content .card-list__inner {
    justify-content: space-between;
  }
  .main-contents .content .card-list__inner .card01 {
    width: 31%;
  }
  .main-contents .content .card-list__inner .card01__body {
    padding: 2rem 0;
  }
  .main-contents .content .prof-list__item {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
  .main-contents .content .prof-list__item:nth-of-type(odd) dt, .main-contents .content .prof-list__item:nth-of-type(odd) dd {
    background: #e9e9e9;
  }
  .main-contents .content .prof-list__item:nth-of-type(even) dt, .main-contents .content .prof-list__item:nth-of-type(even) dd {
    background: #fff;
  }
  .main-contents .content .prof-list__title {
    width: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .main-contents .content .prof-list__description {
    width: 50%;
  }
  body.under .main-contents .content .card-list__inner .card01 {
    width: 30%;
  }
}/*# sourceMappingURL=style.css.map */