@charset "UTF-8";
.home main > section {
  margin-top: 3.5rem;
}

@media screen and (max-width: 500px) {
  .home main > section {
    margin-top: 1rem;
  }
}

.home .mainimg {
  position: relative;
  overflow: hidden;
  background-image: url("../img/home/mainimg_01.png");
  background-size: cover;
  background-position: 25% center;
  max-height: 100vh;
  height: 100vh;
}

@media screen and (max-width: 500px) {
  .home .mainimg {
    max-height: 50vh;
    height: 50vh;
  }
}

@media screen and (max-width: 768px) {
  .home .mainimg {
    margin-bottom: 0;
  }
}

.home main {
  position: relative;
  top: -100px;
}

@media screen and (max-width: 1024px) {
  .home main {
    top: -70px;
  }
}

@media screen and (max-width: 768px) {
  .home main {
    top: 0;
  }
}

.home .main-text {
  font-size: 10rem;
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
}

@media screen and (max-width: 1100px) {
  .home .main-text {
    font-size: 7.5rem;
  }
}

@media screen and (max-width: 1024px) {
  .home .main-text {
    font-size: 6rem;
  }
}

@media screen and (max-width: 768px) {
  .home .main-text {
    font-size: 2.2rem;
  }
}

.home .main-text {
  color: white;
  letter-spacing: 0.18em;
  line-height: 1.2;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 10;
}

.home .mainimg .main-slider {
  padding: 0;
  margin: 0;
  width: 100%;
  position: relative;
}

.home .mainimg .main-slider img {
  width: 100%;
}

.home .bnr-area {
  width: 1100px;
  margin-right: auto;
  margin-left: auto;
  position: relative;
}

@media screen and (max-width: 1100px) {
  .home .bnr-area {
    width: auto;
    margin-right: auto;
    margin-left: auto;
  }
}

@media screen and (max-width: 500px) {
  .home .bnr-area {
    width: 80%;
    height: auto;
    margin-right: auto;
    margin-left: auto;
  }
}

.home .bnr-area a {
  display: block;
}

.home .bnr-area img.bnr-img {
  width: 40.2rem;
  max-width: 42%;
  position: absolute;
  bottom: 0;
  right: 0;
}

@media screen and (max-width: 768px) {
  .home .bnr-area img.bnr-img {
    width: 50%;
    max-width: 50%;
  }
}

@media screen and (max-width: 500px) {
  .home .bnr-area img.bnr-img {
    position: relative;
    width: 100%;
    max-width: 100%;
    margin-top: 2rem;
    margin-left: auto;
    margin-right: auto;
  }
}

.home .-btnarea {
  width: 30%;
}

@media screen and (max-width: 1024px) {
  .home .-btnarea {
    width: 100%;
    height: 10rem;
  }
}

@media screen and (max-width: 768px) {
  .home .-btnarea {
    width: 100%;
    height: 8rem;
  }
}

.home .-picarea {
  width: 70%;
}

@media screen and (max-width: 1024px) {
  .home .-picarea {
    width: 100%;
  }
}

