@charset "UTF-8";
/* -- color --*/
/*------------------------------
            事業紹介
------------------------------*/
.page-service .catch {
  margin-bottom: 22rem;
}
.page-service .catch .catch-copy {
  font-size: 4.8rem;
  font-weight: 600;
  margin-bottom: 3rem;
}
.page-service .catch .catch-content {
  font-size: 2rem;
}
.page-service .about-wrap {
  align-items: center;
  justify-content: center;
}
.page-service .about-wrap .about-content {
  width: 46%;
  margin-left: 4%;
}
.page-service .sec-triangle {
  padding: 10rem 0 0;
  background: url(../img/service/brush_pc.png) no-repeat center center/cover;
}
.page-service .sec-detail {
  padding: 28rem 0 22rem;
}
.page-service .sec-detail .genre-wrap:not(:last-of-type) {
  margin-bottom: 18rem;
}
.page-service .sec-detail .genre-head {
  align-items: flex-end;
  padding-bottom: 10rem;
  margin-bottom: 10rem;
  border-bottom: 0.2rem solid #000;
}
.page-service .sec-detail .genre-head .num-ttl {
  width: 50%;
  font-weight: 600;
}
.page-service .sec-detail .genre-head .num-ttl .num {
  color: #a3a3a3;
  font-size: 6.0416666667vw;
  line-height: 1;
}
.page-service .sec-detail .genre-head .num-ttl .ttl-en {
  font-size: 1.4583333333vw;
}
.page-service .sec-detail .genre-head .num-ttl .ttl-name {
  font-size: 2.5vw;
}
.page-service .sec-detail .genre-head .genre-content {
  width: 50%;
}
.page-service .sec-detail .genre-head .genre-content .exp-ttl {
  font-size: 1.4583333333vw;
  font-weight: 600;
  display: inline-block;
  margin-bottom: 2rem;
}
.page-service .sec-detail .business-item {
  align-items: center;
}
.page-service .sec-detail .business-item:not(:last-of-type) {
  margin-bottom: 10rem;
}
.page-service .sec-detail .business-item .business-detail {
  width: 50%;
  padding-right: 2%;
}
.page-service .sec-detail .business-item .business-img {
  width: 40.8%;
}
.page-service .sec-detail .business-item .business-head {
  font-weight: 600;
  font-size: 1.25vw;
  margin-bottom: 3rem;
}
.page-service .sec-detail .business-item .business-head .cont-ttl {
  display: inline-block;
  font-size: 1.7708333333vw;
}
.page-service .sec-detail .business-item .block-btn {
  margin-top: 4rem;
}
.page-service .sec-reason {
  background: url(../img/service/brush02_pc.png) no-repeat center center/100% auto;
}
.page-service .sec-reason h2.sec-ttl {
  padding-right: 0;
}
.page-service .sec-reason .reason-intro {
  margin: 7rem 0;
}
.page-service .sec-reason .reason-list {
  flex-flow: wrap;
  justify-content: center;
}
.page-service .sec-reason .reason-list li {
  width: 26.3157894737%;
  padding: 0 2%;
}
.page-service .sec-reason .reason-list li:nth-last-child(-n+2) {
  margin-top: 6rem;
}
.page-service .sec-reason .reason-list li .icon {
  margin-bottom: 2rem;
}

