@charset "UTF-8";
/* =====================================================================
  トップ
===================================================================== */
/* mv */
/* .mv {
  height: 80rem;
}
@media screen and (max-width: 767px) {
  .mv {
    height: 71.3rem;
  }
} */
.mv {
  position: relative;
  transform: translate(0%, -15%);
}
.scrolldown {
  position:absolute;
  left: 50%;
  bottom: 19%;
  width: 100%;
  height: 6rem;
  transform: translateX(-50%);
}
.scrolldown span {
  position: absolute;
  bottom: 0;
  left: 50%;
  display: block;
  width: auto;
  color: var(--color-white);
  font-family: var(--font-en);
  font-weight: var(--medium);
  font-size: 1.7rem;
  letter-spacing: 0.05em;
  transform: translateX(-50%);
  line-height: 1;
}

.scrolldown a {
	color: #fff;
}

.scrolldown::after {
  position: absolute;
  top: 0;
  left: 50%;
  content: "";
  width: 0.2rem;
  height: 3rem;
  background: var(--color-white);
  border-radius: 1.5rem;
  transform: translateX(-50%);
  animation: pathmove 1.4s ease-in-out infinite;
  opacity:0;
}
@keyframes pathmove{
  0% {
    height: 0;
    top: 0;
    opacity: 0;
  }
  30% {
    height: 2rem;
    opacity: 1;
  }
  100% {
    height: 0;
    top: 4.5rem;
    opacity: 0;
  }
}
@media screen and (max-width: 767px) {
	
.mv {
  position: relative;
  transform: translate(0%, -18%);
}
	
  .scrolldown {
    bottom: 12.5rem;
  }
  .scrolldown span {
    font-size: 1rem;
  }
  .scrolldown::after {
    height: 2.2rem;
    width: 0.1rem;
  }
  @keyframes pathmove{
    0% {
      height: 0;
      top: 1.5rem;
      opacity: 0;
    }
    30% {
      height: 2rem;
      opacity: 1;
    }
    100% {
      height: 0;
      top: 4.5rem;
      opacity: 0;
    }
  }
}


/* lead */
#lead {
  overflow: hidden;
}
#lead .circleWrap {
  position: relative;
  max-width: 140rem;
  padding: 35.7rem 0 66rem;
  margin: 0 auto;
}
#lead p {
  margin-bottom: 6rem;
  font-size: 2rem;
  font-weight: var(--medium);
  line-height: 2.7;
  letter-spacing: 0.09em;
  text-align: center;
}
#lead p.large {
  margin: 10rem auto 0;
  font-size: 4.5rem;
  font-weight: var(--bold);
  letter-spacing: 0.35em;
}

#lead p.large span {
  margin-right: -4rem;
}

@media screen and (max-width: 767px) {
  /* .circle {
    display: none;
  } */
  #lead .circleWrap {
    padding-top: 23.4rem;
    padding-bottom: 34rem;
  }
  #lead p {
    margin-bottom: 6.8rem;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    line-height: 2.5;
  }
  #lead p.large {
    margin-top: 21.4rem;
    font-size: 2.9rem;
    letter-spacing: 0.15em;
    line-height: 1.79;
  }
  
  #lead p.large span {
	  margin-right: -3rem;
	}
}

