/*
Theme Name: basstemplate
Theme URI:
Author: the WordPress team
Author URI: https://wordpress.org/
Description: Twenty Sixteen is a modernized take on an ever-popular WordPress layout — the horizontal masthead with an optional right sidebar that works perfectly for blogs and websites. It has custom color options with beautiful default color schemes, a harmonious fluid grid using a mobile-first approach, and impeccable polish in every detail. Twenty Sixteen will make your WordPress look beautiful everywhere.
Version: 1.4
License: GNU General publish License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: one-column, two-columns, right-sidebar, accessibility-ready, custom-background, custom-colors, custom-header, custom-menu, editor-style, featured-images, flexible-header, microformats, post-formats, rtl-language-support, sticky-post, threaded-comments, translation-ready, blog
Text Domain: twentysixteen

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.
*/
.orange{
  --stylecolor:  #e5690c;
}
.pink{
  --stylecolor:  #cd3872;
	
}
.green{
  --stylecolor:  #29af9d;
}
.blue{
  --stylecolor:  #0071bc;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,ｆ
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-style:normal;
	font-weight: normal;
	font-size: 100%;
	vertical-align: baseline;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

html{
    overflow-y: scroll;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

input, textarea{
	margin: 0;
	padding: 0;
}

ol, ul{
    list-style:none;
}

table{
    border-collapse: collapse;
    border-spacing:0;
}

caption, th{
    text-align: left;
}

a:focus {
	outline:none;
}
.both{
	clear:both;
}
p {
    display: block;
    -webkit-margin-before:0;
    -webkit-margin-after: 0;
    -webkit-margin-start: 0px;
    -webkit-margin-end: 0px;
}
.inline_block {
	display: inline-block;
	*display: inline;
	*zoom: 1;
}
html{
/*font-family: 'Noto Serif JP', serif;*/
font-family: 'Noto Sans JP', sans-serif,"游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
font-size:10px;
line-height:1.6;
color:#222020;
}
html.fsmall{
	font-size: 8px;
}
html.flarge{
	font-size: 12px;
}

@media (max-width: 700px){
	html{
		font-size: 9px;
	}
	html.fsmall{
		font-size: 8px;
	}
	html.flarge{
		font-size: 10px;
	}
	
}
body{
	font-size: 1.6rem;
}

img{
	display:block;
	max-width:100%;
	height:auto;
}
a,
a:hover,
a:active,
a:visited,
a:link{
	
}
ol, ul{
    list-style:none;
}

.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/*¥*//*/
	height: auto;
	overflow: hidden;
	/**/
}

.both{
	clear:both;
}

.inline_block {
	display: inline-block;
	*display: inline;
	*zoom: 1;
}

span{
	display:inline-block;
	font-weight: inherit;
}

p{margin-bottom:1.3em;
	margin-top: -0.3em;
}
p:last-child{margin-bottom:-0.3em;
}


@media (min-width: 701px){

.twocolumn{
	margin:auto;
	width:100%;
	display:flex;
	justify-content:flex-start;
	flex-wrap:wrap;
	gap:20px;
}
.twocolumn li{
	width:calc(50% - 10px);
	box-sizing:border-box;
}
.twocolumn li img{
	max-width:100%;
	display:block;
	margin:0;
}
.twocolumn li p{
}



.threecolumn{
	display:flex;
	margin:auto;
	justify-content:flex-start;
	flex-wrap:wrap;
	gap:50px;

}
.threecolumn li{
	width:calc(33.33% - 100px / 3);
	box-sizing:border-box;
}
.threecolumn li img{
	max-width:100%;
	display:block;
	margin:0;
}
}

@media (max-width: 640px){
}

.error404.content-area{
	float:none;
	margin:auto;
}
.error404.content-area main{
	text-align:center;
	margin-right:auto;
}

.error404 h1 {
    font-size: 70px;
}
@media screen and (max-width: 800px){
.error404 h1 span {
    display: block;
    font-size: 36px;
    margin-bottom: 20px;
}
}



body{
	background: #f9f9f9;
}
article.toppage{
	max-width: 1450px;
	margin:auto;
	background: #ffffff;
	overflow: hidden;
}

.site-header{
	padding: 0 20px;
	background: #ffffff;
}
.header_container{
	margin:auto;
	max-width:1450px;
	width:100%;
	position:relative;
	display:flex;
	justify-content:space-between;
	margin:auto;
	align-items:center;
	padding-top: 20px;
	padding-bottom: 20px;
}
.headermain{
	position:relative;
	width:100%;
	display:flex;
	justify-content:space-between;
}
.headernavi{
	flex-shrink:0;
}
.headernavi ul{
	margin:auto;
	max-width: 1240px;
	display:flex;
}
.headernavi ul a{
	padding:25px 10px;
	color:#000;
	display:block;
	font-size:15px;
	position:relative;
	transition:0.3s 0.2s;
}
.headernavi ul a.current{
}
.headernavi ul a:after{
	content:"";
	display:block;
	left:0;
	right:0;
	bottom:0;
	height:1px;
	background-color:#999;
	width:0;
    transition: 0.3s 0.3s;
}
.headernavi ul a:hover{
	color:#999;
}
.headernavi ul a:hover:after{
	width:100%;
}
.headernavi ul a.current:after{
	background-color:#000;
	width:100%;
}
.header_right{
	display: flex;
	align-items: center;
    width: 100%;
    justify-content: flex-end;
}
.headernavi{
	display: flex;
	align-items: center;
	margin-right: 20px;
}
.headernavi li{
	margin-right: 10px;
	padding-right: 10px;
	border-right: solid 1px #0067e6;
}
.headernavi a{
	color: #6d6d6d;
	transition: all 1s ease-out;
}
.headernavi a:hover{
}
.headernavi li:last-child{
	border-right: 0;
	padding-right: 0;
	margin-right: 0;
}
.headermain{	align-items: center;
	gap:20px;
}
.headerlogo{
	align-items: center;
	max-width: 240px;
	width: 100%;
	flex-shrink: 0;
}
.headerlogo a{
	width: 100%;
}
.header_btn{
	display: flex;
	gap:16px;
	align-items: center;
	justify-content: flex-end;
    flex-shrink: 1;
	width: 100%;
}
.header_btn a{
	color: #fff;
	font-size: 1.5rem;
	font-weight: 600;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 15px;
	height: 40px;
	border-radius: 30px;
	border: solid 2px #cd3872;
	background-color: #cd3872;
	transition: 0.5s;
	text-decoration: none;
	position: relative;
    gap: 10px;
    align-items: center;
    justify-content: center;
}
.header_btn .btn_pink:before,
.header_btn .btn_orange:before{
    content: "";
    width: 1.2em;
    height: 1.2em;
    display: block;
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    background-image: url(../images/arrow_2.svg);
}
.header_btn a.btn_ma{
	background-color: #cd3872;
	border-color: #cd3872;
}
.header_btn a.btn_or{
	background-color: #e5690c;
	border-color: #e5690c;
}




.header_btn a.btn_blue{
	background-color: #0071bc;
	border-color: #0071bc;
}

.header_btn a.btn_green{
	background-color: #29af9d;
	border-color: #29af9d;
}
.header_btn a.btn_orange{
	background-color: #e5690c;
	border-color: #e5690c;
}

.header_btn a:hover{
	opacity: 0.5;
}
.header_btn_other,
.header_btn_other:active,
.header_btn_other:visited,
.header_btn_other:link{
	background-color: #fff;
	border-color: #cd3872;
	color: #cd3872;
	gap:10px;
	line-height: 1.1;
	
}
.header_btn_other:before {
    content: "";
    width: 1.2em;
    height: 1.2em;
    display: block;
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
	background-image: url(../images/page_common/icon_btn_other_p.svg);
}

.header_btn_link,
.header_btn_link:active,
.header_btn_link:visited,
.header_btn_link:link{
	background-color: #fff;
	border-color: #cd3872;
	color: #cd3872;
	gap:10px;
	line-height: 1.1;
	
}
.header_btn_link:before {
    content: "";
    width: 1.2em;
    height: 1.2em;
    display: block;
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
	background-image: url(../images/arrow_2h.svg);
}
.navibtn{
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	gap:8px;
	flex-direction: column;
	cursor: pointer;
	flex-shrink: 0;
	width: 30px;
}
.navibtn span{
	font-size: 8px;
	font-weight: 500;letter-spacing: -1px;
}
.navibtn img{
	width: 40px;
}
.fsize_area{
	margin: 0 20px;
	padding: 5px 15px;
	border-right: solid 1px #b3b3b3;
	border-left: solid 1px #b3b3b3;
	flex-shrink: 0;
}
.fsize_area > p{
	font-size: 16px;
	margin-bottom: 10px;
	font-weight: 500;
}
.fsize{
	display: flex;
	gap:10px;
	justify-content: center;
}
.fsize p{
	width: 22px;
	margin: 0;
	cursor: pointer;
}
.fsize p img{
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}
.fsize p.active img{
	opacity: 0;
}

.fsize_small.active{
	background-image: url("../images/fsize_s1.svg");
}
.fsize_normal.active{
	background-image: url("../images/fsize_m1.svg");
}
.fsize_large.active{
	background-image: url("../images/fsize_l1.svg");
}
@media (max-width: 1100px){
.header_right .header_btn,
	.header_right .fsize_area{
	display: none;
}
}


.listitem_text{
	display:block;
	width:100%;
	color:#787878;
}
.listitem_text a{
	width:100%;
	display:flex;
	justify-content:flex-start;
	align-items:flex-start;
	position:relative;
}
.listitem_text:last-child{
	margin-bottom:0;
}



.taglist{
	display:flex;
	justify-content:flex-start;
	align-items:flex-start;
	color:#bf1920;
	flex-wrap:wrap;
	margin-bottom:40px;
	gap:8px;
}
.tag{
    border: solid 1px #bf1920;
    border-radius: 5px;
    font-size: 12px;
    display: flex;
    justify-content: center;
    box-sizing: border-box;
    padding: 0px 6px;
    text-align: left;
    min-width: 80px;
    text-align: center;
}
.tag.current,
.tag:hover{
	background-color:#bf1920;
	color:#fff;
}

.btn_a{
	display:flex;
	justify-content:center;
	color:#fff;
}
.btn_a a{

    text-align: center;
    background-color: #0067E6;
	border: solid 2px #0067E6;
    display: flex;
    /* height: 30px; */
    justify-content: center;
    align-items: center;
    font-size: 20px;
    font-size: min(2rem, 3.8vw);
    /* border-radius: 5px; */
    box-sizing: border-box;
    transition: 0.3s;
    line-height: 1;
	padding: 15px;
	border-radius: 50px;
	min-width: 230px;
	box-sizing: border-box;
}
.btn_a a:hover{
	background-color:#ffffff;
	color: #0067E6;
}
.btn_a a span.center{
    margin-bottom: 0.3em;
}

.btn_w{
	display:flex;
	justify-content:center;
	color:#000;
}
.btn_w a{
	box-sizing:border-box;
    width: 140px;
    text-align: center;
    background-color: #fff;
	border:solid 1px #000;
    display: flex;
    height: 30px;
    justify-content: center;
    align-items: center;
    font-size: 14px;
	border-radius:5px;
	transition:0.3s;
}
.btn_w a:hover{
	color:#fff;
	background-color:#000;
}

.two_column_left{
	display: flex;
	justify-content: center;
	align-items:flex-start;
	flex-direction: row-reverse;
}
.two_column_left > article{
	max-width: 745px;
	width: 100%;
	flex-shrink: 1;
}
.two_column_left > aside{
	width: 216px;
	margin-right: 20px;
	flex-shrink: 0;
}

.two_column,
.three_column{
		display: flex;
		flex-wrap: wrap;
	gap:35px;
	flex-direction:column;
	}
.two_column > div,
.two_column > li,
.three_column > div,
.three_column > li{
	width: 100%;
}

@media (min-width: 801px){
.two_column,
.three_column{
	flex-direction: row;
	}
.two_column > div,
	.two_column > li{
	width: calc(50% - 70px / 2);
	}
.three_column > div,
.three_column > li{
	width: calc(33.33% - 70px / 3);
}
}

.movie_list_item{
	background-color: #F2F2F2;
}
.movie_list_item h4{
    height: 3.2em;
    padding: 5px 10px;
    display: block;
    overflow: hidden;
		  overflow: hidden;
		  display: -webkit-box;
		  -webkit-box-orient: vertical;
		  -webkit-line-clamp: 2;
}

.movie_list_item .listitem_box_img{
	position: relative;
}
.movie_list_item .listitem_box_img:after {
    content: "";
    width: 25%;
    height: 0;
    padding-top: 25%;
    background-image: url(../images/icon_play.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    display: block;
    z-index: 10;
    transition: 0.3s;
	opacity: 0;
}
.movie_list_item a:hover .listitem_box_img:after {
    opacity: 0.6;
}
.movie_list_item .listitem_box_img:before {
    content: "";
    width: 100%;
    height: 100%;
    z-index: 5;
    position: absolute;
    top: 0;
    left: 0;
    background-color: rgba(0,0,0,0);
    transition: 0.3s;
}

.movie_list_item a:hover .listitem_box_img:before {
    background-color: rgba(0,0,0,0.60);
}
.listitem_box{
	background-color: #F2F2F2;
}
.listitem_box_img{
	width: 100%;
	display:block;
	padding-top: calc(56.25% - 2px);
	background-position: center;
	background-size: cover;
}

.listitem_box_text{
	padding: 10px;
}
.postdate{
	display: block;
	word-break: keep-all;
	margin: 0;
	font-size: 12px
}
	.listitem_box_text .text{
	   /* height: calc(3em * 1.6);*/
	    display: block;
	    overflow: hidden;
			  overflow: hidden;
			  display: -webkit-box;
			  -webkit-box-orient: vertical;
			  -webkit-line-clamp: 3;
}
.listitem_text h4,
.listitem_box h4{
	color: #5F5F5F;
	font-weight: 600;
	font-size: 18px;
	    height: 1.6em;
	    display: block;
	    overflow: hidden;
			  overflow: hidden;
			  display: -webkit-box;
			  -webkit-box-orient: vertical;
			  -webkit-line-clamp: 1;
}
.listitem_box a:hover h4{
	color: #cd3872;
}




@media (min-width: 701px){
}
@media (max-width: 700px){
}
.site-footer{
	margin: auto;
    background: linear-gradient(120deg, #f2cddc50 7%, #fbb09550 100%);
    background: linear-gradient(120deg, #f9e9f3 7%, #fadeda 100%);
	padding: 60px 20px;
	box-sizing: border-box;
}
.foot_logo{
	max-width: 320px;
    margin-bottom: 2rem;
}
.foot_address{
    margin-bottom: 2rem;
}
.site-footer .icon{
	justify-content:flex-end;
	display:flex;
}
.foot_inner{
	display: flex;
	gap:40px;
	margin: auto;
	max-width: 1450px;
	margin-bottom: 20px;
	border-bottom: solid 1px #222020;
	padding-bottom: 40px;
}
.foot_inner > .left{
	width: 100%;
}
.foot_inner > .right{
	display: flex;
	flex-shrink: 0;
}
.foot_navi{
	margin: auto;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
    justify-content: space-evenly;
	gap:20px;
}
.foot_navi ul li{
	margin-bottom: 1rem
}
.foot_navi ul li:last-child{
	margin-bottom: 0rem
}
.foot_navi a{
	font-weight: 600;
	display: block;
	text-decoration: none;
	color: inherit;
	font-size:1.6rem;
    padding-left: 1.4em;
    background-position: center;
    background-position: left center;
    background-size: 1.4rem auto;
    background-repeat: no-repeat;
    background-image: url("../images/arrow_2_o.svg");
}
.foot_navi a:link,
.foot_navi a:active,
.foot_navi a:visited{
	color: inherit;
}
.foot_navi a:hover{
	text-decoration: none;
}
.foot_navi .child{
	padding-left: 1.4rem;
}
.foot_navi .child a{
    font-weight: 400;
    color: inherit;
    font-size: 1.4rem;
    padding-left: 2em;
    background-position: center;
    background-position: left 1em center;
    background-size: 1.3rem auto;
    background-repeat: no-repeat;
    background-image: url(../images/icon/icon_tree.svg);
}
@media (max-width: 800px){
	.foot_navi a{font-size:1.7rem;}
	.foot_navi .child a{font-size:1.5rem;}
	.site-footer{padding: 40px 20px;}
}
.foot_sns{
	display: flex;
	flex-wrap: wrap;
	gap:15px;
}
.foot_sns a{
	width: 50px;
	display: block;
	max-width: 15%;
}

.top_btn{
	position: fixed;
	display: block;
	width: min(10vw,66px);
	bottom: min(4vw,30px);
	right: min(4vw,30px);
	z-index: 100;
}

.navi_btn{
	margin-top: 1.6rem;
}
.navi_btn a{
	    padding: 0.5em 1.3em;
    display: flex;
    align-items: center;
    justify-content: center;
	background: none;
    border-radius: 100px;
    border: solid 2px #e5690c;
	    background-color: #fff;
    color:  #e5690c;
    gap: 0.5em;
    cursor: pointer;
    margin: 0 !important;
    font-weight: 600;
    font-size: 1.8rem;
    transition: 0.5s;
	text-decoration: none;
}
.navi_btn a:before {
    content: "";
    width: 1.2em;
    height: 1.2em;
    display: block;
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
	background-image: url(../images/page_common/icon_btn_other_o.svg);
}
.navi_btn a:active,
.navi_btn a:visited,
.navi_btn a:link{
    color:  #e5690c;
}
.navi_btn a:hover{
    color:  #e5690c;
    opacity: 0.5;
}

.navi_btn .navi_btn_link:before {
    width: 1em;
    height: 1em;
	background-image: url(../images/arrow_2_o.svg);
}

.foot2{
	margin-bottom: 20px;
display: flex;
justify-content: center;
align-items: center;
	padding: 10px 20px;
	column-gap: 20px;
}
.foot2 a{
	color: #e5690c;
	font-size:1.4rem;
	font-weight: 700;
	
	text-decoration: none;
}
.copyright{
	line-height:1;
	margin: auto;
	text-align:left;
	display:block;
	color:#2A2A2A;
	font-weight: 600;
	font-size:1.4rem;
	margin-bottom: 20px;
    max-width: 1450px;
}


@media (max-width: 800px){
	.foot_inner{
		flex-direction: column-reverse;
	}
	.foot_navi .child{
		gap:15px;
		display: flex;
		flex-wrap: wrap;
	}
	.foot_navi{
        gap: 1rem;
		column-gap: 4rem;
        margin: 0;
        flex-wrap: wrap;
		justify-content: flex-start;
        width: 100%;
	}
}
/*@media (max-width: 1000px){
	.foot_navi{
		flex-wrap: wrap;
		justify-content: flex-start;
        max-width: 400px;
	}
	.foot_navi > div{
		width: calc(50% - 10px);
	}
}
@media (max-width: 600px){
	.foot2{
		flex-direction: column;
		align-items: center;
	}
}*/

.page_container{
	padding:70px 20px;
	padding-bottom:0;
	margin:auto;
    min-height: 500px;
	position: relative;
}
.page_container > .inner{
    padding-bottom: 70px;
}
.page_title{
    font-size: 24px;
    margin: 0px;
    text-align: center;
    color: #ababab;
    line-height: 1.4;
    font-weight: 700;
}
.page_header{
	color: #fff;
	padding: 0 20px;
    height: 100px;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
	background-image: url("../images/pageheader_bg.jpg");
	position: relative;
}
.page_header .imgtitle {
	max-height: 40px;
    height: 7vw;
    margin: 0;
}
.page_header .page_header_kome{
	position: absolute;
	bottom: -30px;;
	padding: 0 20px;
	box-sizing: border-box;
	max-width: 1020px;
	margin: auto;
	left: 0;
	right: 0;
	color: #0067e6;
	text-align: right;
}
.title_illust{
	width: 160px;
}
.page_header .imgtitle img {
    width: auto;
    height: 130%;
	margin: auto;
}

@media (max-width: 800px){
.title_illust{
	width: 80px;
	}
.page_header {
	height: 130px;
}
}
#page{
	position: relative;
	z-index: 10;
}

.listitem_text{
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	gap:15px;
}
.postcat{
    width: 100px;
    display: block;
    flex-shrink: 0;
    padding-top: 5px;
}
.postcat span{
	width: 100%;
	word-break: keep-all;
	background-color: #e3ebf5;
	text-align: center;
	display: block;
    font-size: 12px;
	line-height: 28px;
	color: #5f5f5f;
	line-height: 1.4;
	margin-top: 15px;
}
.postcat span:first-child{
	margin-top: 0px;
}
.listitem_text h4{
	flex-shrink: 1;
	width: 100%;
}
.listitem_text p{
	margin-bottom: 0;
}


.archive_content .information_list {
}
.archive_content .listitem_text{
	border-bottom:solid 1px #5f5f5f;
}
.archive_content .listitem_text:first-child{
	border-top:solid 1px #5f5f5f;
}
.archive_content .listitem_text a{
	padding:10px 0;
}
.navigation .screen-reader-text{
	display:none;
}
.pagenavi{
	margin-top:50px;
	display:flex;
	justify-content:center;
	align-items:center;
}
.contact{
	border:none;
	margin-left:110px;
	max-width:740px;
	width:100%;
}
.contact th,
.contact td{
	border:none;
}
.contact th{
	width:190px;
}
.contact span{
	width:100%;
}
input, textarea{
	
}
/*input[type="submit"]{
    border: solid 3px #5f5f5f;
    color: #ffffff;
	font-size: 20px;
	font-weight: 600;
    background-color: #5f5f5f;
    width: 300px;margin: auto;
    padding: 15px 30px;
	cursor:pointer;
    transition: 0.3s;
	text-align: center;
	display: block;
}
input[type="submit"]:hover{
    color: #5f5f5f;
    background-color: #ffffff;
	border: solid 3px #5f5f5f;
}*/
	.spnavi_bg{
		display: none;
		position: fixed;
		width: 100%;
		top: 0;
		height: 100vh;
		left: 0;
		background-color: rgba(0,0,0,0.50);
		z-index: 90;
		cursor: pointer;
	}


.spnavibtn{
	display:flex;
}
.headernavi,
.en_link{
	display:none;
}
	.head_contact{
		display: none;
	}
.site-header{
	transition:0.5s;
	overflow:hidden;
}
	.header_container{
		padding: 10px 0;
	}
.site-header.active{
}
	.head_navi{
		display: none;
	}
.spnavi{
    position: fixed;
    justify-content: center;
    align-items: center;
	left: 0;
	width: 100%; 
    top: 0;
    padding-top: 60px;
	padding-bottom: 60px;
    margin: auto;
    font-size: 20px;
    background-color: #fff;
	display: none;
	z-index: 101;
	max-height: 100%;
}
.spnavi_close{
	position: absolute;
	top: 15px;
	right: 15px;
}
	.spnavi_bg{
	}
	.search_btn{
		display: none;
	}
.spnavi_inner{
    margin: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: auto;
    align-items: center;
    justify-content: flex-start;
    padding: 0 20px;
    max-height: calc(100vh - 60px);
	box-sizing: border-box;
}
.spnavi_inner ul{
	display: flex;
	align-items: center;
	gap:15px;
	max-width: 500px;
	margin: auto;
	flex-wrap: wrap;
}
.spnavi_inner ul li{
	width: calc(33.33% - 15px * 2 / 3 )
}

.spnavi .navi_btn{
	gap:15px;
	flex-wrap: wrap;
display: flex;
	justify-content: center;
    margin-top: 30px;
    margin-bottom: 30px;
}
@media (max-width: 700px){

.spnavi_inner ul{
	max-width: 300px;
        width: 65%;
}
.spnavi_inner ul li{
	width: calc(50% - 15px * 1 / 2 )
}
}
.spnavi_inner .fsize_area{
	border: none;
}
.navi_parent{
	display:flex;
	flex-wrap:wrap;
    align-items: center;
}
.navi_parent ul{
	width:100%;
}
.navi_parent ul li{
	margin-bottom:0;
	margin-top:0.5em;
	margin-left:1em;
}
.navi_child{
	font-size:16px;
}
.childopen{
	transform:rotateZ(45deg);
	border-bottom:solid 2px #000;
	border-right:solid 2px #000;
    width: 15px;
    height: 15px;
    margin-left: 15px;
    margin-top: 0px;
    margin-top: -10px;
}
.childopen.opend{
	transform:rotateZ(225deg);
    margin-top: 10px;
}


@media (max-width: 800px){
	.box1 .pc{display: none;}.box1 .sp{display: block;}
}
@media (max-width: 700px){

.contact{
	margin:auto;
}
.contact table,
.contact tbody,
.contact td,
.contact th{
	display:block;
	width:100%;
    box-sizing: border-box;
}




.twocolumn li,
.threecolumn li{
	margin-bottom:20px;
}
.twocolumn li:last-child,
.threecolumn li:last-child{
	margin-bottom:0;
}


.page_container {
    padding: 40px 20px;
	padding-bottom:0;

}
.post_detail{
	display:block;
}
.post_detail .left{
    margin-bottom: 10px;
}
}
@media (max-width: 480px){
}

.maincontents{
background: #ffffff;
width: 100%;
	padding: 40px 60px;
	box-sizing: border-box;
}
.single-topics .maincontents{
	background: none;
}
.single-topics .maincontents > .page_inner{
	align-items: flex-start;
}
.single-topics .maincontents .single_content .single_content_inner{
background: #ffffff;
	border-radius: 20px;
	padding: 20px;
}
.single-topics .maincontents .single_content .single_content_inner{
	min-height: 600px;
}
.sidebar.single{
	background: #ffffff;
	border-radius: 20px;
	padding: 20px;
	margin-bottom: 20px;
}
.post_pager{
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 40px;
}
@media (max-width: 1200px){
	.maincontents{
		padding: 40px 20px;
	}
}
.maincontents > .page_inner{
box-sizing: border-box;
width: 100%;
max-width: 1450px;
	margin: auto;
}
@media (min-width: 1001px){
.side_on{
	display: flex;
	justify-content: space-between;
}
	.side_on > main{
		width: 100%;
		flex-shrink: 1;
	}
	.side_on > aside{
		width: 300px;
		margin: 0;
		margin-left: 40px;
		flex-shrink: 0;
	}
	.side_on.left{
		flex-direction: row-reverse;
	}
	.side_on.left > aside{
		margin: 0;
		margin-right: 30px;
}
}

@media (max-width: 1000px){
	.sidebar{
	margin-top: 100px;
        border-top: 1px solid #cccccc;
        padding-top: 60px;
        padding-bottom: 20px;
	}
}
@media (max-width: 800px){
	.side_on > main{
		margin-bottom: 60px;
	}
	.side_on > aside{
	}
}
.navigation.pagination{
	margin-top: 60px;
}
.navigation .screen-reader-text{
	display:none;
}
.pagenavi{
	margin-top:50px;
	display:flex;
	justify-content:center;
	align-items:center;
	color:#004097;
}
.page_num{
	margin-bottom:0;
	margin-right:20px;
	color:#004097;
}
.nav-links{
	display:flex;
    justify-content: center;
	color: #ababab;
}


.page-numbers{
	border:solid 1px #ababab;
	background-color:#fff;
	display:flex;
	justify-content:center;
	align-items:center;
	line-height:1;
	width:30px;
	height:30px;
	margin-right:10px;
	transition:0.3s;
	color: #ababab;
}
.page-numbers:hover{
	color:#fff;
	background-color:#ababab;
}
.page-numbers.current{
	color:#fff;
	background-color:#ababab;
}
.page-numbers:last-child{
	margin-right:0;
}
.page-numbers.prev,
.page-numbers.next{
	display:none;
}
.sidebar{
}
.search_word{
    padding-bottom: 5px;
    margin-bottom: 20px;
    color: #004097;
    border-bottom: solid 1px #004097;
    font-size: 1.2rem;
}

.wpcf7-form-control-wrap{
	width: 100%;
}


@media screen and (max-width: 640px){
.contact_table,
.contact_table tr,
.contact_table td,
.contact_table th{
    display: block;
    width: 100%;
    text-align: left;
    padding: 0;
}
    .contact_table td{
    padding-bottom: 10px;}
    .contact_table th{
        padding-bottom: 0;
}

}
.contact_table .requied{
    font-size: 12px;
    background-color: #FF0004;
    color: #fff;
    display: inline-block;
    padding: 0 5px;
    margin-left: 10px;
}
.contact_table form, 
.contact_table input,
.contact_table textarea{
    border: solid 1px #ccc; 
}
.contact_table input[type="submit"] {
    margin: auto;
    display: block;
    background-color: #ababab;
    color: #fff;
    border: solid 2px #ababab;
}
.contact_table input[type="submit"]:hover{
    background-color: #fff;
    color: #ababab;
}
.contact_table input[type="date"]{
    font-size: 16px;
    padding: 3px 3px;
    border: solid 1px #ccc;
}
.contact_table select {
    font-size: 16px;
    padding: 5px;
    border: solid 1px #ccc; 
}

.popupmoviebox{
	position:fixed;
	width:90%;
	z-index:100001;
	display:none;
	left:5%;
	top:50%;
	margin-top:-25.3125%;	
}
.popupmoviebox iframe{
	width:100%;
}
.popupmoviebg{
	position:fixed;
	height:100vh;
	width:100vw;
	z-index:100000;
	display:none;
     top: 0;
    left: 0;
	background-color:rgba(0,0,0,0.70);
}
.moviethumb{
	cursor:pointer;
}

.youtubearea{
	padding:0 !important;
	width:100%;
	height:0;
	position:relative;
  padding-top: 56.25% !important;
  overflow:hidden;
  margin-bottom:20px;
}
.youtubearea iframe{
	width:100%;
	height:100%;
	position:absolute;
	top:-20%;
	right:-20%;
	left:-20%;
	bottom:-20%;
	margin:auto;
}



.head_navi a{
    letter-spacing: 0.15em;
	font-size:18px;
	font-weight: 700;
	display: block;
	padding: 10px 0 ;
}
.head_navi a:hover{
	color: #cd3872;
}
.head_navi ul{
	max-width: 1200px;
	margin: auto;
	display: flex;
	align-items:center;
	justify-content:flex-start;
    column-gap: 40px;
	flex-wrap: wrap;
}



.modal a{
	display: block;
	
}
.modaltitle{
	display: flex;
	gap:20px;
	align-items: flex-start;
	justify-content: space-between;
	border-bottom: solid 4px var(--stylecolor);
	width: calc(100% - 30px);
	margin-bottom: 30px;
	padding-bottom: 10px;
}
.modaltitle h1{
	font-size: 2.2rem;
	color: var(--stylecolor);
	font-weight: 700;
}
.batu{
	position: relative;
    width: 16px;
    height: 16px;
    display: block;
    background-size: cover;
	cursor: pointer;
}
.batu:after,
.batu:before{
	content: "";
	background-color: var(--stylecolor);
	height: 2px;
	width: 22px;
	position: absolute;
	display: block;
	left: -10px;
	right: -10px;
	top: -10px;
	bottom: -10px;
	margin: auto;
	transform: rotate(45deg);
	transform-origin: 50% 50%;
}
.batu:before{
	transform: rotate(-45deg);
	transform-origin: 50% 50%;
}
.modalouter,
.modalouter_f2,
.modalouter_f3 {
	position: fixed;
	width: 100%;
	z-index: 100001;
	display: none;
	left: 0;
	bottom: 0;
	margin: auto;
	top: 0;
	bottom: 0;
	box-sizing: border-box;
	align-items: center;
	height: 100vh;
	padding: 30px;
	background-color: rgba(0,0,0,0.40);
	flex-direction: column;
	justify-content: flex-start;
}
.modalouter_f2 {
	z-index: 100011;
	padding:40px 40px;
}
.modalouter_f3 {
	z-index: 100012;
	padding:50px 50px;
}
.modalbox {
	display: none;
	max-width: 800px;
	width: 100%;
	background-color:#FFFFFF;
	border-radius: 15px;
	padding: 30px;
	padding-right: 0;
	max-height: calc(100vh - 100px);
	box-sizing: border-box;
	flex-direction: column;
	position: relative;
}
.modalinner{
	overflow: auto;
	width: 100%;
	padding-right: 30px;
	box-sizing: border-box;
}
.modal_f1.hide:before{
	content: "";
	border-radius: 15px;
	background-color: rgba(0,0,0,0.40);
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
}
.modal_f2{
	margin: 0 auto;
	z-index: 10;
    max-width: 780px;
    max-height: calc(100vh - 120px);
}
.modal_f3{
	margin: 0 auto;
	z-index: 10;
    max-width: 760px;
    max-height: calc(100vh - 140px);
}


.accordion_title{
	position:relative;
		cursor: pointer;
}
.page_content .accordion_title h4{
	margin-bottom: 0;
}
.accordion_title h4{
	
}
.accordion_title h4:after{
	content:none;
}
.accordion_title h4:first-child{
	margin-top:0;
}
.finished .accordion_title h4{
    background-color: #ccc;
}
.accordion_title .open_btn{
	right:2rem;
	position:absolute;
	top:0;
	bottom:0;
	margin:auto;
	width:25px;
	height:25px;
	display:block;
	cursor:pointer;
}
.accordion_title .open_btn a{
	position:relative;
	width:25px;
	height:25px;
	display:block;
}
.accordion_title .open_btn a:before,
.accordion_title .open_btn a:after{
	content:"";
	display:block;
	position:absolute;
	top:0;
	bottom:0;
	right:0;
	left:0;
	margin:auto;
	background-color:#fff;
	transition:0.3s
}
.accordion_title .open_btn a:after{
      width: 25px;
    height: 7px;
}
.accordion_title .open_btn a:before{
      width: 7px;
    height: 25px;
}
.accordion_title .open_btn.close a:after{
	transform:rotate(180deg);
}
.accordion_title .open_btn.close a:before{
	transform:rotate(180deg);
	height:0;
}
.accordion_detail{
	display:none;
}

.faqcat_list{
	width:100%;
	margin:auto;
	margin-bottom:40px;
	box-sizing:border-box;
}
.sidebar .faqcat_list {
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
}



.information_list_item{
	border-bottom: solid 1px #e5690c;
}
.information_list_item:last-child{
	border-bottom: none;
}
.information_list_item a{
	padding:0.5em 0 ;
	padding-right: 3.6em;
	font-size: 1.6rem;
	display: block;
	position: relative;
	text-decoration: none;
	
	color: #222020;
	font-weight: 500;
}
.information_list_item a:after{
	content: "";
	background-image: url("../images/arrow.svg");
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	position: absolute;
	right: 1em;
	top: 0;
	bottom: 0;
	margin: auto;
	width: 1.6em;
	height: 1.6em;
}
.information_list_item .postdate{
	color: #e5690c;
	font-size: 1.2rem;
	margin-left: 0!important;
	padding: 0;
}

.search_box input[type="text"]{
	padding: 2rem;
    border-radius: 1rem;
    border: none;
    border: 1px solid #cccccc;
    box-sizing: border-box;
    font-size: 1.8rem;
	line-height: 1;
	width: 100%;
}
.search_box input[type="submit"]{
	width:100%;
	margin-top:1rem;
	padding: 2rem;
	 font-size: 1.8rem;
	background-color:#cd3872;
	border:none;
	color: #fff; 
	box-shadow: none;;
	border: none;
	cursor: pointer;
	box-sizing: border-box;
	line-height: 1;
	border-radius: 1rem;
}
.page_content .search_box{
      display: flex;
    align-items: center;
    max-width: 500px;
    margin: auto;
}
.page_content .search_box input[type="submit"] {
    width: 80px;
	margin:0;
    margin-left: 20px;
}
.page_content .faq_list{
	margin-left: 0;
	margin:auto;
}
.faq_list li.accordion_box {	
    margin-bottom: 2rem;
}
.faq_list .accordion_title .open_btn a:before {
    width: 2px;
    height: 20px;
}
.faq_list .accordion_title .open_btn.close a:before {
    transform: rotate(180deg);
    height: 0;
}
.faq_list .accordion_title .open_btn a:after {
    width: 20px;
    height: 2px;
}
.faq_list .accordion_detail{
	padding: 2rem;
    background-color: #ffffff;
    box-sizing: border-box;
    font-size: 1.6rem;
    margin-top: 5px;
    border: 1px solid #cccccc;
    border-radius: 1rem 1rem 1rem 1rem;
}
.page_content .faq_list .accordion_detail p{
	margin-left: 0;
}
.accordion_title span{
      width: calc(100% - 230px);
}
.accordion_title .catname{
	    display: inline-block;
    font-size: 1.2rem;
    text-align: left;
    width: inherit;
    padding: 5px 10px;
    background-color: #fff;
    /* margin-right: 20px; */
    color: #cd3872;
    box-sizing: border-box;
    font-weight: 600;
    margin-bottom: 0.3rem;
    border-radius: 5px;
}
.accordion_title{
	text-align:left;
	display:flex;
	align-items:center;
	justify-content:flex-start;
	font-size:1.6rem;
     padding: 1.2rem 2rem;
    padding-right: 5rem;
	background-color:#f1f1f1;
	color:#4e4d4d;
	border-radius: 1rem;
}
.page_content .accordion_title h4{
	margin: 0;
	color: inherit;
}
.faqlist_title h4:after{
	content:none;
}
.accordion_box p.q{
	
    font-size: 2.2rem;
    font-weight: 700;
    font-family: "monospace";
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 5rem;
    height: 5rem;
    border-radius: 8rem;
    /* top: 0; */
    /* bottom: 0; */
    /* left: 0; */
    background: var(--stylecolor);
    margin: 0;
	margin-right: 1rem;
    flex-shrink: 0;
}
.accordion_title.faqlist_title .open_btn a:before,
.accordion_title.faqlist_title .open_btn a:after {
    background-color: #4e4d4d;
}
.page_content .faqcat_list{
		display:flex;
	flex-wrap: wrap;
	gap:2rem;
}
.faqcat_list .btn_area{
	width: calc( 33% - 1rem);
	margin-left: 0;
}
.faqcat_list a{
		width: 100%;
		
}

.left_navi .search_box{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: 3rem;
}
.left_navi .search_box input[type="submit"] {
	width: 60px;
	padding: 10px;
	font-size:1.6rem;
	height: 4rem;
	margin: 0;
}
.left_navi .search_box input[type="text"] {
	width: calc(100% - 70px);
	padding: 10px;
	font-size:1.6rem;
	height: 4rem;
	margin: 0;
}
.left_navi dt{
	font-weight: 600;
	font-size:2rem;
	margin-bottom: 2rem;
	position: relative;
	padding-bottom: 1rem;
}
.left_navi dt:after{
	content: "";
	z-index: 2;
	width: 30%;
	height: 5px;
	background: #e5690c;
	display: block;
	position: absolute;
	bottom: 0;
	border-radius: 10px;
}
.left_navi dt:before{
	content: "";
	z-index: 1;
	width: 100%;
	height: 5px;
	background: #cd3872;
	display: block;
	position: absolute;
	bottom: 0;
	border-radius: 10px;
}

.sidebar .faqcat_list a{
	border:1px solid #cccccc;
	text-decoration: none;
	font-size:1.8rem;
	font-weight: 600;
	padding: 0.5rem 2rem;
	border-radius: 60px;
	box-sizing: border-box;
	text-align: center;
	transition: 0.5s;
	
}
.sidebar .faqcat_list a:hover{
	opacity: 0.5;
}
.sidebar .faqcat_list a.active{
	background: #cd3872;
	color: #ffffff;
}

.kijibox{
	border:1px solid #cccccc;
	padding:0;
	border-radius: 6px;
	margin-bottom: 3rem;
	overflow: hidden;
	position: relative;
}
.kijibox h3{
	font-size:2rem;
	font-weight: 700;
	color: #e5690c;
	padding: 1rem;
}
/*
.post_head{
	padding-bottom: 1rem;
	border-top:6px solid #e5690c;
	margin-bottom: 0rem;
	border-bottom:1px solid #cccccc;
    background: linear-gradient(120deg, #f2cddc50 7%, #fbb09550 100%);
	background: linear-gradient(120deg, #f9e9f3 7%, #fadeda 100%);
}
*/
.postdate{
	font-size:1.6rem;
	padding: 0 1rem;
}
.post_main{
	padding: 1.5rem;
}
.single_content .post_main{
	padding: 0;
}

.post_head{
	padding: 2rem;
	margin-bottom: 0rem;
    background: linear-gradient(120deg, #f2cddc50 7%, #fbb09550 100%);
	background: linear-gradient(120deg, #f9e9f3 7%, #fadeda 100%);
	border-radius: 1.5rem;
	margin-bottom: 30px;
}
.post_head h1{
	font-size: 2.4rem;
	font-weight: 600;
	color: #e5690c;
	margin-bottom: 1rem;
}
.post_head .postdate{
	font-size:1.4rem;
	padding: 0;
}

@media (max-width: 1000px){
	.faqlist_title h4{
		display:block;
	}
	.accordion_title .catname{
		margin-bottom:10px;
		width:max-content;
	}
	.faqcat_list .btn_area{
		width: calc( 50% - 1rem);
		margin-left: 0;
	}
}



@media (max-width: 640px){
	.faqcat_list .btn_area{
		width:100%;
		margin-left: 0;
	}
}

.backnumber_list_item{
	margin-bottom: 2rem;
}
.backnumber_list_item:last-child{
	margin-bottom: 0;
}

.backnumber_list_item a{
	display: block;
	background-color: #f1f1f1;
	border-radius: 10px;
	display: flex;
	justify-content: flex-start;
	text-decoration: none;
	align-items: flex-start;
	justify-content: space-between;
	padding:0.5rem 2rem ;;
	gap:1rem;
	color: inherit;
}
.backnumber_list_item .file_type{
	margin: 0;
	height: calc(1.8rem * 1.6);
	display: flex;
	align-items: center;
	padding:0 1em;
	background-color: #cd3872;
	color: #fff;
	border-radius: 5px;
}
.page_content .backnumber_list_item h4{
	margin: 0;
	color: inherit;
}