@media screen and (max-width: 1024px) {
  .page-service .catch {
    margin-bottom: 20vw;
  }
  .page-service .catch .catch-copy {
    font-size: 4.8vw;
    margin-bottom: 3vw;
  }
  .page-service .catch .catch-content {
    font-size: 1.8rem;
  }
  .page-service .about-wrap {
    display: block;
  }
  .page-service .about-wrap .about-content {
    width: 100%;
    margin: 6vw 0 0;
  }
  .page-service .sec-triangle {
    padding: 10vw 0 0;
  }
  .page-service .sec-triangle .service-img {
    width: 80%;
    margin: auto;
  }
  .page-service .sec-detail {
    padding: 28vw 0 22vw;
  }
  .page-service .sec-detail .genre-wrap:not(:last-of-type) {
    margin-bottom: 18vw;
  }
  .page-service .sec-detail .genre-head {
    display: block;
    padding-bottom: 10vw;
    margin-bottom: 10vw;
  }
  .page-service .sec-detail .genre-head .num-ttl {
    width: 100%;
  }
  .page-service .sec-detail .genre-head .genre-content {
    width: 100%;
  }
  .page-service .sec-detail .genre-head .num-ttl {
    margin-bottom: 4vw;
  }
  .page-service .sec-detail .genre-head .num-ttl .num {
    font-size: 11.6vw;
  }
  .page-service .sec-detail .genre-head .num-ttl .ttl-en {
    font-size: 2.8vw;
  }
  .page-service .sec-detail .genre-head .num-ttl .ttl-name {
    font-size: 4.8vw;
  }
  .page-service .sec-detail .genre-head .genre-content .exp-ttl {
    font-size: 2.8vw;
    margin-bottom: 2vw;
  }
  .page-service .sec-detail .business-item {
    display: block;
  }
  .page-service .sec-detail .business-item:not(:last-of-type) {
    margin-bottom: 10vw;
  }
  .page-service .sec-detail .business-item .business-detail {
    width: 100%;
    padding: 0;
    margin-bottom: 6vw;
  }
  .page-service .sec-detail .business-item .business-img {
    width: 100%;
    text-align: center;
  }
  .page-service .sec-detail .business-item .business-head {
    font-size: 2.4vw;
    margin-bottom: 3vw;
  }
  .page-service .sec-detail .business-item .business-head .cont-ttl {
    font-size: 3.4vw;
  }
  .page-service .sec-reason .reason-intro {
    margin: 7vw 0;
  }
  .page-service .sec-reason .reason-list li {
    width: 33.3333333333%;
  }
}
@media screen and (max-width: 750px) {
  .page-service .catch .catch-copy {
    font-size: 5.2vw;
  }
  .page-service .catch .catch-content {
    font-size: 1.4rem;
  }
  .page-service .sec-triangle {
    padding: 14vw 0 0;
    background: url(../img/service/brush_sp.png) no-repeat center center/cover;
  }
  .page-service .sec-triangle .service-img {
    width: 100%;
  }
  .page-service .sec-detail .genre-head {
    padding-bottom: 12vw;
    margin-bottom: 12vw;
  }
  .page-service .sec-detail .genre-head .num-ttl .num {
    font-size: 14vw;
  }
  .page-service .sec-detail .genre-head .num-ttl .ttl-en {
    font-size: 4vw;
  }
  .page-service .sec-detail .genre-head .num-ttl .ttl-name {
    font-size: 5.6vw;
  }
  .page-service .sec-detail .genre-head .genre-content .exp-ttl {
    font-size: 4.4vw;
    margin-bottom: 4vw;
  }
  .page-service .sec-detail .business-item:not(:last-of-type) {
    margin-bottom: 14vw;
  }
  .page-service .sec-detail .business-item .business-head {
    font-size: 4vw;
    margin-bottom: 6vw;
  }
  .page-service .sec-detail .business-item .business-head .cont-ttl {
    font-size: 4.8vw;
  }
  .page-service .sec-detail .business-item .business-detail {
    margin-bottom: 8vw;
  }
  .page-service .sec-reason {
    background: url(../img/service/brush02_sp.png) no-repeat center center/100% auto;
  }
  .page-service .sec-reason .reason-intro {
    margin: 14vw 0;
  }
  .page-service .sec-reason .reason-list li {
    width: 47.619047619%;
    padding: 0;
    margin-bottom: 8vw;
  }
  .page-service .sec-reason .reason-list li:nth-last-child(-n+2) {
    margin-top: 0;
  }
  .page-service .sec-reason .reason-list li:last-child {
    margin-bottom: 0;
  }
}
/*------------------------------
            会社概要
------------------------------*/
.page-company .sec-intro {
  position: relative;
  padding-bottom: 24rem;
}
.page-company .sec-intro::after {
  content: "";
  width: 72rem;
  height: 70rem;
  background: url(../img/company/brush.png) no-repeat center center/cover;
  position: absolute;
  right: 0;
  bottom: -50%;
  z-index: -1;
}
.page-company .sec-intro .intro-catch {
  font-size: 2.5vw;
  font-weight: 600;
}
.page-company .sec-intro .intro-catch-sub {
  font-size: 1.4583333333vw;
  font-weight: 600;
  margin: 2rem 0 4rem;
}
.page-company .sec-message .inner-160 {
  justify-content: space-between;
  align-items: flex-end;
}
.page-company .sec-message .photo-wrap {
  width: 45%;
  margin-bottom: 7rem;
}
.page-company .sec-message .photo-wrap .ceo-img {
  margin-top: 6rem;
}
.page-company .sec-message .message-wrap {
  width: 50%;
}
.page-company .sec-message .message-wrap .ceo-name {
  text-align: right;
  font-weight: 600;
  margin-top: 6rem;
}
.page-company .sec-message .message-wrap .ceo-name .name {
  font-size: 2.4rem;
}
.page-company .sec-exterior {
  padding: 24rem 0 18rem;
}
.page-company .sec-corporate .inner {
  max-width: 100rem;
}
.page-company .sec-corporate .table {
  display: flex;
  flex-flow: wrap;
  margin-top: 6rem;
}
.page-company .sec-corporate .table dt {
  width: 30%;
  border-bottom: 0.1rem solid #000;
}
.page-company .sec-corporate .table dd {
  width: 70%;
  border-bottom: 0.1rem solid #fff;
}
.page-company .sec-corporate .table dt, .page-company .sec-corporate .table dd {
  padding: 3.4rem 0;
}
.page-company .sec-corporate .map {
  margin-top: 10rem;
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
}

