
/***********************************************************************************************************************

home.css

***********************************************************************************************************************/

.info_wrap .ft_btn{
	margin-top: 0;
}
.info_wrap .ft_btn li{
	width: 40%; /* 1つの時だけ */
	min-width: 340px; /* 1つの時だけ */
}
.info_wrap .ft_btn li a{
	border: none;
}

@media screen and (max-width: 767px) {
.info_wrap .ft_btn li{
	width: 100%; /* 1つの時だけ */
	min-width: auto; /* 1つの時だけ */
}
}



/*** swiper **********************************/
.swiper-container {
	overflow: hidden;
	position: relative;
	z-index: 0;
	width: 100%;
	background-color: #000;
}
.swiper-slide{
	position: relative;
}
.swiper-slide video {
	position: absolute;
	top: 0;
	left: 0;
  width: 100%;
  height: auto;
}

.swiper-slide img {
    display: block;
   vertical-align: top;
}

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal {
  width: 100%;
  max-width: 200px;
  left: 50%;
  transform: translateX(-50%);
}

.swiper-container > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 9px;
  position: relative;
  width: 12px;
  height: 12px;
  background-color: #fff;
  opacity: 0.4;
}
.swiper-container > .swiper-pagination-bullets .swiper-pagination-bullet::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 18px;
  height: 18px;
  transform: translate(-50%, -50%);
  border: 0px solid #fff;
  border-radius: 50%;
}
.swiper-container > .swiper-pagination-bullets .swiper-pagination-bullet:hover, 
.swiper-container > .swiper-pagination-bullets .swiper-pagination-bullet.swiper-pagination-bullet-active {
  opacity: 1;
}
.swiper-container > .swiper-pagination-bullets .swiper-pagination-bullet.swiper-pagination-bullet-active::before {
  border-width: 1px;
}



/* videoを最初は非表示にする（チラつき防止）*/
.mv-loop-video{
  opacity:0;
  transition:opacity .6s ease;
}

.mv-loop-video.is-loaded{
  opacity:1;
}



/*** btn_reload **********************************/
.btn_reload {
	position: absolute;
	right: 1em;
	bottom: 1em;
	z-index: 20;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 14px;
	font-size: clamp(12px, 1.4vw, 14px);
}
.btn_reload a{
	display: inline-block;
	color: #fff;
	padding: 0.4em 0.6em;
	background-color: #5a5b5b;	
}
.btn_reload a:hover{
	background-color: #000;	
}


/*** sec **********************************/
.sec_contents{
	margin: 6% 0 0;
	overflow: hidden;
}

@media screen and (max-width: 767px) {
.sec_contents{
	margin: 8% 0 0;
}
}



/*** hd **********************************/
.hd {
	position: relative;
}
.hd img,
.hd_main img{
	width: 100%;
	height: auto;
}
.hd_main figcaption{
	display: none;
}

.hd video#player,
.hd video#player_SP{
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	width: 100%;
}

.hd .pc{display: block;}
.hd .sp{display: none;}


@media screen and (max-width: 767px) {
.hd .pc{display: none;}
.hd .sp{display: block;}
}


/*** slider  **********************************/
.slideBox_inner{

}
.slideBox_inner .pc{
	
}
.slideBox_inner .sp{
	display: none;	
}

.slideBox_inner img{
	width: 100%;
	height: auto;
	line-height: 0;
}

@media screen and (max-width: 767px) {
.slideBox_inner .pc{
	display: none;
}
.slideBox_inner .sp{
	display: block;
}
}



/*** h1〜  **********************************/
h1.h1_ttl{
	font-size: 28px;
	font-size: clamp(20px, 2.8vw, 28px);
	text-align: center;
	color: #fff;
	margin-bottom: 1.5em;
}

h2.h2_cts{
	font-size: 26px;
	font-size: clamp(20px, 2.6vw, 26px);
	line-height: 1.5em;
	letter-spacing: 0.1em;
	margin-bottom: 1em;
}
h2.h2_cts .en{
	display: block;
	font-family: "Cinzel", serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-size: 160%;
	letter-spacing: 0.15em;
	margin-bottom: 0.5em;
}

h3.h3_cts{
	font-size: 18px;
	font-size: clamp(16px, 1.8vw, 18px);
	line-height: 1.8em;
	letter-spacing: 0.1em;
	margin-bottom: 1.8em;
}

h5.h5_info{
	position: relative;
	/*font-family: 'EB Garamond', serif;*/
	font-family: "Cinzel", serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-size: 1.6rem;
	font-size: 16px;
	letter-spacing: 0.2em;
	text-align: center;
	color: #fff;
	text-transform: uppercase;
	margin: 4em 0 20px;
}

.clr_fff{
	color: #fff;
}
.shadow{
	text-shadow: 0 0 5px #000,0 0 5px #000,0 0 5px #000;
}




