@charset "utf-8";
/* common
-------------------------------------------------------------- */
#lead {
  background: var(--lightyellow);
}
#lead h2 {
  margin: auto;
  max-width: 420px;
}
@media (max-width: 1200px) {
  #lead h2 {
    max-width: 290px;
  }
}
@media (max-width: 768px) {
  #lead h2 {
    max-width: 270px;
  }
}
/* cando
-------------------------------------------------------------- */
#cando {
  padding: 100px 0;
}
#cando .txt {
  margin: 30px auto 100px;
  max-width: 800px;
  line-height: 2.2;
}
#cando .ytWrap {
  margin: auto;
  padding: 30px 70px;
  max-width: 1000px;
  background: var(--lightyellow);
}
#cando .btnYt a {
  margin: 0 auto 30px;
  gap: 10px;
  align-items: center;
  justify-content: center;
  padding: 10px 30px;
  max-width: 500px;
  border: 1px solid var(--lightblack);
  border-radius: 30px;
}
#cando .btnYt span {
  font-size: 1.8rem;
  line-height: 1.2;
}
#cando .ytWrap div.flex {
  gap: 30px;
}
#cando .ytWrap dl {
  width: calc((100% - 60px) / 3);
}
#cando .ytWrap dt iframe {
  width: 100%;
  height: 200px;
}
#cando .ytWrap dd {
  padding-top: 10px;
  line-height: 1.4;
}
@media (max-width: 768px) {
  #cando {
    padding: 50px 0;
  }
  #cando .txt {
    margin: 15px auto 50px;
  }
  #cando .ytWrap {
    padding: 15px 20px;
  }
  #cando .btnYt a {
    margin: 0 auto 15px;
    gap: 10px;
    padding: 10px 20px;
    border-radius: 15px;
  }
  #cando .btnYt .arrow {
    width: 30px;
  }
  #cando .btnYt span {
    width: calc(100% - 40px);
    font-size: 1.6rem;
  }
  #cando .ytWrap div.flex {
    gap: 20px;
  }
  #cando .ytWrap dl {
    width: 100%;
  }
  #cando .ytWrap dt iframe {
    height: 180px;
  }
}

