@charset "UTF-8";

@media (max-width: 1400px) and (min-width: 768px) {
  html {
    font-size: calc(10 * (100vw / 1400));
  }
}

/*******************************
FR240319color
*******************************/
#FR240319color{
  display: block;
  width: 100%;
  padding: 0 0 14rem;
  border-bottom: 1px solid #000000;
  box-sizing: border-box;
  overflow: hidden;
  font-family: ryo-display-plusn, serif;
  font-weight: 500;
  font-style: normal;
}

#FR240319color *{box-sizing: border-box;}

#FR240319color picture,
#FR240319color figure,
#FR240319color img{
  display: block;
  width: 100%;
  height: auto;
}

#FR240319color .imgOuter > a{display: block; width: 100%; height: auto;}

#FR240319color a{
  transition: opacity .3s;
}

#FR240319color a:hover{
  opacity: .6;
}


/*******************************
fadeInSetting
*******************************/
#FR240319color .fadeInBlock:not(.fadeSP),
#FR240319color .fadeInList:not(.fadeSP) .fadeInTarget{
  visibility: hidden;
  opacity: 0;
  transform: translateY(2.5rem);
  transition: opacity 0.8s ease 0.2s, transform 0.8s ease 0.2s;
  pointer-events: none;
}


#FR240319color .fadeInBlock:not(.fadeSP).leftIn,
#FR240319color .fadeInList:not(.fadeSP).leftIn .fadeInTarget{
  transform: translateX(-20%);
}

#FR240319color .fadeInBlock:not(.fadeSP).rightIn,
#FR240319color .fadeInList.rightIn .fadeInTarget{
  transform: translateX(20%);
}

#FR240319color .fadeInBlock:not(.fadeSP).upIn,
#FR240319color .fadeInList:not(.fadeSP).upIn .fadeInTarget{
  transform: translateY(3%);
}

#FR240319color .fadeInBlock:not(.fadeSP).downIn,
#FR240319color .fadeInList:not(.fadeSP).downIn .fadeInTarget{
  transform: translateY(-20%);
}

#FR240319color .fadeInBlock:not(.fadeSP).panel,
#FR240319color .fadeInList:not(.fadeSP).panel .fadeInTarget{
  visibility: visible;
  transform-style: preserve-3d;
  transform: rotateY(180deg);
  opacity: 1;
}

#FR240319color .fadeInBlock:not(.fadeSP).view,
#FR240319color .fadeInList:not(.fadeSP) .fadeInTarget.view{
  visibility: visible;
  opacity: 1;
  transform: translate(0, 0) rotateY(0);
  pointer-events: inherit;
}

#FR240319color a.fadeInBlock.view:hover{
  opacity: .7;
}



/*******************************
mv
*******************************/
#FR240319color .mv{
  display: block;
  width: 120rem;
  margin: 0 auto 6.4rem;
  position: relative;
}

/*******************************
firstLede
*******************************/
#FR240319color .firstLede{
  display: block;
  width: 100%;
  margin-bottom: 10rem;
}
#FR240319color .firstLede > p{
  margin-top: calc((-1em * 2 + 1em) / 2);
  margin-bottom: calc((-1em * 2 + 1em) / 2);
  font-size: 1.4rem;
  line-height: 2;
  letter-spacing: 0.16em;
  text-align: center;
  font-weight: 500;
  font-feature-settings: "palt";
  color: #58595B;
  
}

/*******************************
creditLinks
*******************************/
#FR240319color .creditLinks{
  display: block;
  margin-top: calc((-1em * 1.75 + 1em) / 2);
  margin-bottom: calc((-1em * 1.75 + 1em) / 2);
  font-family: "big-caslon-fb", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.2rem;
  line-height: 1.75;
  letter-spacing: 0.045em;
}

#FR240319color .creditLinks >  a{
  display: inline-block;
  white-space: nowrap;
  color: #58595B;
  text-decoration: none;
}

#FR240319color .creditLinks > a:not(:nth-last-of-type(1))::after{
  content: ',';
}

#FR240319color .creditLinks > a + a,
#FR240319color .creditLinks > br.spView + a{
  margin-left: 0.004em;
}

/*******************************
lpSectionTTL
*******************************/
#FR240319color .lpSectionTTL{
  display: block;
  font-family: "big-caslon-fb", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 13.2rem;
  text-align: center;
  letter-spacing: 0.03em;
  line-height: 1;
  font-feature-settings: "palt";
  position: absolute;
  z-index: 3;
}

