@charset "UTF-8";
/*
Theme Name:Original Style - 1column
Version:1.2.1
*/

/*共通パーツ色変え部分*/
a,
a:visited {
	color: #182228;
}

figure {
	text-align: center;
}

/* H2タイトル -------------*/
.page-title {
	overflow: hidden;
	position: relative;
	background: url(img/under_title.jpg)no-repeat center/ cover;
	text-align: center;
	min-height: 200px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}

.page-title h2 {
	font-size: 42px;
	letter-spacing: 0.15em;
	font-weight: bold;
	position: relative;
	line-height: 1.4em;
	display: table;
	margin: 0 auto;
	padding: 0.5em 0;
}

ul.gallery {
	margin-bottom: 1.5em;
}

/*==========================
	投稿（ブログ、新着情報）
==========================*/

.entry-block {
	/* 一投稿を囲むブロック */
	padding-bottom: 1.5em;
	margin-bottom: 2em;
	border-bottom: 1px dotted #ccc;
}

.entry-block .dateBlock {
	/* 日時 */
	color: #888;
	font-size: 13px;
	padding-bottom: 0.5em;
	padding-top: 0.5em;
}

/* ブログページのカテゴリーリスト --------------------*/

#aside .menu-blog {
	padding: 10px 10px 20px;
	box-sizing: border-box;
	margin-top: 1em;
	background: #ecf4f8;
}

#aside .menu-blog h3 {
	border-bottom: 1px dotted #182228;
	color: #182228;
	font-size: 18px;
	padding: 0.6em 0 0.7em;
	text-align: center;
	margin-bottom: 0.8em;
	letter-spacing: 0.12em;
}

#aside .menu-blog li {
	font-size: 11px;
}

#aside .menu-blog li a {
	position: relative;
	padding-left: 1em;
	font-size: 14px;
	color: #182228;
	text-decoration: none;
}

#aside .menu-blog li a:hover {
	color: #66a6d7;
	text-decoration: none;
}

#aside .menu-blog li a::after {
	position: absolute;
	content: "";
	top: 0.5em;
	left: 0.3em;
	width: 3px;
	height: 3px;
	border-radius: 50%;
	background: #182228;
}

/*-- ページネーション ------------*/

.pager {
	font-size: 88%;
	/*14px*/
	margin-bottom: 3em;
}

.pager span.current,
.pager a {
	display: inline-block;
	margin-right: 5px;
	width: 25px;
	height: 25px;
	line-height: 25px;
	background: #fff;
	text-decoration: none;
	color: #182228;
	text-align: center;
}

.pager a:hover {
	background: #ccc;
	color: #fff;
}

.pager span.current {
	/* 今のページ */
	background: #ccc;
	color: #fff;
}

/*==========================
	画像
==========================*/

img {
	height: auto;
	vertical-align: bottom;
	max-width: 100%;
	max-height: 100%;
}

.mainblock img {
	max-width: 100%;
}

/* 真ん中寄せ */
.aligncenter {
	display: block;
	margin: 0 auto 5px;
}

/* 小さい画像に対応 */
.img_size img,
img.img_size {
	width: auto !important;
}

/*==========================
	見出し
==========================*/
h2,
h3,
h4,
h5,
h6,
.title {
	font-weight: bold;
}

/*-- H3 ------------*/

.post-type-page h3,
.under h3 {
	color: #333;
	font-weight: bold;
	font-size: 36px;
	letter-spacing: 0.1em;
	margin-bottom: 1em;
	position: relative;
	text-align: center;
	margin-top: 2.5em;
	line-height: 1.4;
	padding-top: 70px;
	background: url(img/h3.svg)no-repeat center top;
	background-size: 52px;
}

.mainblock>h3:first-child,
.mainblock>div:first-child h3,
.mainblock>h3:first-of-type {
	margin-top: 0;
}


/*-- H4 投稿タイトル ------------*/

.entry-block h3,
.mce-content-body h4,
.under h4 {
	font-weight: bold;
	padding-left: 30px;
	padding-bottom: 10px;
	background-size: 1.4em;
	font-size: 30px;
	letter-spacing: 0.06em;
	position: relative;
	line-height: 1.4em;
	margin-bottom: 1.2em;
	margin-top: 2.5em;
	color: #333;
	border-bottom: 2px solid #0068b7;
}

.entry-block h3:before,
.mce-content-body h4:before,
.under h4:before {
	content: "";
	display: block;
	position: absolute;
	top: 0.45em;
	left: 0;
	margin: 0 auto;
	width: 12px;
	height: 12px;
	background: #0068b7;
}

.mce-content-body div.h3+h4,
div.h3+h4,
.bg-block>h4:first-child,
.border-block>h4:first-child,
.column>h4:first-child,
.h3+.h4 h4 {
	margin-top: 0;
}

.entry-block .dateBlock+h3 {
	margin-top: 10px !important;
}

.mce-content-body .top01 h4 {
	border: inherit;
	text-align: inherit;
}

.entry-block h3 a {
	color: #182228;
	text-decoration: none;
}

.entry-block h3 a:hover {
	color: #66a6d7;
}

/*-- H5 ------------*/
.entry-block h4,
.mce-content-body h5,
.under h5 {
	font-size: 24px;
	color: #333;
	position: relative;
	padding: 0px 10px 10px 20px;
	margin-bottom: 0.8em;
	margin-top: 2em;
	width: fit-content;
	border-bottom: 2px solid #0068b7;
}

