@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&family=Roboto:wght@500;700&display=swap');

/*--------------------------------------------
 ベースのスタイル
--------------------------------------------*/
html {
	font-size: 62.5%;
	word-break: break-all;
}
body {
	color: #000;
	font-size: 1.5rem;
	font-weight: 400;
	background: #fff;
	-webkit-text-size-adjust: 100%;
	font-family: 'Noto Sans JP', sans-serif;
}
.sp{
	display: none !important;
}
@media screen and (max-width: 767px){
	body{
		font-size: 1.4rem;
		font-weight: 400;
	}
	.pc{
		display: none;
	}
	.sp{
		display: block !important;
	}

}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, main, div, ul, li, a {
  box-sizing: border-box;
}
a{
	color: inherit;
	transition: 0.5s;
}
a:hover{
	text-decoration: none;
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}
h1,h2,h3,h4,h5,h6 {
	font-size: 100%;
	font-weight: normal;
}
table{
	width: 100%;
	border-collapse: collapse;
  border-spacing: 0;
  box-sizing: border-box;
}
iframe{
	width: 100%;
	vertical-align: middle;
}

input[type=text], input[type=email], input[type=tel], textarea, button{
	font-family: 'Noto Sans JP', sans-serif;
}
input[type=radio], input[type=checkbox] {
	margin: 0;
	padding: 0;
	vertical-align: middle;
}

ol, ul{
	padding-left: 2.5rem}

.btn{
	text-align: center;
	list-style: none;
}
.btn a{
	position: relative;
	display: block;
	padding: 10px 20px;
	border-radius: 100px;
	background: #e40001;
	box-sizing: border-box;
	text-decoration: none!important;
}
.btn_contact a i{
	margin-right: 5px;
}
.btn_more a,.btn_motto button, .btn_back a{
	position: relative;
	font-size: 1.6rem;
	text-decoration: none;
	width: 320px;
	height: 66px;
	margin: auto;
	display: flex;
	align-items: center;
	justify-content: center;
}
.btn_more a{
	color: #fff!important;
}
.btn_more a i, .btn_motto button i{
	position: absolute;
	right: 2rem;
	top: 0;
	bottom: 0;
	margin: auto;
	height: 1.6rem;
	transition: 0.5s;
}
.btn_motto button{
	color: #000;
	border-radius: 100px;
	background: #eee;
	cursor: pointer;
	border: none;
	transition: all 0.4s ease 0s;
 }
 .btn_motto button i{
 	color: #e40001;
 }
 .btn_back a{
 		color: #444 !important;
		text-decoration: none;
		border: 1px solid #bbb;
		margin: auto;
		background: #fff;
 }
 .btn_back a i{
 	position: absolute;
	left: 2rem;
	top: 0;
	bottom: 0;
	margin: auto;
	height: 1.6rem;
	transition: 0.5s;
 }
 @media (hover: hover) {
 	.btn_more a:hover i{
 		right: 1.5rem;
 	}
 	.btn_back a:hover{
			background: #ddd;
			border-color: #ddd;
	}
	.btn_back a:hover i{
		left: 1.5rem;
	}

 }
 @media screen and (max-width: 767px){
	.btn_more a,.btn_motto button, .btn_back a{
 		width: 250px;
		height: 50px;
		font-size: 1.5rem;
 	}

 }
 /*--------------------------------------------
 block
--------------------------------------------*/
.wrap{
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
}
.wrap1100{
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
}
.wrap1000{
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}
@media screen and (max-width: 1250px){
	.wrap, .wrap1000, .wrap1100{
		padding-left: 25px !important;
		padding-right: 25px !important;
	}
}
@media screen and (max-width: 767px){
	.wrap, .wrap1000, .wrap1100{
		padding-left: 20px !important;
		padding-right: 20px !important;
	}
}

.column_2 .main{
	line-height: 1.6;
}