/*
#FR240319color .lpSectionTTL.fadeInBlock{
  transform: translateY(10%);
  transition: opacity 0.8s ease 0s, transform 0.8s ease 0s;
}
*/

#FR240319color .lpSectionTTL > span{
  display: block;
  font-size: 4.2rem;
  letter-spacing: 0.04em;
  position: absolute;
}

/*******************************
text
*******************************/
#FR240319color .text{
  display: block;
}

#FR240319color .text .catch{
  display: block;
  font-size: 2.0rem;
  line-height: 1.85;
  letter-spacing: 0.32rem;
  font-weight: 700;
  font-feature-settings: "palt";
  color: #000000;
}

#FR240319color .text .catch > p{
  margin-top: calc((-1em * 1.85 + 1em) / 2);
  margin-bottom: calc((-1em * 1.85 + 1em) / 2);
  font-weight: 700;
}

#FR240319color .text .lede{
  display: block;
  font-size: 1.3rem;
  line-height: 2;
  letter-spacing: 0.21rem;
  font-weight: 500;
  font-feature-settings: "palt";
  color: #58595B;
}

#FR240319color .text .lede > p{
  margin-top: calc((-1em * 2 + 1em) / 2);
  margin-bottom: calc((-1em * 2 + 1em) / 2);
}

/*******************************
sec01
*******************************/
#sec01{
  display: block;
  width: 140rem;
  margin: 0 auto 16rem;
  position: relative;
}

#FR240319color #sec01 .lpSectionTTL{
  color: #F3EFBC;
  left: 29.4rem;
  top: 32.5rem;
}

#FR240319color #sec01 .lpSectionTTL > span{
  left: 22.5rem;
  top: -0.7rem;
}

#sec01 .img01{
  display: block;
  width: 54rem;
  background: #FFFFFF;
  margin-left: 64.5rem;
  margin-bottom: 6rem;
}

#sec01 .img02{
  display: block;
  width: 42rem;
  background: #FFFFFF;
  position: absolute;
  z-index: 1;
  left: 27.5rem;
  top: 41rem;
}

#sec01 .img03{
  display: block;
  width: 38rem;
  background: #FFFFFF;
  margin-left: 75.5rem;
}

#sec01 .text{
  display: block;
  position: absolute;
  left: 27.5rem;
  top: 109.0rem;
  text-align: left;
  z-index: 1;
}

#FR240319color #sec01 .text .lede{
  padding-top: 3.1rem;
}

#FR240319color #sec01 .text .creditLinks{
  padding-top: 3.5rem;
}

/*******************************
sec02
*******************************/
#sec02{
  display: block;
  width: 140rem;
  margin: 0 auto 16rem;
  position: relative;
}

#FR240319color #sec02 .lpSectionTTL{
  color: #F3DBEE;
  left: 59.5rem;
  top: 97.9rem;
  letter-spacing: 0.025em;
}

#FR240319color #sec02 .lpSectionTTL > span{
  left: 8.7rem;
  top: -3.8rem;
}

#sec02 .img01{
  display: block;
  width: 58rem;
  background: #FFFFFF;
  margin-left: 52rem;
  margin-bottom: 17.9rem;
}

#sec02 .img02{
  display: block;
  width: 34rem;
  background: #FFFFFF;
  position: absolute;
  z-index: 1;
  left: 24rem;
  top: 20.4rem;
}

#sec02 .img03{
  display: block;
  width: 42rem;
  background: #FFFFFF;
  position: absolute;
  z-index: 1;
  left: 20rem;
  top: 77.4rem;
}

#sec02 .img04{
  display: block;
  width: 46rem;
  background: #FFFFFF;
  margin-left: 68rem;
}


#sec02 .text{
  display: block;
  position: absolute;
  left: 20.0rem;
  top: 145.4rem;
  text-align: left;
  z-index: 1;
}

#FR240319color #sec02 .text .lede{
  padding-top: 3.1rem;
}

#FR240319color #sec02 .text .creditLinks{
  padding-top: 3.5rem;
}

#FR240319color #sec02 .text .creditLinks a:nth-of-type(2){
  margin-left: 0.16em;
}

/*******************************
sec03
*******************************/
#sec03{
  display: block;
  width: 140rem;
  margin: 0 auto 15.7rem;
  position: relative;
}

#FR240319color #sec03 .lpSectionTTL{
  color: #D7D7D7;
  left: 22.1421rem;
  top: 10.2rem;
  font-size: 11.2rem;
  letter-spacing: 0.009em;
}


