@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Staatliches&display=swap");
@media screen and (max-width: 1349px) {
  .u-pc {
    display: none;
  }
}

.u-sp {
  display: none;
}
@media screen and (max-width: 1349px) {
  .u-sp {
    display: block;
  }
}

/* FontFamily */
html {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  color: #333;
  font-weight: 500;
}

/* リキッドレイアウト対応 */
html {
  font-size: 16px;
}
@media (max-width: 375px) {
  html {
    font-size: 4.2666666667vw;
  }
}
@media screen and (min-width: 768px) {
  html {
    font-size: 1.1860637509vw;
  }
}
@media (min-width: 1100px) {
  html {
    font-size: 16px;
  }
}

/* pcの電話番号発信対応 */
a[href^="tel:"] {
  pointer-events: none;
}
@media screen and (max-width: 1023px) {
  a[href^="tel:"] {
    pointer-events: unset;
  }
}

/* ホバー */
a {
  text-decoration: none;
  color: inherit;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
a:hover {
  opacity: 0.8;
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* Remove default type */
ul,
ol {
  list-style: none;
}

li, dd {
  list-style-type: none;
}

/* Remove default margin padding */
body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline;
}

/* Set core root defaults */
html {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
  letter-spacing: 0.075em;
}

/* Remove list styles on ul, ol elements with a class attribute */
ul,
ol {
  list-style: none;
}

/* Make images easier to work with */
img {
  display: block;
  width: 100%;
  height: auto;
}

/* Natural flow and rhythm in articles by default */
article > * + * {
  margin-top: 1em;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Blur images when they have no alt attribute */
img:not([alt]) {
  filter: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg"><filter id="filter"><feGaussianBlur stdDeviation="10" /></filter></svg>#filter');
  -webkit-filter: blur(10px);
          filter: blur(10px);
}

/* Remove all animations and transitions for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  * {
    -webkit-animation-duration: 0.01ms !important;
            animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
            animation-iteration-count: 1 !important;
    -webkit-transition-duration: 0.01ms !important;
            transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/* フォームリセット */
/* input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

textarea {
  resize: vertical;
}

input[type=checkbox],
input[type=radio] {
  display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

select::-ms-expand {
  display: none;
} */

button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}
input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

/* btn */
.btn {
  font-family: "Staatliches", cursive;
  font-size: 18px;
  font-size: 1.125rem;
  border: 1px solid #fff;
  border: 0.0625rem solid #fff;
  width: 220px;
  width: 13.75rem;
  height: 60px;
  height: 3.75rem;
  line-height: 58px;
  line-height: 3.625rem;
  display: block;
  text-align: center;
  position: relative;
}
.btn::after {
  position: absolute;
  content: "";
  width: 60px;
  width: 3.75rem;
  height: 1px;
  height: 0.0625rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: -30px;
  right: -1.875rem;
}

/* card */
.card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .card {
    display: block;
  }
}

.card__item {
  width: calc(33.33333% - 26.66667px);
  margin-right: 40px;
}
@media screen and (max-width: 767px) {
  .card__item {
    width: 100%;
    max-width: 31.25rem;
    margin: 0 auto;
  }
}
.card__item:nth-child(3n) {
  margin-right: 0;
}
@media screen and (max-width: 767px) {
  .card__item:nth-child(3n) {
    margin-right: auto;
  }
}
@media screen and (max-width: 767px) {
  .card__item:not(:last-child) {
    margin-bottom: 3.75rem;
  }
}

/* drawer */
.drawer {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  color: #333;
  background: #fff;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: all 0.6s;
  transition: all 0.6s;
  width: 100%;
  height: 100%;
  padding-top: 100px;
  padding-top: 6.25rem;
}

.drawer__menu-item {
  width: 100%;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: 700;
  text-align: center;
}
.drawer__menu-item a {
  padding: 0.8em 0;
  display: block;
}

/* このクラスを、jQueryで付与・削除する */
.drawer--active {
  -webkit-transform: translateX(0%);
          transform: translateX(0%);
}

.drawer--fixed {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}

/* fnav */
.fnav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .fnav {
    display: block;
    text-align: center;
  }
}

.fnav__menu:not(:last-child) {
  margin-right: 30px;
  margin-right: 1.875rem;
  padding-right: 30px;
  padding-right: 1.875rem;
  border-right: 1px solid #dfdfdf;
  border-right: 0.0625rem solid #dfdfdf;
}
@media screen and (max-width: 767px) {
  .fnav__menu:not(:last-child) {
    border: none;
    padding-right: 0;
    margin-right: 0;
  }
}

.fnav__menu-item {
  font-size: 14px;
  font-size: 0.875rem;
}
@media screen and (max-width: 767px) {
  .fnav__menu-item {
    padding: 0.5rem 0;
  }
}
.fnav__menu-item:not(:last-child) {
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 767px) {
  .fnav__menu-item:not(:last-child) {
    margin-bottom: 0rem;
  }
}
.fnav__menu-item a {
  display: block;
}

/* footer */
.footer {
  padding: 65px 0 15px;
  padding: 4.0625rem 0 0.9375rem;
}

.footer__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 30px;
  margin-bottom: 1.875rem;
}
@media screen and (max-width: 767px) {
  .footer__inner {
    display: block;
  }
}

.footer__logo {
  width: 189px;
  width: 11.8125rem;
}
@media screen and (max-width: 767px) {
  .footer__logo {
    width: 9.375rem;
    margin: 0 auto;
    margin-bottom: 2.5rem;
  }
}

.footer__copyright {
  text-align: center;
  font-size: 10px;
  font-size: 0.625rem;
}

/* gnav */
.gnav {
  height: inherit;
}

