@charset "UTF-8";

/*
Theme Name: 2022mj_ekamjp
Description: 2022mj_ekamjp
Theme URI: https://ekamjapan.org/
Author: https://ekamjapan.org/
Author URI: https://ekamjapan.org/
Version: 1.0.0
License: GNU General Public License
License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/

@font-face {
	font-family: 'Josefin_Sans';
	src: url(fonts/Josefin_Sans/JosefinSans-VariableFont_wght.ttf) format('truetype');
	font-display: swap;
}
.josefin {
	font-family: 'Josefin_Sans', sans-serif;
}
.yu {
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif !important;
}
.yumin {
	font-family: "游明朝体", YuMincho, "游明朝", "Yu Mincho", serif !important;
}


* {
	font-size: inherit;
	line-height: inherit;
}
*, *:before, *:after {
	box-sizing: inherit;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
html, body {
	margin: 0;
	padding: 0;
}
body {
	color: #363636;
	font-size: 16px;
	line-height: 1.8;
	font-weight: 400;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
	/*font-family: "ヒラギノ丸ゴ ProN W4","Hiragino Maru Gothic ProN","メイリオ","Meiryo","ＭＳ Ｐゴシック","MS PGothic",sans-serif;*/
}
*, *:before, *:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}
p {
	margin:0 0 1.5em 0;
	padding: 0;
}
p:last-child {
	margin: 0;
}

@media screen and (max-width: 768px) {
	body {
		font-size: 15px;
	}
}
@media screen and (max-width: 430px) {
	body {
		font-size: 14px;
	}
}
@media screen and (max-width: 320px) {
	body {
		font-size: 13px;
	}
}

/****************************************
 * リンク
*****************************************/

a {
	color: #01224F;
	text-decoration: none;
	transition: all .3s;
	-webkit-transition: all .3s;
	word-break: break-all;
}
a:hover {
	opacity: .7;
}
a img {
	transition: all .3s;
	-webkit-transition: all .3s;
}
a img:hover {
	opacity: .7;
}



/* 別ウィンドウリンク
*****************************************/
a.tab {
	display: inline-block;
	position: relative;
	padding-right: 25px;
	line-height: 1;
}
a.tab:after {
	content: "";
	display: inline-block;
	position: absolute;
	top: 0;
	right: 3px;
	background: url(images/common/icon_tab.png) no-repeat;
	background-size: 100%;
	background-position: center;
	width: 16px;
	height: 16px;
}


/* メインボタン
*****************************************/

.main_btn {
	display: inline-block !important;
	width: auto !important;
	margin: 10px !important;
	padding: 18px 3.6em 18px 2em!important;
	text-align: center !important;
	text-transform: uppercase !important;
	transition: .5s !important;
	color: #FFF !important;
	background: #066cbb;
    background-image: linear-gradient(to right, #047FCC 0%, #0457CC 100%);
	background-size: 200% auto !important;
	position: relative !important;
}
.main_btn:before {
	content: '';
	width: 12px;
	height: 12px;
	border: 0;
	border-top: solid 1px #FFF;
	border-right: solid 1px #FFF;
	position: absolute;
	top: 50%;
	right: 1.6em;
	transform: translateY(-50%) rotate(45deg);
}
.main_btn:hover {
	opacity: 1 !important;
	background-position: right center !important;
	box-shadow: 2px 2px 6px -1px rgb(19 71 52 / 30%) !important;
	color: #fff !important;
	text-decoration: none !important;
}
.big_box .main_btn { /*トップイメージの中のボタン*/
	font-size: 1.3em;
}

@media screen and (max-width: 768px) {
	.main_btn {
		padding: 18px 3em 18px 2em !important;
	}
}
@media screen and (max-width: 430px) {
	.main_btn {
		font-size: 1.1em;
		width: 100% !important;
		padding: 15px 3em 15px 1.3em !important;
		margin: 0 !important;
	}
	button.main_btn {
		margin: 8px 0 0 !important;
	}
}
@media screen and (max-width: 390px) {
	.main_btn {
		font-size: 1em;
		padding: 12px 1.3em 12px .8em !important;
	}
	.main_btn:before {
		width: 10px;
		height: 10px;
		right: 1.2em;
	}
	button.main_btn {
		margin: 6px 0 0 !important;
	}
}
@media screen and (max-width: 320px) {
	.main_btn {
		font-size: 1em;
		padding: 12px 3em 12px 1.3em !important;
	}
	button.main_btn {
		margin: 6px 0 0 !important;
	}
}

/* テキストリンク
*****************************************/
a.line {
	padding-right: 60px;
	position: relative;
}
a.line:before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	background: #000;
	width: 45px;
	height: 1px;
}
a.line:after {
	content: "";
	display: inline-block;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	transform-origin: right bottom;
	width: 12px;
	height: 1px;
	background: #000;
	transform: rotate(45deg);
}
a.line:hover {
	opacity: 1;
	color: #0457CC;
}
a.line:hover:before,
a.line:hover:after {
	background: #0457CC;
}

/****************************************
 * h要素
*****************************************/
h1, h2, h3, h4, h5, h6 {
	font-family: "游明朝体", YuMincho, "游明朝", "Yu Mincho", serif !important;
	font-weight: 600;
	margin: 0;
	text-align: center;
	color: #0457CC;
	line-height: 1.6;
}
#privacy-policy h2,
#privacy-policy h3,
#privacy-policy h4,
#privacy-policy h5 {
	color: #000;
}

h2 {
	font-size: 2.8em;
	margin-bottom: 60px;
}
h3 {
	text-align: left;
	font-size: 2em;
	margin-bottom: 30px;
}
h4 {
	font-size: 1.8em;
	margin-bottom: 30px;
}


.main_title {
	font-size: 2.8em;
	text-align: center;
	margin-bottom: 90px;
	padding-bottom: 42px;
	position: relative;
	z-index: 99;
}
.main_title.up_span {
	padding-top: 42px;
	padding-bottom: 0;
}
.main_title span {
	display: block;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	font-size: .5em;
}
.main_title span.small {
	display: block;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	font-size: .5em;
}
.main_title span.dots {
	display: inline-block;
	position: static;
	left: auto;
	right: auto;
	transform: none;
	font-size: .8em;
	margin-right: -6px;
	margin-left: -6px;
}
#page .main_title {
	margin-bottom: 30px;
	padding-bottom: 45px;
}
#page .main_title:before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%) rotate(45deg) skew(20deg, 20deg); /* 関数同士はスペースで空ける */
	background: #BA9847;
	width: 10px;
	height: 10px;
}
#page .main_title span.number {
	display: inline-block;
	position: static;
	font-size: 1.3em;
	transform: none;
}
#page .main_title span.gold {
	display: inline-block;
	position: static;
	transform: none;
	font-size: 1em;
	
	color: #c5a942;
	background: -webkit-linear-gradient(0deg, #e0c66d, #B67B03);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}


.main_title_ud {
	font-size: 2.5em;
	text-align: center;
	margin-bottom: 90px;
	padding: 45px 0 90px;
	position: relative;
}
.main_title_ud span.toptxt,
.main_title_ud span.btmtxt {
	display: block;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	font-size: .6em;
}
.main_title_ud span.toptxt {
	width: 100%;
	position: absolute;
	top: 0;
}
.main_title_ud span.btmtxt {
	width: 100%;
	position: absolute;
	bottom: 45px;
}
.main_title_ud:before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%) rotate(45deg) skew(20deg, 20deg); /* 関数同士はスペースで空ける */
	background: #BA9847;
	width: 10px;
	height: 10px;
}


.main_title_u {
	font-size: 2.5em;
	text-align: center;
	margin-bottom: 90px;
	padding: 45px 0 90px;
	position: relative;
}
.main_title_u span.toptxt {
	width: 100%;
	display: block;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	font-size: .6em;
}
.main_title_u:before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%) rotate(45deg) skew(20deg, 20deg); /* 関数同士はスペースで空ける */
	background: #BA9847;
	width: 10px;
	height: 10px;
}