@media screen and (max-width: 1024px) {
  .base .col-2-box:not(.-recruit) {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}

.base .col-2-box:not(.-recruit) {
  position: relative;
  top: -83px;
}

@media screen and (max-width: 1024px) {
  .base .col-2-box:not(.-recruit) {
    top: 0;
  }
}

@media screen and (max-width: 768px) {
  .base .col-2-box:not(.-recruit) {
    top: 0;
  }
}

.fnt-100 {
  font-size: 4rem;
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
}

@media screen and (max-width: 1100px) {
  .fnt-100 {
    font-size: 4rem;
  }
}

@media screen and (max-width: 1024px) {
  .fnt-100 {
    font-size: 3rem;
  }
}

@media screen and (max-width: 768px) {
  .fnt-100 {
    font-size: 1.8rem;
  }
}

@media screen and (max-width: 500px) {
  .fnt-100 {
    font-size: 1.7rem;
  }
}

.fnt-101 {
  font-size: 15rem;
  font-family: "Impact", "Anton", sans-serif;
  line-height: 1.26;
}

@media screen and (max-width: 1100px) {
  .fnt-101 {
    font-size: 12rem;
  }
}

@media screen and (max-width: 1024px) {
  .fnt-101 {
    font-size: 9rem;
  }
}

@media screen and (max-width: 768px) {
  .fnt-101 {
    font-size: 4.5rem;
  }
}

@media screen and (max-width: 375px) {
  .fnt-101 {
    font-size: 4.5rem;
  }
}

.pos-101 {
  position: relative;
  top: 4.5rem;
}

@media screen and (max-width: 1024px) {
  .pos-101 {
    top: 2.8rem;
  }
}

@media screen and (max-width: 768px) {
  .pos-101 {
    top: 1.7rem;
  }
}

.fnt-102 {
  font-size: 10rem;
  font-family: "Univers LT 47 CondensedLt", "Oswald", sans-serif;
  font-weight: 550;
  letter-spacing: -0.02em;
}

@media screen and (max-width: 1100px) {
  .fnt-102 {
    font-size: 9rem;
  }
}

@media screen and (max-width: 1024px) {
  .fnt-102 {
    font-size: 6rem;
  }
}

@media screen and (max-width: 768px) {
  .fnt-102 {
    font-size: 3.5rem;
  }
}

@media screen and (max-width: 375px) {
  .fnt-102 {
    font-size: 3.5rem;
  }
}

.pos-102 {
  position: relative;
  display: inline-block;
  top: 4.4rem;
}

@media screen and (max-width: 1024px) {
  .pos-102 {
    top: 2.6rem;
  }
}

@media screen and (max-width: 768px) {
  .pos-102 {
    top: 1.6rem;
  }
}

.section-ttl span.-ja.slf-100 {
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  height: 83px;
}

@media screen and (max-width: 1024px) {
  .section-ttl span.-ja.slf-100 {
    height: 60px;
  }
}

@media screen and (max-width: 768px) {
  .section-ttl span.-ja.slf-100 {
    height: 45px;
  }
}

.section-ttl span.-ja.in-100 {
  padding-top: 10px;
}

@media screen and (max-width: 1024px) {
  .section-ttl span.-ja.in-100 {
    padding-top: 8px;
  }
}

@media screen and (max-width: 768px) {
  .section-ttl span.-ja.in-100 {
    padding-top: 5px;
  }
}

@media screen and (max-width: 500px) {
  .section-ttl span.-ja.in-100 {
    padding-top: 7px;
  }
}

.section-ttl span.-ja.clr-100 {
  color: white;
  background: black;
}

.section-ttl span.-en.slf-101 {
  max-width: 1280px;
  display: inline-block;
}

.-btnarea .linkbox {
  position: relative;
  top: 50%;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}

@media screen and (max-width: 1024px) {
  .-btnarea .linkbox {
    top: 20%;
  }
}

.linkbox {
  display: block;
  position: relative;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-style: solid;
  border-width: 8px;
  width: 290px;
  max-width: 90%;
  height: 100px;
}

@media screen and (max-width: 1024px) {
  .linkbox {
    border-width: 6px;
    width: 80%;
    height: 70px;
  }
}

@media screen and (max-width: 768px) {
  .linkbox {
    border-width: 5px;
    width: 80%;
    height: 60px;
  }
}

@media screen and (max-width: 500px) {
  .linkbox {
    height: 50px;
  }
}

.linkbox.clr-101 {
  color: #CB182E;
  border-color: #CB182E;
}

@media screen and (max-width: 1024px) {
  .linkbox.pos-103 {
    margin-left: auto;
    margin-right: auto;
  }
}

a.linkbox.clr-101:hover {
  background: #CB182E;
  color: white;
}

.fnt-103 {
  font-size: 3rem;
}

@media screen and (max-width: 1100px) {
  .fnt-103 {
    font-size: 3rem;
  }
}

@media screen and (max-width: 1024px) {
  .fnt-103 {
    font-size: 2.5rem;
  }
}

@media screen and (max-width: 768px) {
  .fnt-103 {
    font-size: 1.8rem;
  }
}

@media screen and (max-width: 500px) {
  .fnt-103 {
    font-size: 1.7rem;
  }
}

.linkbox span {
  display: block;
  width: 80%;
  text-align: center;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
}

.linkbox span.arw::after {
  font-family: "Font Awesome 5 Free";
  content: "\f105";
  font-weight: 1000;
  position: absolute;
  right: 0;
}

.home .business {
  position: relative;
  top: -41px;
}

@media screen and (max-width: 1024px) {
  .home .business {
    top: 0;
  }
}

@media screen and (max-width: 768px) {
  .home .business {
    top: 0;
  }
}

.home .business article:nth-child(1) {
  background-image: url("../img/home/img-business-02.png");
}

.home .business article:nth-child(2) {
  background-image: url("../img/home/img-business-01.png");
}

.home .business article:nth-child(3) {
  background-image: url("../img/home/img-business-03.png");
}

.home .business article {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  position: relative;
  padding: 70px 0;
}

@media screen and (max-width: 768px) {
  .home .business article {
    padding: 40px 0;
  }
}

.home .business article .bs-text {
  width: 50%;
}

@media screen and (max-width: 768px) {
  .home .business article .bs-text {
    width: 80%;
  }
}

.home .business article .bs-text.clr-110 {
  background: white;
}

.home .business article .bs-text.pos-110 {
  position: relative;
  z-index: 5;
}

.home .business article .bs-text .bs-text-inner {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 7rem 3.2rem 5.7rem 3.2rem;
}

@media screen and (max-width: 500px) {
  .home .business article .bs-text .bs-text-inner {
    padding: 3rem 2rem 3rem 2rem;
  }
}

.home .business article .bs-text .bs-text-inner p {
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 1.7rem;
  line-height: 1.29;
  margin-bottom: 4rem;
}

@media screen and (max-width: 500px) {
  .home .business article .bs-text .bs-text-inner p {
    font-size: 1.5rem;
  }
}

.home .business .pos-r {
  margin-left: auto;
  margin-right: 0;
}

@media screen and (max-width: 768px) {
  .home .business .pos-r {
    margin-left: auto;
    margin-right: auto;
  }
}

.home .business .pos-l {
  margin-left: 0;
  margin-right: auto;
}

@media screen and (max-width: 768px) {
  .home .business .pos-l {
    margin-left: auto;
    margin-right: auto;
  }
}

.home .business h4 {
  color: #CB182E;
  letter-spacing: 0;
  font-size: 4rem;
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 400;
}

@media screen and (max-width: 1100px) {
  .home .business h4 {
    font-size: 4rem;
  }
}

@media screen and (max-width: 1024px) {
  .home .business h4 {
    font-size: 3rem;
  }
}

@media screen and (max-width: 768px) {
  .home .business h4 {
    font-size: 2.2rem;
  }
}

.home .business h4 span.fntbld {
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
}

.home .linkbox.-more {
  border-width: 6px;
  border-color: #CB182E;
  width: 216px;
  height: 55px;
  background: #CB182E;
  color: white;
}

@media screen and (max-width: 1024px) {
  .home .linkbox.-more {
    margin-left: auto;
    margin-right: auto;
  }
}

@media screen and (max-width: 500px) {
  .home .linkbox.-more {
    height: 45px;
  }
}

.home .linkbox.-more span {
  font-size: 2rem;
}

@media screen and (max-width: 1100px) {
  .home .linkbox.-more span {
    font-size: 2rem;
  }
}

@media screen and (max-width: 1024px) {
  .home .linkbox.-more span {
    font-size: 2rem;
  }
}

@media screen and (max-width: 768px) {
  .home .linkbox.-more span {
    font-size: 1.5rem;
  }
}

.home a.linkbox.-more:hover {
  background: white;
  color: #CB182E;
}

.home .base .fnt-120 {
  font-size: 4rem;
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
}

@media screen and (max-width: 1100px) {
  .home .base .fnt-120 {
    font-size: 4rem;
  }
}

@media screen and (max-width: 1024px) {
  .home .base .fnt-120 {
    font-size: 3rem;
  }
}

@media screen and (max-width: 768px) {
  .home .base .fnt-120 {
    font-size: 2rem;
  }
}

.home .base .pos-120 {
  position: relative;
  bottom: -0.5rem;
  left: 3rem;
}

@media screen and (max-width: 1024px) {
  .home .base .pos-120 {
    bottom: -0.5rem;
    left: 2rem;
  }
}

@media screen and (max-width: 768px) {
  .home .base .pos-120 {
    bottom: -0.7rem;
    left: 1rem;
  }
}

.home .base .-recruit {
  background: black;
}

.home .base .-recruit img {
  padding: 4.5rem 0;
}

@media screen and (max-width: 1024px) {
  .home .base .-recruit img {
    max-width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .home .base .-recruit img {
    position: relative;
    left: 50%;
    top: 0;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
}

.home .base .-recruit h4 {
  color: white;
  line-height: 1.3;
  font-size: 5rem;
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
}

@media screen and (max-width: 1100px) {
  .home .base .-recruit h4 {
    font-size: 4rem;
  }
}

@media screen and (max-width: 1024px) {
  .home .base .-recruit h4 {
    font-size: 3rem;
  }
}

@media screen and (max-width: 768px) {
  .home .base .-recruit h4 {
    font-size: 3rem;
  }
}

@media screen and (max-width: 500px) {
  .home .base .-recruit h4 {
    font-size: 2.2rem;
  }
}

@media screen and (max-width: 768px) {
  .home .base .-recruit h4 br {
    display: none;
  }
}

.home .base .-recruit p {
  color: white;
  font-size: 1.7rem;
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 400;
  margin-top: 3.2rem;
  margin-bottom: 5.3rem;
}

@media screen and (max-width: 500px) {
  .home .base .-recruit p {
    font-size: 1.5rem;
  }
}

.home .base .-recruit .linkbox.slf-121 {
  width: 340px;
}

@media screen and (max-width: 1024px) {
  .home .base .-recruit .linkbox.slf-121 {
    width: 100%;
    max-width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .home .base .-recruit .linkbox.slf-121 {
    width: 80%;
  }
}

.home .base .-recruit .linkbox.pos-121 {
  left: 0;
  margin-left: unset;
  margin-right: unset;
  margin-top: 5rem;
}

@media screen and (max-width: 1024px) {
  .home .base .-recruit .linkbox.pos-121 {
    margin-left: unset;
    margin-right: unset;
    margin-top: 4rem;
  }
}

@media screen and (max-width: 768px) {
  .home .base .-recruit .linkbox.pos-121 {
    margin-left: auto;
    margin-right: auto;
    margin-top: 3rem;
  }
}

.home .base .-recruit .rc-text-inner {
  padding: 45px 45px 45px 0;
}

@media screen and (max-width: 1024px) {
  .home .base .-recruit .rc-text-inner {
    padding: 45px;
  }
}

@media screen and (max-width: 768px) {
  .home .base .-recruit .rc-text-inner {
    padding: 0 0 45px 0;
  }
}

.pagetoparea {
  background: rgba(0, 0, 0, 0.8) url("../img/shop/mainimg-shop-01.png");
  width: 100%;
  height: 250px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}

@media screen and (max-width: 1024px) {
  .pagetoparea {
    height: 220px;
  }
}

@media screen and (max-width: 768px) {
  .pagetoparea {
    height: 180px;
  }
}

.transportpage .pagetoparea {
  background: rgba(0, 0, 0, 0.8) url("../img/trans/mainimg-trans-01.png");
  width: 100%;
  height: 250px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}

.sspage .pagetoparea {
  background: rgba(0, 0, 0, 0.8) url("../img/ss/mainimg-ss-01.png");
  width: 100%;
  height: 250px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}

.cardpage .pagetoparea {
  background: rgba(0, 0, 0, 0.8) url("../img/card/mainimg-card-01.png");
  width: 100%;
  height: 250px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  background-position: 35% 30%;
}

.companypage .pagetoparea {
  background: rgba(0, 0, 0, 0.8) url("../img/company/mainimg-company-01.png");
  width: 100%;
  height: 250px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  background-position: 50% 30%;
}

.recruitpage .pagetoparea {
  background: rgba(0, 0, 0, 0.8) url("../img/recruit/mainimg-recruitt-01.png");
  width: 100%;
  height: 250px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}

.pagetoparea.-large {
  height: 410px;
}

@media screen and (max-width: 1024px) {
  .pagetoparea.-large {
    height: 360px;
  }
}

@media screen and (max-width: 768px) {
  .pagetoparea.-large {
    height: 295px;
  }
}

div:not(.home) > main {
  padding-top: 0;
}

@media screen and (max-width: 1024px) {
  div:not(.home) > main {
    padding-top: 60px;
  }
}

.main-text.-sub {
  color: white;
  letter-spacing: 0.18em;
  line-height: 1.2;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 10;
  font-size: 4rem;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0;
  font-weight: 500;
}

@media screen and (max-width: 1100px) {
  .main-text.-sub {
    font-size: 4rem;
  }
}

@media screen and (max-width: 1024px) {
  .main-text.-sub {
    font-size: 3.2rem;
  }
}

@media screen and (max-width: 768px) {
  .main-text.-sub {
    font-size: 2.8rem;
  }
}

.title-bar {
  background: #000;
  color: white;
  width: 100%;
  text-align: center;
  font-size: 2.5rem;
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
  padding: 1.7rem 0;
  margin-bottom: 5rem;
}

@media screen and (max-width: 768px) {
  .title-bar {
    margin-bottom: 0;
  }
}

@media screen and (max-width: 500px) {
  .title-bar {
    font-size: 2.2rem;
  }
}

@media screen and (max-width: 768px) {
  .title-bar.-flow {
    margin-bottom: 3.3rem;
  }
}

.ggmap {
  position: relative;
  padding-bottom: 42.8%;
  height: 0;
  overflow: hidden;
}

.ggmap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.ggmap object {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.ggmap embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.shoppage .shop {
  margin-top: 6.7rem;
}

@media screen and (max-width: 768px) {
  .shoppage .shop {
    margin-top: 4.5rem;
  }
}

.shoppage .shop:last-child {
  margin-bottom: 6.7rem;
}

.shoppage .linkbox.slf-200 {
  width: 95%;
  max-width: 95%;
}

@media screen and (max-width: 768px) {
  .shoppage .linkbox.slf-200 {
    border: unset;
    height: 50px;
  }
}

.shoppage .linkbox.fnt-200 {
  font-size: 3rem;
}

@media screen and (max-width: 1100px) {
  .shoppage .linkbox.fnt-200 {
    font-size: 3rem;
  }
}

@media screen and (max-width: 1024px) {
  .shoppage .linkbox.fnt-200 {
    font-size: 3rem;
  }
}

@media screen and (max-width: 768px) {
  .shoppage .linkbox.fnt-200 {
    font-size: 3rem;
  }
}

.shoppage .linkbox.clr-200 {
  color: #CB182E;
  border-color: #CB182E;
}

@media screen and (max-width: 768px) {
  .shoppage .linkbox.clr-200 {
    color: black;
  }
}

.shoppage .linkbox.pos-200 {
  margin-left: unset;
  margin-right: unset;
}

.shoppage .linkbox:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  border: 18px solid transparent;
  border-top: 18px solid #CB182E;
  display: block;
}

@media screen and (max-width: 768px) {
  .shoppage .linkbox:before {
    display: none;
  }
}

.shoppage .linkbox span {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
}

@media screen and (max-width: 768px) {
  .shoppage .linkbox span {
    display: block;
    width: auto;
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    position: relative;
    top: unset;
    left: unset;
    -webkit-transform: unset;
            transform: unset;
    text-align: left;
    text-decoration: underline;
    -webkit-text-decoration-color: #CB182E;
            text-decoration-color: #CB182E;
  }
}

.shoppage .shop table.-detail-pc {
  display: block;
  margin-top: 40px;
  width: 95%;
  border-collapse: collapse;
}

@media screen and (max-width: 768px) {
  .shoppage .shop table.-detail-pc {
    display: none;
  }
}

.shoppage .shop th {
  border: 1px solid #D3D3D3;
  background: rgba(0, 0, 0, 0.016);
  padding: 16px;
  white-space: nowrap;
  font-size: 1.5rem;
  font-weight: normal;
  text-align: left;
}

.shoppage .shop td {
  padding: 14px 22px;
  border: 1px solid #D3D3D3;
  width: 100%;
}

.shoppage .shop div.-detail-sp {
  display: none;
  width: auto;
  font-size: 1.6rem;
  margin-bottom: 3rem;
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .shoppage .shop div.-detail-sp {
    display: block;
  }
}

.shoppage .shop div.-detail-sp br {
  display: none;
}

@media screen and (max-width: 490px) {
  .shoppage .shop div.-detail-sp br {
    display: block;
  }
}

.shoppage main a[href^="tel:"].fnt-201 {
  display: block;
  font-size: 2.5rem;
  color: black;
  margin-top: 2.8rem;
  margin-bottom: 2.8rem;
}

@media screen and (max-width: 768px) {
  .shoppage main a[href^="tel:"].fnt-201 {
    margin-top: 1rem;
    margin-bottom: 1rem;
  }
}

.shoppage .title-bar-ul {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  white-space: nowrap;
}

@media screen and (max-width: 768px) {
  .shoppage .title-bar-ul {
    top: 0;
    left: unset;
    -webkit-transform: none;
            transform: none;
    font-size: 3rem;
    font-weight: 500;
    border-bottom: 5px solid #E12933;
    text-align: left;
    display: inline-block;
  }
}

@media screen and (max-width: 500px) {
  .shoppage .title-bar-ul {
    font-size: 2.8rem;
    font-weight: 500;
    border-bottom: 5px solid #E12933;
    text-align: left;
    display: inline-block;
  }
}

.transportpage main {
  font-size: 1.7rem;
}

.transportpage section.trans {
  margin-top: 8.5rem;
}

@media screen and (max-width: 500px) {
  .transportpage section.trans {
    margin-top: 4.5rem;
  }
}

.transportpage section.trans:last-child {
  margin-bottom: 6.7rem;
}

@media screen and (max-width: 768px) {
  .transportpage .title-bar.-service {
    margin-bottom: 5rem;
  }
}

@media screen and (max-width: 600px) {
  .transportpage .title-bar.-service {
    margin-bottom: 0;
  }
}

@media screen and (max-width: 600px) {
  .transportpage .sec-trans-img {
    width: 100%;
  }
}

.transportpage .red-circle {
  position: relative;
  display: inline-block;
  background: #CB212E;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  margin: 20px 8px 0 8px;
}

@media screen and (max-width: 450px) {
  .transportpage .red-circle {
    margin: 20px 4px 0 4px;
  }
}

.transportpage .red-circle span {
  color: white;
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
  font-size: 4rem;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.transportpage p.-big {
  font-size: 2.5rem;
  width: 92%;
  margin-left: 4%;
  margin-right: 4%;
}

@media screen and (max-width: 450px) {
  .transportpage p.-big {
    font-size: 2rem;
  }
}

.transportpage p:not(.big) {
  margin-bottom: 0;
}

.transportpage main a[href^="tel:"] {
  color: #CB182E;
  font-family: "Helvetica Neue", Roboto, Helvetica, Arial, Verdana, "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  font-size: 6rem;
  line-height: 1.2;
}

@media screen and (max-width: 450px) {
  .transportpage main a[href^="tel:"] {
    font-size: 4.8rem;
  }
}

.transportpage .subtext {
  margin-top: 25px;
  margin-left: auto;
  margin-right: auto;
  background: #F8F9FA;
  max-width: 1000px;
  padding: 50px 30px;
  border-radius: 8px;
  line-height: 2.35;
}

@media screen and (max-width: 1050px) {
  .transportpage .subtext {
    max-width: 92%;
    margin-left: 4%;
    margin-right: 4%;
  }
}

.transportpage .title-bar.-area {
  margin-bottom: 2.5rem;
}

.transportpage .sec-trans-map {
  width: 100%;
}

.transportpage .sec-trans-process-grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr 1fr;
      grid-template-columns: 1fr 1fr 1fr;
  gap: 30px;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 75px;
}

@media screen and (max-width: 800px) {
  .transportpage .sec-trans-process-grid {
    max-width: 770px;
    gap: 15px;
  }
}

@media screen and (max-width: 768px) {
  .transportpage .sec-trans-process-grid {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
    gap: 30px;
    max-width: 80%;
  }
}

.transportpage .grid-item {
  background: #F8F9FA;
  border-radius: 8px;
  padding: 15px 24px 35px 24px;
  border: 1px solid #707070;
}

.transportpage .grid-item-inner {
  height: 150px;
  line-height: 1.47;
  margin-bottom: 30px;
}

.transportpage .fnt-small {
  margin-top: 27px;
  font-size: 12px;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .transportpage .fnt-small {
    text-align: center;
  }
}

.transportpage .icon {
  position: relative;
  height: 95px;
}

.transportpage .icon img {
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}

.transportpage article:first-of-type span br {
  display: block;
}

@media screen and (max-width: 768px) {
  .transportpage article:first-of-type span br {
    display: none;
  }
}

.sspage section.ss {
  margin-top: 8.3rem;
}

@media screen and (max-width: 500px) {
  .sspage section.ss {
    margin-top: 4.5rem;
  }
}

.sspage #sec-tirechange-service {
  margin-top: 13rem;
}

.sspage section.ss:last-of-type {
  margin-bottom: 10rem;
}

.sspage .title-bar {
  margin-bottom: 0;
}

.sspage .col-2-box {
  max-width: 1280px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width: 1024px) {
  .sspage .col-2-box {
    max-width: 92%;
  }
}

.sspage .col-2-box .box {
  width: 50%;
}

@media screen and (max-width: 768px) {
  .sspage .col-2-box .box {
    width: 50%;
  }
}

@media screen and (max-width: 500px) {
  .sspage .col-2-box .box {
    width: 100%;
  }
}

.sspage .col-2-box img {
  width: 100%;
  height: auto;
  position: relative;
  vertical-align: bottom;
}

.sspage h4 {
  width: 92%;
  text-align: center;
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
  font-size: 2.5rem;
  margin: 50px auto;
}

.sspage .sec-bg {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  width: 100%;
  height: 427px;
}

@media screen and (max-width: 1024px) {
  .sspage .sec-bg {
    background-position: 10% center;
    width: 100%;
    height: 350px;
  }
}

@media screen and (max-width: 768px) {
  .sspage .sec-bg {
    width: 100%;
    height: 200px;
  }
}

.sspage #sec-servicestation .sec-bg .sec-bg-item {
  display: inline-block;
  width: 50%;
  height: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.sspage #sec-servicestation .sec-bg .sec-bg-item.-left {
  background-image: url("../img/ss/img-ss-01.png");
}

@media screen and (max-width: 768px) {
  .sspage #sec-servicestation .sec-bg .sec-bg-item.-left {
    background-position: 30% 70%;
  }
}

.sspage #sec-servicestation .sec-bg .sec-bg-item.-right {
  background-image: url("../img/ss/img-ss-02.png");
}