/* products */
#products {
  overflow: hidden;
  padding-top: 5rem;
}
#products .in {
  position: relative;
  width: 110rem;
  margin: 0 auto;
}
#products .in .flex {
  position: relative;
  display: flex;
  justify-content: space-between;
}
#products .in .flex:nth-of-type(odd) {
  padding-bottom: 44.5rem;
  align-items: flex-start;
}
#products .in .flex:nth-of-type(even) {
  align-items: flex-end;
  flex-direction: row-reverse;
}
#products .in .flex .txtWrap {
  width: 40rem;
}
#products .in .flex .txtWrap .lead {
  margin-top: 11rem;
  font-size: 1.8rem;
  font-weight: var(--medium);
  letter-spacing: 0.15em;
}
#products .in .flex:nth-of-type(odd) .lead {
  margin-right: -10rem;
}
#products .in .flex:nth-of-type(even) .lead {
  margin-left: -10rem;
  text-align: right;
}
#products .in .flex .txtWrap .txt {
  margin-top: 2.1rem;
  font-size: 1.6rem;
  letter-spacing: 0.03em;
  font-weight: var(--regular);
}
#products .in .flex .imgWrap {
  position: relative;
  width: 70rem;
  height: 70rem;
  overflow: hidden;
}
#products .in .flex .imgWrap img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#products .in .flex:nth-of-type(odd) .imgWrap {
  margin-right: -15rem;
  margin-left: auto;
}
#products .in .flex:nth-of-type(even) .imgWrap {
  margin-left: -15rem;
}
#products .in .flex .imgPos {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 100%;
  height: 44.6rem;
  transform: translateX(-50%);
}
#products .in .flex .imgPos picture {
  position: absolute;
  display: block;
  overflow: hidden;
}
#products .in .flex .imgPos picture:first-of-type {
  left: 8.5rem;
  top: -13.5rem;
  width: 44.6rem;
  height: 42rem;
}
#products .in .flex .imgPos picture:last-of-type {
  /*bottom: -6.9rem;*/
  bottom: 0;
  right: 0;
  /*
  right: -3.7rem;
  */
  width: 31.6rem;
  height: 33.6rem;
}
#products .in .flex .imgPos picture img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (max-width: 767px) {
  #products {
    padding-top: 0;
  }
  #products .in {
    width: auto;
    margin: 0 3rem;
  }
  #products .in .flex {
    flex-direction: column-reverse !important;
  }
  #products .in .flex .txtWrap {
    width: 100%;
  }
  #products .in .flex .imgWrap {
    width: 100%;
    margin-bottom: 4.2rem;
  }
  #products .in .flex:nth-of-type(odd) {
    padding-bottom: 21.4rem;
  }
  #products .in .flex:nth-of-type(odd) .imgWrap {
    margin: 0 -3rem 39.7rem auto;
    height: 32.5rem;
    width: 32.5rem;
  }
  #products .in .flex:nth-of-type(even) .imgWrap {
    margin: 0;
    margin-bottom: 4.2rem;
    height: 31.5rem;
  }
  #products .in .flex .imgPos {
    width: 37.5rem;
    height: 33.6rem;
    bottom: auto;
    top: 35rem;
  }
  #products .in .flex .imgPos picture:first-of-type {
    width: 23.8rem;
    height: 22.4rem;
    top: 0;
    left: -4rem;
  }
  #products .in .flex .imgPos picture:last-of-type {
    width: 16.5rem;
    height: 17.4rem;
    right: 0;
    bottom: 0;
  }
  #products .in .flex .txtWrap .lead {
    margin: 2.9rem 0 0 !important;
    font-size: 1.7rem;
    letter-spacing: 0.1em;
    text-align: left;
  }
  #products .in .flex .txtWrap .txt {
    margin-top: 1.5rem;
    line-height: 1.875;
  }
}

/* news */
#news {
  padding-top: 5.4rem;
  margin-top: -5.4rem;
  overflow: hidden;
}
#news .circleWrap {
  position: relative;
  max-width: 140rem;
  margin: 0 auto;
  padding-top: 64rem;
}
#news .in {
  width: 110rem;
  margin: 0 auto;
}
#news .in .list {
  margin-top: 2.8rem;
}
#news .in .list li a {
  position: relative;
  display: flex;
  align-items: center;
  padding: 4.25rem 0;
  color: #969696;
  font-size: 1.7rem;
  letter-spacing: 0.05em;
  overflow: clip;
}
#news .in .list li a::before,
#news .in .list li a::after {
  position: absolute;
  left: 0;
  bottom: 0;
  content: "";
  width: 100%;
  height: 1px;
  background: #D0D1D3;
}
#news .in .list li a::after {
  transform: translateX(-100%) rotate(.0001deg);
}
#news .in .list li a::before {
  transform: rotate(.0001deg);
}
#news .in .list li a:hover::before {
  transform: translate3d(100%,0,0) rotate(.0001deg);
  transition: transform 1.1s cubic-bezier(.55,0,.275,1);
}
#news .in .list li a:hover::after {
  transform: translateZ(0) rotate(.0001deg);
  transition: transform 1.1s cubic-bezier(.55,0,.275,1) .15s;
}
#news .in .list li a div {
  width: 21.8rem;
  font-family: var(--font-en);
}
#news .in .list li a time {
  width: 21.4rem;
  font-family: var(--font-en);
  font-weight: var(--medium);
}
#news .in .list li a span {
  padding-right: 1.1rem;
  font-weight: var(--bold);
  white-space: nowrap;
}
#news .in .list li a p {
  width: 68.9rem;
  font-weight: var(--regular);
  color: #1E1E1E;
}
#news .in .moreLink {
  margin-top: 4.7rem;
}
@media screen and (max-width: 767px) {
  #news .circleWrap {
    width: auto;
    padding-top: 18.4rem;
    margin: 0 3rem;
  }
  #news .in {
    width: auto;
  }
  #news .in .list {
    margin-top: 0.8rem;
  }
  #news .in .list li a {
    padding: 4rem 0;
    flex-wrap: wrap;
    font-size: 1.4rem;
  }
  #news .in .list li a p {
    width: 100%;
    margin-top: 1.5rem;
    font-size: 1.6rem;
  }
  #news .in .list li a time {
    width: 12rem;
    line-height: 1;
  }
  #news .in .list li a div {
    width: 19.5rem;
  }
  #news .in .list li a span {
    line-height: 1;
  }
}