.sub_title {
	font-size: 2.6em;
	text-align: center;
	margin-bottom: 30px;
	color: #493C1C;
	position: relative;
	z-index: 1;
}
.sub_title span.ph_gr {
	display: block;
	font-size: .8em;
	color: #c5a942;
	background: -webkit-linear-gradient(0deg, #e0c66d, #B67B03);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
.sub_title span.number {
	font-size: 1.6em;
	margin: 0 3px;
}
.sub_title span.gold {
	color: #c5a942;
	background: -webkit-linear-gradient(0deg, #e0c66d, #B67B03);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
.sub_title span.green {
	color: #06b056;
}
.mini_title {
	color: #000;
	font-size: 1.8em;
	text-align: center;
	margin-bottom: 30px;
}
.mini_title span {
	display: block;
	font-size: .8em;
}

@media screen and (max-width: 1024px) {
}
@media screen and (max-width: 768px) {
	h2 {
		font-size: 2.3em;
	}
	h3 {
		font-size: 1.8em;
	}
	h4 {
		font-size: 1.5em;
	}
	
	.main_title {
		font-size: 2.3em;
		margin-bottom: 75px;
	}
	.main_title span.small {
		font-size: .68em;
	}
	.main_title_ud {
		font-size: 2.3em;
		margin-bottom: 75px;
	}
	.main_title_ud span.toptxt,
	.main_title_ud span.btmtxt {
		font-size: .68em;
	}
	.main_title_u {
		font-size: 2.3em;
		margin-bottom: 75px;
	}
	.main_title_u span.toptxt {
		font-size: .68em;
	}
	.sub_title {
		font-size: 1.8em;
	}
	.mini_title {
		font-size: 1.5em;
	}
}
@media screen and (max-width: 560px) {
	h2 {
		font-size: 2em;
	}
	h3 {
		font-size: 1.6em;
	}
	h4 {
		font-size: 1.3em;
	}
	
	.main_title {
		font-size: 2em;
		margin-bottom: 60px;
	}
	.main_title_ud {
		font-size: 2em;
		padding: 30px 0 75px;
		margin-bottom: 60px;
	}
	.main_title_ud span.toptxt,
	.main_title_ud span.btmtxt {
		font-weight: normal;
	}
	.main_title_u {
		font-size: 2em;
		padding: 30px 0 75px;
		margin-bottom: 60px;
	}
	.main_title_u span.toptxt {
		font-weight: normal;
	}
	.sub_title {
		font-size: 1.6em;
	}
	.mini_title {
		font-size: 1.4em;
	}
	
}
@media screen and (max-width: 430px) {
	h2 {
		font-size: 1.8em;
	}
	h3 {
		font-size: 1.4em;
	}
	h4 {
		font-size: 1.2em;
	}
	
	.main_title {
		font-size: 1.8em;
		margin-bottom: 45px;
	}
	.main_title.up_span {
		padding-top: 30px;
		margin-bottom: 30px;
	}
	.main_title_ud {
		font-size: 1.8em;
		line-height: 1.4;
		margin-bottom: 45px;
		padding: 30px 0 70px;
		letter-spacing: -.08em;
	}
	.main_title_ud span.toptxt,
	.main_title_ud span.btmtxt {
		letter-spacing: 0;
	}
	.main_title_ud span.btmtxt {
		bottom: 38px;
	}
	.main_title_u {
		font-size: 1.8em;
		line-height: 1.4;
		margin-bottom: 45px;
		padding: 30px 0 45px;
		letter-spacing: -.08em;
	}
	.main_title_u span.toptxt {
		letter-spacing: 0;
	}
	.sub_title {
		font-size: 1.4em;
	}
	.mini_title {
		font-size: 1.3em;
	}
}
@media screen and (max-width: 390px) {
	.main_title_ud {
		font-size: 1.68em;
	}
	.main_title_u {
		font-size: 1.68em;
	}
}
@media screen and (max-width: 320px) {
	h2 {
		font-size: 1.6em;
	}
	h3 {
		font-size: 1.3em;
	}
	h4 {
		font-size: 1.1em;
	}
	
	.main_title {
		font-size: 1.6em;
	}
	.main_title span.small {
		font-size: .8em;
	}
	.main_title_ud {
		font-size: 1.6em;
	}
	.main_title_u {
		font-size: 1.6em;
		padding: 30px 0;
	}
	.sub_title {
		font-size: 1.3em;
	}
	.mini_title {
		font-size: 1.2em;
	}
}




/*左右にライン*/
.main_title.line {
	font-size: 2.5em;
	font-weight: bold;
	margin: 0 0 12px;
	color: #BA9847;
	
	display: flex;
	align-items: center;
	justify-content: center;
}
.main_title.line:before,
.main_title.line:after {
	content: "";
	border-top: 1px solid;
	width: 3em;
}
.main_title.line:before {
	margin-right: 1em;
}
.main_title.line:after {
	margin-left: 1em;
}
/*左右にライン ここまで */

.archive_title,
.new_arrival_title {
	font-size: 1.8em;
	text-align: center;
	margin-bottom: 60px;
}

@media screen and (max-width: 768px) {
	.main_title.line {
		font-size: 2.3em;
		margin: 0 0 12px;
	}
}
@media screen and (max-width: 560px) {
	.main_title.line {
		font-size: 2em;
	}
	.main_title.line:before,
	.main_title.line:after {
		width: 1em;
	}
}
@media screen and (max-width: 430px) {
	
}
@media screen and (max-width: 320px) {
	.main_title.line {
		font-size: 1.6em;
	}
}




/****************************************
 * リスト
*****************************************/
table {
	border-collapse: collapse;
	table-layout: fixed;
}
dl,
dt,
dd {
	margin: 0;
	padding: 0;
	list-style: none;
}
ul,ol {
	margin: 0;
	padding: 0;
	list-style: none;
}
ul ul{
	margin-left: 1em;
}

/****************************************
 * レスポンシブ
*****************************************/

@media screen and (min-width: 1025px) {/*1025px以上で*/
	.tb {
		display: none !important;
	}
	.pc {
		display: block !important;
	}
	.sp {
		display: none !important;
	}
}
@media screen and (max-width:1024px) {/*1024px以下で*/
	.tb {
		display: block !important;
	}
	.pc {
		display: none !important;
	}
	.sp {
		display: none !important;
	}
}
@media screen and (max-width: 560px) {/*480px以下で*/
	.tb {
		display: none !important;
	}
	.sp {
		display: block !important;
	}
}

/****************************************
 * 上部固定ヘッダー
*****************************************/

.fix_header {
	background: #FFF;
	color: #333;
	position: fixed;
	top: -120px;
	left: 0;
	text-align: center;
	width: 100%;
	margin: 0 auto;
	opacity: 0;
	z-index: 1000;
	box-shadow: 0 0 6px rgb(0 0 0 / 20%);
}
.fix_header_contents {
	width: 100%;
}
.fix_header_flex {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.fix_header_flex .fix_header_flex___logo {
	min-width: 75px;
	padding-left: 30px;
}
.fix_header_flex .fix_header_flex___right___flex {
	display: flex;
	align-items: center;
}
.fix_header_flex .fix_header_flex___nav {
	min-width: 760px;
	padding-left: 18px;
}
.fix_header_flex .fix_header_flex___nav nav#fix_header ul {
	padding: 0;
	margin: 0;
	list-style: none;
	display: flex;
	justify-content: space-between;
}
.fix_header_flex .fix_header_flex___nav nav#fix_header ul li {
	
}
.fix_header_flex .fix_header_flex___nav nav#fix_header ul li:last-child {
	margin-right: 0;
}
.fix_header_flex .fix_header_flex___nav nav#fix_header ul li a {
	font-size: .9em;
	font-weight: bold;
}
.fix_header_flex .fix_header_flex___nav nav#fix_header ul li a:hover {
	opacity: 1;
	color: red;
}
.fix_header_flex .fix_header_flex___contact {
	min-width: 330px;
}
.fix_header_flex .fix_header_flex___contact ul {
	padding: 0;
	margin: 0;
	min-height: 75px;
	display: flex;
	align-items: stretch;
	justify-content: flex-end;
}
.fix_header_flex .fix_header_flex___contact ul li {
	display: flex;
	align-items: center;
}
.fix_header_flex .fix_header_flex___contact ul li.phone {
	padding: 0 18px;
}
.fix_header_flex .fix_header_flex___contact ul li.mail {
	width: 150px;
	position: relative;
}
.fix_header_flex .fix_header_flex___contact ul li.mail:before {
	content: "";
	display: inline-block;
	position: absolute;
	left: 50%;
	top: 12px;
	transform: translateX(-50%);
	background: url(images/common/icon_mail-FFF.png) no-repeat;
	background-size: 100%;
	background-position: center;
	width: 14px;
	height: 14px;
}
.fix_header_flex .fix_header_flex___contact ul li p.phone {
	line-height: 1;
}
.fix_header_flex .fix_header_flex___contact ul li p.phone span.number {
	display: block;
	font-size: 1.3em;
	font-weight: bold;
}
.fix_header_flex .fix_header_flex___contact ul li p.phone span.open {
	display: block;
	margin: 8px 0 0;
	font-size: .8em;
}
.fix_header_flex .fix_header_flex___contact ul li a {
	display: block;
	text-align: center;
	font-weight: bold;
	background: #066cbb;
	background-image: linear-gradient(to right, #047FCC 0%, #0457CC 73%);
	color: #FFF;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}
.fix_header_flex .fix_header_flex___contact ul li a.mail {
	padding-top: 12px;
}

.fix_header_contact {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
}
.fix_header_contact .logo {
	
}
.fix_header_contact .contact {
	margin-left: 45px;
}
.fix_header_contact .contact p.phone {
	display: inline-block;
	margin: 0 0 -5px;
	padding-left: 30px;
	font-size: 1.8em;
	vertical-align: middle;
	position: relative;
}
.fix_header_contact .contact p.phone:before {
	content: '';
	display: block;
	position: absolute;
	margin: auto;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	background: url(images/common/icon140_phone.png) no-repeat;
	background-size: 100%;
	width: 22px;
	height: 22px;
}
.fix_header_contact .contact a.mail {
	display: inline-block;
	margin: 0 0 0 15px;
	padding: 20px 20px;
	border-radius: 60px;
	background: #0F9B9E;
	background-image: linear-gradient(45deg, #0f9b9e, #58a7d2);
	color: #FFF;
}
.fix_header_contact .contact a.mail:hover {
	background: #0F9B9E;
	background-image: none;
}




@media screen and (max-width: 1024px) {
	.fix_header_contents {
		width: 100%;
	}
}
@media screen and (max-width: 568px) {
	.fix_header {
		display: none;
	}
}


/****************************************
 * ヘッダー
*****************************************/

header {
	position: relative;
	border-top: 3px solid #0457CC;
}
header .header {
	padding: 18px 30px;
}
header .header .bloginfo {
	font-weight: normal;
	text-align: left;
	font-size: .9em;
	color: #01224F;
	line-height: 1;
}
header .header_flexbox {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
header .header_flexbox .header_flexbox___logo {
	width: 275px;
	display: flex;
	justify-content: flex-start;
}
header .header_flexbox .logo {
	margin: 0;
	padding: 0;
}
header .header_flexbox .logo a {
	display: inline-block;
}
header .header_flexbox .header_flexbox___nav {
	width: calc(100% - 275px);
}
header .header_flexbox .header_flexbox___nav .header_flexbox___nav_contact {
	display: flex;
	justify-content: flex-end;
}
header .header_flexbox .header_flexbox___nav .header_flexbox___nav_contact .header_flexbox___nav_contact_flex {
	width: 380px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
header .header_flexbox .header_flexbox___nav .header_flexbox___nav_contact .header_flexbox___nav_contact_flex .header_phone {
	
}
header .header_flexbox .header_flexbox___nav .header_flexbox___nav_contact .header_flexbox___nav_contact_flex .header_phone span.hours {
	display: block;
	text-align: center;
	font-size: .8em;
}
header .header_flexbox .header_flexbox___nav .header_flexbox___nav_contact .header_flexbox___nav_contact_flex .header_phone a {
	color: #0457CC;
}
header .header_flexbox .header_flexbox___nav .header_flexbox___nav_contact .header_flexbox___nav_contact_flex .header_phone span.phone_number {
	display: inline-block;
	text-align: center;
	font-size: 1.8em;
	font-weight: bold;
	line-height: 1;
}
header .header_flexbox .header_flexbox___nav .header_flexbox___nav_contact .header_flexbox___nav_contact_flex a.header_form {
	overflow: hidden;
	display: inline-block;
	text-align: center;
	background-image: linear-gradient(to right, #047FCC 0%, #0457CC 73%);
	color: #FFF;
	box-shadow: 0px 3px 5px rgb(0 0 0 / 20%);
	padding: 10px 20px 10px 20px;
	border: 3px solid #FFF;
	text-decoration: none;
	position: relative;
	z-index: 1;
}
header .header_flexbox .header_flexbox___nav .header_flexbox___nav_contact .header_flexbox___nav_contact_flex a.header_form:before {
	content: "";
	display: inline-block;
	position: absolute;
	top: -10px;
	left: -10px;
	transform: rotate(-20deg);
	background: url(images/common/mainbtn_bg.png);
	background-repeat: no-repeat;
	background-size: 100%;
	background-position: center;
	width: 80px;
	height: 55px;
	z-index: -1;
}


/*下部*/
header .header_bottom {
	position: relative;
	left: 0;
	right: 0;
	top: -75px;
	margin: auto;
	z-index: 1;
}
header .header_bottom .inner {
	width: 1260px;
}

@media screen and (max-width: 1260px) {
	header .header_bottom .inner {
		width: auto;
		margin: 0 30px;
	}
	
}
@media screen and (max-width: 1024px) {
	header .header_bottom .inner {
		margin: 0;
		padding: 0 30px;
	}
	
}
@media screen and (max-width: 768px) {
	header .header_bottom .inner {
		padding: 0 20px;
	}
	
}
@media screen and (max-width: 560px) {
	header:before {
		display: none;
	}
	header .header_flexbox .logo {
		width: 90px;
	}
}
@media screen and (max-width: 430px) {
	
}
@media screen and (max-width: 320px) {
	
}

/****************************************
 * レイアウト
*****************************************/

.inner {
	padding: 0;
	width: 1200px;
	margin: 0 auto;
}
.inner__nr {
	padding: 0;
	width: 980px;
	margin: 0 auto;
}
.inner__wd {
	padding: 0;
	width: 99%;
	margin: 0 auto;
}
main {
	width: 100%;
	margin: 0 auto;
}
article {
	width: 100%;
	padding: 60px 0 0;
}
article.front-page {
	padding: 0;
}
article.front-page section {
	padding: 90px 0;
}
section {
	padding: 0;
}
.contents {
	padding-bottom: 90px;
}

/* 2カラム */
article .flexbox {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
article .flexbox .flexbox___main {
	width: calc(100% - 340px);
}
aside {
	width: 280px;
	margin-left: 60px;
}

@media screen and (max-width: 1024px) {
	.inner,
	.inner__nr,
	.inner__wd {
		width: 100%;
		padding: 0 60px;
	}
	aside {
		width: 260px;
	}
}
@media screen and (max-width: 960px) {
	.inner,
	.inner__nr,
	.inner__wd {
		padding: 0 45px;
	}
}
@media screen and (max-width: 768px) {
	article .flexbox {
		flex-direction: column;
	}
	article .flexbox .flexbox___main {
		width: 100%;
	}
	aside {
		width: 100%;
		margin: 0;
	}
}
@media screen and (max-width: 559px) {
	.inner,
	.inner__nr,
	.inner__wd {
		padding: 0 30px;
	}
	article.front-page section {
		padding: 60px 0;
	}
}
@media screen and (max-width: 430px) {
	.inner,
	.inner__nr,
	.inner__wd {
		padding: 0 20px;
	}
}
@media screen and (max-width: 320px) {
	article.front-page section {
		padding: 45px 0;
	}
	article {
		padding: 45px 0;
	}
}

/****************************************
 * ナビゲーション
*****************************************/

nav#general {
	margin: 16px 0 0;
}
nav#general ul {
	position: relative;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	justify-content: flex-end;
}
nav#general ul::after {
	content: '';
	display: block;
	clear: both;
}
nav#general ul li {
	position: relative;
	line-height: 1.3;
	margin-right: 30px;
}
nav#general ul li:last-child {
	margin-right: 0;
}
nav#general ul li:not(:first-child) {
	border-left: none;
}
nav#general ul li a {
	display: inline-block;
	color: #01224F;
	font-weight: bold;
	font-size: .9em;
}
nav#general ul ul {
	width: 10em;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	margin: 22px 0 0 0;
    padding-top: 12px;
	z-index: 1;
}
nav#general ul ul:before {
	content: "";
	position: absolute;
	top: 4px;
	left: 50%;
	transform: translateX(-50%);
	background: #0457CC;
	width: 1px;
	height: 12px;
}
nav#general ul ul li {
	width: 100%;
	margin: 0;
	text-align: left;
	background: #0457CC;
}
nav#general ul ul li a {
	display: block;
	color: #FFF;
	padding: 12px 20px;
}
nav#general ul ul li a:hover {
	opacity: 1;
	background: #034CB2;
}
nav#general ul ul ul {
	position: absolute;
	top: -2px;
	left: 100%;
}
nav#general ul ul {
	visibility: hidden;
	opacity: 0;
	transition: .2s ease-in-out;
}
nav#general ul li:hover > ul {
	visibility: visible;
	opacity: 1;
}

@media screen and (max-width: 1024px) {
	nav#general ul.menu > li > a {
		font-size: .9em;
	}
}
@media screen and (max-width: 768px) {
	nav#general ul li#menu-item-504 ul {
		right: 0;
		left: auto;
	}
}
@media screen and (max-width: 480px) {
	
}

/****************************************
 * ナビゲーション
 * スマートフォン
*****************************************/

#gn-full-screen {
	display: none;
}