@media screen and (max-width: 1024px) {
  .page-company .sec-intro {
    padding-bottom: 24vw;
  }
  .page-company .sec-intro::after {
    width: 60%;
    height: 60vw;
  }
  .page-company .sec-intro .intro-catch {
    font-size: 4.8vw;
  }
  .page-company .sec-intro .intro-catch-sub {
    font-size: 2.8vw;
    margin: 2vw 0 4vw;
  }
  .page-company .sec-message .inner-160 {
    display: block;
  }
  .page-company .sec-message .photo-wrap {
    width: 100%;
    margin-bottom: 6vw;
  }
  .page-company .sec-message .message-wrap {
    width: 100%;
  }
  .page-company .sec-message .message-wrap .ceo-name {
    margin-top: 6vw;
  }
  .page-company .sec-exterior {
    padding: 24vw 0 18vw;
  }
  .page-company .sec-corporate .table {
    margin-top: 8vw;
  }
  .page-company .sec-corporate .table dt, .page-company .sec-corporate .table dd {
    padding: 3vw 0;
  }
  .page-company .sec-corporate .map {
    margin-top: 10vw;
  }
}
@media screen and (max-width: 750px) {
  .page-company .sec-intro::after {
    bottom: -35%;
  }
  .page-company .sec-intro .intro-catch {
    font-size: 5.4vw;
  }
  .page-company .sec-intro .intro-catch-sub {
    font-size: 4.4vw;
    margin: 4vw 0 6vw;
  }
  .page-company .sec-message .photo-wrap {
    margin-bottom: 8vw;
  }
  .page-company .sec-message .photo-wrap .ceo-img {
    margin-top: 10vw;
  }
  .page-company .sec-message .message-wrap .ceo-name .name {
    font-size: 2rem;
  }
  .page-company .sec-exterior {
    padding: 24vw 0;
  }
  .page-company .sec-corporate h2.sec-ttl {
    padding-right: 0;
  }
  .page-company .sec-corporate .table {
    margin-top: 12vw;
  }
  .page-company .sec-corporate .table dt {
    width: 100%;
  }
  .page-company .sec-corporate .table dd {
    width: 100%;
    border-bottom: none;
  }
}
/*------------------------------
            お問いわせ
------------------------------*/
.page-contact .page-content .inner {
  max-width: 100rem;
}
.page-contact .form-table {
  display: flex;
  flex-flow: wrap;
}
.page-contact .form-table dt {
  width: 30%;
  display: flex;
  align-items: center;
}
.page-contact .form-table dt .req {
  color: #cd0000;
}
.page-contact .form-table dd {
  width: 70%;
}
.page-contact .form-table dt, .page-contact .form-table dd {
  padding: 3rem 0;
  border-bottom: 0.1rem solid #000;
}
.page-contact .form-table input[type=text], .page-contact .form-table input[type=tel], .page-contact .form-table input[type=email], .page-contact .form-table textarea {
  background: #fff;
  width: 100%;
  padding: 1.2rem 2rem;
}
.page-contact .form-table .wpcf7-list-item {
  margin: 0 3rem 0 0;
}
.page-contact .form-table .wpcf7-list-item-label {
  cursor: pointer;
  display: block;
  padding-left: 3rem;
  position: relative;
}
.page-contact .form-table .wpcf7-list-item-label::before {
  content: "";
  width: 1.8rem;
  height: 1.8rem;
  border: 0.1rem solid #000;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.page-contact .form-table input[type=radio]:checked + .wpcf7-list-item-label::after {
  content: "";
  width: 1rem;
  height: 1rem;
  background: #000;
  position: absolute;
  left: 0.4rem;
  top: 50%;
  transform: translateY(-50%);
}
.page-contact .flex-btn {
  justify-content: center;
  margin-top: 8rem;
}
.page-contact .flex-btn .form-btn {
  width: 45%;
  max-width: 29.6rem;
  margin: 0 2rem;
}
.page-contact .flex-btn .form-btn input, .page-contact .flex-btn .form-btn button {
  width: 100%;
  padding: 1.4rem;
  text-align: center;
  background: #fff;
  border: 0.1rem solid #000;
}
.page-contact .flex-btn .btn-submit button, .page-contact .flex-btn .btn-submit input {
  color: #fff;
  background: #000;
}