.gnav__menu {
  height: inherit;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.gnav__menu-item {
  text-align: center;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 700;
}
.gnav__menu-item:not(:last-child) {
  margin-right: 65px;
  margin-right: 4.0625rem;
}
@media screen and (max-width: 1699px) {
  .gnav__menu-item:not(:last-child) {
    margin-right: 3.125rem;
  }
}
.gnav__menu-item:hover span {
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
  color: #2cbe89;
}
.gnav__menu-item span {
  font-family: "Staatliches", cursive;
  letter-spacing: 0.1em;
  display: block;
  color: #c3c3c3;
  font-size: 14px;
  font-size: 0.875rem;
}

.gnav__menu-item--current span {
  color: #2cbe89;
}

/* hamburger */
.hamburger {
  display: block;
  position: absolute;
  z-index: 300;
  right: 30px;
  right: 1.875rem;
  top: 30px;
  top: 1.875rem;
  width: 30px;
  width: 1.875rem;
  height: 30px;
  height: 1.875rem;
  cursor: pointer;
  text-align: center;
}

.hamburger__border {
  display: block;
  position: absolute;
  width: 30px;
  width: 1.875rem;
  height: 2px;
  height: 0.125rem;
  left: 6px;
  left: 0.375rem;
  background: #000;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.hamburger__border:nth-child(1) {
  top: 10px;
  top: 0.625rem;
}
.hamburger__border:nth-child(2) {
  top: 20px;
  top: 1.25rem;
}
.hamburger__border:nth-child(3) {
  top: 30px;
  top: 1.875rem;
}

/* ナビ開いてる時のボタン */
.hamburger--active .hamburger__border:nth-child(1) {
  top: 16px;
  top: 1rem;
  left: 6px;
  left: 0.375rem;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.hamburger--active .hamburger__border:nth-child(2), .hamburger--active .hamburger__border:nth-child(3) {
  top: 16px;
  top: 1rem;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

/* header */
.header {
  height: 100px;
  height: 6.25rem;
  padding-left: 50px;
  padding-left: 3.125rem;
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 767px) {
  .header {
    padding-left: 1.25rem;
    height: 6.25rem;
  }
}

.header__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: inherit;
}

@media screen and (max-width: 1349px) {
  .header__logos {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.header__title {
  font-size: 11px;
  font-size: 0.6875rem;
  margin-bottom: 38px;
  margin-bottom: 2.375rem;
  padding-top: 9px;
  padding-top: 0.5625rem;
}
.header__title_sp {
  display: none;
}
@media screen and (max-width: 1349px) {
  .header__title {
    margin-bottom: 0;
    padding-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .header__title {
    display: none;
  }
  .header__title_sp {
    display: block;
    font-size: 8px;
  }
  .header__title_sp br {
    display: none;
  }
}
.header__title br {
  display: none;
}
@media screen and (max-width: 1699px) {
  .header__title br {
    display: block;
  }
}

.header__logo {
  width: 189px;
  width: 11.8125rem;
  position: relative;
  z-index: 200;
}
@media screen and (max-width: 1349px) {
  .header__logo {
    margin-right: 3.75rem;
  }
}
@media screen and (max-width: 767px) {
  .header__logo {
    width: 8.75rem;
    margin-bottom: 28px;
  }
}

.header__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-left: auto;
}

.header__nav {
  margin-right: 65px;
  margin-right: 4.0625rem;
  margin-top: 10px;
  margin-top: 0.625rem;
}
@media screen and (max-width: 1699px) {
  .header__nav {
    margin-right: 3.125rem;
  }
}

.header__tell {
  font-family: "Staatliches", cursive;
  letter-spacing: 0.05em;
  font-size: 32px;
  font-size: 2rem;
  margin-right: 30px;
  margin-right: 1.875rem;
  display: inline-block;
}
@media screen and (max-width: 1699px) {
  .header__tell {
    font-size: 1.75rem;
  }
}
.header__tell span {
  font-size: 24px;
  font-size: 1.5rem;
}

.header__contact {
  color: #fff;
  text-align: center;
  background: #2cbe89;
  font-family: "Staatliches", cursive;
  letter-spacing: 0.15em;
  font-size: 18px;
  font-size: 1.125rem;
  padding: 40px 30px;
  padding: 2.5rem 1.875rem;
}

.l-inner {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  max-width: 1150px;
  padding-right: 25px;
  padding-left: 25px;
}
@media screen and (max-width: 767px) {
  .l-inner {
    padding-right: 20px;
    padding-left: 20px;
  }
}

/* link */
.link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  z-index: 5;
}
@media screen and (max-width: 767px) {
  /* .link {
    display: block;
  } */
}

.link__item {
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  color: #fff;
  display: inline-block;
  width: 60px;
  width: 3.75rem;
  line-height: 60px;
  line-height: 3.75rem;
  padding: 18px 0;
  padding: 1.125rem 0;
}
/* @media screen and (max-width: 767px) {
  .link__item {
    -webkit-writing-mode: unset;
        -ms-writing-mode: unset;
            writing-mode: unset;
    display: block;
    width: 15.625rem;
    margin: 0 auto;
    text-align: center;
    line-height: unset;
  }
} */
.link__item:not(:last-child) {
  margin-bottom: 10px;
  margin-bottom: 0.625rem;
}
@media screen and (max-width: 767px) {
  .link__item:not(:last-child) {
    margin-bottom: 1.25rem;
  }
}

.link__item-text {
  display: inline-block;
  padding-top: 30px;
  padding-top: 1.875rem;
}
/* @media screen and (max-width: 767px) {
  .link__item-text {
    padding-top: 0;
    padding-left: 1.875rem;
  }
} */

.link__item--contact {
  font-family: "Staatliches", cursive;
  font-size: 20px;
  font-size: 1.25rem;
  letter-spacing: 0.2em;
  background: #d0e117;
}
.link__item--contact .link__item-text {
  background: url(../img/mail_icon01.png) no-repeat center top/21px;
  background: url(../img/mail_icon01.png) no-repeat center top/1.3125rem;
}
/* @media screen and (max-width: 767px) {
  .link__item--contact .link__item-text {
    background-position: left center;
  }
} */

.link__item--recruit {
  font-size: 16px;
  font-size: 1rem;
  font-weight: 700;
  background: #2cbe89;
}
.link__item--recruit .link__item-text {
  background: url(../img/recruit_icon.png) no-repeat center top/20px;
  background: url(../img/recruit_icon.png) no-repeat center top/1.25rem;
}
/* @media screen and (max-width: 767px) {
  .link__item--recruit .link__item-text {
    background-position: left center;
  }
} */

.link__item--instagram {
  font-family: "Staatliches", cursive;
  font-size: 20px;
  font-size: 1.25rem;
  letter-spacing: 0.2em;
  background: url(../img/instagram_bg.png) no-repeat center center/cover;
}
.link__item--instagram .link__item-text {
  background: url(../img/instagram_icon.png) no-repeat center top/22px;
  background: url(../img/instagram_icon.png) no-repeat center top/1.375rem;
}
/* @media screen and (max-width: 767px) {
  .link__item--instagram .link__item-text {
    background-position: left center;
  }
} */

/* news */
.news__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 15px;
  font-size: 0.9375rem;
  background: #fff;
  padding: 20px 45px;
  padding: 1.25rem 2.8125rem;
}
@media screen and (max-width: 767px) {
  .news__item {
    display: block;
    padding: 0.9375rem 1.25rem;
  }
}
.news__item:not(:last-child) {
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 767px) {
  .news__item:not(:last-child) {
    margin-bottom: 0.9375rem;
  }
}

.news__item-date {
  margin-right: 35px;
  margin-right: 2.1875rem;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .news__item-date {
    margin-right: 0;
    margin-bottom: 0.3125rem;
  }
}

.news__item-title {
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  letter-spacing: 0.09em;
}

/* pagetop */
.pagetop {
  width: 74px;
  width: 4.625rem;
  position: fixed;
  bottom: 68px;
  bottom: 4.25rem;
  right: 13.5%;
  z-index: 100;
}
@media screen and (max-width: 1699px) {
  .pagetop {
    bottom: 9.375rem;
    right: 10%;
    top: 88%;
  }
}
@media screen and (max-width: 1023px) {
  .pagetop {
    bottom: 12.5rem;
    right: 7%;
  }
}
@media screen and (max-width: 767px) {
  .pagetop {
    right: 5%;
  }
}

/* section-subtitle */
.section-subtitle {
  font-weight: 700;
}

/* section-text */
.section-text {
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.875;
}
@media screen and (max-width: 767px) {
  .section-text {
    line-height: 1.6;
  }
}

/* section-title */
.section-title {
  font-family: "Staatliches", cursive;
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .section-title {
    line-height: 1;
  }
}

/* top-about */
.top-about {
  padding: 65px 0 130px;
  padding: 4.0625rem 0 8.125rem;
  background: linear-gradient(315deg, #f4f4f4 48%, #fff 48%);
  position: relative;
}
@media screen and (max-width: 767px) {
  .top-about {
    padding: 5rem 0 5rem;
    background: linear-gradient(315deg, #f4f4f4 60%, #fff 60%);
  }
}

.top-about__header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  margin-bottom: 40px;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .top-about__header {
    display: block;
  }
}

.top-about__subtitle {
  margin-right: 20px;
  margin-right: 1.25rem;
  font-size: 20px;
  font-size: 1.25rem;
}
@media screen and (max-width: 767px) {
  .top-about__subtitle {
    margin-right: 0;
    font-size: 1.125rem;
  }
}

.top-about__title {
  color: #959595;
  font-size: 100px;
  font-size: 6.25rem;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .top-about__title {
    font-size: 3.75rem;
    letter-spacing: 0.05em;
  }
}

.top-about__inner {
  max-width: 1050px;
  max-width: 65.625rem;
}
@media screen and (max-width: 1349px) {
  .top-about__inner {
    max-width: 59.375rem;
  }
}
@media screen and (max-width: 767px) {
  .top-about__inner {
    padding: 0;
  }
}

.top-about__youtube {
  width: 100%;
  margin: 0 auto;
  padding-top: 55%;
  position: relative;
}
.top-about__youtube video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  
}

.top-about__link {
  position: fixed;
  right: 20px;
  right: 1.25rem;
  top: 60px;
  top: 3.75rem;
  z-index: 9;
}
@media screen and (max-width: 1349px) {
  .top-about__link {
    top: 12.5rem;
  }
}
@media screen and (max-width: 767px) {
.top-about__link {
    position: fixed;
    right: 20px;
    right: 0.25rem;
    top: 60px;
    top: 1.75rem;
}
}

/* top-bg */
.top-bg {
  position: absolute;
  z-index: 5;
  top: 0;
  left: 0;
  width: 100%;
  height: 955px;
  height: 59.6875rem;
  background: url(../img/top-mv_bg.png) no-repeat left top/50%;
}
@media screen and (min-width: 1999px) {
  .top-bg {
    background-size: contain;
  }
}
@media screen and (max-width: 767px) {
  .top-bg {
    height: 37.5rem;
  }
}

/* top-business */
.top-business {
  background: url(../img/top-business_bg.png) no-repeat left top/41.5%;
  padding: 137px 0 90px;
  padding: 8.5625rem 0 5.625rem;
}
@media screen and (max-width: 767px) {
  .top-business {
    padding: 6.25rem 0 5rem;
    background-size: 35%;
  }
}

.top-business__header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 15px;
  margin-bottom: 0.9375rem;
}
@media screen and (max-width: 767px) {
  .top-business__header {
    display: block;
    margin-bottom: 2.5rem;
  }
}

.top-business__title {
  color: #959595;
  font-size: 100px;
  font-size: 6.25rem;
  margin-right: 15px;
  margin-right: 0.9375rem;
  letter-spacing: 0.075em;
}
@media screen and (max-width: 767px) {
  .top-business__title {
    font-size: 3.75rem;
    letter-spacing: 0.05em;
    margin-right: 0;
  }
}

.top-business__subtitle {
  font-size: 20px;
  font-size: 1.25rem;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .top-business__subtitle {
    font-size: 1.125rem;
  }
}

.top-business__btn {
  border-color: #232121;
  margin-left: auto;
  margin-right: 20px;
  margin-right: 1.25rem;
}
@media screen and (max-width: 767px) {
  .top-business__btn {
    margin: 0 auto;
  }
}
.top-business__btn::after {
  background: #232121;
}

@media screen and (max-width: 767px) {
  .top-business__text {
    margin-bottom: 2.5rem;
  }
}

/* top-contact */
.top-contact {
  background: url(../img/top-contact_bg.jpg) no-repeat center center/cover;
  padding: 90px 0 130px;
  padding: 5.625rem 0 8.125rem;
}
@media screen and (max-width: 767px) {
  .top-contact {
    padding: 5rem 0;
  }
}

.top-contact__box {
  background: #d0e117;
  padding: 50px;
  padding: 3.125rem;
  padding-bottom: 60px;
  padding-bottom: 3.75rem;
}
@media screen and (max-width: 767px) {
  .top-contact__box {
    padding: 2.5rem 1.25rem;
  }
}

.top-contact__title {
  text-align: center;
  color: #fff;
  font-size: 60px;
  font-size: 3.75rem;
  margin-bottom: 18px;
  margin-bottom: 1.125rem;
  letter-spacing: 0.075em;
}
@media screen and (max-width: 767px) {
  .top-contact__title {
    font-size: 3.125rem;
    letter-spacing: 0.05em;
  }
}

.top-contact__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  .top-contact__content {
    display: block;
    text-align: center;
  }
}