@media screen and (max-width: 560px) {
	#gn-full-screen {
		display: block;
	}
	
	/*ハンバーガーメニュー*/
	#gn-full-screen .hamburger {
		position: fixed;
		right: 30px;
		top: 18px;
		width: 35px;
		height: 20px;
		z-index: 9999;
	}
	#gn-full-screen .hamburger-line {
		display: block;
		height: 2px;
		background: #BA9847;
		position: absolute;
		transition:transform .3s;
		width: 100%;
	}
	#gn-full-screen .hamburger-line-center{
		top: 12px;
	}
	#gn-full-screen .hamburger-line-bottom{
		bottom: -6px;
	}
	#gn-full-screen .hamburger-line-top.active{
		top: 8px;
		transform: rotate(45deg);
	}
	#gn-full-screen .hamburger-line-top.active {
		top: 13px;
		background: #BA9847;
	}
	#gn-full-screen .hamburger-line-center.active{
		transform:scaleX(0);
	}
	#gn-full-screen .hamburger-line-bottom.active{
		bottom: 5px;
		background: #BA9847;
		transform: rotate(135deg);
	}
	
	/*ナビゲーション*/
	#gn-full-screen nav.gn-full-screen-menu {
		width: 100%;
		height: 100vh;
		overflow-y: scroll;
		background: #FFF;
		display: none;
		height: 100%;
		position: fixed;
		left: 0;
		top: 0;
		z-index: 999;
	}
	#gn-full-screen .menu-sp-menu-container {
		width: 90%;
		margin: 50px auto;
		padding-right: 5px;/*スクロールバー分*/
	}
	#gn-full-screen .menu-sp-menu-container ul#menu-sp-menu,
	#gn-full-screen .menu-sp-menu-container ul#menu-sp-menu ul.sub-menu {
		list-style: none;
		padding: 0;
		margin: 0;
	}
	#gn-full-screen .menu-sp-menu-container ul#menu-sp-menu li {
		border-bottom: 1px solid #fff;
	}
	#gn-full-screen .menu-sp-menu-container ul#menu-sp-menu li.menu-item-206 {
		padding-bottom: 5px;
	}
	#gn-full-screen .menu-sp-menu-container ul#menu-sp-menu li ul.sub-menu {
		margin-left: 30px;
	}
	#gn-full-screen .menu-sp-menu-container ul#menu-sp-menu li ul.sub-menu li {
		padding: 0;
		border: none;
	}
	#gn-full-screen .menu-sp-menu-container ul#menu-sp-menu a {
		color: #fff;
		font-size: 1.3em;
		transition: .5s;
		padding: 15px;
		display: block;
	}
	
	#gn-full-screen .sp_nav  {
		margin: 60px auto 0;
		padding: 15px 0 30px;
	}
	#gn-full-screen ul.sp_nav_list {
		list-style: none;
		margin: 0;
		padding: 0;
		display: flex;
		flex-wrap: wrap;
	}
	#gn-full-screen ul.sp_nav_list li {
		width: 100%;
		border-bottom: 1px solid #BA9847;
	}
	#gn-full-screen ul.sp_nav_list li:first-child {
		border-top: 1px solid #BA9847;
	}
	
	/* アコーディオン */
	.ac-menu input {
		display: none;
	}
	.ac-menu label {
		display: block;
		padding: 13px 30px;
		cursor: pointer;
		position: relative;
	}
	.ac-menu label span.down_icon {
		position: absolute;
		right: 55px;
		top: 63%;
		transform: translate(-50%,0);
	}
	.ac-menu input:checked ~ label span.down_icon:after {
		
	}
	.ac-menu div.ac-menu-inside {
		height: 0;
		overflow: hidden;
		opacity: 0;
		transition: .6s;
	}
	.ac-menu input:checked ~ div.ac-menu-inside {
		height: auto;
		opacity: 1;
		transform: .3s;
	}
	.ac-menu a.nav_item {
		display: block;
		padding: 13px 30px;
	}
	.ac-menu ul.sub_list {
		margin: 0;
		padding: 0;
		background: #F7F4EC;
	}
	.ac-menu ul.sub_list li:last-child {
		border-bottom: none !important;
	}
	.ac-menu ul.sub_list li a {
		padding: 13px 30px 13px 45px;
	}
	
	/*　下向き三角 */
	span.down_icon {
		display: inline-block;
		position: relative;
	}
	span.down_icon:before {
	content: '';
    position: absolute;
    top: 50%;
    right: 42%;
    transform: rotate(135deg) translateY(-40%) translateX(-220%);
    width: 12px;
    height: 12px;
    border-top: solid 1px #BA9847;
    border-right: solid 1px #BA9847;
	}
	
	/*ロゴ*/
	#gn-full-screen .sp_nav .menu_bottom {
		text-align: center;
		margin: 30px 0;
	}
	#gn-full-screen .sp_nav .menu_bottom .logo_box {
		text-align: center;
		margin: 0 auto;
	}
}
@media screen and (max-width: 430px) {
	#gn-full-screen .sp_nav {
		padding: 15px 0 0;
	}
}
@media screen and (max-width: 390px) {
	#gn-full-screen .hamburger {
		right: 25px;
		top: 25px;
	}
	.ac-menu a.nav_item,
	.ac-menu label {
		padding: 12px 25px;
	}
	.ac-menu ul.sub_list li a {
		padding: 13px 25px 13px 40px;
	}
	#gn-full-screen .sp_nav .menu_bottom .logo_box img {
		width: 200px;
	}
	#gn-full-screen .sp_nav .menu_bottom span.phone {
		font-size: 1.3em;
	}
}
@media screen and (max-width: 320px) {
	#gn-full-screen .hamburger {
		right: 20px;
		top: 20px;
	}
	.ac-menu a.nav_item,
	.ac-menu label {
		padding: 10px 20px;
	}
	.ac-menu ul.sub_list li a {
		padding: 10px 20px 10px 35px;
	}
	#gn-full-screen .sp_nav .menu_bottom .logo_box img {
		width: 180px;
	}
	#gn-full-screen .sp_nav .menu_bottom span.phone {
		padding: 0 0 0 31px;
	}
	#gn-full-screen .sp_nav .menu_bottom span.phone:before {
		width: 24px;
		height: 24px;
	}
}

/****************************************
 * パンくず
*****************************************/

.breadcrumbs_area {
	padding: 20px 0;
	background: #fafafa;
}
.breadcrumbs {
	font-size: .8em;
}

@media screen and (max-width: 560px) {
	.breadcrumbs {
		overflow-x: auto;
		white-space: nowrap;
	}
}

/****************************************
 * p-contact.php
*****************************************/

#p-contact {
	padding: 90px 0;
	background-image: linear-gradient(to right, #047FCC 0%, #0457CC 73%, #FFF 73%);
}
#p-contact .inner {
	position: relative;
}
#p-contact a.backbutton {
	position: absolute;
	right: 0;
	bottom: -60px;
	font-size: .8em;
}
#p-contact .p-contact_flex {
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
	justify-content: space-between;
}
#p-contact .p-contact_flex .p-contact_flex___image {
	position: relative;
	width: 50%;
	text-align: right;
}
#p-contact .p-contact_flex .p-contact_flex___image:before {
	content: '';
	position: absolute;
	top: 35px;
	right: 13px;
	width: 100%;
	height: 95%;
	border: 1px solid #1FB4FF;
}
#p-contact .p-contact_flex .p-contact_flex___image img {
	position: relative;
}
#p-contact .p-contact_flex .p-contact_flex___main {
	width: 46%;
	text-align: center;
	color: #FFF;
}
#p-contact .p-contact_flex .p-contact_flex___main .p-contact_first {
	font-size: 1.1em;
}
#p-contact .p-contact_flex .p-contact_flex___main .p-contact_free {
	margin: 30px 0 0;
}
#p-contact .p-contact_flex .p-contact_flex___main .p-contact_phone {
	margin: 30px 0 0;
}
#p-contact .p-contact_flex .p-contact_flex___main .p-contact_phone p.btn_tel_text_phone {
	margin: 0;
}
#p-contact .p-contact_flex .p-contact_flex___main .p-contact_phone p.btn_tel_text_phone a {
	font-size: 2.4em;
	font-weight: bold;
	line-height: 1;
	color: #FFF;
}
#p-contact .p-contact_flex .p-contact_flex___main .p-contact_mail {
	margin: 30px 0 0;
}
#p-contact .p-contact_flex .p-contact_flex___main .p-contact_mail span {
	display: block;
	margin-top: 8px;
}
#p-contact .p-contact_flex .p-contact_flex___main .p-contact_mail .p-contact_mail_btn {
	position: relative;
	z-index: 0;
}
#p-contact .p-contact_flex .p-contact_flex___main .p-contact_mail .p-contact_mail_btn a.mail_btn {
	display: inline-block;
	background: #FFF;
	width: 300px;
	margin: 0 auto;
	padding: 18px 60px;
	border: 2px solid #0457CC;
	color: #0457CC;
	transition: all 0.4s ease-out;
}
#p-contact .p-contact_flex .p-contact_flex___main .p-contact_mail .p-contact_mail_btn a.mail_btn:hover{
	opacity: 1;
	color: #FFF;
	border-color: #FFF;
	background: linear-gradient(270deg, #fa6c9f 0%, #ffe140 50%, #ff357f 100%);
	background-image: linear-gradient(to right, #066cbb, #0256a6);
	background-size: 200% auto;
	background-position: right center;
	box-shadow: 0 2px 18px rgb(255,255,255,0.4);
}
#p-contact .p-contact_flex .p-contact_flex___main .p-contact_mail .p-contact_mail_btn a.mail_btn span.btn_mail_text {
	margin: 0;
	font-size: 1.1em;
	font-weight: bold;
}

@media screen and (max-width: 1024px) {
	#p-contact .p-contact_area {
		padding: 60px 60px 30px 60px;
	}
}
@media screen and (max-width: 768px) {
	#p-contact .p-contact_top {
		padding: 90px 0 60px;
	}
	#p-contact .p-contact_top_box {
		padding: 45px;
	}
}
@media screen and (max-width: 559px) {
	#p-contact .p-contact_top {
		background: url(images/p-contact/bg_sp.jpg) no-repeat;
		background-size: cover;
	}
	#p-contact .p-contact_top:before {
		background: url(images/common/header_wave_sp.png) no-repeat;
		background-size: contain;
		background-position: 50% 0;
	}
	#p-contact .p-contact_top_box .office_box {
		display: flex;
		flex-direction: column;
	}
	#p-contact .p-contact_top_box .office_box .office_left,
	#p-contact .p-contact_top_box .office_box .office_right {
		width: 100%;
		border: none;
	}
	#p-contact .p-contact_top_box .office_box .office_right {
		margin: 12px 0 0;
	}
}
@media screen and (max-width: 430px) {
	#p-contact .p-contact_top {
		padding: 75px 0 45px;
	}
	#p-contact .p-contact_top_box {
		padding: 30px;
	}
	#p-contact .p-contact_top_box .main_title {
		font-size: 1.4em;
	}
	#p-contact .p-contact_top_box .main_title span.main_top {
		font-size: .7em;
	}
	#p-contact p.office_info span.phone:before {
		width: 28px;
		height: 28px;
	}
}
@media screen and (max-width: 320px) {
	#p-contact .p-contact_top_box {
		padding: 20px;
	}
	#p-contact .p-contact_top_box .main_title {
		font-size: 1.3em;
	}
	#p-contact p.office_info span.phone {
		font-size: 1.6em;
		padding: 0 0 0 34px;
	}
	#p-contact p.office_info span.phone:before {
		width: 23px;
		height: 23px;
	}
}


/****************************************
 * お問い合わせ
*****************************************/

#contact {
	padding-bottom: 0;
}
#contact .contact_title {
	text-align: center;
	font-size: 1.9em;
}
#contact .phone_box .contact_title {
	margin: 0 0 6px;
}


/*電話
*****************************************/
#contact .phone_box {
	text-align: center;
	padding: 60px;
	margin: 0 auto 90px;
	color :#FFF;
	background: #0257cc;
	border-radius: 12px;
	box-shadow: 0 0 14px rgb(0 0 0 / 12%);
}
.page-id-48 #contact .phone_box {
	margin: 60px auto 0;
}
#contact .phone_box .phone_flex {
	display: flex;
	justify-content: center;
	align-items: center;
}
#contact .phone_box .phone_flex .phone_flex_title {
	width: 50%;
	padding: 0 60px 0 0;
	border-right: 1px solid #FFF;
}
#contact .phone_box .phone_flex .phone_flex_content {
	width: 50%;
	padding: 0 0 0 60px;
}
#contact .phone_box .phone_flex .phone_flex_content .free_flex {
	display: flex;
	align-items: center;
	justify-content: center;
}
#contact .phone_box .phone_flex .phone_flex_content .free_flex span {
	font-size: .8em;
	line-height: 1.2;
}
#contact .phone_box .phone_flex .phone_flex_content .free_flex a.free {
	font-size: 2.6em;
	line-height: 1;
	color: #FFF;
	padding-left: 8px;
	margin-bottom: 3px;
	text-decoration: none;
}
#contact .phone_box .phone_flex .phone_flex_content p.phone_hour {
	margin: 12px 0 0;
	font-size: 1.1em;
}

@media screen and (max-width: 1024px) {
	#contact .phone_box {
		padding: 45px;
	}
	#contact .contact_title {
		font-size: 1.7em;
	}
	#contact .phone_box .phone_flex .phone_flex_title {
		padding: 0 45px 0 0;
	}
	#contact .phone_box .phone_flex .phone_flex_content {
		padding: 0 0 0 45px;
	}
	#contact .phone_box .phone_flex .phone_flex_content .free_flex a.free {
		font-size: 2.5em;
	}
	
}
@media screen and (max-width: 768px) {
	#contact .phone_box {
		padding: 45px 30px;
		margin: 0 auto 75px;
	}
	#contact .contact_title {
		font-size: 1.5em;
	}
	#contact .phone_box .phone_flex .phone_flex_title {
		padding: 0 30px 0 0;
	}
	#contact .phone_box .phone_flex .phone_flex_content {
		padding: 0 0 0 30px;
	}
	#contact .phone_box .phone_flex .phone_flex_content .free_flex a.free {
		font-size: 2em;
	}
	#contact .phone_box .phone_flex .phone_flex_content .free_flex span {
		font-size: .7em;
	}
}
@media screen and (max-width: 560px) {
	#contact .phone_box {
		margin: 0 auto 60px;
	}
	#contact .phone_box .phone_flex {
		flex-direction: column;
	}
	#contact .phone_box .phone_flex .phone_flex_title,
	#contact .phone_box .phone_flex .phone_flex_content {
		width: 100%;
	}
	#contact .phone_box .phone_flex .phone_flex_title {
		border-right: none;
		border-bottom: 1px solid;
		padding: 0 0 18px 0;
	}
	#contact .phone_box .phone_flex .phone_flex_title p.phone_bottom {
		font-weight: bold;
	}
	#contact .phone_box .phone_flex .phone_flex_content {
		padding: 18px 0 0 0;
	}
	#contact .phone_box .phone_flex .phone_flex_content .free_flex a.free {
		font-size: 2.2em;
	}
	#contact .phone_box .phone_flex .phone_flex_content .free_flex span {
		font-size: .8em;
		font-weight: bold;
	}
	#contact .phone_box .phone_flex .phone_flex_content p.phone_hour {
		font-size: 1em;
		font-weight: bold;
	}
}
@media screen and (max-width: 430px) {
	#contact .phone_box {
		padding: 30px;
		margin: 0 auto 45px;
	}
	#contact .contact_title {
		font-size: 1.3em;
	}
	#contact .phone_box .phone_flex .phone_flex_content .free_flex a.free {
		font-size: 1.8em;
		font-weight: bold;
	}
}
@media screen and (max-width: 320px) {
	#contact .phone_box {
		padding: 20px;
		margin: 0 auto 30px;
	}
	#contact .phone_box .phone_flex .phone_flex_content .free_flex {
		flex-direction: column;
	}
	#contact .phone_box .phone_flex .phone_flex_content .free_flex span {
		font-size: .8em;
		margin-bottom: 10px;
	}
	#contact .phone_box .phone_flex .phone_flex_content .free_flex a.free {
		margin: 0;
	}
	#contact .phone_box .phone_flex .phone_flex_content p.phone_hour {
		margin-top: 10px;
	}
}