.column_2 .navi dl ,.column_2 .navi dt, .column_2 .navi dd,.column_2 .navi ul, .column_2 .navi li{
	margin: 0;
	padding: 0;
	list-style: none;
}
.column_2 .navi a{
	position: relative;
	display: block;
	text-decoration: none;
	box-sizing: border-box;
	font-size: 1.5rem;
	line-height: 1.5;
	padding: 2rem 4.5rem 2rem 1.5rem;
	border-bottom: 1px solid #ddd;
}
.column_2 .navi a::before{
	position: absolute;
	right: 1.5rem;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	content: '\f061';
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  font-size: 1.2rem;
  width: 1.2rem;
  height: 1.2rem;
	color: #cecece;
	transition: .5s;
}
.column_2 .navi .parent a{
	color: #e40001;
	font-size: 1.8rem;
	font-weight: 500;
	padding: 3rem 3rem 3rem 1.5rem;
	border-top: 1px solid #e40001;
}
.column_2 .navi .parent a::before {
    color: #e40001;
    font-size: 1.6rem;
    width: 1.6rem;
    height: 1.6rem;
}
@media (hover: hover) {
	.column_2 .navi a:hover::before{
		right: .5rem;
	}
}

@media screen and (min-width: 901px){
	.column_2{
		display: flex;
		justify-content: space-between;
		margin: 7rem auto 10rem;
	}
	.navi{
		order: 1;
		width: 280px
	}
	.main{
		width: 750px
	}
}
@media screen and (max-width: 1250px){
	.navi{
		width: 25%;
	}
	.main{
		width: 70%;
	}
}
@media screen and (max-width: 900px){
	.navi, .main{
		width: 100%;
	}
	.navi{
		margin-bottom: 8rem;
	}
	.main{
		margin: 3rem auto 6rem;
	}
	.column_2 .navi a{
		padding: 1.5rem 3rem 1.5rem 1.5rem;
	}
}
/*--------------------------------------------
 header
--------------------------------------------*/
header{
	width: 100%;
	display: flex;
	justify-content: space-between;
	background: #fff;
	}

	@media screen and (min-width: 768px){
		body{
			padding-top: 110px;
		}
		header{
			position:fixed;
			top:0;
			z-index: 9999;
			height: 110px;
		}
		header.fixed{
			border-bottom: 1px solid #eee;
		}
	}
header .logo{
	display: flex;
	align-items: center;
	margin-left: 30px;
}
header .logo_name{
	width: 210px;
	margin: 0 3.5rem 0 0;
}
header .logo_name span{
	position: relative;
	top: -4px;
	left: 52px;
	font-weight: 500;
	font-size: 1.3rem;
	display: inline-block;
}
header .logo_sdgs{
	width: 200px;
}
header a{
	text-decoration: none;
}
header .head_navi{
	margin-right: 30px;
}
header .action{
	list-style: none;
	display: flex;
	align-items: stretch;
	justify-content: flex-end;
	margin: 10px 0 0;
	padding: 0;
}
header .action i{
	margin-right: .6rem;
	font-size: 1.8rem;
}
header .action_item{
	position: relative;
	font-size: 1.4rem;
	width: 150px;
	margin-left: 10px;
}
header .action_item a{
	color: #fff;
	height: 100%;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
    }
    @media all and (-ms-high-contrast: none) {
        header .action_item a img{
            width: 100%;
        }
    }
header .btn_support span{
	position: absolute;
	top: 0;
	bottom: 0;
	left: 45px;
	right: 0;
	display: flex;
	align-items: center;
}
header .btn_cms{
	width: 160px;
	font-size: 1.3rem;
}
header .btn_cms a{
	color: #e40001;
	background: #fff;
	border: 1px solid #e40001;
}
.gnavi_list{
	margin: 0;
	padding: 0;
}
.gnavi_item, .child_list, .sub-menu{
	width: 100%;
	padding: 0;
	margin: 0;
	list-style: none;
}
.child_list dd{
	margin: 0;
}