.top-contact__tell {
  font-family: "Staatliches", cursive;
  color: #fff;
  font-size: 45px;
  font-size: 2.8125rem;
  letter-spacing: 0.075em;
  margin-right: 61px;
  margin-right: 3.8125rem;
  display: block;
}
@media screen and (max-width: 767px) {
  .top-contact__tell {
    margin-right: 0;
    font-size: 2rem;
    margin-bottom: 0.625rem;
  }
}
.top-contact__tell span {
  font-size: 26px;
  font-size: 1.625rem;
}
@media screen and (max-width: 767px) {
  .top-contact__tell span {
    font-size: 1.25rem;
  }
}

.top-contact__mail {
  background: #fff;
  display: block;
  width: 400px;
  width: 25rem;
  max-width: 100%;
  height: 80px;
  height: 5rem;
  line-height: 80px;
  line-height: 5rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .top-contact__mail {
    width: 18.75rem;
    height: 4.375rem;
    line-height: 4.375rem;
    margin: 0 auto;
  }
}

.top-contact__mail-text {
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 700;
  display: inline-block;
  padding-left: 45px;
  padding-left: 2.8125rem;
  background: url(../img/mail_icon02.png) no-repeat left center/28px;
  background: url(../img/mail_icon02.png) no-repeat left center/1.75rem;
}
@media screen and (max-width: 767px) {
  .top-contact__mail-text {
    font-size: 1rem;
    background-size: 1.25rem;
    padding-left: 2.1875rem;
  }
}