/* LINE
*****************************************/
#contact #contact_line {
	padding-bottom: 90px;
}
#contact #contact_line .line_box {
	text-align: center;
}
#contact #contact_line .line_box .line_title {
	text-align: center;
	color: #03c755;
}
#contact #contact_line .line_box .line_title span.deco_sideline {
	display: inline-block;
	padding: 0 60px;
	position: relative;
}
#contact #contact_line .line_box .line_title span.deco_sideline:before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translate(0, -50%);
	background-image: url(images/common/deco_sideline_left-green.png);
	background-size: contain;
	background-repeat: no-repeat;
	width: 33px;
	height: 34px;
}
#contact #contact_line .line_box .line_title span.deco_sideline:after {
	content: "";
	display: inline-block;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translate(0, -50%);
	background-image: url(images/common/deco_sideline_right-green.png);
	background-size: contain;
	background-repeat: no-repeat;
	width: 33px;
	height: 34px;
}

@media screen and (max-width: 768px) {
	#contact #contact_line {
		padding-bottom: 75px;
	}
}
@media screen and (max-width: 560px) {
	#contact #contact_line {
		padding-bottom: 60px;
	}
	#contact #contact_line .line_box .line_title {
		font-size: 1.2em;
	}
	#contact #contact_line .line_box .line_title span.deco_sideline {
		padding: 0 45px;
	}
}
@media screen and (max-width: 430px) {
	#contact #contact_line {
		padding-bottom: 45px;
	}
	#contact #contact_line .line_box .line_title {
		font-size: 1.2em;
	}
	#contact #contact_line .line_box .line_title span.deco_sideline {
		display: block;
		padding: 0 30px;
	}
}
@media screen and (max-width: 320px) {
	#contact #contact_line .line_box .line_title {
		font-size: 1em;
	}
}

/*フォーム
*****************************************/
#contact #contact_mail {
	padding: 90px 0;
}
#contact #contact_mail .contact_mail_box {
	background: #FFF;
	padding: 60px;
	border: 1px solid #0457CC;
	position: relative;
}
#contact #contact_mail .contact_mail_box:before {
	content: "";
	position: absolute;
	top: -25px;
	left: 50%;
	transform: translateX(-50%);
	background: #0457CC;
	width: 1px;
	height: 45px;
}
#contact #contact_mail .contact_mail_inbox {
	text-align: center;
}


#contact .mail_box {
	text-align: center;
	padding: 30px;
	border-radius: 12px;
	background: #fafafa;
}
#contact .mail_box .mail_inbox {
	padding: 60px 30px 30px;
	border-radius: 12px;
	background: #FFF;
	position: relative;
}
#contact .mail_box .mail_inbox p.mail_text {
	font-family: sans-serif;
	background: #5498ca;
	text-align: center;
	border-radius: 30px;
	color: #fff;
	left: 50%;
	padding: 11px 76px;
	position: absolute;
	top: -40px;
	transform: translate(-50%);
	white-space: nowrap;
	font-size: 1.3em;
}
#contact .mail_box .mail_inbox p.mail_text:before {
	border-color: #5498ca transparent transparent transparent;
	border-style: solid;
	border-width: 10px 11px 0 11px;
	content: "";
	display: block;
	height: 0;
	left: calc(50% - 11px);
	position: absolute;
	top: 100%;
	width: 0;
}
#contact input.date::placeholder {
	color: #000;
}
#contact .mail_box p.caution {
	
}

/*確認ページのメールアドレス2つめ*/
.page-id-46 span.check_no {
	display: none;
}

/*フォーム*/
#contact .mw_wp_form_input,
#contact .mw_wp_form_confirm {
	margin-top: 30px;
	padding: 30px;
}
#contact table {
	width: 100%;
	margin: 0 auto;
}
#contact table,
#contact table th,
#contact table td {
	border-collapse: collapse;
}
#contact table tr {
	display: flex;
	align-items: center;
	padding: 30px;
	border-bottom: 1px solid #ededed;
}
#contact table th {
	width: 280px;
	font-weight: normal;
	text-align: left;
	line-height: 1;
	position: relative;
}
#contact table th span.hissu {
	display: inline-block;
	line-height: 1;
	font-size: .7em;
	background: #04A7CC;
	color: #FFF;
	padding: 6px;
	margin-right: 8px;
	text-align: center;
	vertical-align: middle;
}
#contact table td {
	width: calc(100% - 280px);
	text-align: left;
	padding-left: 30px;
	line-height: 1;
}
#contact table td dl {
	display: table;
}
#contact table td dt {
	width: 180px;
	display: table-cell;
	vertical-align: middle;
}
#contact table td dd {
	display: table-cell;
	vertical-align: middle;
	padding-left: 12px;
}
#contact textarea.consultation {
	min-height: 220px;
	line-height: 1.6;
}

#contact .information {
	margin-top: 45px;
}
.page-id-25 #contact table.contact_form td.position span.memo {
	display: none;
}
#contact input.mail_check {
	margin-top: 12px;
}
#contact input.postcode {
	width: 120px;
	margin-bottom: 5px;
}
#contact .check_send {
	text-align: center;
	margin-top: 30px;
}
#contact input.form_btn {
	width: auto;
	text-decoration: none !important;
	display: inline-block;
	padding: 0 4em;
	color: #0457CC;
	background: #EBF3FE;
	line-height: 60px;
	font-size: 1.3em;
	border-radius: 0 !important;
	border: 3px solid;
}
#contact input.form_btn:hover {
	opacity: 1;
	color: #EBF3FE;
	background: #0457CC;
	border: 3px solid #FFF;
	box-shadow: 0 2px 18px rgb(2 86 166 / 40%);
}

/*内容確認*/
#contact .mw_wp_form_confirm table td span.check_no {
	display: none;
}
#contact .mw_wp_form_confirm table td.consultation_td {
	line-height: 1.6;
}

@media screen and (max-width: 1024px) {
	#contact table th {
		width: 230px;
	}
	#contact table td {
		width: calc(100% - 230px);
	}
}
@media screen and (max-width: 768px) {
	#contact #contact_mail {
		padding: 75px 0;
	}
	#contact .tel_box .tel_inbox {
		padding: 0 60px;
	}
	#contact .mw_wp_form_input,
	#contact .mw_wp_form_confirm {
		padding: 30px 0;
	}
	#contact table tr {
		padding: 30px 0;
	}
	#contact table th {
		width: 200px;
		font-size: .9em;
	}
	#contact table td {
		width: calc(100% - 200px);
	}
}
@media screen and (max-width: 559px) {
	#contact #contact_mail {
		padding: 60px 0;
	}
	#contact #contact_mail .contact_mail_box {
		padding: 30px;
	}
	#contact table tr {
		flex-direction: column;
	}
	#contact table tr:first-child {
		padding: 0 0 30px;
	}
	#contact table th,
	#contact table td {
		width: 100%;
	}
	#contact table th {
		border-left: 1px solid #F7B8A0;
		padding: 0 0 0 12px;
		margin-bottom: 12px;
		font-weight: bold;
	}
	#contact table td {
		border: none;
		padding: 12px 0 0 12px;
	}
	
	#contact input.form_btn {
		margin: 0;
		padding: 0;
		width: calc(100%/2 - 12px);
		line-height: 52px;
	}
}
@media screen and (max-width: 430px) {
	#contact #contact_mail {
		padding: 45px 0;
	}
	#contact #contact_mail .contact_mail_box {
		padding: 20px;
	}
	#contact #contact_mail .contact_mail_inbox {
		text-align: left;
	}
	#contact table td {
		padding: 12px 0 0 0;
	}
	
	#contact input.form_btn.btn_back {
		margin-right: 6px;
	}
	#contact input.form_btn.btn_submit {
		margin-left: 6px;
	}
}
@media screen and (max-width: 320px) {
	
}


/****************************************
 * フォーム
*****************************************/

/* iOSリセット */
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}
select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    outline: none;
    background: transparent;
}
input[type="submit"] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 0;
    border: none;
    outline: none;
    background: transparent;
}

/*フォーム*/
textarea {
	overflow: auto;
}
input[type="text"],
input[type="tel"],
input[type="email"],
input[type="search"],
textarea {
	font-size: 1em;
	margin: 0;
	padding: 15px;
	width: 100%;
	max-width: 100%;
	outline: none;
	color: #000;
	transition: .3s;
	letter-spacing: .3px;
	border: 1px solid #D2E4FE;
	background: #FFF;
}
input[type="text"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
input[type="search"]:focus,
textarea:focus {
	border: 1px solid #A0C6FD;
	background: #EBF3FE;
	outline: none;
}
select {
	position: relative;
	width: 100%;
	padding: 10px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	color: #000;
	border: 1px solid #BA9847;
	background: #fff url(images/common/select_arrow.jpg) no-repeat;
	background-position: right center;
	background-size: 28px, 100%;
	font-size: 1em;
	border-radius: 0;
}

/*ボタン*/
button,
.button,
input[type="submit"],
input[type="reset"],
input[type="button"],
.button:before,
button:before,
input[type="submit"]:before,
input[type="reset"]:before,
input[type="button"]:before,
.button:after,
button:after,
input[type="submit"]:after,
input[type="reset"]:after,
input[type="button"]:after {
	transition: all .3s;
}
button,
.button,
input[type="submit"],
input[type="reset"],
input[type="button"] {
	display: inline-block;
	text-align: center;
	text-decoration: none;
	border: none;
	cursor: pointer;
	position: relative;
}
.button:before,
button:before,
input[type="submit"]:before,
input[type="reset"]:before,
input[type="button"]:before,
.button:after,
button:after,
input[type="submit"]:after,
input[type="reset"]:after,
input[type="button"]:after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}

@media screen and (max-width: 559px) {
	button,
	.button,
	input[type="submit"],
	input[type="reset"],
	input[type="button"] {
		width: 100%;
	}
}
@media screen and (max-width: 430px) {
	input[type="text"],
	input[type="tel"],
	input[type="email"],
	input[type="search"],
	textarea {
		font-size: .9em;
	}
}

/****************************************
 * 共通
*****************************************/

.black {
	color: #000 !important;
}
.white {
	color: #FFF !important;
}
.purple {
	color: #B74796 !important;
}

