/*
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;
	color:#333;
}
*,
::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;
} */
h1{
	margin:0px;
	padding:0px;
}
ul {
  list-style-type: none;
}
a {
  color: inherit;
  text-decoration: none;
  -webkit-transition: .3s;
  transition: .3s;
  display: block;
}

@media screen and (min-width: 560px) {
    .pc-block {
        display: inline !important;
    }

    .sp-block {
        display: none;
    }

    .sp-br {
        display: none !important;
    }
}

/* 逕ｻ髱｢蟷�′560px莉･荳九�譎�*/

@media screen and (max-width: 559px) {
    .pc-block {
        display: none !important;
    }

    .sp-br {
        display: block !important;
    }
}

.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:1032px;
	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{
  flex: 0 0 31.25%;
  max-width: 31.25%;
	padding: 16px 0px;
	text-align: center;
	cursor: pointer;
  border-radius: 8px;
	background: #fff;
  border:1px solid #F4F5F7;
  transition: .3s;
}
#tab_menu li h3{
	 font-size: 13px;
}
#tab_menu li:last-child {
	margin-right: 0;
}
#tab_menu li.selected {
	background: #F4F5F7;
  color:#8B98A9;
  font-weight: 900;
}
#tab_menu li:hover {
	background: #F4F5F7;
  color:#8B98A9;
  font-weight: 900;
}

@media screen and (min-width: 560px) {
  .tab_panel{
    gap: 40px;
    display: flex;
  justify-content: center;
  }
}

.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%);
  }
}

.btn{
    /*アニメーションの起点とするためrelativeを指定*/
    position: relative;
	overflow: hidden;
    /*ボタンの形状*/
	text-decoration: none;
	display: inline-block;
   	border: 1px solid #555;/* ボーダーの色と太さ */
    padding: 10px 30px;
    text-align: center;
    outline: none;
    /*アニメーションの指定*/
    transition: ease .2s;
	margin-bottom:50px;
}

/*ボタン内spanの形状*/
.btn span {
	position: relative;
	z-index: 3;/*z-indexの数値をあげて文字を背景よりも手前に表示*/
	color:#333;
}

.btn:hover span{
	color:#fff;
	transition:.2s;
	transition-delay:.25s;
}

/*== 背景が流れる（左から右） */
.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
/**************************/
#header{
	position: fixed;
	height: 60px;
	width:100%;
    z-index: 10;
	display: flex;
	justify-content: space-between;
	align-items: center;
	background:#fff;
	text-align: center;
	padding: 15px 0px 15px 15px;
}
@media screen and (min-width: 960px) {
	#header{
		height: 80px;
		padding: 20px 0px 20px 20px;
	}
}
#header.UpMove{
	position: fixed;
	width:100%;
	animation: UpAnime 0.5s forwards;
}
@keyframes UpAnime{
  from {
    opacity: 1;
	transform: translateY(0);
  }
  to {
    opacity: 0;
	transform: translateY(-100px);
  }
}

/*　下に下がる動き　*/

#header.DownMove{
	position: fixed;
	width:100%;
}
@media screen and (min-width: 960px) {
	#header.DownMove{
		animation: DownAnime 0.5s forwards;
	}
}
@keyframes DownAnime{
  from {
  	opacity: 0;
	transform: translateY(-100px);
  }
  to {
  	opacity: 1;
	transform: translateY(0);
  }
}
@media screen and (min-width: 960px) {
nav ul{
	display: flex;
	justify-content: center;
	gap:10px;
}	
}
.entry-content{
	padding-top:80px;
}
@media screen and (max-width: 959px) {
#g-nav{
	position:fixed;
	z-index: 999;
	top:-120%;
	left:0;
	width:100%;
	height: 100vh;
	background: #fff;
	transition: all 0.6s;
}
#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:0px 0px;
}
@media screen and (min-width: 960px) {
	#g-nav li{
		line-height:80px;
		padding:15px 0px;
	}
}
#g-nav li a{
	text-decoration: none;
  padding:20px 10px;
  display: block;
	font-size:18px;
	transition: .5s ease-in-out;
	transform-origin: left;
	display: block;
	transition-delay:.5s;
	opacity:1;
}
@media screen and (min-width: 960px) {
	#g-nav li a{
		font-size:14px;
		padding:0px 10px;
	}
	#g-nav li a:hover{
		opacity:0.6;
	}
}
#g-nav li a.smoothTextAppear{
	opacity:1;
}
.header__logo-inner img{
	max-width:250px;
}
@media screen and (min-width: 960px) {
.u-contact__link{
	/* background-color:#000; */
  background: firebrick;
	color:#fff;
	height:80px;
	line-height:80px;
	width: 130px;
}	
}
/*========= ボタンのためのCSS ===============*/
.openbtn1{
	display:block;
position: fixed;
    z-index: 9999;
    top: 0px;
    right: 0px;
    cursor: pointer;
    width: 60px;
    height: 60px;
    /* background: #000; */
    background: firebrick;
}
@media screen and (min-width: 960px) {
	.openbtn1{
		width: 80px;
    height: 80px;
	}
}
/*×に変化*/
.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:16px;
}

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

