@charset "UTF-8";
/* -----------------------------------------------
mv__wrap
----------------------------------------------- */
.mv__wrap {
  position: relative;
}
.mv__wrap.dotto::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.3);
	background-image: radial-gradient(#111 30%, transparent 31%), radial-gradient(#111 30%, transparent 31%);
	background-size: 4px 4px;
	background-position: 0 0, 2px 2px;
}
.mv__text {
  color: #fff;
  position: absolute;
  z-index: 1;
}
.mv__text h1 {
  font-weight: bold;
}

@media (max-width: 767px) {
  .mv__movie video {
    aspect-ratio: 1 / 1;
    object-fit: cover;
  }
  .mv__text {
    bottom: calc(var(--vw) * 12);
    left: 2.78%;
  }
  .mv__text h1 {
    font-size: calc(var(--vw) * 24);
    line-height: 1.66;
    margin-bottom: calc(var(--vw) * 10);
    text-shadow: 0 0 16px rgba(0,0,0,0.15);
  }
  .mv__text p {
    font-size: calc(var(--vw) * 14);
    line-height: 2;
    text-shadow: 0 0 8px rgba(0,0,0,0.15);
  }
}

@media (min-width: 768px) {
  .mv__text {
    bottom: min(10vw, 144px);
    left: min(8.33vw, 120px);
  }
  .mv__text h1 {
    font-size: min(3.33vw, 48px);
    line-height: 1.66;
    margin-bottom: min(2.08vw, 30px);
    text-shadow: 0 0 16px rgba(0,0,0,0.15);
  }
  .mv__text p {
    font-size: min(1.67vw, 24px);
    line-height: 2;
    text-shadow: 0 0 8px rgba(0,0,0,0.15);
  }
}

/* -----------------------------------------------
lead__wrap
----------------------------------------------- */
.lead__wrap {
  background-color: var(--main-color);
  color: #fff;
  position: relative;
}
.lead__wrap::before {
  content: '';
  aspect-ratio: 529/310;
  background: url(../images/top/about_deco_left.png) center / contain no-repeat;
  position: absolute;
}
.lead__wrap::after {
  content: '';
  aspect-ratio: 529/310;
  background: url(../images/top/about_deco_right.png) center / contain no-repeat;
  position: absolute;
}

@media (max-width: 767px) {
  .lead__wrap {
    padding: 100px 0 100px;
  }
  .lead__wrap::before {
    width: min(36.74vw, 529px);
    top: min(2.01vw, 29px);
    left: min(2.01vw, 29px);
  }
  .lead__wrap::after {
    width: min(36.74vw, 529px);
    bottom: min(2.01vw, 29px);
    right: min(2.01vw, 29px);
  }
  .lead__wrap .sec__heading {
    font-size: 28px;
    letter-spacing: 0.1em;
  }
  .lead__wrap p {
    line-height: 2.625;
  }
}

@media (min-width: 768px) {
  .lead__wrap {
    padding: 220px 0 220px;
  }
  .lead__wrap::before {
    width: min(36.74vw, 529px);
    top: min(2.01vw, 29px);
    left: min(2.01vw, 29px);
  }
  .lead__wrap::after {
    width: min(36.74vw, 529px);
    bottom: min(2.01vw, 29px);
    right: min(2.01vw, 29px);
  }
  .lead__wrap .sec__heading {
    font-size: 42px;
    letter-spacing: 0.1em;
  }
  .lead__wrap p {
    line-height: 2.625;
  }
}