.sspage #sec-wash-service .sec-bg {
  background-image: url("../img/ss/img-ss-05.png");
}

@media screen and (max-width: 768px) {
  .sspage #sec-wash-service .sec-bg {
    background-position: 10% center;
  }
}

.sspage #sec-oilchange-service .sec-bg {
  background-image: url("../img/ss/img-ss-07.png");
}

@media screen and (max-width: 768px) {
  .sspage #sec-oilchange-service .sec-bg {
    background-position: 80% center;
  }
}

.sspage #sec-tirechange-service .sec-bg {
  background-image: url("../img/ss/img-ss-09.png");
}

.sspage .sec-service .col-2-box {
  position: relative;
  max-width: 1000px;
}

@media screen and (max-width: 1100px) {
  .sspage .sec-service .col-2-box {
    max-width: 92%;
    margin-left: auto;
    margin-right: auto;
  }
}

@media screen and (max-width: 768px) {
  .sspage .sec-service .col-2-box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.sspage .sec-service .col-2-box img {
  max-width: 385px;
}

.sspage .sec-service .col-2-box div.box:first-of-type {
  width: 40%;
  margin-bottom: 40px;
}

@media screen and (max-width: 900px) {
  .sspage .sec-service .col-2-box div.box:first-of-type {
    width: 50%;
  }
}

@media screen and (max-width: 768px) {
  .sspage .sec-service .col-2-box div.box:first-of-type {
    width: 80%;
    max-width: 385px;
    margin-left: auto;
    margin-right: auto;
  }
}

@media screen and (max-width: 400px) {
  .sspage .sec-service .col-2-box div.box:first-of-type {
    width: 92%;
  }
}

.sspage .sec-service .col-2-box div.box:nth-of-type(2) {
  width: 60%;
}

@media screen and (max-width: 900px) {
  .sspage .sec-service .col-2-box div.box:nth-of-type(2) {
    width: 50%;
  }
}

@media screen and (max-width: 768px) {
  .sspage .sec-service .col-2-box div.box:nth-of-type(2) {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
}

.sspage #sec-servicestation > p {
  font-size: 2rem;
  line-height: 2.5;
  text-align: center;
  width: 1000px;
  max-width: 92%;
  margin: 45px auto 0 auto;
}

@media screen and (max-width: 768px) {
  .sspage #sec-servicestation > p {
    line-height: 2;
  }
}