#FR240319color #sec03 .lpSectionTTL > span{
  left: 18.2rem;
  top: -3.5rem;
}

#sec03 .img01{
  display: block;
  width: 62rem;
  background: #FFFFFF;
  margin-left: 56.5rem;
  margin-bottom: 5rem;
}

#sec03 .img02{
  display: block;
  width: 44rem;
  background: #FFFFFF;
  position: absolute;
  z-index: 1;
  left: 21.5rem;
  top: 56rem;
}


#sec03 .text{
  display: block;
  margin-left: 70.5rem;
  padding-bottom: 4.95601rem;
  text-align: left;
}


#FR240319color #sec03 .text .lede{
  padding-top: 3rem;
}

#FR240319color #sec03 .text .creditLinks{
  padding-top: 3.6rem;
}

/*******************************
sec04
*******************************/
#sec04{
  display: block;
  width: 140rem;
  margin: 0 auto 13.9rem;
  position: relative;
}

#FR240319color #sec04 .lpSectionTTL{
  color: #B9CEE4;
  left: 38.6291rem;
  top: 116.4rem;
  letter-spacing: 0.01em;
}

#FR240319color #sec04 .lpSectionTTL > span{
  left: 14.88003rem;
  top: -0.9rem;
}

#sec04 .img01{
  display: block;
  width: 42rem;
  background: #FFFFFF;
  margin-left: 74.5rem;
  margin-bottom: 21.9rem;
}

#sec04 .img02{
  display: block;
  width: 52rem;
  background: #FFFFFF;
  position: absolute;
  z-index: 1;
  left: 22.5rem;
  top: 30.4rem;
}

#sec04 .img03{
  display: block;
  width: 55rem;
  background: #FFFFFF;
  margin-left: 61.5rem;
}


#sec04 .text{
  display: block;
  position: absolute;
  right: 83rem;
  top: 137.49014rem;
  text-align: right;
}


#FR240319color #sec04 .text .lede{
  padding-top: 3rem;
  padding-right: 0.2rem;
}

#FR240319color #sec04 .text .creditLinks{
  padding-top: 3.4rem;
  padding-right: 0.6rem;
}

/*******************************
allItemBtn
*******************************/
#FR240319color .allItemBtn{
  display: block;
  margin: 0 auto;
  padding: 0 0 14rem;
  text-align: center;
  position: relative;
}

#FR240319color .allItemBtn > a{
  display: inline-block;
  border-bottom: double medium #58595B;
  font-family: "big-caslon-fb", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2rem;
  text-align: center;
  line-height: 1;
  letter-spacing: 0.04em;
  color: #000000;
  padding-bottom: 0.8rem;
  font-feature-settings: "palt";
  position: relative;
}


/*******************************
allItemBtn
*******************************/
#FR240319color .lpStaffList{
  display: block;
  margin-top: calc((-1em * 1.75 + 1em) / 2);
  margin-bottom: calc((-1em * 1.75 + 1em) / 2);
  font-family: "big-caslon-fb", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.3rem;
  line-height: 1.75;
  letter-spacing: 0.047em;
  text-align: center;
  color: #58595B;
}

/*******************************
figSlider
*******************************/
#FR240319color .figSlider{
	overflow: hidden;
	position: relative;
}

#FR240319color .figSlider .container{
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  z-index: 1;
}

#FR240319color .figSlider .sliderWrapper{}

#FR240319color .figSlider .slider{
  display: block;
  width: 100%;
}

#FR240319color .figSlider .slider a{
  display: block;
  width: 100%;
  height: auto;
}

#FR240319color .figSlider .slider a > img{
  display: block;
  width: 100%;
  height: auto;
}

#FR240319color .figSlider .slider.swiper-slide-active{
  pointer-events: auto;
}

#FR240319color .figSlider ul.pager{
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0 1.2rem;
  padding-right: 1rem;
  padding-bottom: 1rem;
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 1;
}

#FR240319color .figSlider ul.pager > li{
  display: block;
  width: 0.6rem;
  height: 0.6rem;
  border-radius: 50%;
  margin: 0;
  border: 1px solid #000000;
  background-color: inherit;
  transition: background 0.3s ease;
  cursor: pointer;
  opacity: 1;
}

#FR240319color .figSlider ul.pager > li.swiper-pagination-bullet-active{
  background: #000000;
  pointer-events: none;
}

/*******************************
overRide
*******************************/
#FR240319color .spView{display: none;}