/* ページのヘッダーイメージ
*****************************************/
.page_topimage {
	padding: 0;
	position: relative;
}
.page_topimage .mask {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

.page_topimage .topimage_title {
	font-size: 2.6em;
	line-height: 1.3;
	color: #000;
	margin: 0;
}
.page_topimage .topimage_title span {
	background: #1b3f8d;
}
.page_topimage .topimage_title span.gold {
	background: none;
	color: #c5a942;
	background: -webkit-linear-gradient(0deg, #e0c66d, #B67B03);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
.page_topimage .topimage_box_center .topimage_title { /*中央配置のときのタイトル*/
	padding: 0;
}
.big_box {
	text-align: center;
}
.big_box .topimage_title span {
	display: block;
	margin: 30px 0;
	font-size: .9em;
	font-weight: bold;
	color: #FFF;
	background: none;
}

/* オンライン体験クラス */
.ekamexperience.page_topimage .topimage_box {
	padding: 0;
}

/* 掲載メディア */
.page_topimage.medialist .topimage_box_center .topimage_title {
	margin: 0 0 60px;
}
/* 動画視聴 */
.onenessyoga_movie1.page_topimage .topimage_title,
.onenessyoga_movie2.page_topimage .topimage_title {
	color: #FFF !important;
}


@media screen and (max-width: 1700px) {
	.page_topimage .topimage_box_center.right {
		margin-right: 9%;
	}
}
@media screen and (max-width: 1400px) {
	.page_topimage .topimage_box_center.right {
		margin-right: 3%;
	}
}
@media screen and (max-width: 1024px) {
	.page_topimage .topimage_box_center.right {
		width: 570px;
		padding-right: 30px;
	}
}
@media screen and (max-width: 768px) {
	.page_topimage .topimage_box_center.right {
		width: 480px;
		padding-right: 30px;
	}
	.founder.page_topimage .topimage_box_center.right {
		top: auto;
		bottom: 60px;
		left: 50%;
		transform: translate(-50%, 0);
	}
}
@media screen and (max-width: 560px) {
	.page_topimage .topimage_box {
		padding-left: 30px;
	}
	.page_topimage .topimage_title {
		font-size: 2em;
	}
	.page_topimage .lokaa_topimage {
		position: relative;
	}
	.page_topimage .lokaa_topimage a {
		width: 340px !important;
		position: absolute !important;
		bottom: 8%;
		left: 50%;
		transform: translateX(-50%);
	}
}
@media screen and (max-width: 430px) {
	.page_topimage .topimage_title {
		font-size: 1.6em;
	}
}
@media screen and (max-width: 390px) {
	.page_topimage .topimage_title {
		font-size: 1.5em;
	}
	.page_topimage .lokaa_topimage a {
		width: 90% !important;
	}
}
@media screen and (max-width: 320px) {
	.page_topimage .topimage_title {
		font-size: 1.3em;
	}
}

/* YouTube 埋め込み
*****************************************/

.youtube {
  width: 100%;
  aspect-ratio: 16 / 9;
	margin: 90px 0;
}
.youtube iframe {
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 768px) {
	.youtube {
		margin: 75px 0;
	}
}
@media screen and (max-width: 560px) {
	.youtube {
		margin: 60px 0;
	}
}
@media screen and (max-width: 320px) {
	.youtube {
		margin: 45px 0;
	}
}

/* ボタンボックス
*****************************************/
.button_box {
	text-align: center;
	margin-top: 60px;
}
.button_box_right {
	text-align: right;
	margin-top: 60px;
}
.button_box_left {
	text-align: left;
	margin-top: 60px;
}

@media screen and (max-width: 560px) {
	.button_box,
	.button_box_right,
	.button_box_left {
		margin-top: 45px;
	}
}

/* ドット
*****************************************/
.dot {
	margin: 0 -4px;
}

/* ルビ
*****************************************/
ruby rt {
	font-size: .43em;
}

@media screen and (max-width: 560px) {
	ruby rt {
		font-size: .53em;
	}
}


/* 色
*****************************************/
.gr {
	color: #459145;
}



/* マーカー
*****************************************/
.marker_yl {
	display: inline;
	background: linear-gradient(transparent 40%, #ff6 40%);
}


/*アンダーライン
*****************************************/
.marker {
	background-image: -webkit-linear-gradient(left, rgba(226,213,181,0) 50%, rgba(226,213,181,0.75) 50%);
	background-image: -moz-linear-gradient(left, rgba(226,213,181,0) 50%, rgba(226,213,181,0.75) 50%);
	background-image: -o-linear-gradient(left, rgba(226,213,181,0) 50%, rgba(226,213,181,0.75) 50%);
	background-image: -ms-linear-gradient(left, rgba(226,213,181,0) 50%, rgba(226,213,181,0.75) 50%);
	background-image: linear-gradient(left, rgba(226,213,181,0) 50%, rgba(226,213,181,0.75) 50%);
}
.marker_mv {
	background-size: 200% 14px;
	background-position: 0 14px;
	background-repeat: repeat-x;
	transition: all 2s ease;
}
.marker_mv.marker_mv_action {
	background-position: -100% 14px;
}

@media screen and (max-width: 560px) {
	.marker_mv {
		background-size: 200% 8px;
		background-position: 0 8px;
	}
	.marker_mv.marker_mv_action {
		background-position: -100% 8px;
	}
}

/* シェアボタン
*****************************************/
.share {
	border-top: 1px solid #ededed;
	border-bottom: 1px solid #ededed;
	padding: 30px;
	margin: 45px 0 0;
}
.share .share_box {
	width: 380px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	justify-content: space-evenly;
	align-items: center;
}
.share p.share_title {
	margin: 0 0 12px;
	width: 100%;
	text-align: center;
}
.share p.share_title span {
	
}
.share ul {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-around;
}
.share ul li {
	
}

@media screen and (max-width: 1194px) {
}
@media screen and (max-width: 960px) {
}
@media screen and (max-width: 834px) {
}
@media screen and (max-width: 560px) {
}
@media screen and (max-width: 430px) {
	
}
@media screen and (max-width: 320px) {
}



/****************************************
 * トップページ
*****************************************/

.topimage {
	padding: 0;
}

/* 労務相談、手続・給与計算
*****************************************/
.service {
	padding: 0 0 90px !important;
}
.service .service_wrapper {
	position: relative;
    margin: -270px auto 0;
}
.service .service_wrapper .main_title {
	color: #FFF;
}
.service .service_wrapper .service_item {
	margin: 38px auto 0;
	background: #FFF;
    box-shadow: 0 0 14px rgb(0 0 0 / 8%);
    padding: 16px;
}
.service .service_wrapper .service_item .service_inbox {
	padding: 60px;
    border: 1px solid #01224F;
}





/* 私たちについて
*****************************************/
.aboutus {
	padding: 0 !important;
	position: relative;
}
.aboutus figure.aboutus_title_image_figure {
	position: relative;
	overflow: hidden;
	width: 83.4375%;
	/*padding: 18.28125% 0 0 0;*/
}
.aboutus .aboutus_wrapper {
	position: relative;
	margin: 0 8.5625% 0 9.84375%;
	padding: 0 0 90px;
	
}
.aboutus .aboutus_wrapper:before {
	content: "";
	display: block;
	position: absolute;
	top: -95px;
	left: 10.5%;
	background: #fafafa;
	width: 100%;
	height: 100%;
	z-index: -1;
}
.aboutus .aboutus_wrapper .main_title {
	position: absolute;
	left: 50%;
	top: auto;
	bottom: 100%;
	transform: translateX(-50%);
	color: #FFF;
	z-index: 3;
}
.aboutus .aboutus_wrapper .aboutus_article {
	padding: 90px 0 90px 22%;
}





/* 強み
*****************************************/
.strength {
	position: relative;
}
.strength:before {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	background: #fafafa;
	width: 100%;
	height: 64%;
	z-index: -1;
}
.strength .strength_items {
	
}
.strength .strength_items ul {
	margin: 0;
}
.strength .strength_items ul li {
	margin: 38px auto 0;
	background: #FFF;
	box-shadow: 0 0 14px rgb(0 0 0 / 8%);
	padding: 16px;
	
}
.strength .strength_items ul li .strength_items_box {
	padding: 60px;
	border: 1px solid #01224F;
	position: relative;
	display: flex;
	align-items: flex-start;
}
.strength .strength_items ul li .strength_items_box .strength_items_number {
	display: flex;
	align-items: center;
	margin-right: 90px;
}
.strength .strength_items ul li .strength_items_box .strength_items_number span.number_title {
	display: inline-block;
	font-size: .8em;
	font-family: futura-pt, sans-serif;
	font-weight: bold;
}
.strength .strength_items ul li .strength_items_box .strength_items_number span.number {
	display: inline-block;
	font-size: 4.6em;
	line-height: 1;
	margin-right: 12px;
}
.strength .strength_items ul li .strength_items_box .strength_items_article {
	
}
.strength .strength_items ul li .strength_items_box .strength_items_article .strength_items_article_title {
	font-size: 1.6em;
	font-weight: bold;
	margin: 0 0 12px;
}




/* ご相談の流れ
*****************************************/
.flow {
	
}
.flow .flow_wrapper {
	
}
.flow .flow_wrapper .flow_item {
	width: 100%;
	position: relative;
	z-index: 1;
}
.flow .flow_wrapper .flow_item.left:before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	background: #047FCC;
	width: 50%;
	height: 1px;
	z-index: -1;
}
.flow .flow_wrapper .flow_item.right:before {
	content: "";
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	background: #0457CC;
	width: 50%;
	height: 1px;
	z-index: -1;
}
.flow .flow_wrapper .flow_item .flow_box {
	width: 1200px;
	padding: 16px;
	margin: 18px auto 0;
	background: #047FCC;
	background-image: linear-gradient(to right, #047FCC 0%, #0457CC 100%);
}
.flow .flow_wrapper .flow_box .flow_inbox {
	background: #FFF;
	padding: 60px;
}


/* ブログ
*****************************************/

/*タブ*/
.update_box ul.tab_group {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	justify-content: center;
}
.update_box ul.tab_group li.tab{
	width: calc(100%/3);
	line-height: 66px;
	display: block;
	text-align: center;
	cursor: pointer;
	position: relative;
}
.update_box ul.tab_group li.tab:before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	background: #ededed;
	width: 100%;
	height: 1px;
	transition: all .3s;
}
.update_box ul.tab_group li.tab span {
	font-weight: bold;
	transition: all .3s;
}

/* タブコンテンツ */
.update_box .panel_group {
	padding: 30px 0 0;
	background: #FFF;
}
.update_box .panel {
  display:none;
}
.update_box ul.tab_group li.tab.is-active {
	transition: all .3s ease-out;
}
.update_box ul.tab_group li.tab.is-active:before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	background: #0457CC;
	width: 100%;
	height: 1px;
}
.update_box ul.tab_group li.tab.is-active span {
	display: inline-block;
	color: #0457CC;
	transform: translateY(-6px);
}
.update_box ul.tab_group li.tab.tab1.is-active {
	
}
.update_box ul.tab_group li.tab.tab2.is-active {
	
}
.update_box ul.tab_group li.tab.tab3.is-active {
	
}
.update_box .panel.is-show {
	display:block;
	width: 100%;
	animation: show2 .7s linear 0s;
}
@keyframes show2 {
	from{
		opacity: 0;
	}
	to{
		opacity: 1;
	}
}

/*投稿*/
ul.blogs {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	justify-content: flex-start;
	margin-top: -30px;
}
ul.blogs li {
	width: calc(100%/3 - 20px);
	margin: 30px 30px 0 0;
}
ul.blogs li:nth-child(3),
ul.blogs li:nth-child(6) {
	margin-right: 0;
}
ul.blogs li a {
	display: block;
}
ul.blogs li .post_image {
	position: relative;
}
ul.blogs li .post_image span.single_cat {
	position: absolute;
}
ul.blogs li .post_meta {
	margin: 12px 0 0;
	padding: 0 12px;
}
ul.blogs li .post_meta .post_title {
	font-size: 1em;
	margin: 0;
}
ul.blogs li .post_meta p.single_cat {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	margin: 6px auto;
	font-size: .8em;
	font-weight: bold;
	color: #1FB4FF;
}
ul.blogs li .post_meta p.single_cat:before {
	content: "";
	height: 1px;
	flex-grow: 1;
	border-top: 1px solid #1FB4FF;
	margin-right: 1rem;
}
ul.blogs li .post_meta p.single_cat:after{
	content: "";
	height: 1px;
	flex-grow: 1;
	border-top: 1px solid #1FB4FF;
	margin-left: 1rem;
}




/* お知らせ
*****************************************/

.news {
	background: #FFF;
}
.news .news_box {
	
}
.news .news_box .news_item {
	padding: 18px;
	border-bottom: 1px solid #F0EADA;
}
.news .news_box .news_item:first-child {
	border-top: 1px solid #F0EADA;
}
.news .news_box .news_item dl {
	display: flex;
	align-items: center;
}
.news .news_box .news_item dt {
	width: 300px;
}
.news .news_box .news_item dd {
	width: calc(100% - 300px);
}
.news .news_box .news_item dt span.news_cat {
	display: inline-block;
	padding: 3px 8px;
	margin-right: 12px;
	font-size: .9em;
}
.news .news_box .news_item dt span.news_cat.cat-vc_manifest {
	background: #1b3f8d;
	color: #FFF;
}
.news .news_box .news_item dt span.news_cat.cat-vc_peacehome {
	
}
.news .news_box .news_item dt span.cat-vc_onenessyoga {
	background: #cde4ef;
	color: #1b3f8d;
}

@media screen and (max-width: 768px) {
	.news .news_box .news_item dl {
		flex-direction: column;
	}
	.news .news_box .news_item dt {
		width: 100%;
	}
	.news .news_box .news_item dd {
		width: 100%;
		margin: 12px 0 0;
	}
}
@media screen and (max-width: 320px) {
}

/****************************************
 * サイドバー
*****************************************/

.main_contents {
	
}

aside .aside_box {
	margin: 45px 0 0;
}
aside .aside_box:first-child {
	margin: 0;
}
aside .aside_title {
    position: relative;
	padding: 8px 18px;
    background: #0457CC;
	background-image: linear-gradient(to right, #047FCC 0%, #0457CC 73%);
	font-size: 1.3em;
    color: #FFF;
    text-align: center;
}
aside .aside_title::before {
	content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    height: 12px;
    width: 1px;
    background: #0457CC;
}

aside .aside_btn_box {
	margin: 12px 0 0;
	text-align: right;
}
aside .aside_btn_box a.std {
	font-size: .8em;
	text-decoration: underline;
	display: inline-block;
	position: relative;
	padding: 0 18px 0 0;
}
aside .aside_btn_box a.std:before {
	content: '';
    width: 8px;
    height: 8px;
    border: 0;
    border-top: solid 1px #000;
    border-right: solid 1px #000;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%) rotate(45deg);
}

/*カテゴリー*/
aside .category_list ul li {
	width: 100%;
	height: 90px;
	position: relative;
	border-bottom: 1px solid #ededed;
	display: flex;
    align-items: center;
    justify-content: center;
}
aside .category_list ul li:first-child {
	border-top: 1px solid #ededed;
}
aside .category_list ul li:before {
	content: "";
	display: inline-block;
	position: absolute;
	left: 20px;
	top: 50%;
	transform: translateY(-50%);
	background: url(images/common/icon140_folder.png) no-repeat;
	background-size: 100%;
	width: 24px;
	height: 24px;
}
aside .category_list ul li.cat-item-1 {
	background: url(images/aside/category_banner_01.jpg) no-repeat;
	background-size: 100%;
}
aside .category_list ul li.cat-item-7 {
	background: url(images/aside/category_banner_01.jpg) no-repeat;
	background-size: 100%;
	margin: 12px 0 0;
}
aside .category_list ul li a {
	width: 100%;
    height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #FFF;
    font-weight: bold;
}

/*新着*/
aside .newarrival ul li {
	position: relative;
	border-bottom: 1px solid #ededed;
}
aside .newarrival ul li:first-child {
	border-top: 1px solid #ededed;
}
aside .newarrival ul li .na_flexbox {
	display: flex;
	justify-content: space-between;
    align-items: flex-start;
}
aside .newarrival ul li .na_flexbox .na_image {
	width: 75px;
}
aside .newarrival ul li .na_flexbox .na_text {
	width: calc(100% - 95px);
}
aside .newarrival ul li .na_flexbox .na_text .na_meta {
	position: relative;
	margin: 0;
}
aside .newarrival ul li .na_flexbox .na_text span.na_category {
	display: inline-block;
	font-size: .7em;
    font-weight: normal;
	line-height: 1;
	color: #999;
}
aside .newarrival ul li .na_flexbox .na_text span.na_category.cat-blog {
	background: #EEF4F6;
}
aside .newarrival ul li .na_flexbox .na_text span.na_category.cat-news {
	background: #F8F1F7;
}
aside .newarrival ul li .na_flexbox .na_text span.na_date {
	display: inline-block;
	font-size: .7em;
    font-weight: normal;
	line-height: 1;
	color: #999;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}
aside .newarrival ul li .na_flexbox .na_text .na_post_title {
	text-align: left;
    font-size: .8em;
    line-height: 1.3;
	margin: 0;
}
aside .newarrival ul li a {
	display: block;
	padding: 8px 0;
	color: #0067a2;
	font-weight: bold;
}


/*月間アーカイブ*/
aside ul.monthly-list {
	list-style: inside;
}
aside ul.monthly-list li {
	
}

@media screen and (max-width: 768px) {
	/*カテゴリー*/
	aside .category_list ul {
		display: flex;
		align-items: flex-start;
		justify-content: space-between;
	}
	aside .category_list ul li {
		width: calc(100%/2 - 10px);
	}
	aside .category_list ul li:nth-child(2) {
		border-top: 1px solid #ededed;
	}
	
	/*新着*/
	aside .newarrival ul {
		display: flex;
		flex-wrap: wrap;
		align-items: flex-start;
		justify-content: space-between;
	}
	aside .newarrival ul li {
		width: calc(100%/2 - 10px);
	}
	aside .newarrival ul li:nth-child(2) {
		border-top: 1px solid #ededed;
	}
}
@media screen and (max-width: 430px) {
	aside .category_list ul li,
	aside .newarrival ul li {
		width: 100%;
	}
	
	/*カテゴリー*/
	aside .category_list ul {
		flex-wrap: wrap;
	}
	aside .category_list ul li:nth-child(2) {
		border-top: none;
	}
	
	/*新着*/
	aside .newarrival ul li:nth-child(2) {
		border-top: none;
	}
}

/****************************************
 * WPネイティブCSS
*****************************************/

.aligncenter {
  display: block;
  margin-right: auto;
  margin-left: auto;
}
.alignright {
  float: right;
  margin-bottom: 20px;
  margin-left: 20px;
}
.alignleft {
  float: left;
  margin-right: 20px;
  margin-bottom: 20px;
}
.wp-caption,
[class*='wp-image'] {
  display: block;
  max-width: 100% !important;
  margin-top: 1.5em;
  text-align: center;
}
.wp-caption-text {
  margin-top: 0;
}

blockquote {
	margin: 1.5em 0;
	border-left: 5px solid #ddd;
	padding: 1em 0 1em 10px;
	color: #777;
}

/****************************************
 * Gutenberg（グーテンベルク）
*****************************************/

.wp-caption {}
.wp-caption-text {}
.sticky {}
.gallery-caption {}
.bypostauthor {}
.screen-reader-text {}

.wp-block-quote {
	background: #fafafa;
	padding: 15px 15px 15px 1.3em !important;
}
figure.wp-block-table {
	padding: 0;
	width: 100%;
	border-collapse: collapse;
}
figure.wp-block-table table,
figure.wp-block-table table th,
figure.wp-block-table table td,
figure.wp-block-table tfoot {
	border-collapse: collapse;
	border: 1px #999 solid;
}
figure.wp-block-table table th,
figure.wp-block-table table td {
	padding: 18px 15px;
}
figure.wp-block-table table th {
	width: 30%;
	background: #fafafa;
	border-bottom: 2px solid #333;
}
figure.wp-block-table tfoot {
	border-top: 1px solid #333;
}
.wp-block-group {
	margin-top: 60px;
}
.wp-block-image {
	margin-bottom: 1.5em !important;
}
.wp-block-media-text {
	margin-bottom: 1.5em !important;
}
figure {
	display: block;
	margin: 0;
}
figcaption {
	line-height: 1.5;
	font-size: .8em;
	text-align: center;
	margin-top: 15px;
}

/*本文入力欄*/
#single-home .contents_textbox h4 {
	text-align: left;
	margin: 0 0 20px;
	line-height: 1.3;
	font-size: 1.6em;
	border-left: 4px solid #0367a2;
	color: #0367a2;
	padding-left: 16px;
}
#single-home .contents_textbox h5 {
	text-align: left;
	margin: 0 0 20px;
	line-height: 1.3;
	font-size: 1.3em;
	background: #DDE9F7;
	border-left: 2px solid #1A4170;
	padding: 12px 30px;
}
#single-home .contents_textbox h6 {
	text-align: left;
	margin: 0 0 20px;
	padding: 0 0 0 28px;
	line-height: 1.3;
	font-size: 1.1em;
	font-family: sans-serif;
	position: relative;
}
#single-home .contents_textbox h6:before {
	content: "";
	display: block;
	position: absolute;
	top: 0.2em;
	left: 0;
	width: 0.6em;
	height: 0.6em;
	background: #3585E0;
	box-shadow: 0 0.7em 0 #f7c53b;
}
#single-home .contents_textbox ul {
	list-style: inside;
	margin: 0 0 30px;
}
#single-home .contents_textbox ol {
	list-style-type: decimal;
	margin: 0 0 30px;
	padding-left: 1.3em;
}