/* top-greeting */
.top-greeting {
  background: url(../img/top-greeting_bg.png) no-repeat right bottom/30%;
  padding: 95px 0 120px;
  padding: 5.9375rem 0 7.5rem;
}
@media screen and (max-width: 1023px) {
  .top-greeting {
    background-size: 31%;
  }
}
@media screen and (max-width: 767px) {
  .top-greeting {
    padding: 5rem 0;
    background-size: 40%;
  }
}

.top-greeting__header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 30px;
  margin-bottom: 1.875rem;
}
@media screen and (max-width: 767px) {
  .top-greeting__header {
    display: block;
    margin-bottom: 2.5rem;
  }
}

.top-greeting__title {
  font-size: 100px;
  font-size: 6.25rem;
  color: #959595;
  letter-spacing: 0.075em;
  margin-right: 15px;
  margin-right: 0.9375rem;
}
@media screen and (max-width: 767px) {
  .top-greeting__title {
    font-size: 3.75rem;
    letter-spacing: 0.05em;
    margin-right: 0;
  }
}

.top-greeting__subtitle {
  font-size: 20px;
  font-size: 1.25rem;
}
@media screen and (max-width: 767px) {
  .top-greeting__subtitle {
    font-size: 1.125rem;
  }
}

.top-greeting__text:not(:last-child) {
  margin-bottom: 30px;
  margin-bottom: 1.875rem;
}

/* top-infection */
.top-infection {
  background: url(../img/top-infection_bg.jpg) no-repeat center center/cover;
  padding: 90px 0 180px;
  padding: 5.625rem 0 11.25rem;
}
@media screen and (max-width: 767px) {
  .top-infection {
    padding: 5rem 0;
  }
}

.top-infection__title {
  text-align: center;
  color: #fff;
  font-size: 48px;
  font-size: 3rem;
  font-weight: 700;
  letter-spacing: 0.075em;
}
@media screen and (max-width: 767px) {
  .top-infection__title {
    font-size: 2rem;
    letter-spacing: 0.05em;
  }
}

.top-infection__subtitle {
  text-align: center;
  color: #fff;
  font-family: "Staatliches", cursive;
  font-size: 30px;
  font-size: 1.875rem;
  letter-spacing: 0.1em;
  margin-bottom: 30px;
  margin-bottom: 1.875rem;
}
@media screen and (max-width: 767px) {
  .top-infection__subtitle {
    font-size: 1.5rem;
    line-height: 1.2;
  }
}

.top-infection__text {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.66;
  color: #fff;
  margin-bottom: 70px;
  margin-bottom: 4.375rem;
}
@media screen and (max-width: 767px) {
  .top-infection__text {
    font-size: 1rem;
  }
}

.top-infection__item {
  background: #f4f4f4;
  text-align: center;
  padding: 40px 0;
  padding: 2.5rem 0;
}
.top-infection__item:first-child .top-infection__item-number {
  margin-bottom: 15px;
  margin-bottom: 0.9375rem;
}
.top-infection__item:first-child .top-infection__item-img {
  width: 153px;
  width: 9.5625rem;
  margin-bottom: 35px;
  margin-bottom: 2.1875rem;
}
.top-infection__item:nth-child(2) .top-infection__item-number {
  margin-bottom: 5px;
  margin-bottom: 0.3125rem;
}
.top-infection__item:nth-child(2) .top-infection__item-img {
  width: 142px;
  width: 8.875rem;
  margin-bottom: 30px;
  margin-bottom: 1.875rem;
}
.top-infection__item:last-child .top-infection__item-number {
  margin-bottom: 50px;
  margin-bottom: 3.125rem;
}
.top-infection__item:last-child .top-infection__item-img {
  width: 166px;
  width: 10.375rem;
  margin-bottom: 30px;
  margin-bottom: 1.875rem;
}

.top-infection__item-heading {
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 700;
}

.top-infection__item-number {
  color: #d0e117;
  font-family: "Staatliches", cursive;
  font-size: 60px;
  font-size: 3.75rem;
  line-height: 1.2;
}

.top-infection__item-img {
  max-width: 90%;
  margin: 0 auto;
}

.top-infection__item-title {
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .top-infection__item-title {
    font-size: 1.125rem;
  }
}

/* top-mv */
.top-mv {
  position: relative;
  z-index: 9;
}

.top-mv__slider {
  margin-left: auto;
  width: 78.6%;
}
@media screen and (max-width: 767px) {
  .top-mv__slider {
    width: 90%;
  }
}

.top-mv__texts {
  position: absolute;
  left: 6%;
  top: 23%;
}
@media screen and (max-width: 1699px) {
  .top-mv__texts {
    top: 15%;
  }
}
@media screen and (max-width: 767px) {
  .top-mv__texts {
    left: 1.25rem;
  }
}

.top-mv__text {
  font-size: 48px;
  font-size: 3rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 30px;
  margin-bottom: 1.875rem;
  padding-left: 22%;
  line-height: 1.9;
}
@media screen and (max-width: 1699px) {
  .top-mv__text {
    line-height: 1.8;
    font-size: 2.625rem;
  }
}
@media screen and (max-width: 767px) {
  .top-mv__text {
    font-size: 1.125rem;
    padding-left: 0;
    margin-bottom: 0.625rem;
  }
}
.top-mv__text span {
  background: #111111;
  padding: 10px 25px;
  padding: 0.625rem 1.5625rem;
}
@media screen and (max-width: 767px) {
  .top-mv__text span {
    padding: 0.3125rem 0.625rem;
  }
}

.top-mv__entext {
  font-family: "Staatliches", cursive;
  color: #e3e3e3;
  font-size: 130px;
  font-size: 8.125rem;
  letter-spacing: 0.15em;
  line-height: 0.9;
}
@media screen and (max-width: 1699px) {
  .top-mv__entext {
    font-size: 6.25rem;
  }
}
@media screen and (max-width: 767px) {
  .top-mv__entext {
    font-size: 2.5rem;
  }
}

/* top-news */
.top-news {
  padding: 65px 0 50px;
  padding: 4.0625rem 0 3.125rem;
  background: #f4f4f4;
}
@media screen and (max-width: 767px) {
  .top-news {
    padding: 5rem 0;
  }
}

.top-news__inner {
  max-width: 1000px;
  max-width: 62.5rem;
}