.openbtn1 span:nth-of-type(3) {
  top:40px;
}
@media screen and (min-width: 960px) {
	.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: 22px;
    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: 35px;
    left: 0px;
    transform: translateY(-6px) rotate(45deg);
    width: 45%;
}
@media screen and (min-width: 960px) {
	.openbtn1{
		display:none;
	}
}
.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:#205988;
  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(32, 89, 136, 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%);
  }
}
.slider {
  height: 53vw;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden; /* 画像がはみ出ないようにする */
  width: 80vw;
}
.slick-img img {
  width: 100%;
}
@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:10px;
  bottom:10px;
    /*テキストの形状*/
  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;
  left:30%;
  bottom:10px;
    /*全体の高さ*/
  height:50px;
}

/*Scrollテキストの描写*/
.scrolldown1 span{
    /*描画位置*/
  position: absolute;
  left:-15px;
  top: -15px;
    /*テキストの形状*/
  color: #eee;
  font-size: 0.7rem;
  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;
  }
}
footer{
	background-color:#FAFAFA;
	padding:70px 0px;
}
copyright{
	display:block;
	text-align:center;
	padding:15px;
	/* background:#010101; */
  background: firebrick;
	color:#fff;
}
.p-footer__logo-img img{
	max-width:165px;
	width:100%;
}
.contact-thanks{
	padding:100px 0px;
}
.thanks-ttl{
	font-size:3.2rem;
	text-align:center;
	font-weight:bold;
	margin-bottom:40px;
}
.contact-content{
	margin-bottom:100px;
}
.stepBar {
  display: flex;
  max-width: 400px;
  position: relative;
  margin: 4rem auto;
  text-align: center;
}

.stepBar li {
  font-size: 12px;
  list-style: none;
  position: relative;
  width: 33.333%;
}

.stepBar li:after {
  background: #ACB1B9;
  content: "";
  width: calc(100% - 24px);
  height: 4px;
  position: absolute;
  left: calc(-50% + 12px);
  top: 10px;
}

.stepBar li:first-child:after {
  display: none;
}

.stepBar li span {
  background: #ACB1B9;
  color: #ffffff;
  display: inline-block;
  height: 24px;
  margin-bottom: 5px;
  line-height: 24px;
  width: 24px;
  -moz-border-radius: 50%;
  -webkit-border-radius: 50%;
  border-radius: 50%;
}

.stepBar .visited:after {
  background: #2E3642;
}

.stepBar .visited span {
  background: #2E3642;
}

.contact-ttl {
  font-size: 3rem;
  color: #2E3642;
  text-align: center;
  margin-bottom: 3.5rem;
  font-weight: bold;
}

.contact-inner .common-link,
.contact-done .common-link {
  height: 60px;
  line-height: 60px;
  margin-top: 60px;
}

.contact-table {
  width: 100%;
  margin: 0 auto 6.8rem;
}

.contact-form__inner {
  margin-bottom: 3rem;
  border-bottom: 1px solid #D8DDE4;
}

.contact-form__01 {
  border-bottom: 1px solid #D8DDE4;
}

.contact-form__01,
.contact-form__02 {
  display: block;
}

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

  .contact-form__01,
  .contact-form__02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}

