@charset "utf-8";








/*
-------------------------------------------
■ WP_pages Wordpress専用ページ　共通style
-------------------------------------------
*/

.WP_pages {
}


/*    wrapper    */

.WP_pages div.wrapper {
	padding-left: 200px;
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: center;
}
.WP_pages div.wrapper>main {
	flex-basis: 850px;
	margin-right: 30px;
	padding-left: 0;
}


/*    breadcrumb    */

.WP_pages nav.breadcrumb {
	width: 100%;
}
.WP_pages nav.breadcrumb>ol {
	width: auto;
	margin: 0 15px;
	padding: 10px 0;
	letter-spacing: -0.3em;
	text-align: left;
}
.WP_pages nav.breadcrumb>ol>li {
	letter-spacing: normal;
	display: inline-block;
	margin-right: 10px;
	padding-right: 15px;
	background-image: url(../image/00_common/link_arrow_gray.gif);
	background-repeat: no-repeat;
	background-position: right center;
}
.WP_pages nav.breadcrumb>ol>li:last-child {
	margin-right: 0;
	padding-right: 0;
	background-image: none;
}
.WP_pages nav.breadcrumb>ol>li>a {
	text-decoration: none;
	color: #666;
	font-size: 0.9em;
}
.WP_pages nav.breadcrumb>ol>li>a,
.WP_pages nav.breadcrumb>ol>li>span {
	line-height: 1.2em;
}
.WP_pages nav.breadcrumb>ol>li>a:hover {
	color: #999;
	text-decoration: underline;
}
.WP_pages nav.breadcrumb>ol>li:last-child>a {
	pointer-events: none;
}


/*    article_lists category等の記事一覧    */