@media screen and (max-width: 500px) {
  .sspage #sec-servicestation > p {
    font-size: 1.8rem;
  }
}

.sspage ol.selfservice {
  font-size: 1.7rem;
  width: 100%;
  max-width: 100%;
  margin: 0 0 15px 0;
}

@media screen and (max-width: 768px) {
  .sspage ol.selfservice {
    margin: 0 0 30px 0;
    width: 100%;
    max-width: 100%;
  }
}

.sspage ol.selfservice li {
  padding-bottom: 25px;
}

.sspage .attention {
  background-image: url("../img/ss/img-ss-04.png");
  background-repeat: no-repeat;
  background-position: left 10%;
  background-size: cover;
  width: 1000px;
  height: 295px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 80px;
  border-radius: 10px;
}

@media screen and (max-width: 1024px) {
  .sspage .attention {
    width: 92%;
    height: auto;
    padding-bottom: 30px;
  }
}

.sspage .attention h5 {
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
  padding: 30px 0 0 35%;
  font-size: 2.5rem;
  color: #FFFF00;
}

@media screen and (max-width: 1024px) {
  .sspage .attention h5 {
    padding: 30px 0 0 0;
    text-align: center;
  }
}

.sspage .attention ol {
  color: white;
  max-width: 540px;
  margin: 20px 0 0 35%;
  font-size: 1.7rem;
  line-height: 1.76;
}