/* -----------------------------------------------
company__wrap
----------------------------------------------- */
.company__wrap {
  position: relative;
  z-index: 1;
  background-color: var(--main-color);
}
.company__wrap::before {
  content: '';
  width: 100%;
  height: 100%;
  background-color: var(--light-color);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

@media (max-width: 767px) {
  .company__wrap::before {
    border-radius: 0 calc(var(--vw) * 50) 0 0;
  }
}

@media (min-width: 768px) {
  .company__wrap::before {
    border-radius: 0 min(8.33vw, 120px) 0 0;
  }
}

/* -----------------------------------------------
service__wrap
----------------------------------------------- */
.service__wrap {
  position: relative;
  z-index: 1;
  background-color: var(--light-color);
}
.service__wrap::before {
  content: '';
  width: 100%;
  height: 100%;
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

@media (max-width: 767px) {
  .service__wrap::before {
    border-radius: calc(var(--vw) * 50) 0 0 0;
  }
}

@media (min-width: 768px) {
  .service__wrap::before {
    border-radius: min(8.33vw, 120px) 0 0 0;
  }
}

/* -----------------------------------------------
factory__wrap
----------------------------------------------- */
.factory__wrap {
  position: relative;
  z-index: 1;
  background-color: #fff;
}
.factory__wrap::before {
  content: '';
  width: 100%;
  height: 100%;
  background-color: var(--light-color);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

@media (max-width: 767px) {
  .factory__wrap::before {
    border-radius: 0 calc(var(--vw) * 50) 0 0;
  }
}

@media (min-width: 768px) {
  .factory__wrap::before {
    border-radius: 0 min(8.33vw, 120px) 0 0;
  }
}

/* -----------------------------------------------
recrult__wrap
----------------------------------------------- */
.recruit__wrap {
  position: relative;
  z-index: 1;
  background-color: var(--light-color);
}
.recruit__wrap::before {
  content: '';
  width: 100%;
  height: 100%;
  background-color: var(--main-color);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.recruit__wrap .inner__wrap {
  display: grid;
}
.recruit__wrap .sec__heading {
  color: #fff;
  grid-area: sec__heading;
}
.recruit__wrap .link__btn {
  grid-area: link__btn;
}
.recruit__wrap .link__btn a {
  background-color: #fff;
  color: var(--main-color);
}
.recruit__wrap .link__btn a::after {
  background: url(../images/common/link_arrow_green.svg) center / contain no-repeat;
}
.recurit__img__column {
  grid-area: recurit__img__column;
}

@media (max-width: 767px) {
  .recruit__wrap {
    padding: 35px 0;
  }
  .recruit__wrap::before {
    border-radius: min(8.33vw, 120px) 0 0 0;
  }
  .recruit__wrap .inner__wrap {
    grid-template-columns: 100%; 
    grid-template-rows: auto auto 1fr;
    gap: 0 6.73%;
    grid-template-areas: 
    "sec__heading"
    "recurit__img__column"
    "link__btn";
    text-align: center;
  }
  .recruit__wrap .sec__heading {
    display: flex;
    align-items: flex-end;
    padding-bottom: 16px;
  }
  .recruit__wrap .link__btn {
    padding-top: 16px;
  }
  .recurit__img__column {
    display: flex;
    justify-content: space-between;
    gap: 0 1.35%;
  }
  .recurit__img__column picture {
    width: 32.43%;
  }
  .recurit__img__column img {
    border-radius: 10px;
  }
}

@media (min-width: 768px) {
  .recruit__wrap {
    padding: 35px 0;
  }
  .recruit__wrap::before {
    border-radius: min(8.33vw, 120px) 0 0 0;
  }
  .recruit__wrap .inner__wrap {
    grid-template-columns: auto 71.15%; 
    grid-template-rows: 1fr 1fr;
    gap: 32px 6.73%;
    grid-template-areas: 
    "sec__heading recurit__img__column"
    "link__btn recurit__img__column";
  }
  .recruit__wrap .sec__heading {
    display: flex;
    align-items: flex-end;
  }
  .recruit__wrap .link__btn a {
    width: min(230px, 100%);
    min-width: auto;
  }
  .recurit__img__column {
    display: flex;
    justify-content: space-between;
    gap: 0 1.35%;
  }
  .recurit__img__column picture {
    width: 32.43%;
  }
  .recurit__img__column img {
    border-radius: 10px;
  }
}