/* 本文最下部共通挿入*/
#single-home .common_box {
	margin: 30px 0 0;
	padding: 15px;
	background: #1a4170;
	color: #FFF;
}
#single-home .common_box .common_inbox {
	padding: 15px;
	border: 1px solid #000D2E;
	font-size: .9em;
	font-family: 'ShipporiMinchoB1-Bold', serif;
}
#single-home .common_box p.common_bottom {
	text-align: center;
}

@media screen and (max-width: 559px) {
	.wp-block-media-text__content {
		padding: 0 !important;
		margin-top: 45px;
	}
	
	/*本文入力欄*/
	#single-home .contents_textbox h4 {
		font-size: 1.4em;
	}
	#single-home .contents_textbox h5 {
		font-size: 1.2em;
	}
	#single-home .contents_textbox h6 {
		font-size: 1.1em;
	}
}
@media screen and (max-width: 480px) {
	.wp-block-media-text__content,
	.wp-block-group {
		margin-top: 30px;
	}
}
@media screen and (max-width: 430px) {
	.wp-block-group {
		margin-top: 30px;
	}
	figure.wp-block-table table th {
		width: 25%;
	}
	figure.wp-block-table table th,
	figure.wp-block-table table td {
		padding: 15px;
	}
	
	/*本文入力欄*/
	#single-home .contents_textbox h4 {
		font-size: 1.3em;
	}
	#single-home .contents_textbox h5 {
		font-size: 1.1em;
	}
	#single-home .contents_textbox h6 {
		font-size: 1em;
		padding: 0 0 0 20px;
	}
}
@media screen and (max-width: 320px) {
	.wp-block-media-text__content {
		margin-top: 20px;
	}
}

/****************************************
 * 固定ページの共通
*****************************************/

.jump {
	padding: 0;
}
.jump .jump_box ul {
	width: 880px;
	list-style: none;
	margin: 0 auto;
	padding: 0;
	display: flex;
	justify-content: center;
	align-items: center;
}
.jump .jump_box ul li {
	width: calc(100%/3);
	text-align: center;
}
.jump .jump_box ul li a {
	display: block;
	padding-top: 20%;
	position: relative;
}
.jump .jump_box ul li a:before {
	content: "";
	display: inline-block;
	position: absolute;
	left: 50%;
	top: 6px;
	transform: translate(-50%,0);
	background: url(images/service/jump_img.png) no-repeat;
	background-size: 100%;
	width: 45px;
	height: 45px;
	transition: all .6s ease;
}
.jump .jump_box ul li a:hover {
	transform: scale(1.1);
}

@media screen and (max-width: 830px) {
	.jump .jump_box ul {
		width: 100%;
		padding: 0 30px;
	}
}
@media screen and (max-width: 768px) {
	.jump .jump_box ul li a {
		padding-top: 24%;
	}
}
@media screen and (max-width: 560px) {
	.jump .jump_box ul li a {
		padding-top: 38%;
	}
}
@media screen and (max-width: 430px) {
	.jump .jump_box ul {
		padding: 0 20px;
	}
	.jump .jump_box ul li a {
		padding-top: 53%;
		font-size: .9em;
	}
}
@media screen and (max-width: 390px) {
	.jump .jump_box ul li a {
		padding-top: 54%;
		font-size: .8em;
		font-family: sans-serif;
	}
}
@media screen and (max-width: 320px) {
	.jump .jump_box ul li a {
		padding-top: 58%;
	}
	.jump .jump_box ul li a:before {
		width: 35px;
		height: 35px;
	}
}



/* レイアウト
*****************************************/
.textbox {
	margin: 90px auto;
	width: 960px;
}
.textbox .textbox_topleft {
	text-align: left;
	margin: 0 0 0 45px;
	padding: 0 0 20px 45px;
	position: relative;
}
.textbox .textbox_topleft:before {
	content: "";
	position: absolute;
	left: 0;
	background: #ba9747;
	width: 1px;
	height: 150px;
}
.textbox .textbox_topleft:after {
	content: "";
	position: absolute;
	top: 0;
	left: -4px;
	background: #ba9747;
	width: 9px;
	height: 9px;
	border-radius: 9px;
}
.textbox .textbox_topleft p {
	font-size: 1.1em;
}
.textbox .textbox_topleft p span {
	display: block;
	font-size: 1.3em;
}
.textbox100 {
	margin: 90px auto;
	width: 100%;
}
.image {
	margin: 90px auto;
}
.center {
	text-align: center;
}
.strong {
	font-weight: bold;
}
.t_big {
	font-size: 1.3em;
}
.main_box {
	margin: 120px 0 0;
}
.textbox_flex {
	margin: 45px 0 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#mfst_about .textbox_flex {
	background: #FFF;
}
.textbox_flex .textbox___txt {
	width: calc(100%/2 + 30px);
	text-align: center;
	padding: 45px;
}
.textbox_flex .textbox___img {
	width: calc(100%/2 - 30px);
}
.textbox_flex + .textbox { /*.textbox_flexの次*/
	margin: 30px 0 0;
}
.textinbox {
	background: #FCFBF9;
	margin: 45px 0 0;
	padding: 45px;
	position: relative;
}
.textinbox:before {
	content: "";
	display: inline-block;
	position: absolute;
	top: -23px;
	left: 50%;
	transform: translateX(-50%);
	background: #ba9747;
	width: 1px;
	height: 45px;
}

/*
.separation {
	padding: 340px 0 90px !important;
	position: relative;
}
.separation:before {
	content: "";
	display: inline-block;
	position: absolute;
	top: -45%;
	left: 0;
	background: url(images/ekam/point.jpg) no-repeat;
	background-size: 100%;
	background-position: center;
	width: 100%;
	height: 100%;
	z-index: -1;
}
*/
.separation { /*区切り*/
	padding: 25% 0 90px !important;
	position: relative;
}
.separation:before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 0;
	left: 0;
	background: url(images/ekam/point.jpg) no-repeat;
	background-size: 100%;
	background-position: top;
	width: 100%;
	height: 100%;
	z-index: -1;
}

@media screen and (max-width: 1024px) {
	.textbox {
		width: 100%;
	}
}
@media screen and (max-width: 768px) {
	.main_box {
		margin: 90px 0 0;
	}
	.textbox_flex {
		flex-direction: column;
	}
	.textbox_flex .textbox___img {
		width: 100%;
	}
	.textbox_flex .textbox___txt {
		width: 100%;
	}
	
	.separation { /*区切り*/
		padding: 25% 0 75px !important;
	}
}
@media screen and (max-width: 560px) {
	.main_box {
		margin: 75px 0 0;
	}
	.textbox {
		margin: 75px auto;
	}
	.textbox100,
	.image {
		margin: 75px auto;
	}
	
	.textbox_flex .textbox___txt {
		padding: 30px 0;
	}
	
	.separation { /*区切り*/
		padding: 30% 0 0 !important;
	}
}
@media screen and (max-width: 430px) {
	.main_box {
		margin: 60px 0 0;
	}
	.textbox {
		margin: 60px auto;
	}
	.textbox100,
	.image {
		margin: 60px auto;
	}
	.textinbox {
		padding: 30px;
		margin: 30px 0 0;
	}
}
@media screen and (max-width: 320px) {
	.main_box {
		margin: 45px 0 0;
	}
	.textbox {
		margin: 45px auto;
	}
	.textbox100,
	.image {
		margin: 45px auto;
	}
	.textinbox {
		padding: 20px;
		margin: 45px auto;
	}
	.textinbox:before {
		height: 35px;
	}
	.textbox_flex {
		margin: 30px 0 0;
	}
	
	.separation { /*区切り*/
		padding: 30% 0 0 !important;
	}
}


/*時間表記*/
p.min span {
	display: inline-block;
	padding: 12px 60px;
	background: #ba9747;
	font-size: 1.3em;
	font-weight: bold;
	color: #FFF;
	position: relative;
	z-index:1;
}
p.min span:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 0;
	border: none;
	border-left: solid 42px #FFF;
	border-bottom: solid 74px transparent;
	z-index: 2;
}
p.min span:after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 0;
	height: 0;
	border: none;
	border-left: solid 42px transparent;
	border-bottom: solid 74px white;
	z-index: 2;
}
p.min span.num {
	display: inline-block;
	padding: 0;
	margin: 0 8px;
	font-size: 1.3em;
}
p.min span.num:before,
p.min span.num:after {
	content: none;
}

@media screen and (max-width: 430px) {
	p.min span {
		font-size: 1.2em;
		padding: 8px 60px;
	}
}


/*　よくある質問*/
.faq {
	padding: 90px 0;
}
.faq_box ul.faq_list {
	list-style: none;
	margin: 0 auto 0;
	padding: 0;
}
.faq_box ul.faq_list li {
	margin: 0;
	border-bottom: 1px solid #F0EADA;
}
.faq_box ul.faq_list li:first-child {
	border-top: 1px solid #F0EADA;
}
.faq_box ul.faq_list li .faq_title {
	display: block;
	font-size: 1em;
	text-align: left;
	position: relative;
	cursor: pointer;
	background: #FCFBF9;
	margin: 0;
	padding: 18px 30px 18px 60px;
	transition: all .6s ease;
}
.faq_box ul.faq_list li .faq_title.close {
	background: #ba9747;
	color: #FFF;
}
.faq_box ul.faq_list li .faq_title:before {
	content: "";
	display: inline-block;
	position: absolute;
	left: 30px;
	top: 50%;
	transform: translate(0,-50%);
	background: #BA9847;
	width: 18px;
	height: 1px;
	transition: all .6s ease;
}
.faq_box ul.faq_list li .faq_title.close:before {
	content: "";
	background: #FFF;
}
.faq_box ul.faq_list li .box {
	display: none;
	text-align: left;
	background: #FCFBF9;
	padding: 45px;
}
.faq_box ul.faq_list li .box a {
	text-decoration: underline;
	color: #BA9847;
}

@media screen and (max-width: 768px) {
	.faq {
		padding: 75px 0;
	}
}
@media screen and (max-width: 560px) {
	.faq {
		padding: 60px 0;
	}
	.faq_box ul.faq_list li .box {
		padding: 30px;
	}
}
@media screen and (max-width: 430px) {
	.faq_box ul.faq_list li .faq_title {
		padding: 16px 20px 18px 45px;
	}
	.faq_box ul.faq_list li .faq_title:before {
		left: 18px;
	}
	.faq_box ul.faq_list li .box {
		padding: 20px;
	}
}
@media screen and (max-width: 320px) {
	.faq {
		padding: 45px 0;
	}
	.faq_box ul.faq_list li .box {
		padding: 15px;
	}
}


/****************************************
 * 固定ページ
 * 会社概要
*****************************************/

