@charset "UTF-8";
@font-face {
  font-family: "Hiragino Sans";
  src: local(HiraginoSans-W6);
  font-weight: 600;
}
p {
  font-size: 16px;
  color: #535353;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: #535353;
}

h3 {
  font-family: "kozuka-mincho-pr6n", serif;
  font-weight: 700;
  font-style: normal;
  letter-spacing: 0.05em;
}

.sub-title {
  position: relative;
  text-align: left;
}
.sub-title h3 {
  line-height: 150%;
}
.sub-title .under {
  color: white;
  font-size: 50px !important;
  font-family: "kozuka-gothic-pr6n", sans-serif;
  font-weight: 400;
  font-style: normal;
}
.sub-title .up {
  font-size: 30px !important;
  position: absolute;
  top: 30px !important;
  left: 50px !important;
}

.list {
  width: 100%;
  margin: 0 auto;
  padding: 5% 5%;
  background-color: white;
  border-radius: 2em;
  font-size: 22px;
  color: #464646;
  font-family: "kozuka-mincho-pr6n", serif;
  font-weight: 700;
  font-style: normal;
}
.list li {
  padding: 2% 5%;
  padding-right: 0;
}

h4.red-bar {
  border-left: solid 0.3em #d60011;
  font-size: 25px;
  padding: 0% 3%;
  line-height: 120%;
  margin-bottom: 5%;
  font-family: "Hiragino Sans";
  line-height: 1.5em;
}

/******************
トップ
*******************/
.total-box {
  width: 1000px;
  max-width: 90%;
  margin: 7% auto 0 auto;
}
.total-box h1 {
  text-align: center;
  font-size: 40px;
  font-family: "Hiragino Sans";
  line-height: 1.5em;
}
.total-box h2 {
  font-family: "kozuka-gothic-pr6n", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 20px;
  margin: 3% 0;
  line-height: 200%;
}
.total-box img {
  margin-top: 5%;
}

/******************
社長メッセージ
*******************/
.message-box {
  display: flex;
  flex-wrap: wrap;
  padding-top: 70px;
  width: 1000px;
  max-width: 90%;
  margin: 0 auto 7% auto;
}
.message-box .sub-title {
  width: 100%;
  margin-bottom: 50px;
}
.message-box .message-left {
  width: 60%;
  position: relative;
}
.message-box .message-left h3 {
  margin-bottom: 3%;
}
.message-box .message-left p {
  width: 70%;
}
.message-box .message-right {
  width: 40%;
}
.message-box .message-right,
.message-box .message-left {
  margin-bottom: 100px;
}
.message-box .sub-title .under {
  color: #f2f2f2;
}

.nav .vertical-line {
  min-height: 130px;
}

h1 {
  font-size: 40px;
  font-weight: 600;
  white-space: nowrap;
  color: #707070;
}

h2 {
  font-size: 18px;
  margin-top: 10%;
}

.main-text h3 {
  font-size: 25px;
  margin-bottom: 40px;
  margin-top: 70px;
  font-family: "Hiragino Sans";
  line-height: 1.5em;
  font-weight: 400;
}
.main-text h4 {
  font-size: 18px;
  font-weight: 400;
  font-family: "Hiragino Sans";
  line-height: 1.5em;
}
.main-text p {
  margin-bottom: 50px;
}

/******************
企業理念
*******************/
.philosophy-box {
  padding-top: 7%;
  width: 100%;
  margin: 0 auto;
  padding: 100px 0;
  background-color: #f2f2f2;
}
.philosophy-box .list {
  background-color: #f2f2f2;
  width: 1000px;
  max-width: 90%;
}

.ph-box {
  margin-bottom: 7%;
  width: 1000px;
  max-width: 90%;
  margin: 0 auto;
}
.ph-box .ph-left {
  width: 1000px;
  max-width: 90%;
}
.ph-box .ph-right {
  width: 1000px;
  max-width: 100%;
  margin-top: 30px;
}