.entry-block h4::before,
.mce-content-body h5::before,
.under h5::before {
	content: "";
	display: block;
	position: absolute;
	top: 0.3em;
	left: 0;
	margin: 0 auto;
	width: 2px;
	height: 12px;
	background: #0068b7;
	border-radius: 6px;
}

.under h4+h5,
.under div.h4+h5,
.column>h5:first-child {
	margin-top: 0 !important;
}

.entry-block h4 {
	font-size: 18px;
}

/*-- H6 ------------*/
.entry-block h5,
.post-type-page h6,
.under h6 {
	color: #333;
	font-size: 22px;
	line-height: 1.4;
	margin-bottom: 0.5em;
	margin-top: 20px;
	position: relative;
	display: inline;
	padding: 0 10px;
	background: linear-gradient(180deg, transparent 60%, #b2d1e9 60%);
}

.entry-block h5:before,
.post-type-page h6:before,
.under h6:before {
	content: '';
	position: absolute;
	top: 0.2em;
	left: 0;
	width: 9px;
	height: 20px;
	background: url("img/h6.png")no-repeat center / cover;
}

.entry-block h5+*,
.post-type-page h6+*,
.under h6+* {
	margin-top: 1em;
}

.entry-block h5 {
	font-size: 17px;
}

/* カウント見出し */
.number_title .step {
	color: #66a6d7;
	font-size: 150%;
	display: inline-block;
	text-align: center;
	margin-right: 0.5em;
}

.number_title {
	padding: 0 !important;
	padding-left: 130px !important;
	border: none !important;
}

.number_title .number {
	color: #fff;
	background: #66a6d7;
	display: inline-block;
	text-align: center;
	padding: 0.1em 0.5em;
	border-radius: 2px;
	margin-right: 0.5em;
	font-weight: normal;
	position: absolute;
	top: -0.2em;
	left: 0;
}

@media (max-width : 767px) {
	.number_title .number {}
}

.mce-content-body h4.number_title,
.under h4.number_title,
.mce-content-body h5.number_title,
.under h5.number_title {
	padding-left: 0;
}

.mce-content-body h4.number_title:before,
.under h4.number_title:before,
.mce-content-body h5.number_title:before,
.under h5.number_title:before {
	content: none;
}

/*-- title ------------*/
.title p {
	color: #66a6d7;
	font-size: 30px;
	margin-top: 1em;
	margin-bottom: 0;
}

.border-block+.title p,
.bg-block+.title p,
.h3+.title p,
h4+.title p {
	margin-top: 0;
}

@media (max-width : 767px) {
	.title p {
		font-size: 24px;
	}
}

/*==========================
	リスト
==========================*/
/* ページ内リンク（目次） */
.page-list {
	border: 1px solid #ff9d4d;
	border-radius: 10px;
	padding: 30px 60px 20px;
}

@media (max-width : 767px) {
	.page-list {
		padding: 20px;
	}
}

.page-list.ul_arrow li {
	position: relative;
	margin: 0.5em 0 0.8em;
	padding-left: 36px;
}

.page-list.ul_arrow li:before {
	content: '';
	position: absolute;
	top: 1px;
	left: 0;
	margin: auto;
	width: 1.5em;
	height: 1.5em;
	border: 0;
	background: #ff9d4d;
	border-radius: 50%;
}

.page-list.ul_arrow li:after {
	content: '';
	position: absolute;
	top: 10px;
	left: 8px;
	margin: auto;
	width: 5px;
	height: 5px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	transform: rotate(45deg);
}

.page-list.ul_arrow li a {
	text-decoration: none;
}

.page-list.ul_arrow li a:hover {
	text-decoration: underline;
}

.page-list2 li a {
	text-decoration: none;
	color: #66a6d7;
}

.page-list2 li a:hover {
	text-decoration: underline !important;

	text-decoration: none;
}

.page-list2 li {
	position: relative;
	margin: 0.5em 0 0.8em;
}

.page-list2 li a {
	display: block;
	text-decoration: none;
	border: 1px solid #66a6d7;
	border-radius: 100px;
	width: 100%;
	padding: 0.7em 2em 0.7em 1em;
	box-sizing: border-box;
	position: relative;
	transition: 200ms;
	height: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}

.page-list2 li a:after {
	content: '';
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 15px;
	width: 0;
	height: 0;
	border: 4px solid transparent;
	border-left: 6px solid #66a6d7;
}

.page-list2 li a:hover {
	background: #66a6d7;
	color: #fff;
	text-decoration: none !important;
}

.page-list2 li a:hover::after {
	border-left-color: #fff;
}

@media screen and (min-width: 768px) {
	.page-list {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	.page-list li {
		margin-right: 5%;
	}
}

/*-- UL ------------*/

/* ul01 */
.ul01 {
	margin-bottom: 1em;
}

.ul01 li {
	position: relative;
	margin-bottom: 0.5em;
	padding-left: 1.5em;
	box-sizing: border-box;
}

.ul01 li::before {
	position: absolute;
	content: "";
	width: 0.5em;
	height: 0.5em;
	background: #66a6d7;
	border-radius: 50%;
	top: 0.6em;
	left: 0.35em;
}

.ul01.yellow li::before {
	background: #e8bf7d;
}

/* ul02 */
.ul02 {
	margin-bottom: 1em;
}

.ul02 li {
	position: relative;
	margin-bottom: 0.5em;
	padding-left: 1.7em;
	box-sizing: border-box;
}

.ul02 li::before {
	position: absolute;
	content: "";
	width: 0.5em;
	height: 0.5em;
	border: 3px solid #66a6d7;
	border-radius: 50%;
	left: 0.38em;
	top: 0.45em;
}

/* ul_check チェックのリスト */

.ul_check,
.ul_arrow {
	margin-bottom: 1em;
}

.ul_check li {
	position: relative;
	margin-bottom: 0.5em;
	padding-left: 1.8em;
}

.ul_check li::before {
	position: absolute;
	content: "";
	width: 16px;
	height: 16px;
	border-radius: 16px;
	background: #ee923f;
	border: 1px solid #ee923f;
	top: 4px;
	left: 5px;
}

ul.ul_check li:after {
	display: block;
	content: '';
	position: absolute;
	top: 9px;
	left: 9px;
	width: 8px;
	height: 3px;
	border-left: 2px solid #fff;
	border-bottom: 2px solid #fff;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
	z-index: 10;
}

/* ul_arrow 右向き三角のリスト */

.ul_arrow li {
	position: relative;
	margin-bottom: 0.5em;
	padding-left: 1.2em;
}

.ul_arrow li:before {
	position: absolute;
	content: "";
	width: 0;
	height: 0;
	top: 0.35em;
	left: 7px;
	margin: 0px 0 0 0;
	border: 6px solid transparent;
	border-top: 8px solid #66a6d7;
	-moz-transform: rotate(-90deg);
	-webkit-transform: rotate(-90deg);
	-o-transform: rotate(-90deg);
	-ms-transform: rotate(-90deg);
	transform: rotate(-90deg);
}

.ul_arrow li a {
	text-decoration: none;
	color: #182228;
}

.ul_arrow li a:hover {
	text-decoration: underline;
}

/* -------------------------------横並びリスト */

.ul-yoko {
	margin-bottom: 1em;
	padding: 1em;
	box-sizing: border-box;
	background: #EDF2FA;
	display: inline-block;
}

.ul-yoko li {
	display: inline-block;
	padding: 0.5em;
	box-sizing: border-box;
	background: #fff;
	font-size: 18px;
}

.ul-yoko li:not(:last-child) {
	margin-right: 0.5em;
}

/*-- OL ------------*/

ol.ol01 {
	margin-bottom: 1.2em;
}

ol.ol01 li {
	position: relative;
	margin-bottom: 0.4em;
}

ol.ollist {
	margin-bottom: 1.2em;
}

ol.ollist li {
	margin-bottom: 0.5em;
	list-style-type: none;
	list-style-position: inside;
	counter-increment: ollist;
}

ol.ollist li:before {
	display: marker;
	content: "("counter(ollist) ") ";
}

/* 数字のOLリスト */

ol.ol_decimal {
	margin-bottom: 1.2em;
}

ol.ol_decimal {
	counter-reset: li;
	list-style: none;
	padding-left: 0;
}

ol.ol_decimal>li {
	position: relative;
	margin-bottom: 0.5em;
	padding-left: 2em;
}

ol.ol_decimal>li:before {
	content: counter(li) "";
	counter-increment: li;
	position: absolute;
	left: 0;
	width: 25px;
	height: 25px;
	background: #66a6d7;
	border-radius: 100px;
	color: #fff;
	line-height: 25px;
	text-align: center;
	box-sizing: border-box;
	letter-spacing: -1px;
}

@media screen and (max-width: 767px) {
	ol.ol_decimal>li:before {
		width: 26px;
		height: 26px;
		letter-spacing: 0;
	}
}

/*-- 横並びリスト ------------*/

.float-list {
	overflow: hidden;
}

.float-list li {
	margin-bottom: 0.5em;
}

/*==========================
	テーブル
==========================*/

/*-- 診療時間表 ------------*/
.time-table {
	width: 100%;
	margin-bottom: 0.5em;
}

.time-table th,
.time-table td {
	text-align: center;
	font-weight: normal;
	padding: 5px;
	font-size: 16px;
	background: #ffffff;
}

.time-table tr th:first-child {
	width: 36%;
}

.time-table tbody tr:last-child {
	border-bottom: 1px solid #66a6d7;
}

.time-table th {
	padding: 10px 5px;
	border-bottom: 1px solid #dddddd;
}

.time-table thead th {
	background: #66a6d7;
	padding: 6px 5px;
	color: #fff;
	border:none;
}

.time-table td {
	padding: 10px 5px;
	border-bottom: 1px solid #dddddd;
}

.time_box {
	background: #f5efde;
	box-sizing: border-box;
	padding: 20px;
	margin-bottom: 10px;
}

.time-table {
	margin-bottom: 10px;
}

.time-table+p {
	margin-bottom: 20px;
}

/*-- 基本のテーブル ------------*/
.table01 {
	width: 100%;
	margin-bottom: 1.5em;
}

.table01 th,
.table01 td {
	padding: 15px;
	text-align: left;
	vertical-align: top;
}

.table01 th {
	padding-right: 10px;
	width: 36%;
	color: #66a6d7;
	font-weight: bold;
	border-bottom: 1px solid #66a6d7;
}

.table01 tr:first-child th {
	border-top: 1px solid #66a6d7;
}

.table01 td {
	border-bottom: 1px solid #ccc;
}

.table01 tr:first-child td {
	border-top: 1px solid #ccc;
}

/*-- ボーダーのついたテーブル ------------*/
.border-table {
	width: 100%;
	margin-bottom: 1.5em;
}

.border-table thead th,
.border-table thead td {
	background: #66a6d7;
	color: #fff;
	text-align: center;
}

.border-table thead th:first-child {
	width: 32%;
}

.border-table th,
.border-table td {
	text-align: left;
	font-weight: normal;
	padding: 15px;
	border: 1px solid #ccc;
	vertical-align: middle;
}

.border-table tbody th {
	background: #d2ecf7;
	vertical-align: middle;
	width: 32%;
}

.border-table td {
	background: #fff;
}

/*-- 料金表のテーブル(TDが右寄せ) ------------*/
.fee-table {
	width: 100%;
	margin-bottom: 1.5em;
}

.fee-table th,
.fee-table td {
	text-align: left;
	font-weight: normal;
	padding: 15px;
	border: 1px solid #ccc;
	vertical-align: middle;
	line-height: 1.4;
}

.fee-table thead th,
.fee-table thead td {
	background: #66a6d7;
	color: #fff;
	text-align: center;
}

.fee-table tbody th {
	background: #d2ecf7;
	width: 50%;
}

.fee-table tbody td {
	background: #fff;
}

.fee-table tbody td:last-child {
	text-align: right;
}

/*==========================
	DL
==========================*/

/*--  ------------*/
dl.dl01 {
	margin-bottom: 0.5em;
}

dl.dl01 dt {
	margin-bottom: 0.5em;
	padding: 0.4em 0.6em;
	position: relative;
	display: inline-block;
	line-height: 1.4em;
	color: #fff;
	background: #182228;
}

dl.dl01 dd {
	margin-bottom: 1.2em;
}

/*-- 数字つきdl ------------*/
dl.dl_number dt {
	font-size: 117%;
	color: #ccc;
	font-weight: normal;
	position: relative;
}

dl.dl_number dd {
	padding-left: 2em;
	margin-bottom: 1.2em;
}

.dl_number .number {
	display: inline-block;
	vertical-align: baseline;
	font-size: 15px;
	padding: 0.2em 0.6em 0.1em;
	margin-right: 0.5em;
	background: #ccc;
	color: #fff;
	border-radius: 3px;
	margin-bottom: 0.2em;
	line-height: 1.4;
}

/*==========================
	ボックス
==========================*/

/*-- 基本のブロック ------------*/
.block {
	margin-bottom: 2em;
}

/*-- クリアフィックスブロック ------------*/
.block-inner {
	margin-bottom: 60px !important;
	/*padding:0 10px;*/
}

.block>.block-inner:last-child {
	margin-bottom: 0;
}

/*-- ボーダー付きブロック ------------*/
.border-block {
	box-sizing: border-box;
	padding: 40px 4%;
	border-radius: 30px;
	border: 6px solid #faf7f4;
	margin-bottom: 1.2em;
}

.border-block>*:last-child {
	margin-bottom: 0 !important;
}

/*-- 背景色付き ------------*/
.bg-block {
	border-radius: 30px;
	box-sizing: border-box;
	padding: 40px 4%;
	background: #faf7f4;
	margin-bottom: 1.2em;
	overflow: hidden;
}

.bg-block>* {
	margin-bottom: 0 !important;
}

.border-block h5:first-child,
.bg-block h5:first-child {
	margin-top: 0 !important;
}

.border-block ul:last-child {
	margin-bottom: 0 !important;
}

/*-- メリットデメリット------------*/
.ul02.merit li::before {
	border-color: #66a6d7;
}

.ul01.demerit li {
	padding-left: 2.2em;
}

.ul01.demerit li::before {
	content: "×";
	font-size: 150%;
	font-weight: bold;
	top: -0.3em;
	background: none;
	color: #77b3e9;
	width: auto;
	height: auto;
	text-shadow: 0 0 1px #77b3e9,
		0 0 1px #77b3e9,
		0 0 1px #77b3e9,
		0 0 1px #77b3e9;
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

/*-- before after ------------*/
.ba-block {
	background: url(img/arrow_r.svg) no-repeat center 50%;
	background-size: 3%;
	margin-bottom: 10px;
	font-size: 92%;
}

.ba-block .before {
	float: left;
	width: 47%;
	position: relative;
}

.ba-block .after {
	float: right;
	width: 47%;
}

.ba-block img {
	display: block;
	margin: 0 auto 10px;
}

.batitle {
	text-align: center;
	font-size: 15px;
	color: #ccc;
	margin-bottom: 0.5em !important;
}

/*-- 流れ ------------*/
.flow-block {
	position: relative;
	margin-bottom: 4em;
	box-sizing: border-box;
	padding: 40px 4%;
	border-radius: 12px;
	box-shadow: 0 0 15px #ccc;
}

.flow-block:last-child::after {
	display: none;
}

.flow-block:last-child {
	margin-bottom: 0;
}

.flow-block h4 {
	margin-top: 0;
	border: none;
	background: none;
	padding: 0;
}

.flow-block h4:before {
	display: none;
}

.flow-block>*:first-child {
	margin-top: 0;
}

.flow-block *:last-child {
	margin-bottom: 0;
}

.flow-block:not(:last-child)::after {
	position: absolute;
	content: "";
	width: 0;
	height: 0;
	top: calc(100% + 1.2em);
	left: 0;
	right: 0;
	bottom: auto;
	margin: 0 auto;
	border: 2.5em solid transparent;
	border-top: 2em solid #333;
}

/* 流れ（横） */
.side-flow {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.side-flow li {
	position: relative;
}

.side-flow li:after {
	content: '';
	position: absolute;
	top: 0;
	left: calc(100% + 10px);
	bottom: 0;
	margin: auto;
	width: 0;
	height: 0;
	border: 20px solid transparent;
	border-left: 20px solid #66a6d7;
}

@media screen and (min-width: 768px) {
	.side-flow.block3 li {
		width: 30%;
		margin-left: 5%;
		margin-bottom: 20px;
	}

	.side-flow.block3 li:nth-child(3n+1) {
		margin-left: 0;
	}

	.side-flow.block3 li:nth-child(3n):after {
		content: none;
	}

	.side-flow.block4 li {
		width: 21.25%;
		margin-left: 5%;
	}

	.side-flow.block4 li:nth-child(4n+1) {
		margin-left: 0;
	}

	.side-flow.block4 li:nth-child(4n):after {
		content: none;
	}

	.side-flow li:last-child:after {
		content: none;
	}
}

@media screen and (max-width: 767px) {
	.side-flow li {
		width: 100%;
	}

	.side-flow li:not(:last-child) {
		margin-bottom: 3em;
	}

	.side-flow li:after {
		top: calc(100% + 1em);
		left: 0;
		right: 0;
		bottom: auto;
		border: 10px solid transparent;
		border-top: 10px solid #66a6d7;
	}

	.side-flow li:last-child:after {
		content: none;
	}

	.side-flow.sp_block2 {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	.side-flow.sp_block2 li {
		width: 47%;
		margin-left: 6%;
	}

	.side-flow.sp_block2 li:nth-child(2n+1) {
		margin-left: 0;
	}

	.side-flow.sp_block2 li:after {
		top: 0;
		left: calc(100% + 5px);
		bottom: 0;
		border: 10px solid transparent;
		border-left: 10px solid #ccc;
	}

	.side-flow.sp_block2 li:nth-child(2n):after {
		content: none;
	}
}

/*-- Q&A ------------*/
.qa-block {
	margin-bottom: 2.5em;
	padding-bottom: 20px;
	border-bottom: 1px solid #b0b0b0;
	position: relative;
}

.qa-block:last-child {
	margin-bottom: 0;
}

.qa-block::after {
	position: absolute;
	content: '';
	top: 1em;
	right: 10px;
	border-radius: 1px;
	width: 15px;
	height: 15px;
	border-top: 3px solid #66a6d7;
	border-right: 3px solid #66a6d7;
	-webkit-transform: rotate(-225deg);
	transform: rotate(-225deg);
	transition: .3s;
}

.qa-block.open::after {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

/* ＋が○で囲まれているやつ <p class="btn_box"></p>これをh4の前に配置*/
/* .qa-block .btn_box{
	position:relative;
}
.qa-block .btn_box{
	    content: "";
	    display: block;
	    position: absolute;
	    top:0;
	    right:0;
	    margin:0 auto;
	    width: 1.8rem;
	    height: 1.8rem;
	    border-radius: 1.8rem;
	    border:1px solid #c5d8d4;
} */
.mce-content-body .qa-block h4,
.qa-block h4 {
	padding-left: 56px !important;
	padding-right: 50px !important;
	padding-top: 10px;
	border: none;
	padding-bottom: 0;
	display: block;
	position: relative;
	background: none;
	border-left: none;
	font-size: 20px !important;
	margin-top: 0;
	 !importan;
	 !importa;
	 !import;
	 !impor;
	 !impo;
	 !imp;
	 !im;
	 !i;
	 !;
}

.qa-block h4:hover {
	cursor: pointer;
}

.mce-content-body .qa-block h4::before,
.qa-block h4::before {
	position: absolute;
	content: "";
	top: 5px;
	bottom: auto !important;
	left: 0;
	background: #66a6d7;
	height: 44px;
	width: 44px;
	border-radius: 50%;
	margin-top: -0.15em;
}

.mce-content-body .qa-block h4::after,
.qa-block h4::after {
	position: absolute;
	content: "Q";
	font-size: 26px;
	top: 8px;
	bottom: auto !important;
	left: 13px;
	color: #fff;
	border: none;
	background: none;
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

.qa-block .answer {
	display: none;
	padding-top: 20px;
	padding-bottom: 20px;
	padding-left: 56px !important;
	position: relative;
	margin-top: 20px;
}

.answer::before {
	position: absolute;
	content: "";
	top: 15px;
	bottom: auto !important;
	left: 0;
	background: #ee923f;
	height: 44px;
	width: 44px;
	font-size: 26px;
	border-radius: 50%;
	margin-top: -0.15em;
}

.answer::after {
	position: absolute;
	content: "A";
	font-size: 26px;
	font-weight: 700;
	top: 20px;
	bottom: auto !important;
	left: 14px;
	color: #fff;
	border: none;
	background: none;
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

.qa-block .answer p {
	margin: 0;
}

@media (max-width : 767px) {

	.mce-content-body .qa-block h4,
	.qa-block h4 {
		padding-top: 10px;
		font-size: 18px !important;
		margin-bottom: 0;
		min-height: 40px;
		margin-top: 0 !important;
	}

	.qa-block .answer {
		padding-top: 20px;
	}
}

/*==========================
	お問い合わせページ (Contact Form 7)
==========================*/
.wpcf7 dl {
	width: 1000px;
	max-width: 100%;
	margin: 0 auto 20px;
	overflow: hidden;
	border-top: 1px dashed #ccc;
}

.wpcf7 dl dt,
.wpcf7 dl dd {
	padding: 10px 5px;
}

.wpcf7 dl dt {
	clear: both;
	float: left;
}

.wpcf7 dl dd {
	padding-left: 14em;
	border-bottom: 1px dashed #ccc;
}

.wpcf7 .mf {
	font-size: 80%;
	color: #EA0000;
	padding-left: 3px;
}

.wpcf7 .ex,
.wpcf7 .subtxt {
	font-size: 88%;
	color: #ccc;
	line-height: 1.4em;
	display: inline-block;
}

.wpcf7 dl dt .requisite,
.wpcf7 dl .attention {
	font-size: 78%;
	color: #f45000;
}

.wpcf7 .wpcf7-not-valid-tip {
	font-size: 76%;
	color: #af2223;
}

.wpcf7 dl dd input {
	max-width: 90%;
	width: 500px;
}

dl dd .wpcf7-radio input {
	width: 20px !important;
}

.wpcf7 dl dd .radio input,
.wpcf7 dl dd .heckbox input {
	width: 20px;
}

.wpcf7 dl dd .radio01 span.wpcf7-list-item,
.wpcf7 dl dd .sexes span.wpcf7-list-item,
.wpcf7 dl dd .correspondence span.wpcf7-list-item,
.wpcf7 dl dd .course span.wpcf7-list-item,
.wpcf7 dl dd .health-insurance span.wpcf7-list-item {
	display: block;
}

.wpcf7 dl dd.radio01 input {
	max-width: 48%;
	width: auto;
}

.mainblock .wpcf7 dl dt p,
.mainblock .wpcf7 dl dd p {
	margin-bottom: 0;
}

.wpcf7 dl dd textarea {
	max-width: 90%;
	width: 500px;
}

.wpcf7 dl dd .wpcf7-list-item {
	margin-right: 30px;
	display: inline-block;
}

.wpcf7 .btn-style {
	text-align: center;
}

.wpcf7 .btn-style input {
	width: 120px;
	font-size: 16px;
	padding: 0.4em;
}

.btn-style input:hover {
	cursor: pointer;
	opacity: 0.6;
	-moz-opacity: 0.6;
	filter: alpha(opacity=60);
}

div.wpcf7 .ajax-loader {
	position: absolute !important;
}

/*==========================
	サイトマップ
==========================*/
#menu-sitemap {
	padding: 0;
}

#menu-sitemap li {
	position: relative;
	border-bottom: 2px dotted #eee;
	vertical-align: top;
}

#menu-sitemap li::after {
	display: block;
	content: "";
	position: absolute;
	width: 0.3em;
	height: 0.3em;
	top: 1.4em;
	left: 0.1em;
	border-top: solid 2px #ccc;
	border-right: solid 2px #ccc;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}

#menu-sitemap li ul li {
	border-bottom: none;
	padding-bottom: 0;
}

#menu-sitemap li a {
	text-decoration: none;
	color: #182228;
	display: block;
	padding: 0.8em 0.2em 0.7em 1.1em;
}

#menu-sitemap li a:hover {
	color: #66a6d7;
}

/*==========================
	画像のギャラリー
==========================*/
.gallery li {
	margin-bottom: 20px;
}

.gallery li img {
	margin-bottom: 5px;
}

/*==========================
	googlemap
==========================*/
.googlemap {
	position: relative;
	padding-bottom: 40%;
	/*縦横比*/
	height: 0;
	overflow: hidden;
}

#footer .googlemap {
	border-radius: 30px;
}

.googlemap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
}

/*==========================
	Youtube
==========================*/
.youtube-wrap {
	width: 600px;
	max-width: 100%;
	margin: 0 auto 20px;
}

.youtube {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 30px;
	height: 0;
	overflow: hidden;
}

.youtube iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}

