/*
Theme Name: Divi Child
Version: 1.6
Template: Divi
*/
/****************************
共通
****************************/

html {
  font-size: 55%;
}

@media screen and (min-width: 960px) {
  html {
    font-size: 62.5%;
  }
}

body {
  font-size: 1.4rem;
	  font-family:'Noto Sans JP', "ヒラギノ角ゴシック Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "游ゴシック", "Yu Gothic", YuGothic, sans-serif;
  font-weight: 400;
}
*,
::before,
::after {
  background-repeat: no-repeat;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
	text-decoration: inherit; /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit;
}
/* *{
  padding: 0;
  margin: 0;
} */
ul {
    list-style-type: none!important;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}
.logo_container a{
	display:inline-block;
}
/* body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
dl,
dt,
dd {
  margin: 0;
  padding: 0;
}

h2,
h3,
h4 {
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.2rem;
} */

ul {
  list-style-type: none;
}
a {
  color: inherit;
  text-decoration: none;
  -webkit-transition: .3s;
  transition: .3s;
  display: block;
}
.common-mv{
	max-width:100%;
	width:100%;
	padding-bottom: 4.875rem;
    padding-top: 4.875rem;
		border-bottom:1px solid #222;
	margin:0 auto;
}
.common-ttl{
	position: relative;
    padding-left: calc(5.55vw + 140px);
    font-size: 55px;
    font-weight: 700;
    margin-bottom: 20px;
    letter-spacing: 0.15em;
}
.common-ttl::before{
	content: "";
    display: block;
    width: 100px;
    height: 1px;
    position: absolute;
    left: 5.5vw;
    top: 33px;
    background: #313131;
}
.common-ttl span{
    position: relative;
    box-sizing: border-box;
    font-size: 16px;
	display:block;
	letter-spacing: 0.1em;
    font-weight: 500;
	margin-top: 10px;
}
.news-content{
	padding:10rem 0px;
}
.wrap{
	max-width:1432px;
	padding:0px 16px;
	width:100%;
	margin:0 auto;
}
.p-common__2colums{
	margin-bottom:60px;
}
@media screen and (min-width: 560px) {
	.p-common__inner{
		display:flex;
		justify-content:space-between;
		flex-wrap:wrap;
	}
.p-common__2colums{
	flex:0 0 48.25%;
	max-width:48.25%;
}
}
.p-common__link{
	overflow:hidden;
	display:flex;
	justify-content:space-between;
	padding:40px 0px;
	border-bottom:1px solid #efefef;
	position:relative;
	transition:.3s;
}
.p-common__image{
	flex:0 0 28%;
	max-width:28%;
	object-fit: cover;
	overflow:hidden;
}
.p-common__image img{
	    object-fit: cover;
    width: 100%;
    height: 180px;
	border-radius:4px;
	transition:.3s;
}
.p-common__link:hover .p-common__image img{
	transform: scale(1.05);
}
.p-common__block{
	flex:0 0 69%;
	max-width:69%;
}
.p-result__icons{
	    display: block;
    width: 48px;
    height: 48px;
    position: absolute;
	right: 2.75vw;
	top: 0;
    bottom: 0;
    margin: auto;
    border-radius: 48px;
    border: 1px solid #222;
	z-index: 10;
	transition:.3s;
}
.p-common__link:hover .p-result__icons{
	background:#F73B8C;
	border:1px solid #F73B8C;
	right: 2.45vw;
}
.p-result__icons::before{
	content: '';
    position: absolute;
    top: 25px;
    left: 0;
    right: 0;
    margin: auto;
    width: 25px;
    height: 1px;
	transition:.3s;
	background:#222;
}
.p-result__icons::after{
	    content: '';
    position: absolute;
    top: 22px;
    right: 9px;
    width: 10px;
    height: 1px;
    transform: rotate(35deg);
	background:#222;
	transition:.3s;
}
.p-common__link:hover .p-result__icons::before,
.p-common__link:hover .p-result__icons::after{
	background:#fff
}
.p-common__headline{
	margin-top:15px;
	transition:.3s;
	font-weight:bold;
}
.p-common__link:hover .p-common__headline{
	color:#F73B8C;
}
.p-common__date{
	color:#666;
	font-size:13px;
}
.wp-block-image{
	margin:20px 0px;
}
.p-news__headline{
	margin-bottom:40px;
	padding-bottom:20px;
	border-bottom:2px solid #333;
}
.back-btn{
	position:relative;
	transition:.3s;
	text-align:center;
	overflow: hidden;
	background: #000;
	max-width:500px;
	margin:60px auto 0px;
	padding:15px 10px;
	color:#fff;
	font-weight:bold;
}
.back-btn span{
	position: relative;
}
.back-btn::before{
	position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  content: '';
  transition: all .5s ease-in-out;
  transform: translateX(96%);
  background: #0063b2;
}
.back-btn:hover::before{
	transform: translateX(0%);
}
.p-sp__inner{
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.p-wrapper {
  max-width: 1200px;
  padding: 0px;
  width: 100%;
  margin: 0 auto;
}
#tab_menu {
	margin: 0 0 4rem;
	padding:0px;
}
#tab_menu li{
width: calc(100% / 4);
	padding: 16px 0px;
	text-align: center;
	cursor: pointer;
	background: #fff;
  border:1px solid #F4F5F7;
  transition: .3s;
}
#tab_menu li h3{
	 font-size: 13px;
	padding-bottom:0px;
}
#tab_menu li:last-child {
	margin-right: 0;
}
#tab_menu li.selected {
	background: #ffd98b;
  color:#8B98A9;
  font-weight: 900;
}
#tab_menu li:hover {
	background: #ffd98b;
  color:#8B98A9;
  font-weight: 900;
}
.p-menu__image{
	margin-bottom:40px;
	position:relative;
}
.p-menu__image img{
	position:relative;
}
.tab_panel{
	padding:0px!important;
}
@media screen and (min-width: 560px) {
  .tab_panel{
    display: flex;
  justify-content: space-between;
  }
	.p-menu__image{
		flex:0 0 45%;
		max-width:45%;
		margin-bottom:0px;
	}
	.p-menu__block{
		flex:0 0 50%;
		max-width:50%;
	}
}