.top-news__title {
  text-align: center;
  font-size: 80px;
  font-size: 5rem;
  letter-spacing: 0.1em;
  color: #959595;
}
@media screen and (max-width: 767px) {
  .top-news__title {
    letter-spacing: 0.05em;
    font-size: 3.75rem;
  }
}

.top-news__subtitle {
  text-align: center;
  margin-bottom: 30px;
  margin-bottom: 1.875rem;
  font-size: 18px;
  font-size: 1.125rem;
  margin-top: -10px;
  margin-top: -0.625rem;
}
@media screen and (max-width: 767px) {
  .top-news__subtitle {
    margin-top: 0;
  }
}

.top-news__items {
  margin-bottom: 13px;
  margin-bottom: 0.8125rem;
}

.top-news__link-wrapper {
  text-align: right;
}

.top-news__link {
  font-family: "Staatliches", cursive;
  font-size: 16px;
  font-size: 1rem;
  display: inline-block;
  position: relative;
  padding: 5px 0;
  padding: 0.3125rem 0;
  padding-right: 40px;
  padding-right: 2.5rem;
}
.top-news__link::after {
  position: absolute;
  content: "";
  background: #232121;
  width: 30px;
  width: 1.875rem;
  height: 1px;
  height: 0.0625rem;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

/* top-recruit */
.top-recruit {
  background: #232121;
  padding: 75px 0;
  padding: 4.6875rem 0;
}
@media screen and (max-width: 767px) {
  .top-recruit {
    padding: 5rem 0;
  }
}

.top-recruit__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .top-recruit__inner {
    display: block;
  }
}

.top-recruit__item {
  width: 31.8%;
  text-align: center;
  color: #fff;
  padding: 105px 0 77px;
  padding: 6.5625rem 0 4.8125rem;
  display: block;
}
@media screen and (max-width: 767px) {
  .top-recruit__item {
    width: 100%;
    max-width: 31.25rem;
    margin: 0 auto;
    padding: 6.25rem 0;
  }
}
@media screen and (max-width: 767px) {
  .top-recruit__item:first-of-type {
    margin-bottom: 3.75rem;
  }
}
.top-recruit__item:last-child {
  margin-right: 40px;
  margin-right: 2.5rem;
}
@media screen and (max-width: 767px) {
  .top-recruit__item:last-child {
    margin-right: auto;
  }
}

.top-recruit__item--oneday {
  background: url(../img/top-recruit01.jpg) no-repeat center center/cover;
}

.top-recruit__item--recruit {
  background: url(../img/top-recruit02.jpg) no-repeat center center/cover;
}

.top-recruit__item-title {
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: 700;
}

.top-recruit__item-subtitle {
  font-family: "Staatliches", cursive;
  font-size: 18px;
  font-size: 1.125rem;
  letter-spacing: 0.1em;
}

.top-recruit__titles {
  color: #fff;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .top-recruit__titles {
    text-align: center;
    margin-bottom: 2.5rem;
  }
}

.top-recruit__subtitle {
  font-size: 20px;
  font-size: 1.25rem;
  text-align: right;
}
@media screen and (max-width: 767px) {
  .top-recruit__subtitle {
    font-size: 1.125rem;
    text-align: center;
  }
}

.top-recruit__title {
  font-size: 90px;
  font-size: 5.625rem;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .top-recruit__title {
    font-size: 3.75rem;
  }
}

/* top-works */
.top-works {
  background: url(../img/top-work_bg.png) no-repeat right top/30%;
  padding: 75px 0 97px;
  padding: 4.6875rem 0 6.0625rem;
  position: relative;
}
@media screen and (max-width: 1023px) {
  .top-works {
    background-size: 31%;
  }
}
@media screen and (max-width: 767px) {
  .top-works {
    padding: 5rem 0;
    background-size: 40%;
  }
}
.top-works::after {
  background: #2cbe89;
  position: absolute;
  content: "";
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -5;
}

.top-works__title {
  font-size: 100px;
  font-size: 6.25rem;
  letter-spacing: 0.1em;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .top-works__title {
    font-size: 3.75rem;
    letter-spacing: 0.05em;
  }
}

.top-works__subtitle {
  margin-bottom: 60px;
  margin-bottom: 3.75rem;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-size: 1.25rem;
  margin-top: -15px;
  margin-top: -0.9375rem;
}
@media screen and (max-width: 767px) {
  .top-works__subtitle {
    margin-top: 0;
    font-size: 1.125rem;
  }
}

.top-works__items {
  margin-bottom: 73px;
  margin-bottom: 4.5625rem;
}

.top-works__btn-wrapper {
  text-align: center;
  padding-right: 20px;
  padding-right: 1.25rem;
}
@media screen and (max-width: 767px) {
  .top-works__btn-wrapper {
    padding-right: 0;
  }
}

.top-works__btn {
  color: #fff;
  margin: 0 auto;
}
.top-works__btn::after {
  background: #fff;
}








/*=============================
	Sub(Lower)Page setting
===============================*/
/* flex */
.flex {
  display: -moz-flex;
  display: -webkit-flex;
  display: flex;
  -moz-flex-flow: row wrap;
  -webkit-flex-flow: row wrap;
  flex-flow: row wrap;
  -moz-justify-content: space-between;
  -webkit-justify-content: space-between;
  justify-content: space-between; }

.green_num {
  color: #d0e117;
  font-family: "Staatliches", cursive;
  font-size: 1.4em;
  text-align: center;
  margin-right: 0.3em;
}
.br-sp {
  display: none;
}
.marker {
  background:linear-gradient(transparent 75%, #d0e117 75%);
font-weight:bold; 
}

/*	mv
---------------------------------*/
.submainbox-wrap{
	background: url("../img/common/sub_mv.jpg") no-repeat center;
	position: relative;
	height: 400px;
}
.submainbox-wrap h2{
	position: absolute;
	width: 80%;
	top: 60%;
	left: 12%;
	font-size: 20px;
	text-align: left;
	line-height: 60px;
  font-weight: 700;
}
.submainbox-wrap h2 span{
	display: block;
	font-size: 5em;
  font-family: "Staatliches", cursive;
	text-transform: uppercase;
  letter-spacing: 0.075em;
}

/*	business
---------------------------------*/
.katawaku {
  padding: 5.625rem 0 5.625rem;
}
#business .katawaku h3 {
  font-size: 2em;
  text-align: center;
  margin-bottom: 2.5rem;
  font-weight: bold;
  line-height: 1.8;
}
.katawaku p {
  text-align: center;
  margin-bottom: 20px;
}
.strong {
  background: #f4f4f4;
  padding: 5.625rem 0 5.625rem;
}
.strong h3 {
  font-size: 2.6em;
  margin-bottom: 1.5rem;
  font-weight: bold;
}
.strong h3 span {
  font-size: 1.3rem;
  display: block;
  text-transform: uppercase;
  color: #d0e117;
}
.strong .subtxt {
  margin-bottom: 20px;
}
.strong li {
  width: 48%;
  margin-bottom: 20px;
}
.strong li .txt {
  background-color: #fff;
  padding: 1.5rem;
  height: 270px;
}
.strong h4 {
  position: relative;
  font-weight: bold;
  font-size: 1.5em;
  margin-bottom: 0.5em;
}
.strong .green_num {
  color: #d0e117;
  font-family: "Staatliches", cursive;
  font-size: 1.4em;
  text-align: center;
  margin-right: 0.3em;
}
.strong img {
  width: 100%;
  height: auto;
}