/* reason
-------------------------------------------------------------- */
#reason .check {
  margin: 30px auto 50px;
  max-width: 900px;
}
#reason .check li {
  position: relative;
  padding: 5px 0 20px 50px;
  font-size: 1.8rem;
  line-height: 1.4;
}
#reason .check li::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 38px;
  height: 31px;
  background: url(../img/index/ico_check.svg) no-repeat center / contain;
  content: '';
}
#reason .reasonBox .reasonTtl {
  position: relative;
  margin: 0 auto 40px;
  padding: 20px;
  max-width: 1000px;
  background: #fffcdb;
  text-align: center;
}
#reason .reasonBox .reasonTtl .ico {
  position: absolute;
  top: -30px;
  left: 20px;
  width: 140px;
}
#reason .reasonBox .reasonTtl span {
  font-size: 2.4rem;
  font-weight: 500;
}
#reason .reasonBox .txt {
  margin: 0 auto 30px;
  max-width: 790px;
  line-height: 2.2;
}
#reason .linkWrap {
  margin: 0 auto 50px;
  gap: 15px;
  max-width: 1080px;
}
#reason .linkWrap dl {
  width: calc((100% - 45px) / 4);
}
#reason .linkWrap .btn a {
  align-items: center;
  justify-content: center;
  height: 60px;
}
#reason .linkWrap .btn span {
  position: relative;
  display: block;
  padding-left: 25px;
  line-height: 1.2;
}
#reason .linkWrap .btn span::before {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  width: 15px;
  height: 20px;
  background: url(../img/common/arrow_or.svg) no-repeat center / contain;
  content: "";
}
#reason #reason01 .linkWrap .btn a {
  pointer-events: none;
}
#reason #reason01 .btnMore a {
  max-width: 400px;
}
#reason #reason02 {
  margin: 80px auto;
}
#reason #reason02 .reasonTtl span {
  display: block;
  margin: auto;
  max-width: 720px;
  text-align: left;
}
#reason #reason02 .btnMore.orange a {
  background: var(--orange);
  color: var(--white);
}
#reason #reason03 .reasonTtl span {
  display: block;
  margin: auto;
  max-width: 700px;
  text-align: left;
}
#reason #reason03 .photo {
  margin: 0 auto 30px;
  max-width: 1000px;
  gap: 15px;
}
#reason #reason03 .photo li {
  width: calc((100% - 15px) / 2);
}
#reason .prArea {
  margin: 80px auto;
  gap: 20px;
}
#reason .prArea .ttl {
  padding: 20px 5%;
  align-items: center;
  justify-content: center;
  width: calc(36% - 10px);
  background: url(../img/concept/pr_bg.jpg) no-repeat center / cover;
  aspect-ratio: 571 / 429;
}
#reason .prArea ul {
  gap: 20px;
  width: calc(64% - 10px);
}
#reason .prArea li {
  gap: 1px;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: calc((100% - 60px) / 4);
  line-height: 1;
}
#reason .prArea li .charmonman {
  display: block;
  width: 100%;
  text-align: center;
  color: #f8f3a0;
  font-size: 7rem;
  font-weight: 700;
}
#reason .prArea li .jp {
  display: block;
  width: 100%;
  text-align: center;
  color: var(--white);
  font-size: 2.4rem;
}
#reason .prArea li:first-child {
  background: #f8f3a0;
}
#reason .prArea li:nth-child(2) {
  background: #fff553;
}
#reason .prArea li:nth-child(3) {
  background: #b5e061;
}
#reason .prArea li:nth-child(4) {
  background: #91ef3d;
}
#reason .prArea li:nth-child(5) {
  background: #52da28;
}
#reason .prArea li:nth-child(6) {
  background: #29b83d;
}
#reason .prArea li:nth-child(7) {
  background: #0c8a3c;
}
#reason .prArea li:last-child {
  background: #1f603c;
}
#reason .prArea li:first-child .charmonman,
#reason .prArea li:first-child .jp,
#reason .prArea li:nth-child(2) .charmonman,
#reason .prArea li:nth-child(2) .jp {
  color: var(--green);
}
#reason .prArea li:nth-child(2) {
  background: #fff553;
}
@media (max-width: 1200px) {
  #reason .prArea li .charmonman {
    font-size: 5rem;
  }
  #reason .prArea li .jp {
    font-size: 2rem;
  }
}
@media (max-width: 1000px) {
  #reason .prArea li .charmonman {
    font-size: 3rem;
  }
  #reason .prArea li .jp {
    font-size: 1.4rem;
  }
}
@media (max-width: 768px) {
  #reason .check {
    margin: 15px auto 25px;
  }
  #reason .check li {
    position: relative;
    padding: 0 0 20px 30px;
    font-size: 1.5rem;
  }
  #reason .check li::before {
    top: 1px;
    width: 28px;
    height: 21px;
  }
  #reason .reasonBox .reasonTtl {
    margin: 0 auto 20px;
  }
  #reason .reasonBox .reasonTtl .ico {
    top: -25px;
    left: 10px;
    width: 100px;
  }
  #reason .reasonBox .reasonTtl span {
    font-size: 1.8rem;
  }
  #reason .reasonBox .txt {
    margin: 0 auto 15px;
    line-height: 2;
  }
  #reason .linkWrap {
    margin: 0 auto 25px;
    gap: 10px;
  }
  #reason .linkWrap dl {
    width: calc((100% - 10px) / 2);
  }
  #reason .linkWrap .btn a {
    height: 50px;
  }
  #reason .linkWrap .btn span {
    padding-left: 15px;
  }
  #reason .linkWrap .btn span::before {
    width: 10px;
    height: 15px;
  }
  #reason #reason01 .btnMore span {
    font-size: 1.4rem;
  }
  #reason #reason02 {
    margin: 50px auto;
  }
  #reason #reason03 .photo {
    margin: 0 auto 15px;
    gap: 10px;
  }
  #reason #reason03 .photo li {
    width: calc((100% - 10px) / 2);
  }
  #reason .prArea {
    margin: 40px auto;
    gap: 10px;
  }
  #reason .prArea .ttl {
    padding: 20px 5%;
    align-items: center;
    justify-content: center;
    width: 100%;
    background: url(../img/concept/pr_bg.jpg) no-repeat center / cover;
    aspect-ratio: 571 / 429;
  }
  #reason .prArea ul {
    gap: 10px;
    width: 100%;
  }
  #reason .prArea li {
    padding: 10px 0;
    width: calc((100% - 30px) / 4);
    line-height: 1;
  }
  #reason .prArea li .charmonman {
    font-size: 2.8rem;
  }
  #reason .prArea li .jp {
    font-size: 1.2rem;
  }
}