.p-menu__table{
	    width: 100%;
    border-collapse: collapse;
	display: block;
	border:none!important;
}
.p-menu__table tbody{
	display: block;
    width: 100%;
}
.p-menu__table tr{
	display: flex;
	    border-bottom: 1px solid #fff;
    padding: 2rem 0rem;
}
.p-menu__table th{
	width: 30%;
    display: inline;
	font-weight:normal;
	padding:0px!important;
	color:#fff!important;
}
.p-menu__table td{
	width: 70%;
	border-top:none!important;
	padding:0px!important;
	color:#fff!important;
}
.p-flow__content .p-common__3colums,
.p-flow__content .p-common__4colums {
  position: relative;
  padding-bottom: 80px;
  /* display: flex;
  justify-content: space-between; */
}

.p-flow__content .p-common__4colums {
  margin-bottom: 4rem;
}

@media screen and (min-width: 560px) {
	.p-common__3colums{
		flex: 0 0 31.25%;
    max-width: 31.25%;
	}
  .p-flow__content .p-common__3colums,
  .p-flow__content .p-common__4colums {
    display: block;
    padding-bottom: 0rem;
  }

  .p-flow__content .p-common__4colums {
    margin-bottom: 0px;
  }
}
.c-columns__headline{
  color:#005A73;
  text-align: center;
  font-size: 18px;
	padding:28px 0px 8px;
  font-weight: 900;
}
.p-icon__images{
	text-align:center;
}
/* .p-flow__content-list:not(:last-child)::after{
  content: '\f078';
  font-family: fontAwesome;
  position: absolute;
  color: #999999;
  right: 0%;
  left: 0;
  top: auto;
  bottom: 5%;
  text-align: center;
  font-size: 3rem;
} */

@media screen and (min-width: 560px) {

  .p-flow__content-list:not(:last-child)::after{
    content: '\f054';
    right: -8%;
    top: 23%;
    left: auto;
    bottom: auto;
    text-align: left;
    transform: translateY(-50%);
  }
}

/*== 背景が流れる（左から右） */
.bgleft:before {
 	content: '';
    /*絶対配置で位置を指定*/
 	position: absolute;
 	top: 0;
 	left: 0;
 	z-index: 2;
    /*色や形状*/
 	background:#333;/*背景色*/
 	width: 100%;
	height: 100%;
    /*アニメーション*/
 	transition: transform .6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
 	transform: scale(0, 1);
	transform-origin: right top;
}

/*hoverした際の形状*/
.bgleft:hover:before{
	transform-origin:left top;
	transform:scale(1, 1);
}