@media screen and (max-width: 1024px) {
  .sspage .attention ol {
    width: 400px;
    max-width: 90%;
    margin: 20px auto 0 auto;
    font-size: 1.6rem;
  }
}

.sspage .attention > p {
  color: white;
  max-width: 540px;
  margin: 20px 0 0 35%;
  font-size: 1.7rem;
  line-height: 1.76;
}

@media screen and (max-width: 1024px) {
  .sspage .attention > p {
    width: 400px;
    max-width: 90%;
    margin: 20px auto 0 auto;
    font-size: 1.6rem;
  }
}

.sspage table.wash-course {
  width: 954px;
  max-width: 92%;
  border-collapse: collapse;
  border: 1px solid #D9DADA;
  margin-left: auto;
  margin-right: auto;
  font-size: 1.7rem;
  display: block;
}

@media screen and (max-width: 1000px) {
  .sspage table.wash-course {
    margin-left: 4%;
    margin-right: 4%;
  }
}

@media screen and (max-width: 768px) {
  .sspage table.wash-course {
    display: none;
  }
}

.sspage table.wash-course th {
  border: 1px solid #D9DADA;
  background: #D9DADA;
  padding: 15px 0;
  background: #F8F9FA;
}

.sspage table.wash-course td {
  border: 1px solid #D9DADA;
  positon: relative;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 318px;
  padding: 30px 25px;
}

