@charset "UTF-8";

@media (max-width: 767px) {

}

@media (min-width: 768px) and (max-width: 1260px) {

  .inner__wrap {
    width: 88%;
  }

}

/* -----------------------------------------------
mv
----------------------------------------------- */
.mv__wrap {
  position: relative;
}
.mv__wrap::after {
  content: "";
  background: url(../images/top/top_mv_mask.svg) 50% 100% / contain no-repeat;
  display: block;
  position: absolute;
  bottom: -1px;
}
.mv__inner .mv__cap {
  color: #fff;
}
.mv__inner .mv__cap h1 {
  font-weight: normal;
}

@media (max-width: 767px) {
  .mv__wrap {
    aspect-ratio: 750 / 1200;
    background: url(../images/top/mv_sp.jpg) 50% 0 / cover no-repeat;
    width: 100%;
    height: auto;
  }
  .mv__wrap::after {
    aspect-ratio: 990 / 55;
    width: auto;
    left: -107%;
    height: 65px;
  }
  .mv__inner {
    display: flex;
    align-items: flex-start;
    width: 84%;
    height: 100%;
    margin: 0 auto;
  }
  .mv__inner .mv__cap {
    margin-top: 88.5%;
  }
  .mv__inner .mv__cap h1 {
    /* font-size: var(--fs-30); */
    font-size: min(calc(var(--vw) * 30px),30px);
    letter-spacing: .05em;
    margin-bottom: 0.62em;
    line-height: 1.66;
    text-shadow: 0px 0px 10px rgba(0,0,0,1);
  }
  .mv__inner .mv__cap p {
    /* font-size: var(--fs-14); */
    font-size: min(calc(var(--vw) * 14px),14px);
    line-height: 2.285;
    text-shadow: 0px 0px 10px rgba(0,0,0,1);
  }

  
}
@media (min-width: 768px) {
  .mv__wrap {
    aspect-ratio: 1440 / 760;
    background: url(../images/top/mv_pc.jpg) 50% 0 / cover no-repeat;
    width: 100%;
    height: auto;
  }
  .mv__wrap::after {
    aspect-ratio: 1886 / 103;
    width: 130.97%;
    left: -14%;
  }
  .mv__inner {
    display: flex;
    align-items: flex-start;
    width: 91.12%;
    height: 100%;
    margin: 0 auto;
  }
  .mv__inner .mv__cap {
    margin-top: 33.5%;
  }
  .mv__inner .mv__cap h1 {
    font-size: 48px;
    letter-spacing: .1em;
    margin-bottom: 0.62em;
  }
  .mv__inner .mv__cap p {
    font-size: 16px;
    line-height: 1.75;
  }

}



/* -----------------------------------------------
head__icon
----------------------------------------------- */
.inner__wrap:has(.head__icon) {
  position: relative;
}
.head__icon {
  background-image: url(../images/common/icon_head.svg);
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-color: #fff;
  font-weight: normal;
  writing-mode: vertical-rl;
}

@media (max-width: 767px) {
  .head__icon {
    background-position: 50% 5%;
    background-size: 1.25em auto;
    /* font-size: var(--fs-20); */
    font-size: min(calc(var(--vw) * 20px),20px);
    letter-spacing: .4em;
    line-height: 2em;
    width: 2em;
    padding: 2.5em 0 .20em;
  }

}
@media (min-width: 768px) {
  .head__icon {
    background-position: 50% 60px;
    font-size: 20px;
    letter-spacing: .5em;
    line-height: 84px;
    width: 84px;
    padding: 140px 0 50px;
  }
  .inner__wrap .head__icon {
    position: absolute;
    top: 0;
  }
  .head__icon.__rg {
    left: calc(100% - 20px);
  }
  .head__icon.__lf {
    right: calc(100% - 20px);
  }
}



/* -----------------------------------------------
about
----------------------------------------------- */
.about__wrap {}
.about__wrap h3 {
  font-weight: normal;
}