/*	company
---------------------------------*/
#company h3 {
  font-size: 2.6em;
  margin-bottom: 1.5rem;
  font-weight: bold;
  text-align: center;
}
#company h3 span {
  font-size: 1.3rem;
  display: block;
  text-transform: uppercase;
  color: #d0e117;
}
#company .about {
  padding: 5.625rem 0 5.625rem;
}
table.def-table{
	width: 100%;
	table-layout: fixed;
	border-collapse: collapse;
	text-align: left;
	margin-top: 2rem;
	border:1px solid #e2e2e2;
}
table.def-table th{
	width: 24%;
	padding: 1rem;
	border: 1px solid #e2e2e2;
  background: #d0e117;
  color: #fff;
}
table.def-table td{
	width: 76%;
	padding: 1.5rem;
	border-bottom: 1px solid #e2e2e2;
  background: #fff;
}
.partner {
  background: #f4f4f4;
  padding: 5.625rem 0 5.625rem;
}
.partner .subtxt {
  text-align: center;
  margin-bottom: 2.8em;
  font-weight: bold;
}
.partner img {
  width: 90%;
  margin: 0 auto;
  box-shadow: 10px 10px #2cbe89;
}
iframe {
  vertical-align: bottom;
}

/*	oneday
---------------------------------*/
#oneday h3 {
  font-size: 2.6em;
  margin-bottom: 1.5rem;
  font-weight: bold;
  text-align: center;
}
#oneday h3 span {
  font-size: 1.3rem;
  display: block;
  text-transform: uppercase;
  color: #d0e117;
}
.flow {
  padding: 5.625rem 0 5.625rem;
}
.flow-wrap {
  position: relative;
  text-align: left;
  margin-top: 2rem;
}
.flow-content:not(:last-of-type):before {
  content: "";
  position: absolute;
  left: 22px;
  top: 0;
  border: 1px dashed #c1c7c5;
  height: 93%;
  width: 0px;
  z-index: -5;
}
.flow-content:not(:last-of-type) {
  padding-bottom: 100px;
}
.flow-content__num {
  width: 45px;
  height: 45px;
  background: #d0e117;
  position: relative;
}
.flow-content-box {
  background: #f9faea;
  flex: 1;
  padding: 36px;
  margin-left: 40px;
  position: relative;
}
.flow-content-box:before {
  content: "";
  position: absolute;
  top: 28px;
  left: -30px;
  margin-top: -15px;
  border: 15px solid transparent;
  border-right: 15px solid #f9faea;
}
.flow-content-text {
  flex: 1;
  margin-right: 32px;
}
.flow-content-text__title {
  font-size: 28px !important;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  margin-bottom: 0.625em;
  line-height: 1.15;
  padding-bottom: 6px;
  border-bottom: 1px dashed #c1c7c5;
  margin-top: 0 !important;
}
.flow-content-text__text {
  margin-top: 20px;
}
.flow-content-figure {
  width: 30%;
  height: 150px;
  position: relative;
  overflow: hidden;
}

/*	recruit
---------------------------------*/
#recruit {
  padding: 5.625rem 0 5.625rem;
  background: linear-gradient( 
    315deg
     , #f4f4f4 48%, #fff 48%);
}
#recruit p {
  text-align: center;
  font-weight: bold;
  margin-bottom: 20px;
}
#recruit h3 {
  font-size: 2.6em;
  margin-bottom: 1.5rem;
  font-weight: bold;
  text-align: center;
}
#recruit h3 span {
  font-size: 1.3rem;
  display: block;
  text-transform: uppercase;
  color: #d0e117;
}
#recruit img {
  width: 90%;
  margin: 0 auto;
  margin-bottom: 2.8em;
}

/*	works
---------------------------------*/
.works {
  padding: 5.625rem 0 5.625rem;
}
#works h3 {
  font-size: 2.6em;
  margin-bottom: 1.5rem;
  font-weight: bold;
  text-align: center;
}
#works h3 span {
  font-size: 1.3rem;
  display: block;
  text-transform: uppercase;
  color: #d0e117;
}
.works-list li .img-box .date {
  position: absolute;
  background: #d0e117;
  color: #fff;
  font-family: "Staatliches", cursive;
  text-align: center;
  width: 110px;
  left: 0;
  top: 0;
  padding: 5px;
  font-size: 16px;
}
.works-list li .txt-box {
  padding: 20px 0 20px;
}
.works-list li {
  width: 31%;
  margin: 0 1% 10px;
}
.works-list li .img-box {
  position: relative;
}
.wp-pagenavi {
  clear: both;
  text-align: center;
  margin-top: 30px;
  font-family: "Staatliches", cursive;
}
.wp-pagenavi span.pages {
  display: none;
}
.wp-pagenavi a, .wp-pagenavi span {
  display: inline-block;
  color: #232121;
  background-color: #fff;
  padding: 5px 12px!important;
  margin: 0 2px 5px!important;
  white-space: nowrap;
  text-align: center;
  text-decoration: none;
  border: 1px solid #232121!important;
  -webkit-transition: .4s;
  transition: .4s;
}
.wp-pagenavi span.current {
  color: #fff;
  border: 1px solid #232121!important;
  font-weight: bold;
  background: #232121;
}
.wp-pagenavi a:hover {
  color: #fff !important;
  background: #232121;
  opacity: 1;
}

/* works-detail
----------------------------------- */
.works-detail {
  padding: 5.625rem 0 5.625rem;
}
.works-detail .ttl {
  text-align: center;
  font-size: 24px;
  font-weight: bold;
}
.works-detail .box {
  width: 48%;
}
.works-detail .btn {
  text-align: center;
}

.works-detail dl {
  margin-bottom: 50px;
  padding: 0 30px;
}
.works-detail dd.box {
  margin-left: 20px;
}
.works-detail a {
  text-align: right;
  display: block;
}
.works-detail .date {
  text-align: right;
  font-size: 20px;
  color: #d0e117;
  font-family: "Staatliches", cursive;
  margin-bottom: 1.5rem;
}