/*== 背景が流れる（上から下） */
.bgtop:before {
 	content: '';
    /*絶対配置で位置を指定*/
 	position: absolute;
 	top:0;
 	left: 0;
 	z-index: 2;
    /*色や形状*/
 	background:  #333;/*背景色*/
 	width: 100%;
	height: 0;
    /*アニメーション*/
 	transition:.3s cubic-bezier(0.8, 0, 0.2, 1) 0s;
}

/*hoverした際の形状*/
.bgtop:hover:before{
	 height: 100%;
 	 background-color: #333;
}
/*== 背景が流れる（下から上） */
.bgbottom:before {
 	content: '';
    /*絶対配置で位置を指定*/
 	position: absolute;
 	bottom:0;
 	left: 0;
 	z-index: 2;
    /*色や形状*/
 	background:  #333;/*背景色*/
 	width: 100%;
	height: 0;
    /*アニメーション*/
 	transition:.3s cubic-bezier(0.8, 0, 0.2, 1) 0s;
}

/*hoverした際の形状*/
.bgbottom:hover:before{
	 height: 100%;
 	 background-color: #333;
}
.rittai{
	box-shadow: 0 5px 0 #aaaaaa;
	background-color: #cccccc;
}
.rittai:hover{
	transform: translateY(3px);
  text-decoration: none;
  box-shadow: 0 2px 0 #aaaaaa;
}

.btnarrow5{
    /*矢印の基点とするためrelativeを指定*/
	position: relative;
    /*ボタンの形状*/
	border: 1px solid #555;
    padding: 8px 30px;
    display: inline-block;
    text-align: center;
    text-decoration: none;
    color: #333;
    outline: none;
    /*アニメーションの指定*/
    transition: all .2s linear;
}

.btnarrow5:hover{
	background:#333;
	color:#fff;
}

/*矢印と下線の形状*/
.btnarrow5::before{
	content:"";
    /*絶対配置で下線の位置を決める*/
	position: absolute;
	top:50%;
	right:-26px;
    /*下線の形状*/
	width:40px;
	height:1px;
	background:#333;
    /*アニメーションの指定*/
    transition: all .2s linear;
}

.btnarrow5::after{
	content:"";
    /*絶対配置で矢印の位置を決める*/
	position: absolute;
    top: 20%;
    right: -21px;
    /*矢印の形状*/
	width:1px;
	height:12px;
	background:#333;
    transform:skewX(45deg);
    /*アニメーションの指定*/
    transition: all .2s linear;
}

/*hoverした際の移動*/
.btnarrow5:hover::before{
	right:-30px;
}

.btnarrow5:hover::after{
	right:-25px;
}
.borderleft:hover {
	color:#ccc;
	border-color: transparent;
    /*色の変化を遅らせる*/
	transition-delay: .6s;
}

/*線の設定*/
.borderleft span{
    display: block;
    z-index: 2;
}

/*== 線から塗に変化（左から右） */

/*線の設定*/
.borderleft span::before,
.borderleft span::after {
    content: '';
    /*絶対配置で線の位置を決める*/
    position: absolute;
    width:0;
    height:1px;
    /*線の形状*/
    background: #333;
    /*アニメーションの設定*/
	transition: all .3s;
}

/*左上線*/
.borderleft span::before {
    left:0;
    top:0;
}

/*左下線*/
.borderleft span::after {
    left:0;
    bottom:0;
}

/*hoverをすると線が伸びる*/
.borderleft:hover span::before,
.borderleft:hover span::after {
    width: 100%;
}

/*背景の設定*/
.borderleft::before{
	content: '';
    /*絶対配置で線の位置を決める*/
	position: absolute;
	left: 0;
    bottom:0;
	z-index: -1;
    /*背景の形状*/
	height: 100%;
	width: 0;
	background:#333;
    /*アニメーションの設定*/
	transition: all .3s;
}

/*hoverをすると背景が伸びる*/
.borderleft:hover::before{
	width: 100%;
    /*0.4秒遅れてアニメーション*/
	transition-delay: .4s;
}

.btn-55 {
  display: block;
  box-sizing: border-box;
  padding: 30px 90px;
  border-radius: 999px;

  position: relative;
  overflow: hidden;

  font-weight: 900;
  text-transform: uppercase;

  color: black;
  background: linear-gradient(to right, blue, red);
}