.contact-form__name {
  margin-right: 1rem;
  max-width: 244px;
  width: 100%;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  font-weight: normal;
  font-size: 16px;
  text-align: left;
  padding: 16px 0;
  display: block;
}

@media screen and (min-width: 560px) {
  .contact-form__name {
    display: inline;
    padding: 32px 0;
    flex: 0 0 22.4%;
  }
}

.contact-form__required {
  display: inline-block;
  /* background-color: #333; */
  background: firebrick;
  color: #ffffff;
  padding: 0 0.5em;
  font-size: 12px;
  line-height: 2;
  margin-left: 16px;
}

.contact-table td {
  -ms-flex-preferred-size: 0;
  flex-basis: 0;
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  max-width: 816px;
  width: 100%;
  display: block;
  padding: 0px 0 32px;
}

@media screen and (min-width: 560px) {
  .contact-table td {
    padding: 32px 0;
    flex: 0 0 75%;
  }
}

.contact-table input,
.contact-table textarea {
  width: 100%;
  background-color: #F1F2F3;
  border: none;
  padding: 14px 10px;
  border-radius: 4px;
}

.contact-common__body {
  color: #6C737E;
}

/* .contact-table input::placeholder,.contact-table textarea{
  color: #ACB1B9;
} */
.contact-table textarea {
  min-height: 208px;
}

/* IE */
input:-ms-input-placeholder {
  color: #ACB1B9;
}

/* Edge */
input::-ms-input-placeholder {
  color: #ACB1B9;
}

.contact-agreement h3 {
  font-size: 1.6rem;
  font-weight: normal;
}

.contact-agreement__inner {
  padding: 14px 0 32px;
}

@media screen and (min-width: 560px) {
  .contact-agreement__inner {
    padding: 14px 0 60px;
    display: flex;
  }
}

.contact-privacy {
  text-decoration: underline;
  color: #333;
  display: inline;
}

@media screen and (min-width: 560px) {
  .contact-privacy {
    margin-left: 20px;
  }
  .contact-privacy:hover {
    opacity: 0.6;
  }
}

.mwform-checkbox-field input[type="checkbox"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  -o-appearance: none;
  appearance: none;
  position: relative;
  right: 0;
  bottom: 0;
  left: 0;
  height: 20px;
  width: 20px;
  vertical-align: -.8px;
  transition: all .15s ease-out 0s;
  color: #3C3D3C;
  cursor: pointer;
  display: inline-block;
  margin: .4px;
  outline: none;
  background-color: #ECECEC;
  border: 1px solid #D8DDE4;
}

input[type=checkbox]::before,
input[type=checkbox]::after {
  position: absolute;
  content: "";
  background: #3C3D3C;
  transition: all .2s ease-in-out;
}

input[type=checkbox]::before {
  left: 2px;
  top: 6px;
  width: 0;
  height: 2px;
  transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
}

input[type=checkbox]::after {
  right: 9px;
  bottom: 3px;
  width: 2px;
  height: 0;
  transform: rotate(40deg);
  -webkit-transform: rotate(40deg);
  -moz-transform: rotate(40deg);
  -ms-transform: rotate(40deg);
  -o-transform: rotate(40deg);
}

input[type=checkbox]:checked::before {
  left: 2px;
  top: 11px;
  width: 6px;
  height: 2px;
}

input[type=checkbox]:checked::after {
  right: 6px;
  bottom: 2px;
  width: 2px;
  height: 14px;
}

input[type=checkbox]:indeterminate:before,
input[type=checkbox]:indeterminate:after {
  width: 7px;
  height: 2px;
  transform: rotate(0);
  -webkit-transform: rotate(0);
  -moz-transform: rotate(0);
  -ms-transform: rotate(0);
  -o-transform: rotate(0);
}

input[type=checkbox]:indeterminate:before {
  left: 1px;
  top: 7px;
}

input[type=checkbox]:indeterminate:after {
  right: 6px;
  bottom: 2px;
}

input[type=submit] {
  cursor: pointer;
  outline: none;
}

.mw_wp_form .common-link {
  pointer-events: auto;
  color: #fff;
	/* background-color:#000; */
  background:firebrick;
  margin: 0 auto;
  height: 60px;
  line-height: 56px;
  display: block;
}