@media screen and (max-width: 1000px) {
  .sspage table.wash-course td {
    padding: 12px;
  }
}

.sspage table.wash-course .menu-wash {
  width: 63%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.sspage table.wash-course .menu-price {
  width: 37%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  color: #CB212E;
}

.sspage table.wash-course.-sp {
  width: 450px;
  margin-left: auto;
  margin-right: auto;
  display: none;
}

@media screen and (max-width: 768px) {
  .sspage table.wash-course.-sp {
    display: block;
  }
}

@media screen and (max-width: 520px) {
  .sspage table.wash-course.-sp {
    width: 300px;
  }
}

.sspage table.wash-course.-sp {
  margin-bottom: 60px;
}

.sspage table.wash-course.-sp th {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 450px;
  display: block;
}

@media screen and (max-width: 520px) {
  .sspage table.wash-course.-sp th {
    width: 300px;
  }
}

.sspage table.wash-course.-sp td {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 450px;
  display: block;
}

@media screen and (max-width: 520px) {
  .sspage table.wash-course.-sp td {
    width: 300px;
  }
}

.sspage .col-2-box .box p {
  width: 100%;
  max-width: 100%;
  margin: 0 0 15px 0;
  line-height: 1.47;
  font-size: 1.7rem;
  margin-bottom: 30px;
  padding-left: 15px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .sspage .col-2-box .box p {
    margin: 0 0 30px 0;
    width: 100%;
    max-width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .sspage .col-2-box .box p {
    padding-left: 0;
  }
}

.sspage #sec-oilchange-service .oil-titlebar {
  height: auto;
  width: 92%;
  max-width: 1000px;
  text-align: center;
  background: #A78D45;
  margin: 50px auto 45px auto;
}

.sspage #sec-oilchange-service .oil-titlebar img {
  height: 70px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  vertical-align: bottom;
}