/* imgBg */
.imgBg {
  position: relative;
  width: 100%;
  height: 67.4rem;
  margin-top: 14.5rem;
  overflow: hidden;
}
.imgBg img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (max-width: 767px) {
  .imgBg {
    /* ニュース追加時適応 */
    /* margin-top: 13.8rem; */
    margin-top: 0;
    height: 50rem;
  }
}

/* counseling */
#counseling .circleWrap {
  position: relative;
  padding: 32.4rem 0 33.8rem;
  max-width: 140rem;
  margin: 0 auto;
}
#counseling {
  overflow: hidden;
}
#counseling .in {
  width: 110rem;
  margin: 0 auto;
}
#counseling .in .flex {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-right: -15rem;
}
#counseling .in .flex .txtWrap {
  width: 38.4rem;
}
#counseling .in .flex .txtWrap .txt {
  margin-top: 4.2rem;
  font-size: 1.6rem;
  letter-spacing: 0.03em;
  font-weight: var(--regular);
}
#counseling .in .flex .imgWrap {
  position: relative;
  width: 80rem;
  height: 45rem;
  overflow: hidden;
}
#counseling .in .flex .imgWrap img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#counseling .in .flex .imgWrap::before,
#counseling .in .flex .imgWrap::after {
  position: absolute;
  left: 50%;
  top: 50%;
  content: "";
  display: block;
  transform: translate(-50%, -50%);
  z-index: 1;
  transition: .5s;
}
#counseling .in .flex .imgWrap::before {
  width: 10rem;
  height: 10rem;
  border-radius: 100%;
  background: var(--color-blue);
}
#counseling .in .flex .imgWrap::after {
  width: 0;
  height: 0;
  left: 50.2%;
  border-style: solid;
  border-width: 1rem 0 1rem 1.5rem;
  border-color: transparent transparent transparent var(--color-white);
}
#counseling .in .flex .imgWrap:hover {
  opacity: 1;
}
#counseling .in .flex .imgWrap:hover::before {
  background: var(--color-white);
}
#counseling .in .flex .imgWrap:hover::after {
  border-color: transparent transparent transparent var(--color-blue);
}
#counseling .in .btn {
  margin-top: 4.8rem;
}
@media screen and (max-width: 767px) {
  #counseling .circleWrap {
    padding: 17.3rem 0 17.7rem;
  }
  #counseling .in {
    width: auto;
    margin: 0 3rem;
  }
  #counseling .in .flex {
    flex-direction: column-reverse;
    margin: 0;
  }
  #counseling .in .flex .txtWrap {
    width: auto;
    margin-top: 3.8rem;
  }
  #counseling .in .flex .imgWrap {
    width: 100%;
    height: 17.7rem;
  }
  #counseling .in .flex .txtWrap .txt {
    margin-top: 2.4rem;
    letter-spacing: 0;
  }
  #counseling .in .btn {
    margin-top: 3.79rem;
  }
  #counseling .in .flex .imgWrap::before {
    width: 6rem;
    height: 6rem;
  }
  #counseling .in .flex .imgWrap::after {
    left: 50.7%;
    border-width: 0.8rem 0 0.8rem 1.1rem;
  }
}