@media screen and (max-width: 767px){

	/*header
	------------------------------------*/
	header .logo {
    margin-left: 10px;
	}
	header .logo_name{
		width: 130px;
		margin: 0 2.5rem 0 0;
	}
	header .logo_name span{
		font-size: .9rem;
		left: 30px;
	}
	header .logo_sdgs {
    width: 120px;
	}

}

@media screen and (max-width: 340px){
	header .logo_name{
		width: 120px;
		margin: 0 1.5rem 0 0;
	}
	header .logo_name span{
		display: none;
	}
	header .logo_sdgs {
    width: 100px;
	}
}

/*--------------------------------------------
 gnavi
--------------------------------------------*/

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

	header .tb_action{
		display: none;
	}

	.modaal-overlay{
		position: fixed;
		top: 0;
		left: -100%;
		z-index: 999;
		width: 100vw;
		height: 100vh;
		background-color: #000;
		opacity: 0;
		-webkit-transition: left 0s linear .45s,opacity .45s ease;
		transition: left 0s linear .45s,opacity .45s ease;
		poiner-events: none;
	}
	.modaal-overlay.active{
		left: 0;
		opacity: .5;
		-webkit-transition: opacity .45s ease;
		transition: opacity .45s ease;
	}

	.openbtn{
		display: none;
	}
	.gnavi{
		display: flex;
		align-items: center;
	}
	.gnavi_list{
		display: flex;
	}
	.gnavi_item>a,
	.gnavi_item>span{
		display: block;
		padding: 0 2rem;
		white-space: nowrap;
		font-weight: 600;
	}
	.gnavi_item>a>span,
	.gnavi_item>span{
		position: relative;
		display: block;
		cursor: pointer;
		font-size: 1.6rem;
		height: 6rem;
		line-height: 6rem;
	}
	.gnavi_item>a>span:after,
	.gnavi_item.has-child.active>span::after{
		position: absolute;
		left: 0;
		bottom: 0;
		height: 1px;
		content: "";
		display: block;
		background: #e40001;
		width: 0;
		transition: .5s all;
	}
	.gnavi_item span:hover::after,
	.gnavi_item.has-child.active span::after{
		width: 100%;
	}

	/* 展開の動き
	----------------------- */
	.has-child .gnavi_child{
		display: none;
		position: absolute;
		z-index: 4;
		left: 0;
		right: 0;
		width: 100%;
		pointer-events: none;
	}
	.has-child.active .gnavi_child{
		pointer-events: inherit;
	}
	.has-child .gnavi_child{
		background: #fff;
		border-top: 1px solid #ddd;
		border-bottom: 1px solid #ddd;
	}

	/* 内部デザイン
	----------------------- */
	.child{
		padding: 4% 5%;
	}

	.child_tit{
		color: #e40001;
		font-weight: 600;
		font-size: 3.5rem;
		max-width: 1200px;
		margin: 0 auto 3rem;
		padding: 0 2rem;
	}
	.child_wrap{
		display: flex;
		max-width: 1200px;
		margin: auto;
	}
	.child_list{
		margin: 0 2rem;
	}
	.child_list dt{
		font-size: 2rem;
		font-weight: 600;
		margin-bottom: 2rem;
		border-bottom: 1px solid #ddd;
	}
	.child_list dt a, .child_list dt span{
		display: block;
		padding: 2rem 0;
	}
	.child_list dt a i{
		color: #e40001;
    margin-left: 1rem;
	}
	.child_list dd{
	}
	.child_list dd .sub-menu{
		display: flex;
		flex-wrap: wrap;
	}
	.child_list dd .sub-menu li{
		width: 50%;
		margin: 1rem 0;
	}
	.child_list dd .sub-menu li a{
		position: relative;
        padding-left: 1.5em;
        display: block;
        line-height: 1.4;
	}
	.child_list dd .sub-menu li a i {
		color: #e40001;
        position: absolute;
        left: 0;
        top: 1px;
	}
	.child_list dd .has_child-list{
		margin-top: 1.5rem;
	}
    .child_list dd .sub-menu .has_child-list li a{
        padding-left: 1em;
    }
	.child_list dd .has_child-list li{
		list-style: none;
		font-size: 1.4rem;
		width: 100%;
	}

	/* search
	----------------------- */
	.search{
		position: relative;
	}
	.search_btn{
		font-size: 0;
	}
	.search_btn::before {
		cursor: pointer;
		content: '\f002';
		font-family: 'Font Awesome 5 Free';
		font-weight: 900;
		font-size: 20px;
		text-align: center;
		width: 30px;
		height: 30px;
		line-height: 30px;
		display: block;
	}
	.search_wrap{
		position: absolute;
		z-index: -1;
		opacity: 0;
		top: -1rem;
		right: 0;
		transition: all 0.4s;
		padding: 1rem 1rem 1rem 1.5rem;
		pointer-events: none;
		display: flex;
	}
	.search_wrap.active{
		opacity: 1;
		z-index: 10;
		background: #fff;
		border-radius: 10px;
		box-shadow: 0 0 10px rgb(0 0 0 / 10%);
	}
	.search_wrap form{
		display: flex;
		pointer-events: auto;
	}
	.search-text, .search-text:focus{
		border: none;
		outline: none;
	}
	.search-submit, .search_close{
		font-size: 2rem;
		width: 3rem;
		height: 3rem;
		line-height: 3rem;
		text-align: center;
		cursor: pointer;
		margin: 0;
		padding: 0;
	}
	.search-submit{
		color: #e40001;
		border: none;
		background: none;
	}
	.search_close{
		font-size: 2.2rem;
		color: #ccc;
	}
}