@media screen and (max-width: 450px) {
  .sspage #sec-oilchange-service .oil-titlebar img {
    width: 92%;
    height: auto;
  }
}

.sspage .grid-oillist {
  display: -ms-grid;
  display: grid;
  gap: 1rem;
  -ms-grid-columns: (144px)[auto-fit];
      grid-template-columns: repeat(auto-fit, 144px);
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 3.4rem;
}

.sspage .grid-oillist p {
  text-align: center;
  font-size: 1rem;
  font-weight: 500;
  margin-top: 0;
  margin-bottom: 0;
}

.sspage #sec-oilchange-service > p {
  font-size: 1.7rem;
}

@media screen and (max-width: 768px) {
  .sspage #sec-oilchange-service > p {
    max-width: 92%;
    margin-left: 4%;
    margin-right: 4%;
  }
}

.cardpage section.card {
  margin-top: 8.3rem;
}

@media screen and (max-width: 500px) {
  .cardpage section.card {
    margin-top: 4.5rem;
  }
}

.cardpage section.card:last-of-type {
  margin-bottom: 10rem;
}

.cardpage section.card:first-of-type {
  margin-bottom: 13rem;
}

.cardpage .title-bar {
  margin-bottom: 0;
}

.cardpage h4 {
  text-align: center;
  font-family: "Hiragino Sans", "Noto Sans JP", sans-serif;
  font-weight: 800;
  font-size: 2.5rem;
  line-height: 1.32;
  margin: 65px auto 34px auto;
}

@media screen and (max-width: 500px) {
  .cardpage h4 {
    font-size: 2.2rem;
  }
}

.cardpage .btn-free {
  background: #CB212E;
  color: white;
  font-size: 2.5rem;
  font-weight: 900;
  width: 340px;
  height: 67px;
  position: relative;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 83px;
}