/* news
----------------------------------- */
#news .news {
  padding: 5.625rem 0 5.625rem;
}
#news h3 {
  font-size: 2.6em;
  margin-bottom: 1.5rem;
  font-weight: bold;
  text-align: center;
}
#news h3 span {
  font-size: 1.3rem;
  display: block;
  text-transform: uppercase;
  color: #d0e117;
}
ul.news_list li a,ul.news_list li .simple { position: relative; margin: 0; padding: 30px 0px 20px; display: block; background: url(../img/common/line01.png) no-repeat left bottom;
}
ul.news_list li a .cmn-news-ttl,.news_list li .simple .cmn-news-ttl{font-weight: bold; }
ul.news_list li a .top-news-txt p.b_ttl,ul.news_list li .simple .top-news-txt p.b_ttl { margin: 0 0 5px; font-weight: 500; color: #333; }
.cmn-news-date {
	display: block;
	margin: 0 0 10px;
	font-weight: 500;
}
.news-img {
    width: 30%;
	margin: 0 auto;
}
.news-img a {
	background: none !important;
}
.news_list a:hover {
	opacity: 0.7;
}
.news-img a:hover {
	opacity: 0.8 !important;
}
.news-text {
  padding-bottom: 1.7rem;
  border-bottom: 1px solid #838383;
}

/* news-detail
----------------------------------- */
.news-detail {
  padding: 5.625rem 0 5.625rem;
}
.news-detail .ttl {
  text-align: center;
  font-size: 24px;
  font-weight: bold;
}
.news-detail .box {
  width: 48%;
}
.news-detail .btn {
  text-align: center;
}

.news-detail dl {
  margin-bottom: 50px;
  padding: 0 30px;
}
.news-detail dd.box {
  margin-left: 20px;
}
.news-detail a {
  text-align: right;
  display: block;
}
.news-detail .date {
  text-align: right;
  font-size: 20px;
  color: #d0e117;
  font-family: "Staatliches", cursive;
  margin-bottom: 1.5rem;
}

/* sitemap
----------------------------------- */
.sitemap {
  padding: 5.625rem 0 5.625rem;
}
ul.sitemap_list {
  margin-top: 45px;
  text-align: center;
}
ul.sitemap_list li{
  width: 48%;
  margin: 0 1% 24px;
}
ul.sitemap_list li a{
  display: block; 
  padding: 20px 20px;
  background-color: #333;
  color: #fff
}
ul.sitemap_list li a:hover{
  background-color: #333;
   color: #fff; 
   transition: 0.4s;
   text-decoration: none;
}

/* privacy
----------------------------------- */
.privacy {
  padding: 5.625rem 0 5.625rem;
}
.privacy .ttl-02 {
  font-size: 24px;
  font-weight: bold;
  border-bottom: 1px solid #111e3f;
  padding-bottom: 10px;
  margin-bottom: 20px;
}
.mt60 {
  margin-top: 60px;
}

/*	contact
---------------------------------*/
.contact {
  padding: 5.625rem 0 5.625rem;
}
#contact h3 {
  font-size: 2.6em;
  margin-bottom: 1.5rem;
  font-weight: bold;
  text-align: center;
}
#contact h3 span {
  font-size: 1.3rem;
  display: block;
  text-transform: uppercase;
  color: #d0e117;
}

/* contact
----------------------------------- */
#contact p.con_cen{border: 1px solid #d0e117;text-align:center; padding:30px 50px 30px; font-size:16px; line-height:180%; margin:50px 0px 60px;}
#contact p.con_cen a{ display: inline-block; margin:15px 0px;}
#contact p.con_cen a.cc-tel{margin: 5px 0 0px; padding: 5px 0 5px 0px; font-size: 2.5rem;font-weight: normal;font-family: 'Oswald', sans-serif;}
#contact p.con_cen a.cc-tel small{font-size: 1.8rem;}
#contact p.con_cen span{font-size: 1.0rem;color: #888;display:block;font-weight: normal;}
#contact p.con_cen a img:hover{ opacity:1.0;}
#contact table.defTable01{ padding:15px 40px ;margin:0px auto;border-collapse:collapse; font-size:16px; width:100%;box-sizing:border-box;}
#contact table.defTable01 tr{ display:block;border-bottom:1px solid #ddd; padding:15px 0px;}
#contact table.defTable01 tr:first-child{ border-top: 1px solid #ddd;}
#contact table.defTable01 th{ padding:15px 40px 15px 30px;width:36%;display:inline-block; box-sizing:border-box; font-weight:bold; font-size: 16px;}
#contact table.defTable01 th span{ background: #ff5c7a; padding: 5px 30px; text-align: center; width: 200px; color: #fff; display: block;}
#contact table.defTable01 td{ padding:15px 0px 15px 0px;display:inline-block;box-sizing:border-box;width: 56.5%;; text-align:left;}
#contact table.defTable01 td a{color: #d0e117; font-weight: bold; text-decoration: underline;}
#contact table.defTable01 th em.clrred{ font-size:12px;color:#fff;font-style:normal; text-align:center;background:#d30000; padding:1px 5px; display:block; width:50px; float:right;}
#contact table.defTable01 th em.any{ font-size:12px;color:#fff;font-style:normal; text-align:center;background:#333;padding:1px 5px;width:50px; float:right;}
#contact table.defTable01 td.cen{ text-align:center; margin:0 auto; display:block;}
#contact table.defTable01 td.cen input{padding: 10px;color: #000;font-size: 16px;width: 250px;background: #fff;cursor: pointer; border:2px solid #ccc; display:block; text-align:center; margin:0 auto;}
#contact table.defTable01 td.cen input:hover{ background: #000;opacity: 0.8;filter: alpha(opacity=80);-moz-opacity: 1.0;-webkit-transition: 0.3s ease-in-out;-moz-transition: 0.3s ease-in-out;-o-transition: 0.3s ease-in-out;transition: 0.3s ease-in-out; color:#fff;}
#contact table.defTable01 input {padding: 8px 10px; background: #eee; font-size:13px;border:none;box-sizing:border-box;width:100%;}
#contact table.defTable01 textarea  {padding:8px 10px;background: #eee;font-size:13px; border:none; width:100%;box-sizing: border-box;}
#contact table.defTable01 .bbn {border-bottom: none!important;}
#contact table.defTable01 a.bb01 {color: #d0e117;}
#contact table.defTable01 td.tel_area input {width:23%;}
#contact table.defTable01 input[type="checkbox"] { width: auto;}
#contact table.defTable01 input[type="radio"] { width: auto;}