/******************
事業内容
*******************/
.business-box {
  margin: 0 auto;
  width: 1000px;
  padding: 100px 0;
  max-width: 90%;
}
.business-box .sub-title {
  text-align: left;
}
.business-box .sub-title .under {
  color: #f2f2f2;
}
.business-box .sub-title .up {
  left: 13%;
}
.business-box img {
  width: 700px;
  max-width: 100%;
  margin: 5% auto;
}
.business-box h4 {
  text-align: center;
  font-size: 25px;
  margin-top: 40px;
  font-family: "Hiragino Sans";
  line-height: 1.5em;
}
.business-box h5 {
  text-align: center;
  font-size: 35px;
}

/******************
事業内容②
*******************/
.works {
  width: 100%;
  background-color: #f2f2f2;
  padding: 100px 0;
}
.works .work-box {
  display: flex;
  margin-bottom: 50px;
  width: 1000px;
  max-width: 80%;
  margin: 0 auto;
}
.works .work-box .work-left {
  width: 60%;
}
.works .work-box .work-left h4.red-bar {
  padding: 10px;
  margin-bottom: 30px;
}
.works .work-box .work-left h5 {
  font-size: 18px;
  margin-bottom: 20px;
}
.works .work-box .work-left p {
  width: 100%;
  margin-bottom: 50px;
}
.works .work-box .work-right {
  width: 40%;
}
.works .work-box .work-right img {
  width: 80%;
  border-radius: 2em;
  margin: 15% 0 5% auto;
}
.works .list {
  margin-bottom: 10%;
}

/******************
事業所
*******************/
.place-box {
  width: 1000px;
  margin: 0 auto 0% auto;
  max-width: 80%;
  padding: 100px 0;
}
.place-box p {
  width: 50%;
}
.place-box img {
  width: 80%;
  margin: 0 auto;
}

.place-flex {
  display: flex;
}
.place-flex .place-left {
  width: 50%;
}
.place-flex .place-left h5 {
  font-size: 35px;
}
.place-flex .place-right {
  width: 50%;
  font-size: 16px;
}

/******************
福利厚生
*******************/
.welfare {
  padding: 7% 10%;
  width: 100%;
  background-color: #f2f2f2;
}
.welfare .sub-title {
  text-align: left;
}
.welfare .sub-title .up {
  left: 13%;
}
.welfare p {
  margin: 5% 0;
}
.welfare .wel {
  display: flex;
  font-family: "kozuka-mincho-pr6n", serif;
  font-weight: 700;
  font-style: normal;
  font-size: max(1.7vw, 15px);
}
.welfare .wel .wel-left {
  width: 25%;
  padding: 2% 3%;
}
.welfare .wel .wel-right {
  width: 75%;
}
.welfare .wel:nth-child(odd) {
  border: solid 0.1em white;
}
.welfare .wel:nth-child(odd) .wel-left {
  background-color: white;
}
.welfare .wel2 {
  display: flex;
  margin: 10% 0;
}
.welfare .wel2 h5 {
  font-size: max(1.3vw, 15px);
}
.welfare .wel2 img {
  padding: 2% 0;
}
.welfare .wel2 .wel2-card:nth-child(1) {
  padding-right: 1.5%;
}
.welfare .wel2 .wel2-card:nth-child(2) {
  padding: 0 2%;
}
.welfare .wel2 .wel2-card:nth-child(3) {
  padding-left: 1.5%;
}
.welfare .map img {
  width: 80%;
  margin: 0 auto;
  padding: 5%;
  background-color: white;
  border-radius: 2em;
}

/******************
会社概要
*******************/
.company-title {
  border-bottom: solid 0.2em #d60011;
  padding-bottom: 3%;
  width: 1000px !important;
  max-width: 80%;
}
.company-title .sub-title .under {
  color: #f2f2f2;
}
.company-title .sub-title .up {
  left: 15%;
}