/* facility
-------------------------------------------------------------- */
#facility .txt {
  margin: 30px auto;
  max-width: 800px;
  line-height: 2.2;
}
#facility .facilityWrap {
  margin: 50px auto;
  gap: 20px;
  max-width: 1100px;
}
#facility .facilityBox {
  padding: 20px;
  border: 1px solid var(--green);
  width: calc((100% - 40px) / 3);
}
#facility .facilityBox h3 {
  color: var(--green);
  font-size: 2rem;
  font-weight: 500;
}
#facility .txtNote {
  align-items: flex-end;
  width: calc((100% - 40px) / 3);
  font-size: 1.4rem;
}
#facility .btnMore a {
  max-width: 300px;
}
@media (max-width: 768px) {
  #facility .txt {
    margin: 20px auto 0;
  }
  #facility .facilityWrap {
    margin: 30px auto;
    gap: 10px;
  }
  #facility .facilityBox {
    padding: 10px;
    border: 1px solid var(--green);
    width: calc((100% - 10px) / 2);
  }
  #facility .facilityBox h3 {
    font-size: 1.6rem;
  }
  #facility .txtNote {
    width: calc((100% - 40px) / 2);
    font-size: 1rem;
  }
  #facility .btnMore a {
    max-width: 240px;
  }
}

/* works
-------------------------------------------------------------- */
#works {
  margin: 80px auto 20px;
  max-width: 1000px;
}
#works .worksBox {
  margin: 50px 0 30px;
  gap: 20px;
}
#works .worksBox .main {
  width: calc(50% - 20px);
}
#works .worksBox .txtArea {
  padding-left: 20px;
  width: 50%;
}
#works .worksBox .txtArea h3 {
  padding-bottom: 10px;
  font-size: 2.4rem;
  font-weight: 500;
}
#works .worksBox .txtArea p {
  line-height: 2;
}
#works .worksBox ul {
  gap: 20px;
}
#works .worksBox li {
  width: calc((100% - 80px) / 5);
  cursor: pointer;
}
#works .worksBox li:hover img,
#works .worksBox li img.active {
  outline: 3px solid var(--orange);
}
#works .linkArea {
  gap: 30px
}
#works .linkArea li {
  padding: 25px;
  width: calc((100% - 30px) / 2);
}
#works .linkArea li a {
  padding: 25px;
  justify-content: center;
  align-items: center;
  gap: 20px;
  color: var(--white);
}
#works .linkArea li span {
  font-size: 1.7rem;
}
#works .linkArea li:first-child {
  background: url(../img/concept/works_btn01_bg.jpg) no-repeat center / cover;
}
#works .linkArea li:last-child {
  background: url(../img/concept/works_btn02_bg.jpg) no-repeat center / cover;
}
#works .linkArea li:first-child a {
  background: var(--green);
}
#works .linkArea li:last-child a {
  background: #ec671f;
}
@media (max-width: 768px) {
  #works {
    margin: 40px auto 10px;
  }
  #works .worksBox {
    margin: 25px 0 15px;
    gap: 10px;
  }
  #works .worksBox .main {
    width: 100%;
  }
  #works .worksBox .txtArea {
    padding: 10px 0;
    width: 100%;
    order: 3;
  }
  #works .worksBox .txtArea h3 {
    font-size: 2rem;
  }
  #works .worksBox ul {
    gap: 5px;
  }
  #works .worksBox li {
    width: calc((100% - 20px) / 5);
    cursor: pointer;
  }
  #works .worksBox li:hover img,
  #works .worksBox li img.active {
    outline: 2px solid var(--orange);
  }
  #works .linkArea {
    gap: 20px
  }
  #works .linkArea li {
    padding: 15px;
    width: 100%;
  }
  #works .linkArea li a {
    padding: 15px;
    gap: 10px;
  }
  #works .linkArea li span {
    font-size: 1.4rem;
  }
}