/*-------------------------*/
/* SPレイアウト 767px*/
/*-------------------------*/
@media screen and (max-width: 767px) {

.br-sp {
  display: block;
}
  
/*	mv
---------------------------------*/
.submainbox-wrap{
  background: url(../img/common/sub_mv.jpg) no-repeat left 68% bottom;
	position: relative;
	height: 200px;
  background-color: rgba(255,255,255,0.3);
  background-blend-mode: lighten;
}
.submainbox-wrap h2{
	position: absolute;
	width: 80%;
	top: 40%;
	left: 50%;
	transform: translateX(-50%);
	font-size: 20px;
	text-align: center;
	line-height: 40px;
}
.submainbox-wrap h2 span{
    font-size: 3.75rem;
    letter-spacing: 0.05em;
    margin-right: 0;
    margin-bottom: 6px;
}

/*	business
---------------------------------*/
.strong li {
  width: 100%;
}

/*	company
---------------------------------*/
table.def-table th{
	width: 100%;
	display: block;
	padding: 1rem .5rem;
	border: none;
	border-bottom: 1px solid #e2e2e2;
}
table.def-table td{
	display: block;
	width: 100%;
	padding: 1rem .5rem;
	border-bottom: 1px solid #e2e2e2;
}

/*	oneday
---------------------------------*/
.flow-content__num {
  width: 100%;
  height: 40px;
}
.flow-content-box:before {
  display: none;
}
.flow-content-box {
  margin-left: 0;
}
.flow-content-figure {
  width: 100%;
}
.flow-content:not(:last-of-type):before {
  content: "";
  position: absolute;
  left: calc( 50% - 2px);
}
.flow-content:not(:last-of-type) {
  padding-bottom: 60px;
}
.flow-content-text {
  margin: 0;
  margin-bottom: 2rem;
}

/* works
----------------------------------- */
.works-list li {
  width: 100%;
}

/* works-detail
----------------------------------- */
.works-detail dd.box {
  margin-left: 0px;
}
.works-detail .box {
  width: 100%;
}
.works-detail img {
  margin-bottom: 1rem;
}

/* news
----------------------------------- */
.news-img {
  width: 80%;
  margin-bottom: 20px;
}

/* news-detail
----------------------------------- */
.news-detail dd.box {
  margin-left: 0px;
}
.news-detail .box {
  width: 100%;
}
.news-detail img {
  margin-bottom: 1rem;
}

/* sitemap
----------------------------------- */
ul.sitemap_list li {
  width: 100%;
  margin: 0 1% 24px;
}
/* contact
----------------------------------- */
#contact p.con_cen{border: 1px solid #d0e117;text-align:center; padding:15px 10px 15px; font-size:14px; line-height:160%; margin:30px 0px 30px;}
#contact p.con_cen a{ display: inline-block; margin:10px 0px;}
#contact p.con_cen a.cc-tel{margin: 5px 0 0px; padding: 5px 0 5px 0px; font-size: 24px;font-weight: normal;font-family: 'Oswald', sans-serif;}
#contact p.con_cen a.cc-tel small{font-size: 19px;}
#contact p.con_cen span{font-size: 14px;color: #888;display:block;font-weight: normal;}
#contact p.con_cen a img:hover{ opacity:1.0;}
#contact table.defTable01{ padding:0px 0px;margin:0px auto ;border-collapse:collapse; font-size:14px; width:100%;box-sizing:border-box;}
#contact table.defTable01 tr{ display:block;border-bottom:0px solid #ddd; padding:0px 0px;}
#contact table.defTable01 tr:first-child{ border-top: 0px solid #ddd;}
#contact table.defTable01 th{ padding:10px 0px 10px 0px;width:100%;display:block;border-top: 1px solid #ddd;border-bottom: 1px solid #ddd; box-sizing:border-box; font-weight:bold; font-size: 14px; text-align: left;}
#contact table.defTable01 th span{ background: #ff5c7a; padding: 5px 20px; text-align: center; width: 150px; color: #fff; display: block;}
#contact table.defTable01 td{ padding:15px 0px 15px 0px;display:block;box-sizing:border-box;width:100%; text-align:left;}
#contact table.defTable01 td a{color: #17b5e9; font-weight: bold; text-decoration: underline;}
#contact table.defTable01 th em.clrred{ font-size:12px;color:#fff;font-style:normal; text-align:center;background:#d30000; padding:1px 5px; display:block; width:50px; float:right;}
#contact table.defTable01 th em.any{ font-size:12px;color:#fff;font-style:normal; text-align:center;background:#333;padding:1px 5px;width:50px; float:right;}
#contact table.defTable01 td.cen{ text-align:center; margin:0 auto; display:block;}
#contact table.defTable01 td.cen input{padding: 10px;color: #000;font-size: 14px;width: 100%;background: #fff;cursor: pointer; border:2px solid #ccc; display:block; text-align:center; margin:0 auto;}
#contact table.defTable01 td.cen input:hover{ background: #000;opacity: 0.8;filter: alpha(opacity=80);-moz-opacity: 1.0;-webkit-transition: 0.3s ease-in-out;-moz-transition: 0.3s ease-in-out;-o-transition: 0.3s ease-in-out;transition: 0.3s ease-in-out; color:#fff;}
#contact table.defTable01 input {padding: 8px 10px; background: #eee; font-size:13px;border:none;box-sizing:border-box;width:100%;}
#contact table.defTable01 textarea  {padding:8px 10px;background: #eee;font-size:13px; border:none; width:100%;box-sizing: border-box;}
#contact table.defTable01 .bbn {border-bottom: none!important;}
#contact table.defTable01 a.bb01 {color: #d0e117;}
#contact table.defTable01 td.tel_area input {width:23%;}
#contact table.defTable01 input[type="checkbox"] { width: auto;}
#contact table.defTable01 input[type="radio"] { width:auto;}
/* privacy
----------------------------------- */
#contact.privacy h3:first-child{ margin-top: 10px;}
#contact.privacy h3{text-align:left; font-size: 18px; font-weight: bold;margin-bottom:20px; width:100%;position: relative;display: inline-block; margin-top:20px;font-weight: bold;text-align: left;padding: 0px;letter-spacing: 0.05em;}
#contact.privacy h3:before {top:inherit;background: none; content: '';position: absolute;bottom: -15px;display: inline-block;width:100px;height:2px;left:0%;-moz-transform: translateX(0%);-webkit-transform: translateX(0%);-ms-transform: translateX(0%);transform: translateX(0%);background-color:#ff9933;}
#contact.privacy h3:before, #contact h3.privacy:after{border-top: solid 2px #ff9933; border-bottom:none;}
#contact.privacy h3::after{display: none;}
#contact.privacy hr{border:0.5px solid #ddd;margin: 40px auto 20px; border-bottom: none;}



}





@media screen and (max-width: 500px) {
/*	business
---------------------------------*/
.strong li .txt {
  height: auto;
}



}



.agrBox .wpcf7-list-item {width: 100%!important;}
.wpcf7-list-item{margin: 0 15px 0 0!important;}
.wpcf7 .ajax-loader{ margin-top:30px!important;}
@media screen and (max-width: 767px) {
.wpcf7-list-item {
	display:block!important;
	margin:0!important;
	width:100%!important;
}
}