.page-thanks .page-content .inner {
  max-width: 100rem;
}
.page-thanks h3 {
  font-size: 3.4rem;
  font-weight: 600;
  margin-bottom: 3rem;
}
.page-thanks p:not(:last-of-type) {
  margin-bottom: 3rem;
}
.page-thanks .block-btn {
  margin: 6rem auto 0;
}

@media screen and (max-width: 1024px) {
  .page-contact .form-table dt, .page-contact .form-table dd {
    padding: 4vw 0;
  }
  .page-contact .flex-btn {
    margin-top: 8vw;
  }
  .page-thanks h3 {
    font-size: 3.8vw;
    margin-bottom: 3vw;
  }
  .page-thanks p:not(:last-of-type) {
    margin-bottom: 3vw;
  }
}
@media screen and (max-width: 750px) {
  .page-contact .form-table {
    display: block;
  }
  .page-contact .form-table dt, .page-contact .form-table dd {
    width: 100%;
  }
  .page-contact .form-table dt {
    border-bottom: none;
    padding-bottom: 0;
    padding-top: 6vw;
  }
  .page-contact .form-table dd {
    padding: 4vw 0 6vw;
  }
  .page-contact .form-table input[type=text], .page-contact .form-table input[type=tel], .page-contact .form-table input[type=email], .page-contact .form-table textarea {
    padding: 3vw;
  }
  .page-contact .flex-btn {
    margin-top: 12vw;
    flex-flow: wrap;
  }
  .page-contact .flex-btn .form-btn {
    width: 72%;
  }
  .page-contact .flex-btn .form-btn input, .page-contact .flex-btn .form-btn button {
    padding: 3vw;
  }
  .page-contact .flex-btn .btn-submit {
    margin-top: 4vw;
  }
  .page-thanks h3 {
    font-size: 5vw;
    margin-bottom: 6vw;
  }
  .page-thanks p:not(:last-of-type) {
    margin-bottom: 4vw;
  }
  .page-thanks .block-btn {
    margin: 14vw auto 0;
  }
}
/*------------------------------
            採用求人
------------------------------*/
.page-recruit .page-content .inner {
  max-width: 120rem;
}
.page-recruit .tab {
  display: flex;
  justify-content: center;
  border-bottom: 0.1rem solid #000;
  margin-bottom: 4rem;
}
.page-recruit .tab li {
  border: 0.1rem solid #000;
  border-bottom: none;
  text-align: center;
  font-size: 2.4rem;
  font-weight: 600;
  width: 50%;
  max-width: 44rem;
  padding: 0.95rem 1.2rem;
  background: #fff;
}
.page-recruit .tab li.select {
  color: #fff;
  background: #000;
}
.page-recruit .tab-item.hide {
  display: none;
}
.page-recruit .table {
  display: flex;
  flex-flow: wrap;
}
.page-recruit .table dt {
  width: 30%;
}
.page-recruit .table dd {
  width: 70%;
}
.page-recruit .table dt, .page-recruit .table dd {
  padding: 4rem 0;
  border-bottom: 0.1rem solid #000;
}
.page-recruit .table .service-content {
  padding: 4rem 0;
  border-bottom: 0.1rem solid #898989;
}
.page-recruit .table .service-content:first-of-type {
  padding-top: 0;
}
.page-recruit .table .service-content:last-of-type {
  padding-bottom: 0;
  border-bottom: none;
}
.page-recruit .table .service-content .service-ttl {
  font-weight: 600;
  margin-bottom: 1rem;
}
.page-recruit .block-btn {
  margin: 12rem auto 0;
}