.btn-55 span {
  position: absolute;
  inset: 5px;
  display: grid;
  place-items: center;

  border-radius: 999px;

  color: white;
  background: rgb(30 41 59);
  transition: background 0.3s;
}
.btn-55:hover span {
  background: none;
}

.gradient1{
    /*ボタンの形状*/
    display: inline-block;
    color:#fff;
    padding: 18px 60px;
    border-radius:30px;
    text-decoration: none;
    outline: none;
    /*背景の色と形状*/
    background: linear-gradient(270deg, #3bade3 0%, #576fe6 25%, #9844b7 51%, #ff357f 100%);
    background-position: 1% 50%;
    background-size: 200% auto;
    /*アニメーションの指定*/
    transition: all 0.3s ease-out;
	margin-bottom:50px;
}

/*hoverした際の、背景の場所とテキスト色の変更*/
.gradient1:hover {
    color: #fff;
    background-position: 99% 50%;
}
.btn02 a {
	background-color: #ceb849;
	border: 1px solid #ceb849;
	border-radius: 35px;
	height: 60px;
	line-height:60px;
}

.btn02 a:hover {
	background-color: #B99b00;
	border: 1px solid #333;
}

.btn02 a::before {
	content: '';
	position: absolute;
	top: calc(50% - 5px);
	right: -35px;
	transform: rotate(30deg);
	width: 12px;
	height: 1px;
	background-color: #333;
}

.btn02 a::after {
	content: '';
	position: absolute;
	top: 50%;
	right: -35px;
	transform: translateY(-50%);
	width: 70px;
	height: 1px;
	background-color: #333;
}
.btn08{
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	width: 100%;
	height: 80px;
	background-color: #ceb849;
	border: 1px solid transparent;
	margin-bottom:50px;
}
.btn08::before{
	content: '';
	position: absolute;
	bottom: -5px;
	right: -5px;
	width: 100%;
	height: 100%;
	background-image: repeating-linear-gradient(-45deg, #BAB38C, #BAB38C 3px, transparent 0, transparent 6px);
	z-index: -1;
	transition:.3s;
}
.btn08:hover::before{
	bottom: 0px;
	right: 0px;
}
.btn08::after{
	background-color: #B99b00;
	border: 1px solid #333;
}
.textlink01{
	position:relative;
	margin-bottom:50px;
	text-align:center;
}
.textlink01::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 2px;
	background-color: #ceb849;
	transform: scaleX(0);
	transition: transform 0.3s;
}

.textlink01:hover::after {
	transform: scaleX(1);
}

.textlink02{
	position:relative;
	text-align:center;
	margin-bottom:50px;
}
.textlink02::after{
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 2px;
	background-color: #ceb849;
	transition: width 0.3s;
}
.textlink02:hover::after{
	width: 100%;
}
/**************************/
/*header
/**************************/

#g-nav{
    position:fixed;
    z-index: 999;
    /*ナビのスタート位置と形状*/
  top:-120%;
    left:0;
  width:100%;
    height: 100vh;/*ナビの高さ*/
      background: #2c303a;
    /*動き*/
  transition: all 0.6s;
}

/*アクティブクラスがついたら位置を0に*/
#g-nav.panelactive{
    top: 0;
}

/*ナビゲーションの縦スクロール*/
#g-nav.panelactive #g-nav-list{
    /*ナビの数が増えた場合縦スクロール*/
    position: fixed;
    z-index: 999;
    width: 100%;
    height: 100vh;/*表示する高さ*/
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

/*ナビゲーション*/
#g-nav ul {
    /*ナビゲーション天地中央揃え*/
    position: absolute;
    z-index: 999;
    top:50%;
    left:50%;
    transform: translate(-50%,-50%);
}

/*リストのレイアウト設定*/
.openbtn1.active span{
	background-color:#fff;
}
#g-nav li{
    text-align: center;
	padding:15px 0px;
}

#g-nav li a{
	color: #fff;
	text-decoration: none;
  padding:10px;
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: bold;
	font-size:24px;
	transition: .8s ease-in-out;
	transform-origin: left;
	display: block;
	transition-delay:.5s;
	opacity:0;
}
#g-nav li a.smoothTextAppear{
	opacity:1;
}
@media screen and (min-width: 560px) {
	#g-nav li a{
		font-size:32px;
	}
}
/*========= ボタンのためのCSS ===============*/
.openbtn1{
position: fixed;
    z-index: 9999;
    top: 0px;
    right: 0px;
    cursor: pointer;
    width: 80px;
    height: 80px;
    background: #000;
}