.WP_pages main ul.article_lists>li {
	margin-top: 10px;
	box-shadow: 0 0 3px rgba(0,0,0,0.2);
}
.WP_pages main ul.article_lists>li:first-child {
	margin-top: 0;
}
.WP_pages main ul.article_lists>li>article>a {
	display: block;
	width: 100%;
	text-align: left;
	padding: 20px 20px 20px 0;
	min-height: 180px;
	background-color: rgba(255,255,255,1.0);
	text-decoration: none;
	position: relative;
	overflow: hidden;
}
.WP_pages main ul.article_lists>li>article>a:after {
	content: "";
	display: block;
	background-color: rgba(230,0,45,0.3);
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.WP_pages main ul.article_lists li>article>a:hover:after {
	left: 0;
}
.WP_pages main ul.article_lists>li>article span.thumb {
	display: block;
	width: 270px;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background-size: cover;
	background-position: center;
}
.WP_pages main ul.article_lists>li>article span.date {
	display: inline-block;
	font-size: 0.9em;
	color: rgba(0,0,0,0.6);
	padding-left: 300px;
}
.WP_pages main ul.article_lists>li>article span.category_tag {
	/*display: inline-block;
	width: 110px;
	margin-left: 3px;*/
}
.WP_pages main ul.article_lists>li>article span.category_tag:first-child {
	margin-left: 10px;
}
.WP_pages main ul.article_lists>li>article span.title {
	display: block;
	width: 100%;
	font-size: 1.3em;
	line-height: 1.2em;
	color: #333;
	margin-top: 15px;
	padding-left: 300px;
}
.WP_pages main ul.article_lists>li>article span.detail {
	display: block;
	line-height: 1.4em;
	width: 100%;
	color: rgba(0,0,0,0.6);
	margin-top: 15px;
	padding-left: 300px;
}

.WP_pages main div.nopost {
	width: auto;
	text-align: center;
	padding: 150px 0;
	background-color: rgba(255,255,255,1);
	box-shadow: 0 0 5px rgba(0,0,0,0.3);
}


/*    page_nation 一覧ページ内のページ送り    */

.WP_pages main aside.pager_pc {
	display: block;
}
.WP_pages main aside.page_nation {
	margin-top: 30px;
}
.WP_pages main aside.page_nation ul {
	width: 100%;
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: nowrap;
	flex-wrap: nowrap;
	justify-content: center;
}
.WP_pages main aside.page_nation ul li {
	margin: 0 3px;
}
.WP_pages main aside.page_nation ul li a {
	display: block;
	width: 40px;
	height: 40px;
	line-height: 39px;
	border: solid 1px #E6002D;
	border-radius: 20px;
	color: rgba(0,0,0,0.6);
	background-color: rgba(255,255,255,0.6);
	text-decoration: none;
	text-align: center;
	-webkit-transition: all .4s;
	transition: all .4s;
}
.WP_pages main aside.page_nation ul li a:hover {
	color: #FFF;
	background-color: #E6002D;
}
.WP_pages main aside.page_nation ul li span {
	display: block;
	width: 40px;
	height: 40px;
	line-height: 40px;
	color: #FFF;
	background-color: #E6002D;
	border: solid 1px #E6002D;
	border-radius: 20px;
	text-align: center;
}


/*    next_page_link 一覧ページ内のページ送り SPページ    */

.WP_pages main aside.pager_sp {
	display: none;
}


/*    side_page_link_pc 次（前）の記事へのリンク    */

.WP_pages aside.side_page_link_pc {
	width: auto;
	margin: 30px auto 0;
}
.WP_pages aside.side_page_link_pc>ul {
	width: 100%;
	border: solid 1px #CCC;
	border-radius: 3px;
	padding: 20px 0;
	display: table;
}
.WP_pages aside.side_page_link_pc>ul>li {
	display: table-cell;
	width: 33%;
	vertical-align: middle;
	padding: 0 30px;
}
.WP_pages aside.side_page_link_pc>ul>li>a {
	display: inline-block;
}
.WP_pages aside.side_page_link_pc>ul>li:nth-of-type(1) {
	text-align: left;
	padding-right: 30px;
}
.WP_pages aside.side_page_link_pc>ul>li:nth-of-type(1)>a {
	padding-left: 20px;
	background-image: url(../image/00_common/side_page_link_prev.gif);
	background-repeat: no-repeat;
	background-position: left center;
}
.WP_pages aside.side_page_link_pc>ul>li:nth-of-type(2) {
	width: 34%;
	padding: 0 30px;
	text-align: center;
	border-right: dotted 1px #AAA;
	border-left: dotted 1px #AAA;
}
.WP_pages aside.side_page_link_pc>ul>li:nth-of-type(3) {
	text-align: right;
	padding-left: 30px;
}
.WP_pages aside.side_page_link_pc>ul>li:nth-of-type(3)>a {
	padding-right: 20px;
	background-image: url(../image/00_common/side_page_link_next.gif);
	background-repeat: no-repeat;
	background-position: right center;
}

.WP_pages aside.side_page_link_sp {
	display: none;
}


/*    social_links    */

.WP_pages div.social_links {
	width: 100%;
	text-align: left;
	margin-top: 35px;
}








/*
-------------------------------------------
■ sidebar
-------------------------------------------
*/
aside#sidebar {
	flex-basis: 300px;
}


/*    sidebar_list    */

aside#sidebar section.sidebar_list {
	margin-top: 30px;
}
aside#sidebar section.sidebar_list:first-child {
	margin-top: 0;
}
aside#sidebar section.sidebar_list p.sidebar_tit {
	color: #FFF;
	font-weight: normal;
	font-size: 0.9em;
	padding: 3px 10px;
	background-color: #CCC;
	border-radius: 3px;
	position: relative;
}
aside#sidebar section.sidebar_list p.sidebar_tit:after {
	content: "";
	display: block;
	position: absolute;
	left: 30px;
	bottom: -14px;
	border-top: solid 7px #CCC;
	border-right: solid 7px transparent;
	border-bottom: solid 7px transparent;
	border-left: solid 7px transparent;
}
aside#sidebar section.sidebar_list>ul {
	margin-top: 10px;
}
aside#sidebar section.sidebar_list>ul>li {
	margin-top: 2px;
}
aside#sidebar section.sidebar_list>ul>li:first-child {
	margin-top: 0;
}
aside#sidebar section.sidebar_list>ul>li a {
	display: block;
	padding: 15px 20px;
	color: rgba(0,0,0,0.6);
	background-color: rgba(255,255,255,0.3);
	box-shadow: 0 0 3px rgba(0,0,0,0.1);
	text-decoration: none;
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: nowrap;
	flex-wrap: nowrap;
	justify-content: space-between;
	-webkit-transition: all .3s;
	transition: all .3s;
}
aside#sidebar section.sidebar_list>ul>li a:hover {
	color: rgba(0,0,0,1);
	background-color: rgba(255,255,255,1);
	box-shadow: 0 0 5px rgba(0,0,0,0.3);
}
aside#sidebar section.sidebar_list>ul>li>a span {
	display: block;
}