@media screen and (max-width: 1100px){

	header .head_navi{
		margin-right: 0;
	}
	header .action, .child_tit, header .search{
		display: none;
	}
	header .tb_action{
		display: block;
		float: left;
		max-width: 234px;
		width: 100%;
		height: 60px;
		margin: 30px 5px 10px;
		font-size: 1.6rem;
		}
		header .tb_action i{
			font-size: 2rem;
			margin-right: 8px;
		}
		header .tb_action.btn_support{
			margin-left: 15px;
		}
		header .tb_action.btn_support a span{
			left: 75px;
		}

	/* ボタン
	----------------------- */
	.openbtn{
		display: block;
		position: relative;
		cursor: pointer;
		width: 110px;
		height: 110px;
		background:#e40001;
	}
	.openbtn span{
		display: inline-block;
		transition: all .4s;
		position: absolute;
		left: 0;
		right: 0;
		height: 3px;
		margin: auto;
		border-radius: 2px;
		background: #fff;
		width: 45%;
  }
	.openbtn span:nth-of-type(1) {
	  top: 38px;
	}
	.openbtn span:nth-of-type(2) {
	  top: 54px;
	}
	.openbtn span:nth-of-type(3) {
	  bottom: 38px;
	}
	/*回転*/
	.openbtn.active span:nth-of-type(1) {
	    top: 47px;
	    transform: translateY(6px) rotate(-45deg);
	}
	.openbtn.active span:nth-of-type(2) {
	  opacity: 0;
	}
	.openbtn.active span:nth-of-type(3){
	    top: 60px;
	    bottom: auto;
	    transform: translateY(-6px) rotate(45deg);
	}

	/* 展開の動き
	----------------------- */
	body.fixed{
	  position: fixed;
	  width:100%;
	}
	header .logo, .head_navi{
		position: relative;
		z-index: 1000;
	}
	.gnavi{
		position: fixed;
		z-index: -1;
  	opacity: 0;
    width: 100%;
    height: 100vh;
    left: 0;
    z-index: 100;
    background: #fff;
    transition: all 0.3s;
		border-top: 1px solid #e4e4e4;
		pointer-events: none;
	}
	.gnavi.active{
		opacity: 1;
  	z-index:999;
		pointer-events: auto;
	}
	.gnavi.active .gnavi_list{
    position: fixed;
    z-index: 999; 
    width: 100%;
    height:100%;
    overflow-y: scroll;
    padding-bottom: 150px;
    -webkit-overflow-scrolling: touch;
	}
	/* 内部アコーディオンアイコン
	----------------------- */
	.has-child>a>span,
	.child_list dt{
		position: relative;
	}
	.has-child>a>span::before, .has-child>a>span::after,
	.child_list dt::before, .child_list dt::after{
    content: '';
    display: block;
    width: 1em;
    height: 2px;
    border-radius: 5px;
    background: #e40001;
    position: absolute;
    right: 45px;
    top: 50%;
    transform: translateY(-50%);
	}
	.has-child>a>span::after,
	.child_list dt::after {
    transform: translateY(-50%) rotate(90deg);
    transition: 0.5s;
	}
	.has-child.active>a>span::after,
	.child_list dt.active::after{
    transform: rotate(0);
    transition: 0.5s;
	}
	.gnavi_child{
		display: none;
	}

	/* 内部デザイン
	----------------------- */
	.gnavi_item>a{
		font-size: 2rem;
		font-weight: 600;
		display: block;
		border-bottom: 1px solid #eee;
	}
	.gnavi_item>a>span{
		display: block;
		padding: 30px 25px;
	}
	.child_list{
		border-bottom: 1px solid #eee;
	}
	.child_list dt{
		font-size: 1.7rem;
		font-weight: 600;
		padding: 30px 35px;
	}
	.child_list dt a i {
    color: #e40001;
    margin-left: 1rem;
	}
	.child_list dd{
		display: none;
	}
	.sub-menu li a{
		display: block;
		padding: 15px 50px;
	}
	.sub-menu li a i{
		color: #e40001;
    margin-right: 1rem;
	}
	.child_list dd{
		padding-bottom: 30px;
		font-weight: 500;
	}
}

