@charset "UTF-8";

.archive{border-top: none!important;}

/*******************************
FR240319color
*******************************/
#FR240319color{
  display: block;
  width: 100%;
  padding: 0 0 calc(160 * (100vw / 750));
  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;}


/*******************************
fadeInSetting
*******************************/
#FR240319color .fadeInBlock:not(.fadePC),
#FR240319color .fadeInList:not(.fadePC) .fadeInTarget{
  visibility: hidden;
  opacity: 0;
  transform: translateY(calc(30 * (100vw / 750)));
  transition: opacity 0.8s ease 0.2s, transform 0.8s ease 0.2s;
  pointer-events: none;
}

#FR240319color .fadeInBlock:not(.fadePC).view,
#FR240319color .fadeInList:not(.fadePC) .fadeInTarget.view{
  visibility: visible;
  opacity: 1;
  transform: translate(0, 0) rotateY(0);
  pointer-events: inherit;
}

#FR240319color a.fadeInBlock.view:hover{
  opacity: 1;
}


/*******************************
mv
*******************************/
#FR240319color .mv{
  display: block;
  width: 100%;
  margin: 0 auto calc(120 * (100vw / 750));
  position: relative;
}

/*******************************
firstLede
*******************************/
#FR240319color .firstLede{
  display: block;
  width: 100%;
  margin-bottom: calc(264 * (100vw / 750));
}
#FR240319color .firstLede > p{
  margin-top: calc((-1em * 2 + 1em) / 2);
  margin-bottom: calc((-1em * 2 + 1em) / 2);
  font-size: calc(27 * (100vw / 750));
  line-height: 2;
  letter-spacing: 0.11em;
  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: calc(24 * (100vw / 750));
  line-height: 1.75;
  letter-spacing: 0.04em;
}

#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;
}

/*******************************
lpSectionTTL
*******************************/
#FR240319color .lpSectionTTL{
  display: block;
  font-family: "big-caslon-fb", serif;
  font-weight: 400;
  font-style: normal;
  font-size: calc(126 * (100vw / 750));
  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: calc(42 * (100vw / 750));
  letter-spacing: 0.04em;
  position: absolute;
}

/*******************************
text
*******************************/
#FR240319color .text{
  display: block;
}

#FR240319color .text .catch{
  display: block;
  font-size: calc(34 * (100vw / 750));
  line-height: 1.958823529411765;
  letter-spacing: 0.2rem;
  font-weight: 700;
  font-feature-settings: "palt";
  color: #000000;
}

#FR240319color .text .catch > p{
  margin-top: calc((-1em * 1.958823529411765 + 1em) / 2);
  margin-bottom: calc((-1em * 1.958823529411765 + 1em) / 2);
  font-weight: 700;
}

#FR240319color .text .lede{
  display: block;
  font-size: calc(26 * (100vw / 750));
  line-height: 2;
  letter-spacing: 0.12em;
  font-weight: 500;
  text-align: justify;
  line-break: strict;
  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: 100%;
  margin: 0 auto calc(194 * (100vw / 750));
  position: relative;
}

#FR240319color #sec01 .lpSectionTTL{
  color: #F3EFBC;
  left: calc(42*(100vw / 750));
  top: calc(-77*(100vw / 750));
  letter-spacing: 0.025em;
}

#FR240319color #sec01 .lpSectionTTL > span{
  left: calc(208*(100vw / 750));
  top: calc(-14*(100vw / 750));
}

#sec01 .img01{
  display: block;
  width: calc(640 * (100vw / 750));
  background: #FFFFFF;
  margin-right: 0;
  margin-left: auto;
  margin-bottom: calc(821.537 * (100vw / 750));
}

#sec01 .img02{
  display: block;
  width: calc(540 * (100vw / 750));
  background: #FFFFFF;
  position: absolute;
  z-index: 1;
  left: calc(40 * (100vw / 750));
  top: calc(910 * (100vw / 750));
}

#sec01 .img03{
  display: block;
  width: calc(520 * (100vw / 750));
  background: #FFFFFF;
  margin-left: calc(170 * (100vw / 750));
  margin-bottom: calc(70 * (100vw / 750));
}

#sec01 .text{
  display: block;
  width: calc(524 * (100vw / 750));
  margin-left: calc(170 * (100vw / 750));
  text-align: left;
  z-index: 1;
}

#FR240319color #sec01 .text .lede{
  padding-top: calc(54 * (100vw / 750));
}

#FR240319color #sec01 .text .creditLinks{
  padding-top: calc(51 * (100vw / 750));
}

/*******************************
sec02
*******************************/
#sec02{
  display: block;
  width: 100%;
  margin: 0 auto calc(308 * (100vw / 750));
  position: relative;
}

#FR240319color #sec02 .lpSectionTTL{
  color: #F3DBEE;
  left: calc(450.123 * (100vw / 750));
  top: calc(88 * (100vw / 750));
  letter-spacing: 0.025em;
}

#FR240319color #sec02 .lpSectionTTL > span{
  left: calc(79.3477 * (100vw / 750));
  top: calc(-39 * (100vw / 750));
}

#sec02 .img01{
  display: block;
  width: calc(670 * (100vw / 750));
  background: #FFFFFF;
  margin-left: 0;
  margin-bottom: calc(60 * (100vw / 750));
}