.cardpage .btn-free span {
  white-space: nowrap;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.cardpage .col-2-box {
  max-width: 750px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 50px;
}

@media screen and (max-width: 768px) {
  .cardpage .col-2-box {
    max-width: 100%;
    margin-bottom: 0;
  }
}

.cardpage .col-2-box .box {
  width: 50%;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width: 768px) {
  .cardpage .col-2-box .box {
    width: 100%;
    margin-bottom: 50px;
  }
}

.cardpage .col-2-box img {
  width: 100%;
  height: auto;
  position: relative;
  vertical-align: bottom;
}

.cardpage .card-part {
  width: 330px;
  margin-left: auto;
  margin-right: auto;
}

.cardpage .card-part > p {
  text-align: left;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding-left: 15px;
}

.cardpage h5 {
  font-size: 2rem;
  font-weight: 700;
  margin: 24px 0;
}

.cardpage table.tbl-pay {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 1000px;
  border-collapse: collapse;
  border: 1px solid #D9DADA;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 40px;
  font-size: 1.7rem;
}

@media screen and (max-width: 1100px) {
  .cardpage table.tbl-pay {
    width: 100%;
  }
}

.cardpage table.tbl-pay th {
  width: auto;
  border: 1px solid #D9DADA;
  background: #D9DADA;
  background: #F8F9FA;
  max-width: 210px;
  padding: 30px 25px;
  font-size: 1.5rem;
  font-weight: 500;
  text-align: left;
}

@media screen and (max-width: 1024px) {
  .cardpage table.tbl-pay th {
    display: block;
    padding: 15px 25px;
    max-width: unset;
    text-align: center;
  }
}

.cardpage table.tbl-pay td {
  border: 1px solid #D9DADA;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 30px 25px;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 2.5;
}

@media screen and (max-width: 1000px) {
  .cardpage table.tbl-pay td {
    padding: 12px;
  }
}

@media screen and (max-width: 1024px) {
  .cardpage table.tbl-pay td {
    width: 100%;
    display: block;
  }
}

.cardpage .text-enekey {
  text-align: center;
  margin-bottom: 80px;
}

.cardpage .icon-grid {
  margin-left: auto;
  margin-right: auto;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 300px 1fr 1fr 1fr;
      grid-template-columns: 300px 1fr 1fr 1fr;
}

@media screen and (max-width: 880px) {
  .cardpage .icon-grid {
    -ms-grid-columns: 1fr 1fr;
        grid-template-columns: 1fr 1fr;
    width: 500px;
  }
}

@media screen and (max-width: 768px) {
  .cardpage .icon-grid {
    -ms-grid-columns: 1fr 1fr;
        grid-template-columns: 1fr 1fr;
    width: 100%;
    max-width: 500px;
  }
}

.cardpage .icon-grid .item {
  width: auto;
  -ms-grid-column-align: center;
      justify-self: center;
}

.cardpage .icon-grid .item img {
  width: 161px;
}

.cardpage .icon-grid .item:first-of-type {
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  grid-row: 1 / 3;
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
  -ms-grid-column-align: start;
      justify-self: start;
  margin-bottom: 0;
}

@media screen and (max-width: 880px) {
  .cardpage .icon-grid .item:first-of-type {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    grid-row: 1 / 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
    grid-column: 1 / 3;
    -ms-grid-column-align: center;
        justify-self: center;
    margin-bottom: 50px;
  }
}

.cardpage .icon-grid .item:first-of-type img {
  width: auto;
}

.cardpage .icon-grid .item > p {
  max-width: 200px;
  text-align: center;
  margin-top: 0;
  margin-bottom: 15px;
}

.cardpage .col-3-grid {
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 45px;
  display: -ms-grid;
  display: grid;
  gap: 20px;
  -ms-grid-columns: 1fr 1fr 1fr;
      grid-template-columns: 1fr 1fr 1fr;
}

@media screen and (max-width: 930px) {
  .cardpage .col-3-grid {
    -ms-grid-columns: 1fr 1fr;
        grid-template-columns: 1fr 1fr;
  }
}

@media screen and (max-width: 650px) {
  .cardpage .col-3-grid {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
  }
}

.cardpage .col-3-grid .box-grid {
  width: auto;
  -ms-grid-column-align: center;
      justify-self: center;
}

.cardpage .col-3-grid .box-grid .card-part {
  height: 242px;
  display: table-cell;
  position: relative;
  vertical-align: bottom;
}

.cardpage .col-3-grid .box-grid img {
  width: 271px;
  position: relative;
  vertical-align: bottom;
}

@media screen and (max-width: 860px) {
  .companypage .section-inner, .recruitpage .section-inner {
    width: 100%;
    margin: 0;
  }
}

.companypage .main-text.-sub {
  color: #000;
  -webkit-filter: drop-shadow(2px 2px 3px #fff);
          filter: drop-shadow(2px 2px 3px #fff);
}

.recruitpage .main-text.-sub {
  color: #000;
  -webkit-backdrop-filter: blur(3px);
          backdrop-filter: blur(3px);
}

.companypage section.company:first-of-type, .companypage section.recruit:first-of-type, .recruitpage section.company:first-of-type, .recruitpage section.recruit:first-of-type {
  margin-top: 4.5rem;
}

@media screen and (max-width: 768px) {
  .companypage section.company:last-of-type, .recruitpage section.company:last-of-type {
    margin-top: -50px;
  }
}

@media screen and (max-width: 580px) {
  .companypage section.company:last-of-type, .recruitpage section.company:last-of-type {
    margin-top: 4.5rem;
  }
}

.companypage section.company:last-of-type, .companypage section.recruit:last-of-type, .recruitpage section.company:last-of-type, .recruitpage section.recruit:last-of-type {
  margin-bottom: 53px;
}

.companypage .title-bar-ul, .recruitpage .title-bar-ul {
  font-size: 3rem;
  font-weight: 500;
  border-bottom: 5px solid #E12933;
  text-align: left;
  display: inline-block;
  position: relative;
  left: 20px;
}

@media screen and (max-width: 580px) {
  .companypage .title-bar-ul, .recruitpage .title-bar-ul {
    left: 4%;
  }
}

@media screen and (max-width: 500px) {
  .companypage .title-bar-ul, .recruitpage .title-bar-ul {
    font-size: 2.8rem;
    font-weight: 500;
    border-bottom: 5px solid #E12933;
    text-align: left;
    display: inline-block;
  }
}

.companypage .col-2-box, .recruitpage .col-2-box {
  position: relative;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin-top: 23px;
}

.companypage .col-2-box .box > img, .recruitpage .col-2-box .box > img {
  width: 100%;
  position: relative;
  top: 50%;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}

@media screen and (max-width: 768px) {
  .companypage .col-2-box .box > img, .recruitpage .col-2-box .box > img {
    width: auto;
    position: relative;
    right: 0;
    top: -100px;
    -webkit-transform: none;
            transform: none;
  }
}

@media screen and (max-width: 580px) {
  .companypage .col-2-box .box > img, .recruitpage .col-2-box .box > img {
    width: 100%;
    top: unset;
    -webkit-transform: none;
            transform: none;
  }
}

.companypage .col-2-box .box.-text, .recruitpage .col-2-box .box.-text {
  width: 55%;
}

@media screen and (max-width: 768px) {
  .companypage .col-2-box .box.-text, .recruitpage .col-2-box .box.-text {
    width: 100%;
  }
}

.companypage .col-2-box .box.-img, .recruitpage .col-2-box .box.-img {
  width: 45%;
}

@media screen and (max-width: 768px) {
  .companypage .col-2-box .box.-img, .recruitpage .col-2-box .box.-img {
    width: 100%;
    text-align: right;
  }
}

.companypage table.-profile, .recruitpage table.-profile {
  background: white;
  border-collapse: collapse;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.47;
  width: 100%;
  position: relative;
  z-index: 10;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width: 768px) {
  .companypage table.-profile, .recruitpage table.-profile {
    max-width: 80%;
    margin-left: 4%;
  }
}

.companypage table.-profile th, .recruitpage table.-profile th {
  white-space: nowrap;
  font-weight: 500;
  position: relative;
  vertical-align: top;
  width: 30%;
  max-wigth: 153px;
  text-align: left;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 12px 20px;
}

.companypage table.-profile td, .recruitpage table.-profile td {
  width: 70%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  vertical-align: top;
  padding-top: 12px;
  padding-bottom: 12px;
}

.recruitpage .col-2-box {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}

@media screen and (max-width: 768px) {
  .recruitpage .col-2-box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}

.recruitpage .col-2-box .box > img {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding-left: 40px;
}

@media screen and (max-width: 768px) {
  .recruitpage .col-2-box .box > img {
    padding-left: 0;
    width: 80%;
    top: -50px;
  }
}

@media screen and (max-width: 580px) {
  .recruitpage .col-2-box .box > img {
    padding-left: 0;
    width: 100%;
    top: 0;
  }
}

.recruitpage .welcome {
  font-weight: 500;
  font-size: 2.5rem;
  text-align: center;
}
/*# sourceMappingURL=style.css.map */