@media screen and (max-width: 767px){
	header .tb_action{
		font-size: 1.5rem;
		float: none;
		margin: 10px auto auto;
	}
	header .tb_action.btn_support{
		margin: 40px  auto auto;
	}
	/* ボタン
	----------------------- */
	.openbtn{
		width: 60px;
  	height: 60px;
	}
	.openbtn span:nth-of-type(1) {
  	top: 20px;
	}
	.openbtn span:nth-of-type(2) {
		top: 28px;
	}
	.openbtn span:nth-of-type(3) {
	  bottom: 21px;
	}
	.openbtn.active span:nth-of-type(1) {
    top: 21px;
  }
  .openbtn.active span:nth-of-type(3){
    top: 33px;
	}
	/* 内部アコーディオンアイコン
	----------------------- */
	.has-child>a>span::before, .has-child>a>span::after,
	.child_list dt::before, .child_list dt::after{
		right: 20px;
	}

	/* 内部デザイン
	----------------------- */
	.gnavi_item>a{
		font-size: 1.7rem;
	}
	.gnavi_item>a>span{
		padding: 20px 20px;
	}
	.child_list dt{
		font-size: 1.6rem;
		padding: 20px 35px;
	}
	.child_list dd .has_child-list{
		margin-bottom: 1rem;
	}
	.child_list dd .has_child-list li{
		list-style: none;
	}

}