#office .office_box {
	margin-top: 90px;
}

#office table.company {
	width: 100%;
}
#office table.company,
#office table.company th,
#office table.company td {
	border-collapse: collapse;
}
#office table.company tr {
	border-top: 1px solid #ededed;
}
#office table.company tr:last-child {
	border-bottom: 1px solid #ededed;
}
#office table.company th {
	width: 320px;
	padding: 26px;
	text-align: left;
	font-weight: normal;
	position: relative;
}
#office table.company th:after {
	content: '';
	position: absolute;
	width: 100%;
	height: 1px;
	top: -1px;
	left: 0;
	background: #0457CC;
}
#office table.company tr:last-child th:before {
	content: '';
	position: absolute;
	width: 100%;
	height: 1px;
	bottom: -1px;
	left: 0;
	background: #0457CC;
}
#office table.company td {
	width: calc(100% - 320px);
	padding: 26px;
}
#office table.company td.hour span {
	margin-left: 20px;
}
#office table.company td .button_box_right {
	margin: 12px 0 0;
}

#office ul.office_member,
#office ul.office_contact,
#office ul.office_works {
	list-style: none;
	padding: 0;
	margin: 0;
}
#office ul.office_works {
	list-style: inside;
}
#office ul.office_works li {
	width: 100%;
}
#office ul.office_contact li.phone {
	display: block;
}
#office ul.office_contact li.fax {
	display: block;
}
#office ul.office_contact span {
	margin-right: 8px;
}
#office .freee_box {
	
}
#office .freee_box .freee_flex {
	width: 880px;
	margin: 45px auto 0;
	display: flex;
	align-items: center;
}
#office .freee_box .freee_flex .freee_flex___img {
	width: 200px;
}
#office .freee_box .freee_flex .freee_flex___text {
	width: calc(100% - 200px);
	padding-left: 45px;
}


@media screen and (max-width: 1194px) {
	#office table.company th {
		width: 280px;
	}
	#office table.company td {
		width: calc(100% - 280px);
	}
}
@media screen and (max-width: 1024px) {
	#office table.company th {
		width: 220px;
	}
	#office table.company td {
		width: calc(100% - 220px);
	}
	#office table.company td .td_flex .td_flex_right a {
		width: 240px;
		padding: 18px 20px;
	}
	
}
@media screen and (max-width: 768px) {
	#office .office_box {
		margin-top: 75px;
	}
	#office table.company th {
		width: 200px;
	}
	#office table.company td {
		width: calc(100% - 200px);
	}
	
	#office table.company td .td_flex {
		flex-direction: column;
		align-items: stretch;
	}
	#office table.company td .td_flex .td_flex_right {
		text-align: right;
		margin: 12px 0 0;
	}
	#office table.company td .td_flex .td_flex_right a {
		text-align: left;
		width: 220px;
	}
	
}
@media screen and (max-width: 560px) {
	#office .office_box {
		margin-top: 60px;
	}
	#office table.company th {
		width: 130px;
	}
	#office table.company td {
		width: calc(100% - 130px);
	}
	#office ul.office_contact li.line {
		margin: 12px 0 0;
	}
}
@media screen and (max-width: 430px) {
	#office .office_box {
		margin-top: 45px;
	}
	#office table.company tr {
		flex-direction: column;
		
	}
	#office table.company th {
		width: 100%;
		text-align: left;
		font-size: .9em;
		padding-left: 20px;
		color: #ED5314;
		border-left: 1px solid #F7B8A0;
	}
	#office table.company td {
		width: 100%;
		padding-left: 20px;
	}
	
}
@media screen and (max-width: 380px) {
	
}


/****************************************
 * 固定ページ
 * サイトマップ
*****************************************/

#sitemaps a {
	display: block;
	padding: 15px 30px 15px 40px;
	text-decoration: none;
    text-align: left;
}
#sitemaps a:hover {
	background: #F7F4EC;
}
#sitemaps ul#menu-sitemaps-nav {
	list-style-type: none;
	text-align: center;
}
#sitemaps ul#menu-sitemaps-nav li {
	border-bottom: 1px solid #F4F4F4;
	position: relative;
	transition: all .3s;
}
#sitemaps ul#menu-sitemaps-nav li:first-child {
	border-top: 1px solid #F4F4F4;
}
#sitemaps ul#menu-sitemaps-nav li:before {
	content: "";
	position: absolute;
	top: 29px;
	left: 12px;
	transform: translateY(-50%);
	background: url(images/common/icon_carrow.png) no-repeat;
	background-size: 100%;
	width: 12px;
	height: 12px;
}
#sitemaps ul#menu-sitemaps-nav ul {
	margin: 0;
}
#sitemaps ul#menu-sitemaps-nav ul li {
	padding: 0 0 0 30px;
}
#sitemaps ul#menu-sitemaps-nav ul li:before {
	content: "";
	position: absolute;
	top: 29px;
	left: 42px;
	transform: translateY(-50%);
	background: url(images/common/icon_carrow.png) no-repeat;
	background-size: 100%;
	width: 12px;
	height: 12px;
}
#sitemaps ul#menu-sitemaps-nav ul li:last-child {
	border-bottom: none;
}
#sitemaps ul#menu-sitemaps-nav ul li:hover {
	background: #F7F4EC;
}
#sitemaps ul#menu-sitemaps-nav ul li a:hover {
	background: none;
}

@media screen and (max-width: 430px) {
	#sitemaps a {
		padding: 12px 20px 12px 30px;
	}
	#sitemaps ul#menu-sitemaps-nav li:before {
		top: 25px;
		left: 12px;
	}
	#sitemaps ul#menu-sitemaps-nav ul li {
		padding: 0 0 0 20px;
	}
	#sitemaps ul#menu-sitemaps-nav ul li:before {
		top: 25px;
		left: 28px;
	}
}
@media screen and (max-width: 390px) {
	#sitemaps a {
		padding: 12px 12px 12px 20px;
	}
	#sitemaps ul#menu-sitemaps-nav li:before {
		top: 25px;
		left: 3px;
	}
	#sitemaps ul#menu-sitemaps-nav ul li {
		padding: 0 0 0 16px;
	}
	#sitemaps ul#menu-sitemaps-nav ul li:before {
		top: 25px;
		left: 18px;
	}
}

/****************************************
 * ブログ
 * home.php
 * archive.php
 * single.php
*****************************************/

/* カテゴリ名
*****************************************/




/* home.php
*****************************************/



@media screen and (max-width: 1194px) {
	
}
@media screen and (max-width: 960px) {
	
}
@media screen and (max-width: 560px) {
	#voices .voices_photo .voices_photo_flex a {
		width: calc(100%/2);
	}
}
@media screen and (max-width: 430px) {
	
}
@media screen and (max-width: 320px) {
	#voices .voices_photo .voices_photo_flex a {
		width: 100%;
		margin: 3px 0 0;
	}
}

/* single.php
*****************************************/

.single_meta {
	position: relative;
}
.single_meta span.single_cat {
	display: inline-block;
    position: relative;
    padding: 6px 60px 6px 30px;
    background: #0457CC;
    background-image: linear-gradient(to right, #047FCC 0%, #0457CC 73%);
}
.single_meta span.single_cat:before {
	content: "";
    position: absolute;
    right: 0;
    top: 0;
    border: none;
    border-right: solid 40px #FFF;
    border-bottom: solid 40px transparent;
}
.single_meta span.single_cat a {
	color: #FFF;
}

.single_meta span.single_date {
	position: absolute;
	right: 0;
}
.single_image {
	
}
.single_image .single_title {
	font-size: 1.8em;
    text-align: left;
    font-weight: normal;
	margin: 30px auto 0;
    padding-bottom: 30px;
	border-bottom: 1px solid #ededed;
}
.single_text {
	margin: 30px auto 0;
}

/*スライド*/
.xo-slider {
	margin-bottom: 30px;
}
.xo-slider-template-default .slide-content {
	position: static !important;
	padding: 30px 30px 60px !important;
	color: #000 !important;
}
.xo-slider-template-default .slide-content-text {
	font-size: 1em !important;
	line-height: 1.8 !important;
}
.swiper-button-next, /*ナビゲーションの位置*/
.swiper-button-prev {
	top: 200px !important;
}
.xo-slider-template-default .swiper-pagination-white {
    --swiper-pagination-color: #0457CC !important;
}
.xo-slider-template-default .swiper-pagination-bullet {
	opacity: 1 !important;
}

@media screen and (max-width: 1024px) {
	.swiper-button-next, /*ナビゲーションの位置*/
	.swiper-button-prev {
		top: 130px !important;
	}
}
@media screen and (max-width: 960px) {
	.swiper-button-next, /*ナビゲーションの位置*/
	.swiper-button-prev {
		top: 115px !important;
	}
}
@media screen and (max-width: 768px) {
	.swiper-button-next, /*ナビゲーションの位置*/
	.swiper-button-prev {
		top: 160px !important;
	}
}
@media screen and (max-width: 560px) {
	.swiper-button-next, /*ナビゲーションの位置*/
	.swiper-button-prev {
		top: 115px !important;
	}
}
@media screen and (max-width: 430px) {
	.swiper-button-next, /*ナビゲーションの位置*/
	.swiper-button-prev {
		top: 90px !important;
	}
}
@media screen and (max-width: 390px) {
	.swiper-button-next, /*ナビゲーションの位置*/
	.swiper-button-prev {
		top: 80px !important;
	}
}
@media screen and (max-width: 370px) {
	.swiper-button-next, /*ナビゲーションの位置*/
	.swiper-button-prev {
		top: 75px !important;
	}
}
@media screen and (max-width: 320px) {
	.swiper-button-next, /*ナビゲーションの位置*/
	.swiper-button-prev {
		top: 65px !important;
	}
}

/*関連*/
.related {
	padding: 60px 0 0;
}
.related .related_title {
	text-align: center;
}
.related .related_items {
	
}

@media screen and (max-width: 560px) {
	#single-home .contents_textbox {
		padding: 0;
	}
	#single-home .category_box {
		margin: 45px 0 0;
	}
}
@media screen and (max-width: 430px) {
	#single-home .single_content p {
		font-size: .9em;
	}
}

/****************************************
 * イベント
 * p-eventslist.php
 * archive-event.php
 * single-event.php
*****************************************/


/* p-eventslist.php
*****************************************/

.p-eventslist .select_box {
	position: relative;
}
.p-eventslist select {
	position: absolute;
	right: 0;
	width: 150px;
	line-height: 1.3;
}
.p-eventslist .eventslist_box {
	
}
.eventslist:nth-of-type(n+2) {
	display: none;
}
.p-eventslist .month {
	display: inline-block;
	position: relative;
	padding: 0 0 0 75px;
}
.p-eventslist .month:before {
	content: "";
	display: inline-block;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	background: #BA9847;
	width: 60px;
	height: 1px;
}

ul.items li {
	padding: 18px 30px;
	border-bottom: 1px solid #BA9847;
}
ul.items li.head {
	background: #F7F4EC;
	border-top: 1px solid #BA9847;
	border-bottom: 1px solid #BA9847;
}
ul.items li .flex {
	display: flex;
	justify-content: space-around;
	align-items: center;
}
ul.items li .flex .cat {
	width: 15%;
}
ul.items li .flex .cat span {
	display: inline-block;
	padding: 3px 8px;
	font-size: .9em;
}
ul.items li .flex .cat span.cat_trial { /*体験クラス*/
	background: #FFC84D;
}
ul.items li .flex .cat span.cat_manifest {
	background: #1b3f8d;
	color: #FFF;
}
ul.items li .flex .cat span.cat_manifest_call {
	background: #1b3f8d;
	color: #FFF;
}
ul.items li .flex .cat span.cat_homapooja {
	background: #fc7805;
	color: #FFF;
}
ul.items li .flex .cat span.cat_peacehome {
	background: #47B750;
	color: #FFF;
}
ul.items li .flex .cat span.cat_awakening {
	background: #785330;
	color: #FFF;
}
ul.items li .flex .cat span.cat_oneness {
	background: #cde4ef;
	color: #1b3f8d;
}
ul.items li .flex .cat span.cat_general {
	background: #B7476B;
	color: #FFF;
}
ul.items li .flex .cat span.cat_lfmeditation {
	background: #AEB747;
	color: #FFF;
}
ul.items li .flex .cat span.cat_foryoung {
	background: #6747B7;
	color: #FFF;
}
ul.items li .flex .cat span.cat_indiacourse {
	background: #B76747;
	color: #FFF;
}
ul.items li .flex .cat span.cat_seeker {
	background: #745D00;
	color: #FFF;
}

ul.items li .flex .date {
	width: 15%;
	text-align: left;
}
ul.items li .flex .date span {
	display: block;
}
ul.items li .flex .program {
	width: 35%;
	text-align: left;
}
ul.items li .flex .location {
	width: 20%;
	font-size: .9em;
	text-align: left;
}
ul.items li .flex .location span.instructor {
	display: block;
	color: #BA9847;
}
ul.items li .flex .add {
	width: 15%;
	text-align: center;
}
ul.items li .flex .add span {
	display: block;
}
ul.items li .flex .add p.event_finish {
	font-weight: bold;
}

/*詳細を見るボタン*/
ul.items li .flex .add a.more {
	display: inline-block;
	position: relative;
	padding: 8px 35px 8px 20px !important;
	border: 1px solid;
	box-shadow: 2px 2px 6px -1px rgb(19 71 52 / 30%) !important;
}
ul.items li .flex .add a.more:before {
	content: '';
	width: 10px;
	height: 10px;
	border: 0;
	border-top: solid 1px #000;
	border-right: solid 1px #000;
	position: absolute;
	top: 50%;
	right: 1em;
	transform: translateY(-50%) rotate(45deg);
	transition: all .3s;
}
ul.items li .flex .add a.more:hover {
	opacity: 1;
	background: #BA9847;
	color: #FFF;
	box-shadow: 2px 2px 6px -1px rgb(19 71 52 / 30%) !important;
}
ul.items li .flex .add a.more:hover:before {
	border-top: solid 1px #FFF;
	border-right: solid 1px #FFF;
}