/*×に変化*/
.openbtn1 span{
display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 0px;
    height: 2px;
    background-color: #fff;
    width: 45%;
    right: 0px;
    margin: 0 auto;
  }

.openbtn1 span:nth-of-type(1) {
  top:26px;
}

.openbtn1 span:nth-of-type(2) {
  top:40px;
}

.openbtn1 span:nth-of-type(3) {
  top:54px;
}

.openbtn1.active span:nth-of-type(1) {
    top: 32px;
    left: 0px;
    transform: translateY(6px) rotate(-45deg);
    width: 45%;
}

.openbtn1.active span:nth-of-type(2) {
  opacity: 0;
}

.openbtn1.active span:nth-of-type(3){
    top: 45px;
    left: 0px;
    transform: translateY(-6px) rotate(45deg);
    width: 45%;
}
.et_fixed_nav.et_show_nav #page-container {
    padding-top: 0px;
}
.p-english__text{
	font-size:12px;
	font-weight:normal;
	display:block;
	padding-top:8px;
}
.murakami-link{
	position: relative;
	border: 1px solid #c1c1c1;
	background-color: transparent;
	color: #1f1f1f;
	letter-spacing: 1.2px;
	font-size: 14px;
	  -webkit-user-select: none;
	  -moz-user-select: none;
	  -ms-user-select: none;
	  display: inline-block;
	  padding: 15px 1.5rem;
	  font-weight: 300;
	  line-height: 1.5;
	  text-align: center;
	  vertical-align: middle;
	  transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
	  user-select: none;
}
.murakami-link::before{
	  position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		transform: scaleY(0);
		transform-origin: top left;
		background-color: #1f1f1f;
		content: "";
		transition: all .3s cubic-bezier(.19,1,.22,1);
		transition-property: all;
		transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
		transition-property: transform;
		transition-timing-function: cubic-bezier(.19,1,.22,1);
}
.murakami-link span{
	z-index: 2;
	position: relative;
}
.murakami-link:hover{
	color: #fff;
}
.murakmi-link:hover::before{
	transform: scaleY(1);
	transform-origin: bottom left;
}
.p-curten__link{
	margin: 80px 0 0;
  padding: 100px 0;
	text-align: center;
  font-size: 36px;
  font-weight: 700;
  background: #ec2020;
	position:relative;
	display:block;
}
.p-curten__link::before{
	 position: absolute;
	  top: 0;
	  left: 0;
	  content: '';
	  display: block;
	  width: 100%;
	  height: 100%;
	  transform: translateZ(0) scaleX(0);
	  transform-origin: right top;
	  transition: 0.8s transform cubic-bezier(0.65, 0.05, 0.35, 1);
	  background: #fd2020;
}
.p-curten__link:hover::before{
	transform: translateZ(0) scaleX(1);
  transform-origin: left top;
}
.p-curten__link p{
	position:relative;
	z-index:2;
	color:#fff;
}
.btn09{
	background: #ff701e;
    border: 2px solid #ff701e;
    border-radius: 60px;
    color: #fff;
    display: block;
    font-weight: bold;
    max-width: 300px;
    padding: 15px 40px;
    text-align: center;
}
.btn09:hover{
	transform: translateY(-5px);
}
.btn10{
	position: relative;
  z-index: 1;
  padding: 0 10px;
display: block;
    font-weight: bold;
    max-width: 300px;
    padding: 15px 40px;
    text-align: center;
	    color: #ff701e;
    font-size: 22px;
}
.btn10::before{
	background: #ff701e;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  bottom: 0;
  margin: auto;
  transform: scale(0, 1);
  transform-origin: right top;
  transition: transform .3s;
  z-index: -1;
}
.btn10:hover{
	color: #fff;
}
.btn10:hover::before{
	transform-origin: left top;
  transform: scale(1, 1);
}