/*--------------------------------------------
 footer
--------------------------------------------*/
footer{
	background: #0d0d0d;
}
/* f_contact
------------------------------*/
.f_contact{
	padding: 70px 0 80px;
	text-align: center;
	background: #f6f6f6;
}
.f_contact-tit{
	font-size: 3.2rem;
	font-weight: 600;
}
.f_contact-txt{
	line-height: 1.5;
}
.f_actions{
	max-width: 800px;
	padding: 0;
	margin: 30px auto 0;
	list-style: none;
	display: flex;
	justify-content: space-between;
}
.f_actions li{
	width: 48.5%;
}
.f_actions a{
	height: 120px;
	text-decoration: none;
	display: flex;
	align-items: center;
	border-radius: 10px;
	background: #fff;
	transition: .5s;
}
.f_actions a:hover{
	box-shadow: 0 5px 25px rgb(0 0 0 / 10%);
}
.f_actions a i{
	width: 35%;
	text-align: center;
	color: #e40001;
	font-size: 3.6rem ;
}
.f_actions a .txt{
	text-align: left;
}
.f_actions a .txt span{
	display: block;
	margin-bottom: .5rem;
}
.f_actions .tel span{
	color: #e40001;
	font-weight: 700;
	font-size: 2.8rem;
	font-family: 'Roboto', sans-serif;
	letter-spacing: 1px;
}
.f_actions .mail span{
	font-size: 1.8rem;
	font-weight: 700;
}

@media screen and (max-width: 767px){

	.f_contact{
		padding: 50px 0;
	}
	.f_contact-tit{
		font-size: 2rem;
	}
	.f_contact-txt{
		line-height: 1.5;
	}
	.f_actions{
		display: block;
	}
	.f_actions {
    margin: 20px auto 0;
  }
	.f_actions li {
    width: 100%;
	}
	.f_actions li+li{
		margin-top: 1rem;
	}
	.f_actions a {
    height: 70px;
  }
	.f_actions a i{
		width: 30%;
		font-size: 2.6rem;
	}
	.f_actions a .txt{
		font-size: 1.2rem;
	}
	.f_actions .tel span{
		font-size: 2rem;
	}
	.f_actions .mail span{
		font-size: 1.5rem;
	}

}

/* foot-conts
------------------------------*/
.foot_conts{
	padding: 50px 0;
}
.foot_conts, .foot_conts a{
	color: #fff;
	font-size: 1.4rem;
	font-weight: 300;
	text-decoration: none;
}
.foot_info{
	font-size: 1.3rem;
	display: flex;
	align-items: center;
}
.foot_logo{
	margin-right: 70px;
}
.foot_logo img{
	width: 150px;
}
.foot_info-address{
	line-height: 1.5;
	letter-spacing: 1px;
}

@media screen and (min-width: 768px){
	/* f_menu
	------------------------------*/
	.f_menu, .f_menu .box, .f_menu dd{
		display: flex;
	}
	.f_menu{
		margin: 50px 0;
	}
	.f_menu .box{
		width: 22%;
		padding: 0 2%;
		border-left: 1px solid #2e2e2e;
	}
	.f_menu .box:last-child{
		border-right: 1px solid #2e2e2e;
	}
	.f_menu .f_menu-service {
		flex-grow: 1
	}
	.f_menu-service{
		display: flex;
		justify-content: space-between;
	}
	.f_menu dd ul{
		margin-left: 5px;
	}
	.f_menu li a{
		display: block;
		padding: 10px 0;
	}
	.f_menu dl{
		flex-grow: 1;
	}
	.f_menu dt{
		margin-bottom: 10px;
	}
	.f_menu dd li a{
		color: #b6b6b6;
		font-size: 1.3rem;
		padding: 6px 0;
	}
	.f_menu dd ul{
		width: 100%;
	}
	.f_menu dd .has_child-list{
		margin-bottom: .8rem;
		margin-left: 1.5rem;
	}
	.f_menu dd .has_child-list li a{
		font-size: 1.2rem;
	}
	
}/*min-width: 769px*/

.f_menu ul, .f_menu dd{
	padding: 0;
	margin: 0;
}
.f_menu li{
	list-style: none;
}
.foot_conts .copy{
	text-align: center;
	letter-spacing: 2px;
	font-size: 1.2rem;
}