/* circle */
.circle span {
  display: block;
  width: 10rem;
  height: 10rem;
  margin-bottom: 1rem;
  background: var(--color-blue);
  border-radius: 100%;
}
.circle .in {
  position: absolute;  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  z-index: -1;
}
.circle span.circleAnime {
  opacity: 0;
}
.circle span.active {
  animation: circle 1s .07s ease-out forwards;
}
/* lead */
#lead .circle .in:nth-of-type(1) {
  top: 12rem;
  left: 21rem;
  width: 21rem;
}
#lead .circle .in:nth-of-type(1) span:nth-of-type(odd) {
  margin-left: 11.1rem;
}
#lead .circle .in:nth-of-type(1) span:last-of-type {
  margin-top: 12rem;
}
#lead .circle .in:nth-of-type(2) {
  top: 34.2rem ;
  right: -1.1rem;
  width: 32rem;
}
#lead .circle .in:nth-of-type(2) span:first-of-type {
  margin-bottom: 11.6rem;
  margin-right: 22rem;
}
#lead .circle .in:nth-of-type(2) span:nth-of-type(2) {
  margin: 0 11.1rem 1rem;
}
#lead .circle .in:nth-of-type(2) span:nth-of-type(6),
#lead .circle .in:nth-of-type(2) span:nth-of-type(9) {
  margin-left: 22rem;
}
#lead .circle .in:nth-of-type(2) span:nth-of-type(7) {
  margin-bottom: 12rem;
  margin-right: 22rem;
}
#lead .circle .in:nth-of-type(3) {
  bottom: 49.8rem ;
  left: -1.1rem;
  width: 32.2rem;
}
#lead .circle .in:nth-of-type(3) span:nth-of-type(2) {
  margin-left: 11rem;
}
#lead .circle .in:nth-of-type(3) span:nth-of-type(4),
#lead .circle .in:nth-of-type(3) span:nth-of-type(6) {
  margin-right: 11rem;
}

#lead .circle .in:nth-of-type(4) {
  bottom: 16.8rem ;
  right: -1.1rem;
  width: 43rem;
}
#lead .circle .in:nth-of-type(4) span:nth-of-type(1) {
  margin-right: 11rem;
}
#lead .circle .in:nth-of-type(4) span:nth-of-type(4) {
  margin-left: 11rem
}
#lead .circle .in:nth-of-type(4) span:nth-of-type(5) {
  margin-right: 11rem
}


/* news */
#news .circle .in:nth-of-type(1) {
  top: -5.4rem;
  left: -1.1rem;
  width: 32rem;
}
#news .circle .in:nth-of-type(1) span:nth-of-type(1),
#news .circle .in:nth-of-type(1) span:nth-of-type(4) {
  margin-right: 11rem;
}
#news .circle .in:nth-of-type(1) span:nth-of-type(8) {
  margin-right: 22rem;
}
#news .circle .in:nth-of-type(1) span:nth-of-type(9) {
  margin-left: 11rem;
}
#news .circle .in:nth-of-type(2) {
  top: 17.6rem;
  left: 43.1rem;
  width: 64.6rem;
}
#news .circle .in:nth-of-type(2) span:nth-of-type(2) {
  margin-left: 43.6rem;
}
#news .circle .in:nth-of-type(2) span:nth-of-type(3) {
  margin-left: 22rem;
}
#news .circle .in:nth-of-type(2) span:nth-of-type(4) {
  margin-right: 21.7rem;
}
#news .circle .in:nth-of-type(2) span:nth-of-type(5) {
  margin-left: 11rem;
}
#news .circle .in:nth-of-type(2) span:nth-of-type(6) {
  margin-right: 32.6rem;
}
#news .circle .in:nth-of-type(3) {
  top: 28.5rem;
  right: -1.1rem;
  width: 32rem;
}
#news .circle .in:nth-of-type(3) span:nth-of-type(1),
#news .circle .in:nth-of-type(3) span:nth-of-type(5),
#news .circle .in:nth-of-type(3) span:nth-of-type(6),
#news .circle .in:nth-of-type(3) span:nth-of-type(7) {
  margin-left: 22rem;
}
#news .circle .in:nth-of-type(3) span:nth-of-type(2) {
  margin: 0 11.1rem 1rem;
}
#news .circle .in:nth-of-type(3) span:nth-of-type(4) {
  margin-right: 11rem;
}
#news .circle .in:nth-of-type(3) span:nth-of-type(5) {
  margin-bottom: 12rem;
}