@media screen and (max-width: 767px) {
h2.h2_cts{
	margin-bottom: 1.2em;
}
h2.h2_cts .en{
	margin-bottom: 0.4em;
}
h5.h5_info{
	font-family: 1.4rem;
	font-size: 14px;
}
h3.h3_cts{
	margin-bottom: 1em;
}

}



/*** info_wrap **********************************/
.info_wrap{
	position: relative;
	padding: 6% 0;
	background-color: rgba(31,57,105,0.8); /*web指定カラー #1f3969;*/
}

.info_wrap #topix{
	/*height: 400px;
	overflow-y:scroll;*/
	padding: 20px 20px; /*20px 10px*/
	border: 1px solid #333;
	-ms-overflow-style: none; /* IE, Edge 対応 */
	scrollbar-width: none; /* Firefox 対応 */
	background-color: #fff;
}
.info_wrap #topix::-webkit-scrollbar {  /* Chrome, Safari 対応 */
	display:none;
}
.info_wrap .tpb{
	font-family: 'Noto Serif JP', serif;
	margin-bottom: 3em;
	padding-bottom: 2em;
	border-bottom: 1px solid #e6e6e6;
}
.info_wrap .tpb:last-child{
	margin-bottom: 0;
	border-bottom: none;
}
.info_wrap .tpb .dat{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 1.4rem;
	font-size: 14px;
}
.info_wrap .tpb h3.ttl{
	font-weight: 600;
	font-size: 2.4rem; /*1.8rem*/
	font-size: 24px;/*18pc*/
	padding: 0;
	margin: 0 0 10px;
}
.info_wrap .tpb p{
	padding: 0 0 0.5em;
}

.info_wrap .tpb p a{
	color: #00a0e9;
}

@media screen and (max-width: 767px) {
.info_wrap{
	padding: 8% 0;
}
.info_wrap #topix{
	/*height: 300px;*/
}
.info_wrap .tpb .dat{
	font-size: 1.2rem;
	font-size: 12px;
}
.info_wrap .tpb h3.ttl{
	font-size: 1.8rem;
	font-size: 18px;
}
}


/*** point **********************************/
.point{

}
.point .pc{}
.point .sp{ display: none;}

@media screen and (max-width: 767px) {
.point .pc{ display: none;}
.point .sp{ display: block;}
}



/*** teiki **********************************/
.teiki{
	padding-top: 4%;
}
.teiki_ttl{
	font-family: 'Noto Serif JP', serif;
	font-size: 46px;
	font-size: clamp(26px, 4.6vw, 46px);
	text-align: center;
	color: #d6c560;
	/*letter-spacing: 0.2em;*/
}
.teiki_ttl .small{
	font-size: 60%;
}


/*** list_cts **********************************/
.list_cts{
	display: flex;
	justify-content: space-between;
	flex-flow: wrap;
	align-items: center;
	margin-top: 10%;
}
.list_cts.reverse{
	flex-direction: row-reverse;
}

.list_cts li{
}
.list_cts li.photo{
	width: 50%;
}
.list_cts li.txt{
	width: 40%;
	margin: 0 auto;
}
.list_cts.reverse li.txt{
	text-align: right;
}

.list_cts li.photo img{
	width: 100%;
	height: auto;
}
.list_cts li.photo figure{
	position: relative;
}
.list_cts li.photo figure figcaption{
	position: absolute;
	bottom: 1em;
	left: 1em;
}
.list_cts.reverse li.photo figure figcaption{
	left: auto;
	right: 1em;
}



@media screen and (max-width: 767px) {
.list_cts{
	margin-top: 15%;
}
.list_cts li.photo{
	width: 100%;
}
.list_cts li.txt{
	width: 90%;
	margin: 8% auto 0;
}
}




/*** btn_more **********************************/
.btn_more{
	font-family: "Cinzel", serif;
	font-optical-sizing: auto;
	/*font-weight: 400;*/
	font-style: normal;
	font-size: 20px;
	font-size: clamp(16px, 2vw, 20px);
	letter-spacing: 0.2em;
	line-height: 1em;
}
.list_cts.reverse .btn_more{
	padding-right: 1.5em;
}

.btn_more a{
	position: relative;
	color: #002f7b;
	font-weight: 600;
}
.btn_more a:before{
	content: "";
	position: absolute;
	right: -0.8em;
	top: 0.3em;
  width: 0.4em;
  height: 0.4em;
  border: 2px solid;
  border-color: #002f7b #002f7b transparent transparent;
  transform: rotate(45deg);
  transition: all .3s linear;
}

.btn_more a:hover{
	color: #69a2ff;
}
.btn_more a:hover:before{
	right: -1.2em;
  border-color: #69a2ff #69a2ff transparent transparent;
}



/*************************************************************************************
*************************************************************************************

print

*************************************************************************************
**************************************************************************************/

@media print {
.hd video#player,
.hd video#player_SP{
	display: none;
}
.swiper-slide img {
    width: 1200px;
	height: auto;
}
}