#stalker {
  pointer-events: none;
  position: fixed;
  top: -8px;
  left: -8px;
  width: 16px;
  height: 16px;
  background: #f8d92f;
  border-radius: 50%;
  transition: transform 0.2s, top, 0.5s, left 0.5s, width 0.5s, height 0.5s, background-color 0.5s;
  transition-timing-function: ease-out;
  z-index: 999;
}
#stalker.hov_ {
  top: -32px;
  left: -32px;
  width: 64px;
  height: 64px;
  transition: 0.5s;
  background: rgba(248, 217, 47, 0.5);
}
.c-loop__inner{
	position:relative;
	z-index:-1;
	    width: 100%;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
    pointer-events: none;
	overflow:hidden;
	margin-bottom:100px;
}
.text-loop{
	animation: animate-banner 80s linear infinite;
	color:#efefef;
	font-size:32px;
	font-weight:bold;
	white-space : nowrap;
	display : inline-block;
		padding:20px 0px;
}
.text-loop-02{
	animation: animate-banner-02 200s linear infinite;
	color:#efefef;
	font-size:80px;
	font-weight:bold;
	white-space : nowrap;
	display : inline-block;
	padding:40px 0px;
}

@keyframes animate-banner {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
@keyframes animate-banner-02{
	0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
.p-top__hero{
	overflow:hidden;
}
.home .entry-content{
	overflow:hidden;
}
.slider {
  overflow: hidden!important; /* 画像がはみ出ないようにする */
  width: 100vw;
	margin: 0 calc(50% - 50vw);
	position:relative;
    overflow: hidden;
    position: absolute;
    top: 0px;
    left: 0px;
	padding:0px!important;
	line-height:0px!important;
/*     height: 100%; */
}
.slick-img img {
  width: 100%;
	position:relative;
	object-fit: cover;
	height:100vh;
}
.slider::after{
content: '';
    background-color: #000;
    opacity: 0.3;
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0px;
    top: 0px;
    right: 0px;	
}
.slick-img img::after{
	    content: '';
    background-color: #000;
    opacity: 0.3;
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0px;
    top: 0px;
    right: 0px;
}
@keyframes fadezoom {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.1); /* 拡大率 */
  }
}
.add-animation {
  animation: fadezoom 5s 0s forwards;
}
/*========= スクロールダウン ===============*/
.scrolldown3{
    /*描画位置※位置は適宜調整してください*/
  position:absolute;
  bottom:10px;
  right:50%;
    /*マウスの動き1.6秒かけて動く永遠にループ*/
  animation:mousemove 1.6s ease-in-out infinite;
}

/*下からの距離が変化して上から下に動く*/
@keyframes mousemove{
      0%{bottom:10px;}
      50%{bottom:5px;}
     100%{bottom:10px;}
 }

/*Scrollテキストの描写*/
.scrolldown3 span{
    /*描画位置*/
  position: absolute;
  left:-15px;
  bottom:45px;
    /*テキストの形状*/
  color: #eee;
  font-size: 0.7rem;
  letter-spacing: 0.05em;
}

/*マウスの中の線描写 */
.scrolldown3 span::after{
  content: "";
    /*描画位置*/
  position: absolute;
  top:10px;
  left:17px;
    /*線の形状*/
  width: 1px;
  height: 15px;
  background: #eee;
    /*線の動き1.4秒かけて動く。永遠にループ*/
  animation: mousepathmove 1.4s linear infinite;
  opacity:0;
}

/*上からの距離・不透明度・高さが変化して上から下に流れる*/
@keyframes mousepathmove{
  0%{
    height:0;
    top:10px;
    opacity: 0;
  }
  50%{
    height:15px;
    opacity: 1;
  }
  100%{
    height:0;
    top:30px;
    opacity: 0;
  }
}

/*マウスの描写 */
.scrolldown3:before {
    content: "";
    /*描画位置*/
    position: absolute;
    bottom:0;
    left:-10px;
    /*マウスの形状*/
  width:25px;
  height:37px;
  border-radius: 10px;
  border:1px solid #eee;
}


/*マウスの中の丸の描写*/
.scrolldown3:after{
  content:"";
    /*描画位置*/
  position: absolute;
  bottom:26px;
  left:0%;
    /*丸の形状*/
  width:5px;
  height: 5px;
  border-radius: 50%;
  border:1px solid #eee;
}
.scrolldown2{
    /*描画位置※位置は適宜調整してください*/
  position:absolute;
  bottom:30px;
  left:15%;
}

/*Scrollテキストの描写*/
.scrolldown2 span{
    /*描画位置*/
  position: absolute;
  left:50%;
  bottom:50px;
    /*テキストの形状*/
  color: #eee;
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  /*縦書き設定*/
  -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
}