/* .mw_wp_form .common-link:hover {
  color: #fff;
} */

.contact-conversion__btn {
  margin: 0 auto;
  display: flex;
  max-width: 800px;
}

.check-content table th {
  background-color: #F1F2F3;
  padding: 23px 20px;
  border: none;
}

.check-content .contact-table td {
  padding: 23px 20px;
  font-size: 16px;
}

.check-content .contact-agreement {
  display: none;
}

.mw_wp_form .back-btn {
  pointer-events: auto;
  color: #fff;
  border: 1px solid #6C737E;
  background-color: #6C737E;
  margin: 0 auto;
/*   height: 60px;
  line-height: 56px; */
  display: block;
/*   background-size: 200% 100%; */
  font-size: 16px;
  text-align: center;
  max-width: 384px;
  width: 100%;
  position: relative;
  overflow: hidden;
/*   background-image: linear-gradient(to right, rgba(108, 115, 126, 1) 50%, transparent 50%);
  -webkit-transition: background-position .3s cubic-bezier(0.19, 1, 0.22, 1) .1s, color .5s ease 0s, background-color .5s ease; */
/*   transition: background-position .3s cubic-bezier(0.19, 1, 0.22, 1) .1s, color .5s ease 0s, background-color .5s ease; */
	transition:.3s;
  border-radius: 30px;
	font-weight:normal;
}

.mw_wp_form .back-btn:hover {
	opacity:0.5;
/*   color: #6C737E;
  background-color: #fff;
  background-position: -100% 100%; */
}

.check-content {
  margin-top: 32px;
}

.check-content .common-link {
  background-image: linear-gradient(to right, rgba(90,107,95,1) 50%, transparent 50%);
  color: #fff;
}

.check-content .common-link:hover {
  color: #333;
  background-position: -100% 100%;
}

.check-content .contact-form__02 {
  border-bottom: 1px solid #D8DDE4;
}

.check-content tr:first-child {
  border-top: 1px solid #D8DDE4;
}

.check-content tr:nth-child(5) {
  display: none;
}
/********link********/
.common-link {
	display:block;
	font-size:16px;
  text-align: center;
  max-width: 384px;
  width: 100%;
  margin: 0 auto;
  border: 1px solid #333;
  position: relative;
  overflow: hidden;
  height: 44px;
  line-height: 40px;
/*   background-size: 200% 100%; */
  background-color: #fff;
/*   background-image: linear-gradient(to right, transparent 50%, rgba(90,107,95,1) 50%); */
/*   transition: background-position .3s cubic-bezier(0.19, 1, 0.22, 1) .1s, color .5s ease 0s, background-color .5s ease; */
	transition:.3s;
  border-radius: 30px;
}

.common-link:hover {
	opacity:0.5;
}

.common-link span {
  color: #333;
  position: relative;
  font-weight: 400;
  transition: .3s;
}

.common-link:hover span {
  color: #fff;
}
.entry-content{
	margin-bottom : 100px;
}


.entry-content tr td{
       border-top: 0px solid #eee!important;
   padding: 30px 0px 30px 0px;
}

.entry-content table:not(.variations) {
    border: 0px solid #eee!important;
}



.entry-content thead th, .entry-content tr th{
padding: 30px 0px 0px 0px;
font-size: 14px;
font-weight: 400;
}

.contact-agreement{
	margin-top:40px;
	
}

.mwform-checkbox-field input[type="checkbox"] {
	top:4px;
}
#et-main-area{
	padding-top:60px;
}
@media screen and (min-width: 960px) {
	#et-main-area{
	padding-top:80px;
}
}
.flowing {
	width: 0;
	padding:3px 0px;
	white-space: nowrap;
	overflow: hidden;
	animation: flowing-anim 1.25s forwards linear;
	animation-delay:.5s;
}

.flowing:nth-child(2) {
	animation-delay: 1s;
}

@keyframes flowing-anim {
 0%{
     width: 0%;
   }
100%{
     width: 100%;
   }
}
.p-footer__link{
	margin-top:40px;
}
@media screen and (min-width: 560px) {
	.p-footer__link{
	margin-top:0px;
}
}
.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;
}