@media screen and (max-width: 1250px){
	.f_contact, .foot_conts{
		padding-left: 30px;
		padding-right: 30px;
	}
}/*max-width: 1250px*/

@media screen and (max-width: 767px){
	.foot_info {
    margin: 0 2.5rem 4rem;
	}
	.foot_info{
		display: block;
	}
	.foot_logo p{
		font-size: 1.2rem;
	}
	.foot_info-address{
		font-size: 1.3rem;
	}

	.foot_conts {
    padding-left: 0!important;
    padding-right: 0!important;
	}
	.f_menu{
		border-bottom: 1px solid #424242;
	}
	.f_menu li{
		position: relative;
	}
	.f_menu li::after{
		color: #575757;
		position: absolute;
    right: 0;
    top: 0;
    width: 60px;
    height: 100%;
    font-size: 1.7rem;
    text-align: center;
    content: '\f105';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    display: flex;
    align-items: center;
    cursor: pointer;
    justify-content: center;
	}
	.f_menu .box>ul>li>a{
		display: block;
		padding: 1.8rem 3rem;
		border-top: 1px solid #424242;
	}
	.f_menu .box dl{
		display: none;
	}
	.foot_conts .copy{
		margin-top: 3rem;
		letter-spacing: 0;
	}

}/*max-width: 768px*/

#pagetop {
	display: none;
	color: #fff;
  position: fixed;
  bottom: 20px;
  right: 20px;
  font-size: 14px;
  line-height: 1;
  z-index: 99;
}
#pagetop a{
	display: block;
	width: 40px;
	height: 40px;
	line-height: 40px;
	border-radius: 40px;
	text-align: center;
  background: #e40001;
}

/*--------------------------------------------
 パーツデザイン
--------------------------------------------*/
/* レイアウトデザイン
------------------------------*/
@media only screen and (min-width: 768px){
		.alignnone{
        margin: 15px auto;
		}
    .aligncenter{
        display: block;
        margin: 15px auto;
    }
    p .aligncenter, p .alignnone{
    	margin-top: 0;
    	margin-bottom: 0;
    }
    .alignleft{
        float: left;
        margin: 0 40px 10px 0;
    }
    .alignright {
        float: right;
        margin: 0 0 10px 20px;
    }
}
@media only screen and (max-width: 767px){
		.aligncenter, .alignleft, .alignright, .alignnone{
				margin: 1.5rem auto;
				display: block;
		}
		p .aligncenter, p .alignleft, p .alignright, p .alignnone{
				margin: 0 auto;
		}
}
.gallery img{
	border: none !important;
}
.gallery .gallery-item{
	margin: 1.5rem 0 !important;
}
.wp-caption{
	width: auto!important;
}
.wp-caption-text{
	font-size: .9em;
	color: #888;
}

blockquote {
	position: relative;
	padding: 1rem 4rem 1rem 6rem;
	box-sizing: border-box;
	background: #efefef;
	color: #555;
	margin: 2rem 0;
}
blockquote:before{
	display: inline-block;
	position: absolute;
	top: 18px;
	left: 15px;
	content: "\f10d";
	font-family: FontAwesome;
	color: #cfcfcf;
	font-size: 30px;
	line-height: 1;
	font-weight: 900;
}

table th, table td{
	vertical-align: middle;
	padding: 2.4% 3.4%;
	border: 1px solid #ddd;
  box-sizing: border-box;
}
table th{
	text-align: left;
	width: 25%;
	background: #eee;
}

