@charset "UTF-8";
/*----------------------------------------------------
  変数セット
----------------------------------------------------*/
/*----------------------------------------------------
  メイン
----------------------------------------------------*/
.mainimage-area {
  position: relative;
}
.mainimage-area .catch {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: 0;
  left: 6vw;
}
@media screen and (max-width: 767.98px) {
  .mainimage-area .catch {
    position: static;
    -webkit-transform: none;
            transform: none;
    padding: 2rem 0 0 2rem;
  }
}
.mainimage-area .catch h1 {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.mainimage-area .catch h1 ::before {
  content: "";
  width: 0.7em;
  height: 0.7em;
  background-color: #F8CF03;
  border-radius: 50%;
  display: inline-block;
  margin-right: 1rem;
}
.mainimage-area .catch h1 span {
  display: inline-block;
  color: #569164;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 4.6rem;
  font-weight: 700;
  line-height: 1.4;
  padding: 0.3em 0.6em;
  border-radius: 0.5em;
  background-color: #fff;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767.98px) {
  .mainimage-area .catch h1 span {
    font-size: 3.6rem;
  }
}
@media screen and (max-width: 575.98px) {
  .mainimage-area .catch h1 span {
    font-size: 3.2rem;
  }
}
.mainimage-area .page-block {
  width: calc(34vw - 4rem);
}
@media screen and (max-width: 767.98px) {
  .mainimage-area .page-block {
    width: 94vw;
  }
}
.mainimage-area .page-block .txt-catch {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 0.7em;
}
.mainimage-area .page-block p {
  line-height: 2;
}
.mainimage-area .main-image {
  z-index: -1;
  width: 75vw;
  overflow: hidden;
  margin-left: auto;
  border-radius: 5rem 0 0 5rem;
}
@media screen and (max-width: 767.98px) {
  .mainimage-area .main-image {
    width: calc(100vw - 30px);
    border-radius: 4rem 0 0 4rem;
    margin-right: 15px;
    margin-left: 15px;
  }
}
.mainimage-area .page-img {
  height: calc(440px - 2rem);
  overflow: hidden;
}
@media screen and (max-width: 767.98px) {
  .mainimage-area .page-img {
    height: 400px;
    min-height: none;
  }
}
.mainimage-area .page-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/*----------------------------------------------------
  代表挨拶
----------------------------------------------------*/
.greeting-wrap {
  padding: 0 8rem;
}
@media screen and (max-width: 767.98px) {
  .greeting-wrap {
    padding: 0em;
  }
}
.greeting-wrap p {
  font-size: 1.8rem;
  line-height: 2.5;
}
@media screen and (max-width: 767.98px) {
  .greeting-wrap p {
    font-size: 1.6rem;
  }
}

/*----------------------------------------------------
  会社概要・沿革
----------------------------------------------------*/
.outline-wrap table.table01 {
  width: 100%;
  background: #fff;
}
.outline-wrap table.table01 tr {
  border-top: 1px solid #ccc;
}
.outline-wrap table.table01 tr:last-child {
  border-bottom: 1px solid #ccc;
}
.outline-wrap table.table01 th {
  width: 20%;
  padding: 2rem;
}
.outline-wrap table.table01 td {
  width: 80%;
  padding: 2rem;
}

/*----------------------------------------------------
  アクセス
----------------------------------------------------*/
.access-wrap .map {
  width: 100%;
  overflow: hidden;
}
.access-wrap .map iframe {
  width: 100%;
  height: 530px;
}