/*    side_recent_list    */

aside#sidebar section#side_recent_list>ul>li>article>a {
	display: block;
	width: 100%;
	text-align: left;
	padding: 10px 15px;
}
aside#sidebar section#side_recent_list>ul>li>article>a>span.date {
	font-size: 0.8em;
}
aside#sidebar section#side_recent_list>ul>li>article>a>span.category_tag {
	/*display: inline-block;
	font-size: 0.8em;
	padding: 1px 10px;
	min-width: 60px;*/
	margin-left: 3px;
}
aside#sidebar section#side_recent_list>ul>li>article>a>span.title {
	display: block;
	line-height: 1.4em;
	max-width: 100%;
	margin-top: 5px;
}








/*
-------------------------------------------
■ Single_page
-------------------------------------------
*/
#Single_page {
}
#Single_page main article#cont_area {
	padding-top: 30px;
	background-color: rgba(255,255,255,0.7);
	box-shadow: 0 0 5px rgba(0,0,0,0.1);
	text-align: left;
}
#Single_page main article#cont_area span.date {
	font-size: 0.9em;
	color: rgba(0,0,0,0.6);
	display: inline-block;
	padding-left: 30px;
}
#Single_page main article#cont_area span.category_tag {
	/*width: 110px;
	display: inline-block;*/
	margin-left: 10px;
}
#Single_page main article#cont_area h1 {
	font-size: 2.0em;
	line-height: 1.2em;
	margin-top: 10px;
	padding: 0 30px 30px;
	border-bottom: dotted 2px rgba(0,0,0,0.4);
}
#Single_page main article#cont_area div.article_detail {
	padding: 30px;
	min-height: 300px;
	position: relative;
}








/*
-------------------------------------------
■ Single_pages　記事装飾
-------------------------------------------
*/
.cms_editor h1,
.cms_editor h2 {
	color: #333;
	font-size: 1.8em;
	letter-spacing: 0.1em;
	text-indent: 0.1em;
	margin: 60px 0 30px;
	padding-bottom: 30px;
	border-bottom: solid 3px #CCC;
	position: relative;
}
.cms_editor h1:first-of-type,
.cms_editor h2:first-of-type {
	margin-top: 30px;
}
.cms_editor h1:after,
.cms_editor h2:after {
	content: "";
	display: block;
	width: 30%;
	height: 3px;
	position: absolute;
	left: 0;
	bottom: -3px;
	background-color: #666;
}
.cms_editor h3 {
	color: #333;
	font-size: 1.6em;
	margin: 60px 0 30px;
	padding-left: 20px;
	border-left: solid 3px #333;
}
.cms_editor h4 {
	color: #444;
	font-size: 1.2em;
	margin: 60px 0 30px;
	padding-left: 20px;
	border-left: solid 1px #333;
}
.cms_editor h5 {
	color: #444;
	font-size: 1.1em;
	margin: 60px 0 30px;
}
.cms_editor p {
	margin-top: 20px;
}
.cms_editor p:first-child {
	margin-top: 0;
}
.cms_editor strong {
	font-weight: bold !important;
}
.cms_editor em {
	font-style: italic !important;
}
.cms_editor ul,
.cms_editor ol {
	margin-left: 20px;
}
.cms_editor ul>li {
	list-style: disc !important;
}
.cms_editor ol>li {
	list-style: decimal !important;
}
.cms_editor blockquote {
	width: 80%;
	margin: 30px auto;
	padding: 30px;
	border: dashed 1px #CCC;
	border-radius: 3px;
	background-color: #EFEFEF;
}
.cms_editor hr {
	border-top: none;
	border-right: none;
	border-left: none;
	border-bottom: dotted 1px #BBB;
}
.cms_editor table {
	width: 100%;
	border-top: solid 1px #BBB;
	border-bottom: solid 1px #BBB;
	border-left: solid 1px #BBB;
}
.cms_editor table tr {
	border-bottom: dotted 1px #BBB;
}
.cms_editor table tr:last-of-type {
	border-bottom: none;
}
.cms_editor table tr th,
.cms_editor table tr td {
	padding: 5px 10px;
	border-right: solid 1px #BBB;
}
.cms_editor img {
	max-width: 100%;
	height: auto;
}
.cms_editor img.aligncenter {
	display: block;
	margin: 0 auto;
}
.cms_editor img.alignleft {
	display: block;
	margin: 0 auto 0 0;
}
.cms_editor img.alignright {
	display: block;
	margin: 0 0 0 auto;
}