#sec02 .img02{
  display: block;
  width: calc(460 * (100vw / 750));
  background: #FFFFFF;
  margin-left: calc(60 * (100vw / 750));
  margin-bottom: calc(760 * (100vw / 750));
}

#sec02 .img03{
  display: block;
  width: calc(500 * (100vw / 750));
  background: #FFFFFF;
  position: absolute;
  z-index: 1;
  right: 0;
  top: calc(1815 * (100vw / 750));
}

#sec02 .img04{
  display: block;
  width: calc(590 * (100vw / 750));
  background: #FFFFFF;
  margin-left: calc(40 * (100vw / 750));
  margin-bottom: calc(70 * (100vw / 750));
}


#sec02 .text{
  display: block;
  width: calc(588 * (100vw / 750));
  margin-left: calc(40 * (100vw / 750));
}

#FR240319color #sec02 .text .lede{
  padding-top: calc(50 * (100vw / 750));
  letter-spacing: 0.1em;
}

#FR240319color #sec02 .text .creditLinks{
  padding-top: calc(48 * (100vw / 750));
}

#FR240319color #sec02 .text .creditLinks a:nth-of-type(2){
  
}

/*******************************
sec03
*******************************/
#sec03{
  display: block;
  width: 100%;
  margin: 0 auto calc(198 * (100vw / 750));
  position: relative;
}

#FR240319color #sec03 .lpSectionTTL{
  color: #D7D7D7;
  left: calc(117*(100vw / 750));
  top: calc(-64*(100vw / 750));
  font-size: calc(110 * (100vw / 750));
  letter-spacing: 0.009em;
}


#FR240319color #sec03 .lpSectionTTL > span{
  left: calc(178.4581 * (100vw / 750));
  top: calc(-40*(100vw / 750));
}

#sec03 .img01{
  display: block;
  width: 100%;
  background: #FFFFFF;
  margin-bottom: calc(850 * (100vw / 750));
}

#sec03 .img02{
  display: block;
  width: calc(560 * (100vw / 750));
  background: #FFFFFF;
  position: absolute;
  z-index: 1;
  left: calc(95 * (100vw / 750));
  top: calc(1065 * (100vw / 750));
}


#sec03 .text{
  display: block;
  margin: 0 auto;
  text-align: center;
}


#FR240319color #sec03 .text .lede{
  width: calc(562 * (100vw / 750));
  padding-top: calc(50 * (100vw / 750));
  margin: 0 auto;
  text-align-last: center;
}

#FR240319color #sec03 .text .creditLinks{
  padding-top: calc(50 * (100vw / 750));
}

/*******************************
sec04
*******************************/
#sec04{
  display: block;
  width: 100%;
  margin: 0 auto calc(160 * (100vw / 750));
  position: relative;
}

#FR240319color #sec04 .lpSectionTTL{
  color: #B9CEE4;
  left: calc(44.5645 * (100vw / 750));
  top: calc(340 * (100vw / 750));
  letter-spacing: 0.01em;
}

#FR240319color #sec04 .lpSectionTTL > span{
  left: calc(140.7773 * (100vw / 750));
  top: calc(-14 * (100vw / 750));
}

#sec04 .img01{
  display: block;
  width: calc(480 * (100vw / 750));
  background: #FFFFFF;
  margin-left: calc(220 * (100vw / 750));
  margin-bottom: calc(825 * (100vw / 750));
}

#sec04 .img02{
  display: block;
  width: calc(550 * (100vw / 750));
  background: #FFFFFF;
  position: absolute;
  z-index: 1;
  left: calc(40 * (100vw / 750));
  top: calc(780 * (100vw / 750));
}

#sec04 .img03{
  display: block;
  width: calc(632 * (100vw / 750));
  background: #FFFFFF;
  margin-right: 0;
  margin-left: auto;
  margin-bottom: calc(70 * (100vw / 750));
}


#sec04 .text{
  display: block;
  width: calc(630 * (100vw / 750));
  padding-right: calc(50 * (100vw / 750));
  background: #FFFFFF;
  margin-right: 0;
  margin-left: auto;
}


#FR240319color #sec04 .text .lede{
  padding-top: calc(50 * (100vw / 750));
}

#FR240319color #sec04 .text .creditLinks{
  padding-top: calc(48 * (100vw / 750));
}

/*******************************
allItemBtn
*******************************/
#FR240319color .allItemBtn{
  display: block;
  margin: 0 auto;
  padding: 0 0 calc(156 * (100vw / 750));
  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: calc(40 * (100vw / 750));
  text-align: center;
  line-height: 1;
  letter-spacing: 0.04em;
  color: #000000;
  padding-bottom: calc(16 * (100vw / 750));
  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: calc(24 * (100vw / 750));
  line-height: 1.75;
  letter-spacing: 0.042em;
  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 calc(20 * (100vw / 750));
  padding-right: calc(20 * (100vw / 750));
  padding-bottom: calc(20 * (100vw / 750));
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 1;
}

#FR240319color .figSlider ul.pager > li{
  display: block;
  width:  calc(10 * (100vw / 750));
  height: calc(10 * (100vw / 750));
  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 .pcView{display: none;}











