@charset "UTF-8";
/* CSS Document */
/*----------------------------------------
変数
----------------------------------------*/
/* 代表挨拶
---------------------------------------------- */
@media screen and (max-width: 899px) {
  #greeting {
    margin-top: 40px;
  }
}
@media screen and (min-width: 900px) {
  #greeting {
    margin-top: 80px;
  }
}
#greeting .greetingContainer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 899px) {
  #greeting .greetingContainer {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 32px;
  }
}
@media screen and (min-width: 900px) {
  #greeting .greetingContainer {
    gap: 8%;
  }
}
@media screen and (min-width: 900px) {
  #greeting .greetingContainer .areaImage {
    width: 38%;
    max-width: 520px;
  }
}
@media screen and (min-width: 900px) {
  #greeting .greetingContainer .areaText {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-top: 56px;
  }
}
@media screen and (min-width: 900px) {
  #greeting .greetingContainer .areaText .noteWrap {
    margin-top: 32px;
  }
}
#greeting .greetingContainer .areaText .noteWrap .note {
  font-family: var(--fontJp);
  line-height: 2.25;
  letter-spacing: 0.02em;
}
#greeting .greetingContainer .areaText .noteWrap .note:not(:first-of-type) {
  margin-top: 2em;
}
#greeting .greetingContainer .areaText .post {
  font-family: var(--fontJp);
  font-weight: 700;
  line-height: 2;
}
@media screen and (max-width: 899px) {
  #greeting .greetingContainer .areaText .post {
    margin-top: 40px;
  }
}
#greeting .greetingContainer .areaText .post {
  letter-spacing: 0.02em;
}
@media screen and (min-width: 900px) {
  #greeting .greetingContainer .areaText .post {
    margin-top: 64px;
  }
}

/* 経営理念
---------------------------------------------- */
#vision {
  background-image: url("images/vision_bg.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
@media screen and (max-width: 899px) {
  #vision {
    padding-top: 64px;
    padding-bottom: 88px;
    margin-top: 72px;
  }
}
@media screen and (min-width: 900px) {
  #vision {
    padding-top: 88px;
    padding-bottom: 152px;
    margin-top: 140px;
  }
}
#vision .visionInner {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
@media screen and (max-width: 899px) {
  #vision .visionInner {
    padding-left: 16px;
    padding-right: 16px;
  }
}
@media screen and (min-width: 900px) {
  #vision .visionInner {
    padding-left: 80px;
    padding-right: 80px;
  }
}
#vision .sectionTitle .titleJp,
#vision .sectionTitle .titleEn {
  color: var(--colorTextSub);
}
#vision .visionBox {
  background-color: rgba(255, 254, 250, 0.9);
}
@media screen and (max-width: 899px) {
  #vision .visionBox {
    padding: 40px 24px 40px 32px;
    margin-top: -17px;
  }
}
@media screen and (min-width: 900px) {
  #vision .visionBox {
    padding: 80px;
    margin-top: -25px;
  }
}
#vision .visionBox .visionList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin-left: 2em;
}
@media screen and (max-width: 899px) {
  #vision .visionBox .visionList {
    gap: 32px;
  }
}
@media screen and (min-width: 900px) {
  #vision .visionBox .visionList {
    gap: 64px;
  }
}
#vision .visionBox .visionList .visionListItem {
  list-style: decimal-leading-zero;
  font-family: var(--fontJp);
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 899px) {
  #vision .visionBox .visionList .visionListItem {
    font-size: var(--size18px);
  }
}
@media screen and (min-width: 900px) {
  #vision .visionBox .visionList .visionListItem {
    font-size: var(--size24px);
  }
}
#vision .visionBox .visionList .visionListItem strong {
  color: var(--colorMain);
}