/* 丸の描写 */
.scrolldown2:before {
    content: "";
    /*描画位置*/
    position: absolute;
    bottom:0;
    left:-4px;
    /*丸の形状*/
  width:10px;
  height:10px;
  border-radius: 50%;
  background:#eee;
    /*丸の動き1.6秒かけて透過し、永遠にループ*/
  animation:
    circlemove 1.6s ease-in-out infinite,
    cirlemovehide 1.6s ease-out infinite;
}

/*下からの距離が変化して丸の全体が上から下に動く*/
@keyframes circlemove{
      0%{bottom:45px;}
     100%{bottom:-5px;}
 }

/*上から下にかけて丸が透過→不透明→透過する*/
@keyframes cirlemovehide{
      0%{opacity:0}
     50%{opacity:1;}
    80%{opacity:0.9;}
  100%{opacity:0;}
 }

/* 線の描写 */
.scrolldown2:after{
  content:"";
    /*描画位置*/
  position: absolute;
  bottom:0;
  left:0;
    /*線の形状*/
  width:2px;
  height: 50px;
  background:#eee;
}

.scrolldown1{
	position:absolute;
  bottom:10px;
  right:50%;
}

/*Scrollテキストの描写*/
.scrolldown1 span{
		position: absolute;
	left:-15px;top: -15px;
	color: #eee;
	font-size: 13px;
  letter-spacing: 0.05em;
}

/* 線の描写 */
.scrolldown1::after{
  content: "";
    /*描画位置*/
  position: absolute;
  top: 0;
    /*線の形状*/
  width: 1px;
  height: 30px;
  background: #eee;
    /*線の動き1.4秒かけて動く。永遠にループ*/
  animation: pathmove 1.4s ease-in-out infinite;
  opacity:0;
}

/*高さ・位置・透過が変化して線が上から下に動く*/
@keyframes pathmove{
  0%{
    height:0;
    top:0;
    opacity: 0;
  }
  30%{
    height:30px;
    opacity: 1;
  }
  100%{
    height:0;
    top:50px;
    opacity: 0;
  }
}
.btn__container {
  max-width: 220px;
  margin: 2rem auto;
  border: 1px solid #c2c2c2;
  border-radius: 20px;
}
.btn {
  padding: 1.5rem 2rem;
  text-decoration: none;
  color: #c71e7e;
  display: flex;
  transition: all 0.2s ease-in-out;
/*   margin-right: 10px; */
}
.btn i {
  color: #df3796;
  font-size: 20px;
  padding-right: 10px;
  transition: all 0.3s ease-in-out;
}
.btn span {
  font-family: "Roboto", sans-serif;
  align-self: center;
  transform: translateX(0px);
  transition: all 0.1s ease-in-out;
  opacity: 1;
	font-size:16px;
}
.p-footer__logo{
	text-align:center;
}
.p-footer__logo img{
	max-width:160px;
}
copyright{
	margin-top:80px;
	display:block;
	background:#000;
	color:#fff;
	padding:15px 0px;
	text-align:center;
	font-size:13px;
}
/* スライダーのwrapper */
.infinite-slider .swiper-wrapper {
  transition-timing-function: linear;
}

/* スライド */
.infinite-slider .swiper-slide {
  width: auto !important;
}

/* スライド内の画像 */
.infinite-slider .swiper-slide img {
  width: auto;
  height: 100%;
}

/*********************************
スライダー
*********************************/
.swiper-wrap {
  margin: 0 calc(50% - 50vw);
  max-width: 100vw;
  position: relative;
  overflow: hidden;
  position: absolute;
  top: 0px;
  left: 0px;
/*   z-index: -1; */
  height: 100%;
}

.swiper-slide-active .slide-img,
.swiper-slide-duplicate-active .slide-img,
.swiper-slide-prev .slide-img {
  animation: zoom-in 10s linear 0s 1 normal both;
}
@keyframes zoom-in {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.2);
  }
}
.slide-img img {
  object-fit: cover;
  height: 70vh;
  width: 100vw;
}
@media only screen and (min-width: 560px) {
	.slide-img img {
		height: 100vh;
	}
}
.et-fb-switch-editor-mode{
	    position: relative;
    display: flex;
    justify-content: flex-end;
    position: relative;
}
.et-fb-switch-editor-mode__tab--active{
	margin-left: auto;
    position: absolute;
    top: 0px;
    left: 123px;
}
.et-db #et-boc .et-l .et-fb-option--tiny-mce .et-fb-switch-editor-mode{
	height:auto!important;
}