@media screen and (max-width: 1024px) {
  .page-recruit .tab {
    margin-bottom: 4vw;
  }
  .page-recruit .tab li {
    font-size: 1.8rem;
  }
  .page-recruit .table dt, .page-recruit .table dd {
    padding: 4vw 0;
  }
  .page-recruit .table .service-content {
    padding: 4vw 0;
  }
  .page-recruit .block-btn {
    margin: 12vw auto 0;
  }
}
@media screen and (max-width: 750px) {
  .page-recruit .tab {
    margin-bottom: 6vw;
  }
  .page-recruit .tab li {
    font-size: 1.6rem;
    padding: 2vw;
  }
  .page-recruit .table dt, .page-recruit .table dd {
    width: 100%;
    padding: 6vw 0;
  }
  .page-recruit .table dt {
    border-bottom: none;
    padding-bottom: 0;
  }
  .page-recruit .table dd {
    padding-top: 4vw;
  }
  .page-recruit .table .service-content {
    padding: 6vw 0;
  }
  .page-recruit .block-btn {
    margin: 16vw auto 0;
  }
}
/*------------------------------
        プライバシーポリシー
------------------------------*/
.page-policy .policy-intro {
  margin-bottom: 8rem;
}
.page-policy .policy-item:not(:last-of-type) {
  margin-bottom: 8rem;
}
.page-policy .policy-item .policy-ttl {
  font-size: 2.4rem;
  font-weight: 600;
  padding-bottom: 2rem;
  margin-bottom: 3rem;
  border-bottom: 0.1rem solid #000;
}
.page-policy .policy-item p:last-of-type {
  margin-top: 3rem;
}
.page-policy .policy-item ul {
  margin-top: 3rem;
}
.page-policy .policy-item ul li {
  position: relative;
  padding-left: 2rem;
}
.page-policy .policy-item ul li::before {
  content: "";
  width: 1.2rem;
  height: 1.2rem;
  background: #000;
  position: absolute;
  left: 0;
  top: 0.8rem;
}

@media screen and (max-width: 1024px) {
  .page-policy .policy-intro {
    margin-bottom: 8vw;
  }
  .page-policy .policy-item:not(:last-of-type) {
    margin-bottom: 8vw;
  }
  .page-policy .policy-item .policy-ttl {
    font-size: 2rem;
    padding-bottom: 2vw;
    margin-bottom: 3vw;
  }
  .page-policy .policy-item ul {
    margin-top: 3vw;
  }
  .page-policy .policy-item p:last-of-type {
    margin-top: 3vw;
  }
}
@media screen and (max-width: 750px) {
  .page-policy .policy-intro {
    margin-bottom: 12vw;
  }
  .page-policy .policy-item:not(:last-of-type) {
    margin-bottom: 12vw;
  }
  .page-policy .policy-item .policy-ttl {
    font-size: 1.6rem;
    margin-bottom: 4vw;
  }
  .page-policy .policy-item p:last-of-type {
    margin-top: 6vw;
  }
  .page-policy .policy-item ul li:before {
    top: 0.5rem;
  }
}