/* 会社概要
---------------------------------------------- */
#about {
  overflow-x: hidden;
}
@media screen and (max-width: 899px) {
  #about {
    margin-top: 64px;
  }
}
@media screen and (min-width: 900px) {
  #about {
    margin-top: 136px;
  }
}
#about .aboutTitleContainer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 899px) {
  #about .aboutTitleContainer {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 32px;
  }
}
@media screen and (min-width: 900px) {
  #about .aboutTitleContainer {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media screen and (min-width: 900px) {
  #about .aboutTitleContainer .areaTitle {
    width: 400px;
  }
}
@media screen and (min-width: 900px) {
  #about .aboutTitleContainer .areaList {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    max-width: 800px;
  }
}
#about .aboutTitleContainer .areaList .aboutDetailList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
#about .aboutTitleContainer .areaList .aboutDetailList dt,
#about .aboutTitleContainer .areaList .aboutDetailList dd {
  font-family: var(--fontJp);
  line-height: 1.75;
  letter-spacing: 0.02em;
}
#about .aboutTitleContainer .areaList .aboutDetailList dt {
  position: relative;
  color: var(--colorMain);
  font-weight: 700;
}
@media screen and (max-width: 899px) {
  #about .aboutTitleContainer .areaList .aboutDetailList dt {
    width: 120px;
    padding: 24px 8px;
  }
}
@media screen and (min-width: 900px) {
  #about .aboutTitleContainer .areaList .aboutDetailList dt {
    width: 160px;
    padding: 24px 8px;
  }
}
#about .aboutTitleContainer .areaList .aboutDetailList dt::before {
  content: "";
  display: inline-block;
  width: 100vw;
  position: absolute;
  top: 0;
  left: 0;
  border-top: 1px solid var(--colorBorder);
}
#about .aboutTitleContainer .areaList .aboutDetailList dt:last-of-type::after {
  content: "";
  display: inline-block;
  width: 100vw;
  position: absolute;
  bottom: 0;
  left: 0;
  border-top: 1px solid var(--colorBorder);
}
@media screen and (max-width: 899px) {
  #about .aboutTitleContainer .areaList .aboutDetailList dd {
    width: calc(100% - 120px);
    padding: 24px 8px;
  }
}
@media screen and (min-width: 900px) {
  #about .aboutTitleContainer .areaList .aboutDetailList dd {
    width: calc(100% - 160px);
    padding: 24px 32px 24px 8px;
  }
}
#about .officeContainer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
@media screen and (max-width: 899px) {
  #about .officeContainer {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 40px;
    margin-top: 32px;
  }
}
@media screen and (min-width: 900px) {
  #about .officeContainer {
    gap: 5.8%;
    margin-top: 40px;
  }
}
#about .officeContainer .officeBox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
}
@media screen and (min-width: 900px) {
  #about .officeContainer .officeBox {
    width: 47.1%;
  }
}
#about .officeContainer .officeBox .text {
  font-family: var(--fontJp);
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (min-width: 900px) {
  #about .officeContainer .officeBox .text {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}

/* 沿革
---------------------------------------------- */
#history .historyContainer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 899px) {
  #history .historyContainer {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 56px;
    margin-top: 80px;
  }
}
@media screen and (min-width: 900px) {
  #history .historyContainer {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 160px;
  }
}
@media screen and (min-width: 900px) {
  #history .historyContainer .areaTitle {
    width: 400px;
  }
}
@media screen and (min-width: 900px) {
  #history .historyContainer .areaList {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    max-width: 832px;
  }
}
#history .historyContainer .areaList .historyDetailList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
#history .historyContainer .areaList .historyDetailList dt {
  position: relative;
  color: var(--colorMain);
  font-family: var(--fontJp);
  font-weight: 700;
}
@media screen and (max-width: 899px) {
  #history .historyContainer .areaList .historyDetailList dt {
    width: 104px;
    font-size: var(--size24px);
  }
}
@media screen and (min-width: 900px) {
  #history .historyContainer .areaList .historyDetailList dt {
    width: 148px;
    font-size: var(--size32px);
  }
}
#history .historyContainer .areaList .historyDetailList dt span {
  font-size: 0.75em;
}
#history .historyContainer .areaList .historyDetailList dt::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  position: absolute;
  right: 0;
  z-index: 10;
  -webkit-transform: translate(50%, 0);
          transform: translate(50%, 0);
  background-image: url("images/history_dot.svg");
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 899px) {
  #history .historyContainer .areaList .historyDetailList dt::before {
    top: 8px;
  }
}
@media screen and (min-width: 900px) {
  #history .historyContainer .areaList .historyDetailList dt::before {
    top: 16px;
  }
}
#history .historyContainer .areaList .historyDetailList dt:not(:last-of-type)::after {
  content: "";
  display: inline-block;
  width: 1px;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 0;
  -webkit-transform: translate(50%, 0);
          transform: translate(50%, 0);
  background-color: var(--colorMain);
}
@media screen and (max-width: 899px) {
  #history .historyContainer .areaList .historyDetailList dt:not(:last-of-type)::after {
    top: 8px;
  }
}
@media screen and (min-width: 900px) {
  #history .historyContainer .areaList .historyDetailList dt:not(:last-of-type)::after {
    top: 16px;
  }
}
#history .historyContainer .areaList .historyDetailList dd {
  position: relative;
  font-family: var(--fontJp);
  line-height: 1.75;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 899px) {
  #history .historyContainer .areaList .historyDetailList dd {
    width: calc(100% - 104px);
    padding-top: 0.25em;
    padding-left: 32px;
    padding-bottom: 32px;
  }
}
@media screen and (min-width: 900px) {
  #history .historyContainer .areaList .historyDetailList dd {
    width: calc(100% - 148px);
    padding-left: 48px;
    padding-bottom: 64px;
    padding-top: 1em;
  }
}
#history .historyContainer .areaList .historyDetailList dd:first-of-type::before {
  content: "";
  display: inline-block;
  width: 1px;
  height: 64px;
  position: absolute;
  left: 0;
  z-index: 0;
  -webkit-transform: translate(-50%, -100%);
          transform: translate(-50%, -100%);
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(10%, rgba(255, 255, 255, 0)), color-stop(90%, rgb(35, 153, 42)));
  background-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 10%, rgb(35, 153, 42) 90%);
}
@media screen and (max-width: 899px) {
  #history .historyContainer .areaList .historyDetailList dd:first-of-type::before {
    top: 8px;
  }
}
@media screen and (min-width: 900px) {
  #history .historyContainer .areaList .historyDetailList dd:first-of-type::before {
    top: 16px;
  }
}
#history .historyContainer .areaList .historyDetailList dd:last-of-type::before {
  content: "";
  display: inline-block;
  width: 1px;
  height: 64px;
  position: absolute;
  left: 0;
  z-index: 0;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  background-image: -webkit-gradient(linear, left bottom, left top, color-stop(10%, rgba(255, 255, 255, 0)), color-stop(90%, rgb(35, 153, 42)));
  background-image: linear-gradient(0deg, rgba(255, 255, 255, 0) 10%, rgb(35, 153, 42) 90%);
}
@media screen and (max-width: 899px) {
  #history .historyContainer .areaList .historyDetailList dd:last-of-type::before {
    top: 24px;
  }
}
@media screen and (min-width: 900px) {
  #history .historyContainer .areaList .historyDetailList dd:last-of-type::before {
    top: 40px;
  }
}

/* アクセス
---------------------------------------------- */
@media screen and (max-width: 899px) {
  #access {
    margin-top: 80px;
  }
}
@media screen and (min-width: 900px) {
  #access {
    margin-top: 176px;
  }
}
#access .accessContainer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 899px) {
  #access .accessContainer {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 32px;
  }
}
@media screen and (min-width: 900px) {
  #access .accessContainer {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media screen and (min-width: 900px) {
  #access .accessContainer .areaTitle {
    width: 400px;
  }
}
@media screen and (min-width: 900px) {
  #access .accessContainer .areaMap {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    max-width: 976px;
  }
}
#access .accessContainer .areaMap .map {
  height: 360px;
}
#access .accessContainer .areaMap .map iframe {
  width: 100%;
  height: 100%;
}/*# sourceMappingURL=company.css.map */