section.company {
  width: 900px;
  margin: 5% auto 0 auto;
  max-width: 80%;
  letter-spacing: 0.02em;
}
section.company .co-info {
  margin: 7% auto;
}
section.company h3 {
  font-size: 18px;
  font-family: "MS PGothic", "Hiragino Kaku Gothic StdN", sans-serif;
  font-weight: 600 !important;
  color: #464646;
  margin-bottom: 1%;
  font-family: "Hiragino Sans";
  line-height: 1.5em;
}
section.company p {
  font-size: 16px;
  line-height: 180%;
}
section.company ul li {
  font-size: max(1.2vw, 13px);
  line-height: 180%;
}
section.company ul {
  padding-left: 3%;
  list-style: "●";
  margin-top: 5px;
}
section.company .co-info-title {
  margin-top: 10px;
}
section.company .co-info-flex {
  display: flex;
  flex-wrap: wrap;
}
section.company .co-info-flex .left {
  width: 300px;
  max-width: 100%;
}
section.company .co-info-flex .right {
  width: 300px;
  max-width: 100%;
}
section.company li.dot {
  list-style: "・";
  margin-left: 10px;
  margin-bottom: 5px;
}

/******************
フッター
*******************/
.sub-logo {
  margin: 10% auto 0% auto;
}

@media (max-width: 1250px) {
  .nav .vertical-line {
    min-height: 100px;
  }
}
@media (max-width: 700px) {
  h1 {
    font-size: max(8vw, 20px);
  }
  .fo-menu-box.top {
    margin-top: 50px;
  }
  .total-box {
    width: 90%;
  }
  .message-box {
    padding: 80px 0% 0 0%;
    margin-top: -50px;
    margin-bottom: 15%;
    display: block;
  }
  .message-box .message-left {
    width: 100%;
  }
  .message-box .message-left p {
    width: 90%;
  }
  .message-box .message-right {
    width: 100%;
  }
  .philosophy-box {
    padding-top: 15%;
    padding-bottom: 20%;
  }
  .ph-box {
    display: block;
  }
  .ph-box .ph-left {
    width: 100%;
  }
  .ph-box .ph-right {
    width: 100%;
  }
  .ph-box .ph-right p {
    margin-top: 10%;
    margin-bottom: 10%;
  }
  .ph-box .sub-title .up {
    left: 25%;
  }
  section.company-title {
    width: 90%;
    padding-top: 80px;
    margin-top: -50px;
  }
  section.company {
    width: 90%;
    margin-bottom: 20%;
  }
  section.company ul {
    padding-left: 5%;
  }
  .business-box {
    padding: 15% 0%;
  }
  .business-box h4 {
    font-size: 20px;
  }
  .business-box h5 {
    font-size: 25px;
  }
  .business-box .sub-title .up {
    left: 21%;
  }
  .business-box img {
    width: 90%;
  }
  .business-box h4 {
    margin-bottom: 3%;
  }
  .works {
    padding: 15% 5%;
  }
  .works .list {
    margin-bottom: 15%;
  }
  .works .work-box {
    max-width: 100%;
  }
  .works .work-box {
    display: block;
  }
  .works .work-box .work-left {
    width: 100%;
  }
  .works .work-box .work-right {
    width: 100%;
  }
  .works .work-box .work-right img {
    margin: 10% 0 10% auto;
  }
  .place-flex {
    display: block;
  }
  .place-box {
    padding-top: 15%;
    padding-bottom: 15%;
    max-width: 90%;
  }
  .place-box .place-left,
  .place-box .place-right {
    width: 100%;
    margin-bottom: 20px;
  }
  .place-box .place-left h5 {
    font-size: 23px;
  }
  .place-box p {
    width: 80%;
    margin: 10% 0;
  }
  .place-box img {
    width: 100%;
  }
  .welfare .sub-title .up {
    left: 20%;
  }
  .welfare {
    padding: 15% 5%;
  }
  .welfare p {
    margin: 10% 0;
  }
  .welfare .wel .wel-left {
    width: 35%;
  }
  .welfare .wel .wel-right {
    width: 65%;
  }
  .welfare .map img {
    width: 100%;
  }
  .welfare .description {
    margin-top: 2%;
  }
  .welfare .wel2 {
    display: block;
  }
  .company-title {
    max-width: 90%;
  }
  section.company {
    padding: 0 5%;
  }
  button#scroll-to-top-btn {
    margin: 5% 10px 100px auto;
  }
}/*# sourceMappingURL=company.css.map */