@media (max-width: 767px) {
  .about__wrap {
      padding-block: 14px 100px;
  }
  .about__inner {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .about__wrap .about__box {
    width: 77.78%;
    padding-block: 42px 123px;
  }
  .about__wrap h3 {
    /* font-size: var(--fs-26); */
    font-size: min(calc(var(--vw) * 26px),26px);
    margin-bottom: 10% ;
    letter-spacing: 0.02em;
    line-height: 1.76;
  }
  .about__wrap p {
    /* font-size: min(3.73vw, 14px); */
    font-size: min(calc(var(--vw) * 14px),14px);
    line-height: 2.14;
    letter-spacing: .12em;
  }
  .about__swiper {
    transform: translateX(26%);
    overflow: visible;
  }
  .about__swiper .swiper-slide.is-odd {
    margin-top: 45px;
  }

}
@media (min-width: 768px) {
  .about__wrap {
    padding-block: 140px 208px;
  }
  .about__wrap .about__inner {
    padding-block: 66px 182px;
  }
  .about__wrap h3 {
    font-size: 32px;
    margin-bottom: 28px;
    margin-left: 8.2%;
    letter-spacing: 0.1em;
  }
  .about__wrap p {
    font-size: 16px;
    line-height: 2.5;
    margin-left: 8.2%;
  }
  .about__swiper .swiper-slide.is-odd {
    margin-top: 50px;
  }

}



/* -----------------------------------------------
business
----------------------------------------------- */
.business__wrap {
  background: #FBFAF5;
}
.business__img {
  overflow: hidden;
}
.business__cap h3 {
  font-weight: normal;
}

@media (max-width: 767px) {

  .business__wrap .head__icon {
    position: absolute;
    top: 0;
    right: 0;
  }
  .business__fx__wrap {
    padding-block: 20% 22%;
  }
  .business__img {
    border-radius: 16px;
  }
  .business__fx {
	display: flex;
	flex-direction: column-reverse;
	justify-content: flex-end;
	align-items: stretch;  }
  .business__fx.rev:after {
    content: "";
    position: absolute;
    top: 100%;
    left: calc(50% - 25px);
    width: 50px;
    height: 2px;
    background: #222;
  }
  .business__fx.rev {
    padding-bottom: 17%;
    margin-bottom: 17%;
    position: relative;
  }
  .business__img {
    border-radius: 16px;
  }
  .business__cap {
    margin-bottom: 15%;
  }
  .business__cap h3 {
    /* font-size: var(--fs-26); */
    font-size: min(calc(var(--vw) * 26px),26px);
    line-height: 1.92;
    margin-bottom: 9.8%;
  }
  .business__cap p {
    font-size: min(calc(var(--vw) * 14px),14px);
    line-height: 2.14;
    margin-bottom: 11%;
  }
  .business__wrap .more__btn {
    text-align: left;
  }
}
@media (min-width: 768px) {

  .business__fx__wrap {
    padding-block: 130px;
  }
  .business__fx {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding-inline: 55px;
  }
  .business__fx.rev:after {
    content: "";
    position: absolute;
    top: 100%;
    left: calc(50% - 55px);
    width: 110px;
    height: 2px;
    background: #222;
  }
  .business__fx.rev {
    flex-direction: row-reverse;
    padding-bottom: 100px;
    margin-bottom: 100px;
    position: relative;
  }
  .business__img {
    border-radius: 23px;
    width: 57.58%;
    max-width: 570px;
  }
  .business__cap {
    width: 37.38%;
    max-width: 370px;
    padding-top: 4.2%;
  }
  .business__cap h3 {
    font-size: 30px;
    margin-bottom: 28px;
  }
  .business__cap p {
    font-size: 16px;
    line-height: 2.5;
    margin-bottom: 35px;
  }
  .business__wrap .more__btn {
    text-align: right;
  }

}



/* -----------------------------------------------
example
----------------------------------------------- */
.example__wrap {}
.example__swiper__wrap .example__controller__wrap {
  position: relative;
}
.example__wrap .example__swiper {
  margin-inline: auto;
}
.example__swiper .swiper-button-prev {
  right: calc(100% + 3.2rem);
}
.example__swiper .swiper-button-next {
  left: calc(100% + 3.2rem);
}
.swiper-pagination-bullet-active {
  background: #3A7322;
}
.example__prev:after,
.example__next:after {
  font-size: 0;
  background-repeat: no-repeat;
  background-position: 50% 0;
  width: 26px;
  height: auto;
  aspect-ratio: 1 / 1;
}
.example__prev:after {
  background-image: url(../images/common/icon_arrow_lf.svg);
}
.example__next:after {
  background-image: url(../images/common/icon_arrow_rg.svg);
}

.example__swiper .swiper-slide picture {
  overflow: hidden;
}
.example__swiper a {}
.example__swiper .example__cap {}
.example__cap {}
.example__cap time.date {}
.example__cap span.cat {
  background: #222;
  color: #fff;
  border-radius: 50vh;
  display: inline-block;
}
.example__cap p {}

@media (max-width: 767px) {

  .example__wrap {
    padding-block: 94px 100px;
  }
  .example__inner {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .example__inner .example__box {
    width: 74.61%;
  }
  .example__swiper {
    overflow: visible;
  }
  .example__swiper .swiper-wrapper {
    display: block;
    transform: none !important;
  }
  .example__swiper .swiper-slide {
    width: 100% !important;
    margin: 0 0 18%;
  }
  .example__swiper .swiper-slide:nth-child(n+4) {
    display: none;
  }
  .example__swiper .swiper-slide:nth-child(3) {
    margin-bottom: 12.4%;
  }
  .example__swiper__wrap .swiper-pagination,
  .example__swiper__wrap .swiper-button-next,
  .example__swiper__wrap .swiper-button-prev {
    display: none;
  }
  .example__swiper .swiper-slide picture {
    border-radius: 10px;
    margin-bottom: 7%;
  }
  .example__cap time.date {
    /* font-size: var(--fs-15); */
    font-size: min(calc(var(--vw) * 15px),15px);
  }
  .example__cap span.cat {
    /* font-size: var(--fs-12); */
    font-size: min(calc(var(--vw) * 12px),12px);
    line-height: 1.42;
    padding-inline: 1.15em;
    margin-left: .8em;
  }
  .example__cap p {
    font-size: min(calc(var(--vw) * 14px),14px);
    line-height: 2;
    margin-top: 4%;
  }

}
@media (min-width: 768px) {
  .example__wrap {
    padding-bottom: 120px;
  }
  .example__swiper__wrap {
    min-height: 274px;
    padding-block: 124px 88px;
  }
  .example__swiper {
    max-width: 940px;
  }
  .swiper-controller {
    position: absolute;
    top: 0;
    left: 50%;
    width: 100%;
    padding-top: 19.2%;
    max-width: 940px;
    transform: translateX(-50%);
  }
  .example__prev {
    left: auto;
    right: calc(100% + 26px);
  }
  .example__next {
    right: auto;
    left: calc(100% + 26px);
  }
  .example__pagination {
    bottom: -14% !important;
    top: auto !important;
  }
  .example__swiper .swiper-slide picture {
    border-radius: 10px;
    margin-bottom: 28px;
  }
  .example__cap time.date {
    font-size: 18px;
  }
  .example__cap span.cat {
    font-size: 14px;
    line-height: 20px;
    padding-inline: 1.15em;
  }
  .example__cap p {
    font-size: 16px;
    line-height: 1.75;
    margin-top: 14px;
  }

}



/* -----------------------------------------------
notice
----------------------------------------------- */
.notice__wrap {
  background: #F0F5E1;
}
.notice__list__wrap {
  margin-inline: auto;
}
.notice__list li {
  border-bottom: 1px solid #97A791;
}

@media (max-width: 767px) {
  .notice__wrap {
    padding-bottom: 70px;
  }
  .notice__inner {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-direction: row-reverse;
  }
  .notice__box {
    width: 74.61%;
    padding-top: 40px; 
  }
  .notice__box .notice__list {
    margin-bottom: 42px;
  }
  .notice__list li {
    margin-bottom: 10px;
  }
  .notice__list li a {
    padding-block: 10px;
    display: block;
  }
  .notice__list li a time {
    /* font-size: var(--fs-16); */
    font-size: min(calc(var(--vw) * 16px),16px);
    display: block;
    margin-bottom: 2%;
  }
  .notice__list li p {
    font-size: min(calc(var(--vw) * 14px),14px);
    line-height: 2.14;
  }

}
@media (min-width: 768px) {
  .notice__wrap {
    padding-bottom: 70px;
  }
  .notice__list__wrap {
    padding-block: 124px 30px;
    max-width: 1000px;
    min-height: 310px;
  }
  .notice__list li {
    margin-bottom: 18px;
  }
  .notice__list li a {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    padding-block: 18px 17px;
    font-size: 16px;
  }
  .notice__list li a time {
    margin-right: 44px;
  }

}