@media only screen and (max-width: 767px){
	.tags {
		position: relative;
		width: 100%;
		height: 0;
		padding-top: 70%;
	}
	.tags iframe {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
}
/* 見出し
------------------------------*/
.midashi{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	text-align: center;
	line-height: 1.4;
	margin-bottom: 2.6rem;
}
.midashi-tit{
	order: 2;
	width: 100%;
	margin: 0;
	display: block;
	font-size: 3.2rem;
	font-weight: 700;
}
.midashi-eg{
	display: block;
	margin: 0 0 .5rem;
	color: #e40001;
	font-weight: 700;
	font-size: 1.7rem;
	letter-spacing: 1px;
	font-family: 'Roboto', sans-serif;
	text-transform: capitalize;
}
.midashi_txt{
	text-align: center;
	margin: 0 auto 4rem;
}

@media screen and (max-width: 767px){
	.midashi{
		margin-bottom: 1.8rem;
	}
	.midashi h3{
		font-size: 2rem;
	}
	.midashi p{
		font-size: 1.4rem;
		margin: 0 0 0.3rem;
	}
	.midashi_txt{
		text-align: left;
		margin: 0 0 3.5rem;
	}
}

/* タブ
------------------------------*/
.tab_navi{
	margin: 0;
	padding: 0;
	display: flex;
	align-items: stretch;
	justify-content: space-between;
}
.tab_navi li{
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	list-style: none;
	box-sizing: border-box;
	text-align: center;
	line-height: 1.4;
	font-weight: 500;
}

.tab_conts .box:not(:first-child){
  display: none;
}

/* アコーディオン
------------------------------*/
.acd{
	font-weight: 500;
	position: relative;
	cursor: pointer;
	padding: 1.8rem 1.5rem 1.8rem 8rem;
	}
	.acd::before{
		position: absolute;
		left: 2.5rem;
		color: #aaa;
		content: '\2b';
		font-family: 'Font Awesome 5 Free';
		font-weight: 900;
		font-size: 2.2rem;
		line-height: 1;
	}
	.acd.open{
		color: #e40001;
	}
	.acd.open::before{
		content: '\f068';
		color: #e40001;
	}
	.acd_inner{
		padding: 1rem 3rem 4rem 3rem;
	}

/* ぱんくず
------------------------------*/
.pan{
	background: #fafafa;
	box-shadow:0px 6px 6px -1px #eee inset;
}
.pan p{
	font-size: 1.2rem;
	padding: 1.5rem 0;
	margin-top: 0;
	margin-bottom: 0;
	}
	.pan p a{
		color: #333;
		display: inline-block;
		margin-right: .5em;
		text-decoration: none;
	}
	.pan p a+span{
		display: inline;
		margin-left: .5em;
	}
	@media screen and (max-width: 767px){
		.pan p{
			font-size: 1rem;
			line-height: 1.5;
			padding: 1.2rem 0;
		}
	}

/* cate
------------------------------*/
.cate{
	position: relative;
	background-size: cover;
	background-image: url(../img/common_bg.jpg);
	background-position: center;
}
.cate::after{
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	content: "";
	display: block;
	opacity: 0.3;
}
.catename{
	position: relative;
	z-index: 1;
	max-width: 1100px;
	height: 220px;
	margin: auto;
	display: flex;
	flex-wrap: wrap;
	align-content: center;
}
.catename h1{
		font-size: 3.4rem;
		font-weight: 700;
		width: 100%;
	}
	@media screen and (max-width: 1250px){
		.catename{
			padding: 0 2.5rem;
		}
	}
	@media screen and (max-width: 767px){
		.catename{
			height: 125px;
		}
		.catename h1{
			font-size: 2.1rem;
		}
	}

/* ページリンク
------------------------*/
.wp-pagenavi{
  text-align: center;
}
.wp-pagenavi span, .wp-pagenavi a{
	width: 30px;
	height: 30px;
	line-height: 30px;
	text-align: center;
	text-decoration: none;
	display: inline-block;
	border-radius: 50px;
	margin: 0 .3rem;
}
.wp-pagenavi span:not(.extend){
	color: #fff;
	background: #e40001;
}
@media (hover: hover) {
	.wp-pagenavi a:hover{
		color: #e40001;
	}
}



.grecaptcha-badge{
	bottom: 80px !important;
}