/* products */
#products .circle {
  position: absolute;
  top: 0;
  right: -15rem;
  width: 70rem;
  height: 70rem;
}
#products .circle .in {
  top: -5rem;
  left: -5rem;
  z-index: 0;
}

/* counseling */
#counseling .circle .in:nth-of-type(1) {
  width: 10rem;
  height: 10rem;
  left: 54rem;
  top: 20.4rem;
}
#counseling .circle .in:nth-of-type(2) {
  width: 21rem;
  right: 8rem;
  bottom: 17rem;
}
#counseling .circle .in:nth-of-type(2) span:nth-of-type(1) {
  margin-left: 11rem;
} 
#counseling .circle .in:nth-of-type(3) {
  width: 31.6rem;
  right: 32.3rem;
  bottom: -6.2rem;
}
@media screen and (max-width: 767px) {
  .circle span {
    width: 6rem;
    height: 6rem;
    margin-bottom: 0.5rem;
  }
  /* lead */
  #lead .circle .in:nth-of-type(1) {
    top: 0;
    left: auto; 
    right: -3.9rem;
    width: 19rem; 
  }
  #lead .circle .in:nth-of-type(1) span:nth-of-type(1) {
    margin: 0 7rem 0.5rem 0;
  }
  #lead .circle .in:nth-of-type(1) span:nth-of-type(3) {
    margin: 0 6.5rem 0.5rem;
  }
  #lead .circle .in:nth-of-type(1) span:nth-of-type(4) {
    margin-left: 6.5rem;
  }
  #lead .circle .in:nth-of-type(1) span:nth-of-type(5) {
    margin: 0
  }
  #lead .circle .in:nth-of-type(2) {
    width: 12.5rem;
    top: 40.3rem;
    left: -3.8rem;
    right: auto;
  }
  #lead .circle .in:nth-of-type(2) span:nth-of-type(1),
  #lead .circle .in:nth-of-type(2) span:nth-of-type(2) {
    margin: 0 6.5rem 0.5rem 0;
  }
  #lead .circle .in:nth-of-type(2) span:nth-of-type(3) {
    margin: 33.3rem 0 0 6.5rem;
  } 
  #lead .circle .in:nth-of-type(3) {
    width: 12.5rem;
    top: 73.6rem;
    bottom: auto;
    left: auto;
    right: -3.9rem;
  }
  #lead .circle .in:nth-of-type(3) span:nth-of-type(1),
  #lead .circle .in:nth-of-type(3) span:nth-of-type(2),
  #lead .circle .in:nth-of-type(3) span:nth-of-type(3) {
    margin: 0 0 0.5rem 6.5rem;
  }
  #lead .circle .in:nth-of-type(3) span:nth-of-type(4) {
    margin: 7.6rem 6.5rem 0 0;
  }
  #lead .circle .in:nth-of-type(4) {
    width: 45.2rem;
    right: -3.9rem;
    bottom: 8.8rem;
  }
  #lead .circle .in:nth-of-type(4) span:nth-of-type(1) {
    margin-right: 39rem;
  }
  #lead .circle .in:nth-of-type(4) span:nth-of-type(3) {
    margin: 0 32.6rem 0.5rem 0.5rem;
  }
  #lead .circle .in:nth-of-type(4) span:nth-of-type(4) {
    margin: 0 6.5rem 0.5rem 32.6rem;
  }
  #lead .circle .in:nth-of-type(4) span:nth-of-type(5),
  #lead .circle .in:nth-of-type(4) span:nth-of-type(6) {
    margin: 0 0 0.5rem 39rem;
  }
  #lead .circle .in:nth-of-type(4) span:nth-of-type(7) {
    margin: 5rem 0 0.5rem 6.5rem;
  }
  #lead .circle .in:nth-of-type(4) span:nth-of-type(8) {
    margin: 5rem 6.5rem 0.5rem 20.1rem;
  }
  #lead .circle .in:nth-of-type(4) span:nth-of-type(9) {
    margin-left: 6.5rem;
  } 
  #lead .circle .in:nth-of-type(4) span:nth-of-type(10) {
    margin-right: 26rem;
  }

  #news .circle,
  #counseling .circle {
    display: none;
  }
}