/*==========================
	汎用
==========================*/
.color01 {
	color: #0068b7;
}

.color02 {
	color: #ee923f;
}

.attention {
	color: #cf1c16;
}

.bgcolor01 {
	background-color: #faf7f4;
	padding: 0 0.3em;
}

.line01 {
	background: -webkit-linear-gradient(180deg, transparent 60%, #faf7f4 60%, #faf7f4 90%, transparent 90%);
	background: -moz-linear-gradient(180deg, transparent 60%, #faf7f4 60%, #faf7f4 90%, transparent 90%);
	background: linear-gradient(180deg, transparent 60%, #faf7f4 60%, #faf7f4 90%, transparent 90%);
}

.line02 {
	background: -webkit-linear-gradient(180deg, transparent 60%, #e9ebff 60%, #e9ebff 90%, transparent 90%);
	background: -moz-linear-gradient(180deg, transparent 60%, #e9ebff 60%, #e9ebff 90%, transparent 90%);
	background: linear-gradient(180deg, transparent 60%, #e9ebff 60%, #e9ebff 90%, transparent 90%);
}

.font-big {
	font-size: 120%;
}

.font-small {
	font-size: 82%;
}

.fl {
	float: left !important;
}

.fr {
	float: right !important;
}

.tac {
	text-align: center
}

.tal {
	text-align: left
}

.tar {
	text-align: right;
}

.mt0 {
	margin-top: 0px !important;
}

.mt10 {
	margin-top: 10px !important;
}

.mt20 {
	margin-top: 20px !important;
}

.mb0 {
	margin-bottom: 0px !important;
}

.mb10 {
	margin-bottom: 10px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb30 {
	margin-bottom: 30px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.mb50 {
	margin-bottom: 50px !important;
}

.w10 {
	width: 10% !important;
}

.w20 {
	width: 20% !important;
}

.w30 {
	width: 30% !important;
}

.w40 {
	width: 40% !important;
}

.w33 {
	width: 33.3333% !important;
}

.w50 {
	width: 50% !important;
}

/* #a01, #a02, #a03, #a04, #a05, #a06, #a07, #a08, #a09, #a10, #a11, #a12, #a13, #a14, #a15, #a16, #a17, #a18, #a19, #a20 {
    margin-top: -60px;
    padding-top: 60px;
}
@media screen and (max-width: 767px) {
	#a01, #a02, #a03, #a04, #a05, #a06, #a07, #a08, #a09, #a10, #a11, #a12, #a13, #a14, #a15, #a16, #a17, #a18, #a19, #a20 {
    margin-top: -10px;
    padding-top: 10px;
}
} */
.bold {
	font-weight: bold;
}

.under .slick-slider {
	max-width: 767px;
	margin: auto;
}

.under .slick-slider p {
	background: #888;
	color: #fff;
	text-align: center;
}

#thumbnail_slider {
	margin-top: 10px;
}

.under img.slide-arrow.next-arrow.slick-arrow {
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 0;
	z-index: 50;
}

.under img.slide-arrow.prev-arrow.slick-arrow {
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	left: 0;
	z-index: 50;
}

/********************************
	Responsive
*********************************/

@media screen and (min-width: 768px) {
	/* タブレットまで */
	/*==========================
	画像
==========================*/
	/* img float */

	#tinymce img.alignright,
	#tinymce img.alignleft,
	.mainblock img.alignright,
	.mainblock img.alignleft {
		max-width: 34%;
	}

	.mainblock .alignright {
		float: right;
		margin: 0 0 30px 2%;
	}

	.mainblock .alignleft {
		float: left;
		margin: 0 2% 30px 0;
	}

	/*==========================
	リスト
==========================*/

	.float-list {
		overflow: hidden;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	.float-list li {
		float: left;
		box-sizing: border-box;
		margin: 0 1.2em 0.5em 0;
	}

	.float-list2 li {
		display: inline-block;
		width: 50%;
		margin: 0 0 10px 0;
		padding-right: 0.8em;
	}

	.float-list2 li:nth-child(2n) {
		padding-right: 0;
		/* padding-left:0.8em; */
	}

	.float-list3 li {
		display: inline-block;
		width: 33.3%;
		margin: 0 0 0.5em;
		padding-right: 0.8em;
	}

	.float-list3 li:nth-child(3n) {
		padding-right: 0;
	}

	.float-list3 li.no-float {
		float: none;
		margin: 0 0 0.5em;
		width: auto;
	}

	/*==========================
	ブロック
==========================*/

	/*-- 横ならびbox -----------*/

	.box2 {
		/* 横並び　X2 */
		display: inline-block;
		margin: 0 0.5%;
		width: 48%;
		box-sizing: border-box;
		vertical-align: top;
	}

	.box3 {
		/* 横並び　X3 */
		display: inline-block;
		margin: 0 0.5%;
		width: 31%;
		box-sizing: border-box;
		vertical-align: top;
	}

	.box4 {
		/* 横並び　X4 */
		float: left;
		margin: 0 1%;
		width: 23%;
		box-sizing: border-box;
		vertical-align: top;
	}

	.box5 {
		/* 横並び　X5 */
		float: left;
		margin: 0 1%;
		width: 18%;
		box-sizing: border-box;
		vertical-align: top;
	}

	/*==========================
	汎用
==========================*/
	/* 
#a01,#a02,#a03,#a04,#a05,#a06,#a07,#a08,#a09,#a10,#a11,#a12,#a13,#a14,#a15,#a16,#a17,#a18,#a19,#a20 {
    margin-top:-50px;
    padding-top:50px;
} */

	br.pc {
		display: inline;
	}

	br.sp2 {
		display: none;
	}

	.con_l {
		float: left;
	}

	.con_c {
		float: left;
	}

	.con_r {
		float: right;
	}

	.w25 {
		width: 25%;
	}

	.w35 {
		width: 35%;
	}

	.w40 {
		width: 40%;
	}

	.w48 {
		width: 48%;
	}

	.w56 {
		width: 56%;
	}

	.w60 {
		width: 60%;
	}

	.w62 {
		width: 62%;
	}

	.mw500p {
		max-width: 500px !important;
	}

}

@media screen and (min-width: 768px) and (max-width: 768px) {

	/*sitemap*/
	#menu-sitemap li::after {
		top: 1.55em;
	}
}

@media screen and (max-width: 900px) {
	.time-table thead th {
		font-size: 16px;
	}

	.time-table th,
	.time-table td,
	.border-table th,
	.border-table td {
		font-size: 16px;
		padding: 10px 5px;
	}

	.time-table+p {
		font-size: 16px;
	}
}

@media screen and (max-width: 767px) {

	/* スマホ */
	.text_large {
		font-size: 20px;
	}

	/*==========================
    スクロール表示
  ==========================*/
	.scroll {
		overflow: auto;

		width: 100%;
	}

	.scroll::-webkit-scrollbar {
		height: 5px;
	}

	.scroll::-webkit-scrollbar-track {
		background: #F1F1F1;
	}

	.scroll::-webkit-scrollbar-thumb {
		background: #BCBCBC;
	}

	/*==========================
	投稿（ブログ、新着情報）
==========================*/
	#aside .menu-blog {
		margin-bottom: 2em;
	}

	/*==========================
	画像
==========================*/
	.alignright,
	.alignleft {
		float: none;
		margin: 0 auto 20px;
		display: block;
	}

	/*==========================
	見出し
==========================*/
	.page-title {
		padding: 10px 25px;
		min-height: 0;
	}

	.page-title h2 {
		font-size: 26px;
	}

	.post-type-page h3,
	.mainblock h3 {
		font-size: 24px;
		margin-top: 2em;
		padding-top: 56px;
		background-size: 40px;
	}

	.entry-block h3 {
		margin-top: 50px;
		font-size: 24px;
		padding-top: 0!important;
	}

	.post-type-page h4,
	.mainblock h4 {
		font-size: 22px;
		margin-top: 2em;
	}

	.entry-block h3:before,
	.mce-content-body h4:before,
	.under h4:before {
		top: 0.45em;
	}

	.post-type-page h5,
	.mainblock h5 {
		font-size: 20px;
		margin-top: 1.5em;
		padding-bottom: 5px;
	}

	.entry-block h4::before,
	.mce-content-body h5::before,
	.under h5::before {
		top: 8px;
	}

	.post-type-page h6,
	.mainblock h6 {
		font-size: 18px;
	}

	h3.number_title .number {
		font-size: 140%;
		margin-right: 0;
	}

	.catch_title {
		line-height: 1.4em;
		font-size: 18px;
		letter-spacing: 0.05em;
	}

	.title {
		font-size: 19px;
	}

	/*==========================
	ブロック
==========================*/

	/* 横ならびbox */
	.box2,
	.box3,
	.box4 {
		margin-bottom: 20px;
	}

	/*-- before after ------------*/
	.ba-block {
		background: none;
		margin-bottom: 10px;
		font-size: 92%;
	}

	.ba-block .before,
	.ba-block .after {
		float: none;
		width: 100%;
	}

	.ba-block .before {
		padding-bottom: 40px;
		background: url(img/arrow_b.svg) no-repeat center bottom;
		background-size: 50px auto;
		margin-bottom: 20px;
	}

	/*==========================
	お問い合わせ
==========================*/
	.wpcf7 {
		width: 800px;
		max-width: 100%;
		margin: auto;
	}

	.wpcf7 dl dt {
		float: none;
		margin-bottom: 0em;
		padding-bottom: 2px;
	}

	.wpcf7 dl dd {
		padding-left: 5px;
		padding-top: 5px;
	}

	.wpcf7 dl dd input,
	.wpcf7 dl dd textarea {
		padding: 5px 2px;
		border: 1px solid #ccc;
		box-shadow: none;
		/* -webkit-appearance: none; */
		max-width: 100%;
		width: 100%;
		box-sizing: border-box;
	}

	/*==========================
	サイトマップ
==========================*/
	#menu-sitemap li::after {
		top: 1.5em;
	}

	/*==========================
	googlemap
==========================*/
	.googlemap {
		padding-bottom: 60%;
		/*縦横比*/
	}

	/*==========================
	汎用
==========================*/

	.con_l {
		margin-bottom: 1em;
	}

	.scroll {
		width: 100%;
		background-color: #ffffff;
		overflow-y: scroll;
		margin-left: 6px;
	}

	.scroll .border-table {
		width: 770px;
	}

	.border-block,
	.bg-block,
	.flow-block {
		padding: 30px 4%;
	}

	.page-list li:after {
		left: 9px;
	}

	.mce-content-body .qa-block h4::after,
	.qa-block h4::after {
		top: 10px;
	}

	.flow-block h4 {
		padding-left: 90px !important;
	}

	.qa-block {
		margin-bottom: 1em;
		padding-bottom: 25px;
	}

	.block-inner {
		margin-bottom: 2em !important;
	}

	.sp_float-list {
		overflow: hidden;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	.sp_float-list li {
		float: left;
		box-sizing: border-box;
		margin: 0 1.2em 0.5em 0;
	}

	.sp_float-list li {
		display: inline-block;
		width: 50%;
		margin: 0 0 10px 0;
		padding-right: 0.8em;
	}

	.sp_float-list li:nth-child(2n) {
		padding-right: 0;
		/* padding-left:0.8em; */
	}
}

@media screen and (max-width: 480px) {

	/* googlemap --------------------*/
	.googlemap {
		padding-bottom: 60%
	}

}


/*==========================
改行用
==========================*/
@media (min-width : 768px) {
	.pc_br {
		display: block;
		width: 100%;
	}
}

@media only screen and (min-width:768px) and (max-width: 1439px) {
	.tb_br {
		display: block;
		width: 100%;
	}
}

@media (max-width : 767px) {
	.sp_br {
		display: block;
		width: 100%;
	}
}

/* ------------------------------------ 下層*/

.box_form {
	width: 850px;
	max-width: 100%;
	margin: auto;
}

.under .columns {
	margin-top: 2em;
}

@media (max-width : 767px) {
	.under .clearfix+.h3 h3 {
		margin-top: 2em;
	}
}

.under .h4:first-child h4 {
	margin-top: 0 !important;
}

.under .col_2>*:last-child,
.under .col_3>*:last-child {
	margin-bottom: 0 !important;
}

.text-right {
	text-align: right;
}