/*イベントなし*/
.noevents {
	width: 100%;
	background: #F1F0ED;
	padding: 60px 45px;
	display: flex;
	align-items: stretch;
	justify-content: center;
}
.noevents p.noevents_msg {
	text-align: center;
	font-size: 1.3em;
	font-family: serif;
}

.go_pastevents {
	text-align: right;
	margin: 12px 12px 0 0;
}
.go_pastevents a {
	text-decoration: underline;
}

@media screen and (max-width: 1024px) {
	ul.items li {
		padding: 18px 20px;
	}
	ul.items li .flex > div {
		padding-right: 20px !important;
		font-size: .9em;
	}
	ul.items li .flex > div:last-child {
		padding-right: 0 !important;
	}
	ul.items li .flex .cat {
		width: 18%;
	}
	ul.items li .flex .cat span {
		font-size: .9em;
		letter-spacing: -.08em;
	}
	ul.items li .flex .date {
		width: 15%;
	}
	ul.items li.item .date {
		font-size: .9em;
	}
	ul.items li .flex .location {
		width: 18%;
	}
	ul.items li .flex .program {
		width: 32%;
	}
	ul.items li .flex .add {
		width: 17%;
	}
	ul.items li .flex .add a.more {
		padding: 8px 30px 8px 18px !important;
	}
}
@media screen and (max-width: 768px) {
	ul.items li {
		padding: 18px 15px;
	}
	ul.items li .flex > div {
		padding-right: 15px !important;
	}
	ul.items li .flex .cat {
		width: 19%;
	}
	ul.items li .flex .date {
		width: 17%;
	}
	ul.items li .flex .location {
		width: 15%;
	}
	ul.items li .flex .program {
		width: 31%;
	}
	ul.items li .flex .add {
		width: 18%;
	}
	ul.items li .flex .add a.more {
		padding: 8px 26px 8px 15px !important;
	}
}
@media screen and (max-width: 560px) {
	.items_box {
		overflow-x: scroll;
	}
	ul.items {
		width: 760px;
		margin: 0 0 12px;
	}
	
	/*スライドできます*/
	.eventslist_box p.drag {
		text-align: right;
		margin: 0 30px 12px;
		font-weight: bold;
		font-size: .8em;
		line-height: 1;
		animation: SlideIn 1.6s infinite;
	}
	.eventslist_box p.drag span {
		
	}
	@keyframes SlideIn {
		0% {
			opacity: 0;
			transform: translateX(30px);
		}
		100% {
			opacity: 1;
			transform: translateX(0);
		}
	}
	/*スライドできます end*/
}
@media screen and (max-width: 430px) {
	.p-eventslist .month {
		padding: 0 0 0 60px;
		margin-bottom: 25px;
	}
	.p-eventslist .month:before {
		width: 45px;
	}
	.p-eventslist select {
		width: 130px;
		line-height: 1;
	}
	
	.noevents {
		padding: 60px 30px;
	}
	.noevents p.noevents_msg {
		font-size: 1.1em;
	}
}
@media screen and (max-width: 390px) {
	ul.items {
		width: 680px;
	}
	ul.items li .flex > div {
		padding-right: 10px !important;
	}
	ul.items li .flex .location {
		font-size: .8em;
	}
}
@media screen and (max-width: 320px) {
	.p-eventslist .month {
		padding: 0 0 0 45px;
		margin-bottom: 25px;
	}
	.p-eventslist .month:before {
		width: 35px;
	}
	.p-eventslist select {
		width: 120px;
	}
	
	ul.items {
		width: 640px;
	}
	ul.items li .flex .date {
		width: 15%;
	}
	ul.items li .flex .program {
		width: 33%;
	}
	
	.noevents {
		padding: 45px 30px;
	}
	.noevents p.noevents_msg {
		font-size: 1em;
	}
}


/* archive-event.php
*****************************************/



/* single-event_default.php
*****************************************/

.contents_text {
	padding: 60px 60px 0;
	position: relative;
}
.contents_text:before {
	content: "";
	display: inline-block;
	position: absolute;
	top: -30px;
	left: 50%;
	transform: translate(-50%, 0);
	background: url(images/event/single_icon.png) no-repeat;
	background-size: 100%;
	width: 60px;
	height: 60px;
	z-index: 1;
}
.contents_text:after {
	content: "";
	display: inline-block;
	position: absolute;
	left: 0;
	top: 0;
	background: #BA9847;
	width: 100%;
	height: 1px;
}
.contents_text .btn_box {
	text-align: center;
	margin: 45px auto 0;
}
.contents_text dl.event_info {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 45px auto 0;
	padding: 45px 0 0;
	position: relative;
}
.contents_text dl.event_info:before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, 0);
	background: url(images/event/single_icon.png) no-repeat;
	background-size: 100%;
	width: 45px;
	height: 45px;
	z-index: 1;
}
.contents_text dl.event_info dt {
	padding: 30px;
	font-size: 1.3em;
}
.contents_text dl.event_info dt span {
	font-size: .9em;
	margin-left: 10px;
}
.contents_text dl.event_info dd {
	padding: 30px;
	font-size: 1.3em;
}
.contents_text dl.event_info dd span.date {
	color: #2D3675;
	font-weight: bold;
}
.contents_text dl.event_info dd span.time {
	color: #2D3675;
	font-weight: bold;
}

@media screen and (max-width: 768px) {
	.contents_text {
		padding: 75px 0 0;
	}
}
@media screen and (max-width: 560px) {
	.contents_text dl.event_info {
		padding: 60px 0 0;
	}
	.contents_text dl.event_info dt,
	.contents_text dl.event_info dd {
		padding: 20px;
	}
}
@media screen and (max-width: 430px) {
	.contents_text dl.event_info {
	    flex-direction: column;
		padding: 90px 0 0;
	}
	.contents_text dl.event_info dt,
	.contents_text dl.event_info dd {
		display: block;
		width: 100%;
		text-align: center;
		padding: 0;
	}
	.contents_text dl.event_info dt span {
		margin: 0;
	}
}
@media screen and (max-width: 320px) {
	.contents_text:before {
		top: -22px;
		width: 45px;
		height: 45px;
	}
}


/****************************************
 * ページナビゲーション
*****************************************/

nav.navigation {
	overflow: hidden;
	float: none;
	max-width: 100%;
	text-align: center;
	padding: 0;
	margin: 60px 0 0;
}
nav.navigation a {
	text-decoration: none;
	color: #251E1F;
}
nav.navigation > div {
	width: 30%;
}
nav.navigation h2.screen-reader-text {
	display: none;
}
nav.navigation .nav-links {
	width: 100%;
	display: block;
}
nav.navigation .nav-links span.current {
	display: inline-block;
	color: #C3C6C9;
	padding: 0 15px;
	text-align: center;
}
nav.navigation .nav-links a.page-numbers {
	display: inline-block;
	background: #FFF;
	color: #000;
	padding: 0 15px;
	text-align: center;
}
nav.navigation .nav-links a:hover {
	opacity: 1;
	display: inline-block;
	color: #0457cc;
}
nav.navigation .nav-links a.prev,
nav.navigation .nav-links a.next {
	width: auto;
	float: none;
	color: #000;
	background: #FFF;
	margin: 0;
	padding: 0;
}
nav.navigation .nav-links a.prev {
	margin: 0 6px 0 0;
}
nav.navigation .nav-links a.next {
	margin: 0 0 0 6px;
}
nav.navigation .nav-links a.prev:hover,
nav.navigation .nav-links a.next:hover {
	color: #0457cc;
}

@media screen and (max-width: 768px) {
	nav.navigation {
		display: block;
	}
}


/****************************************
 * 404.php
*****************************************/

#error .error_title {
	text-align: center;
	font-size: 2em;
	margin-bottom: 30px;
}
#error .error_box {
	text-align: center;
	font-size: 1.3em;
}
#error p.error_url span {
	color: #5498ca;
}

@media screen and (max-width: 559px) {
	#error .error_box {
		font-size: 1.2em;
	}
}
@media screen and (max-width: 430px) {
	#error .error_box {
		font-size: 1em;
	}
}

/****************************************
 * フッター
*****************************************/

footer {
	clear: both;
	overflow: hidden;
	font-size: .9em;
	background: #EBF3FE;
	color: #01224F;
	padding: 90px 0 0;
	border-top: 3px solid #0457CC;
	position: relative;
}
footer a {
	color: #01284C;
}

/*トップへ戻る*/
footer .totop {
	position: fixed;
	bottom: 60px;
	right: 30px;
	z-index: 9;
}

footer .footer_flex {
	display: flex;
	justify-content: space-between;
}
footer .footer_flex .footer_flex___information {
	width: 600px;
}
footer .footer_flex .footer_flex___nav {
	width: calc(100% - 720px);
	margin: 30px 0 0;
}

footer .information {
	margin: 30px auto 0;
}
footer .information p.info {
	margin: 0;
}
footer .information p.info span {
	display: inline-block;
	margin-right: 8px;
}
footer .information p.info.name {
	
}
footer .information p.info.add {
	
}
footer .information p.info.add span {
	display: block;
}
footer .information p.info.tel {
	
}
footer .information p.info.fax {
	
}
footer .information p.info.open {
	
}
footer .information a.mail_btn_blue {
	display: inline-block;
	text-align: center;
	width: 240px;
	margin: 18px auto 0;
	padding: 15px 30px;
	border: 2px solid #FFF;
	font-weight: bold;
	color: #FFF;
	border-color: #FFF;
	background: linear-gradient(270deg, #fa6c9f 0%, #ffe140 50%, #ff357f 100%);
	background-image: linear-gradient(to right, #066cbb, #0256a6);
	background-size: 200% auto;
	background-position: right center;
	transition: all 0.4s ease-out;
}
footer .information a.mail_btn_blue:hover {
	opacity: 1;
	background: #FFF;
	color: #0256a6;
	border: 2px solid #0256a6;
	box-shadow: 0 2px 18px rgb(2,86,166,0.4);
}


footer .footer_nav {
	width: 100%;
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-end;
	align-items: flex-start;
}
footer .footer_nav .footer-nav {
	
}
footer .footer_nav .footer-nav.nav1,
footer .footer_nav .footer-nav.nav2 {
	width: calc(100%/2 - 30px);
}
footer .footer_nav ul {
	margin: -3px 0 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
}
footer .footer_nav ul li {
	margin: 3px 0 0;
	padding-left: 22px;
	position: relative;
}
footer .footer_nav ul li:last-child {
	margin-right: 0;
}
footer .footer_nav ul li:before {
	content: "";
	display: inline-block;
	position: absolute;
	left: 0;
	top: .9em;
	background: #0256a6;
	width: 8px;
	height: 1px;
}
footer .footer_nav .footer-nav ul ul {
	margin-left: 1em;
}

/* SNSアイコンとmust-nav */
footer .footer_bottom {
	margin: 45px 0 0;
	padding: 45px 0 0;
	display: flex;
	justify-content: center;
	align-items: center;
	border-top: 1px solid #D3E4FC;
	position: relative;
}
footer .footer_bottom:before {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%);
	background: #FFF;
	width: 100%;
	height: 1px;
}
footer .footer_bottom .sns {
	
}
footer .footer_bottom .sns ul {
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-evenly;
	border-radius: 30px;
}
footer .footer_bottom .sns ul li {
	margin: 0 18px;
}
footer .footer-must ul {
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: .9em;
	display: flex;
	justify-content: flex-end;
	align-items: flex-start;
}
footer .footer-must ul li {
	margin: 3px 30px 0 0;
}
footer .footer-must ul li:last-child {
	margin-right: 0;
}


/*コピーライト*/
footer #copyright {
	text-align: center;
	margin: 60px 0 0;
	padding: 30px;
	background: #0457CC;
}
footer #copyright a {
	color: #FFF;
}
footer #copyright p {
	text-align: center;
	font-size: .9em;
	color: #FFF;
}

@media screen and (max-width: 1024px) {
	footer .footer_nav .footer-nav.nav1 {
		width: calc(100%/3 + 120px);
	}
	footer .footer_nav .footer-nav.nav2 {
		width: calc(100%/3);
	}
	footer .footer_nav .contact {
		width: calc(100%/3 - 45px);
	}
}
@media screen and (max-width: 768px) {
	footer .totop img.icon {
		width: 40px;
	}
	
	footer .footer_nav {
		flex-wrap: wrap;
	}
	footer .footer_nav .footer-nav.nav1 {
		width: calc(100%/2 + 45px);
	}
	footer .footer_nav .footer-nav.nav2 {
		width: calc(100%/2 - 45px);
	}
	footer .footer_nav .contact {
		width: 100%;
		margin: 30px 0 0;
	}
}
@media screen and (max-width: 560px) {
	footer {
		padding: 60px 0 30px;
	}
	footer .footer_box {
		display: flex;
		flex-direction: column;
	}
	footer .footer_box .footer_information {
		width: 100%;
		text-align: center;
	}
	footer .footer_menu {
		margin: 30px 0 0;
	}
	footer .footer_nav .contact {
		margin: 0;
	}
	footer .footer_bottom {
		margin: 30px 0 0;
		flex-direction: column;
	}
	footer .footer_menu .footer-must {
		margin: 30px 0 0;
	}
	footer #copyright {
		margin: 45px 0 0;
	}
}
@media screen and (max-width: 430px) {
	nav.footer-must {
		width: 100%;
	}
	nav.footer-must ul {
		flex-direction: column;
		align-items: center;
	}
	nav.footer-must ul li {
		width: 100%;
		text-align: center;
		margin: 12px 0 0;
	}
	nav.footer-must ul li a {
		display: block;
	}
}
@media screen and (max-width: 390px) {
	
}
@media screen and (max-width: 320px) {
	footer .totop img.icon {
		width: 35px;
	}
	footer .logo_bottom .sns ul {
		width: 100%;
		padding: 8px 30px;
	}
	footer .logo_bottom .sns ul li:first-child {
		margin-right: 20px;
	}
}


/****************************************
 * ログイン中メッセージ
*****************************************/

.login_template {
	text-align: center;
	margin: 30px;
	font-size: .7em;
}
.login_template span {
	margin-left: 30px;
}

@media screen and (max-width: 430px) {
	.login_template span {
		display: block;
		margin: 0;
	}
}