/*
-------------------------------------------
■ Contact Form 7
-------------------------------------------
*/

/*　フォーム先頭に出るメッセージ　*/
div.wpcf7 .screen-reader-response {
	display: none;
}
/*　フォーム先頭に出るメッセージ下　各項目のエラー内容　*/
div.wpcf7 .screen-reader-response ul {
	display: none;
}
/*　各項目の直下に表示されるエラー内容　*/
div.wpcf7 .wpcf7-not-valid-tip {
	display: block;
	color: #FFF;
	text-align: left;
	position: relative;
	background-color: rgba(255,0,40,1.0);
	width: 100%;
	padding: 5px 10px;
	border-radius: 5px;
	margin-top: 5px;
}
div.wpcf7 div.privacy_check .wpcf7-not-valid-tip {
	text-align: center;
}
div.wpcf7 .wpcf7-not-valid-tip:after {
	content: "";
	position: absolute;
	top: -20px;
	left: 20px;
	width: 0px;
	height: 0px;
	margin: auto;
	border-style: solid;
	border-color: transparent transparent rgba(255,0,40,1.0) transparent;
	border-width: 10px 5px 10px 5px;
}
div.wpcf7 div.privacy_check .wpcf7-not-valid-tip:after {
	left: 49%;
}
/*　フォーム最後に表示されるエラーメッセージ　*/
/*　フォーム最後に表示される送信エラーメッセージ　*/
/*div.wpcf7 .wpcf7-validation-errors,
div.wpcf7 div.wpcf7-spam-blocked {
	color: #FFF;
	text-align: center;
	border: none;
	background-color: rgba(255,0,40,1.0);
	width: 1000px;
	margin: 30px auto 0;
	padding: 20px 10px;
	border-radius: 5px;
}*/
/*　フォーム最後に表示される送信エラーメッセージ　*/
.wpcf7 form .wpcf7-validation-errors,
.wpcf7 form .wpcf7-spam-blocked,
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
	color: #FFF;
	text-align: center;
	border: none;
	background-color: rgba(255,0,40,1.0);
	border-color: rgba(255,0,40,1.0);
	width: 1000px;
	margin: 30px auto 0;
	padding: 20px 10px;
	border-radius: 5px;
}
/*　フォーム最後に表示される送信エラーメッセージ　*/
/*.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
	color: #FFF;
	text-align: center;
	border: none;
	background-color: rgba(255,0,40,1.0);
	border-color: rgba(255,0,40,1.0);
	width: 1000px;
	margin: 30px auto 0;
	padding: 20px 10px;
	border-radius: 5px;
}*/
/*　フォーム送信後にフォーム入力項目を非表示　*/
div.wpcf7 form.sent section.input_area,
div.wpcf7 form.sent section.privacy_policy,
div.wpcf7 form.sent div.submit_button,
div.wpcf7 form.sent div.inv-recaptcha-holder {
	display: none !important;
}
/*　フォーム最後に表示されるメール送信完了メッセージ　*/
div.wpcf7 .wpcf7-mail-sent-ok {
	border: none;
	font-size: 1.1em;
	width: 1000px;
	margin: 0 auto;
	padding: 100px 30px;
	border: solid 1px #CCC;
	border-color: #CCC !important;
	background-color: #FFF;
	border-radius: 5px;
	box-shadow: 0 0 3px rgba(0,0,0,0.1);
}
.wpcf7 form.sent .wpcf7-response-output {
	border: none;
	font-size: 1.1em;
	width: 1000px;
	margin: 0 auto;
	padding: 100px 30px;
	border: solid 1px #CCC;
	border-color: #CCC !important;
	background-color: #FFF;
	border-radius: 5px;
	box-shadow: 0 0 3px rgba(0,0,0,0.1);
}







