@charset "utf-8";
/* CSS Document */

* {
	text-decoration: none;
	line-height: 1.5;
	box-sizing: border-box;
}
body {
	margin: 0;
	font-family: Lato,-apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
	font-size: 15px;
	line-height: 2.0;
	color: #2a2a2a;
}
p {
	text-align: justify;
	text-justify: inter-ideograph;
}
a {
	color: #303030;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all  0.3s ease;
}
a:hover {
	opacity: 0.6;
	filter: alpha(opacity=60);
	-ms-filter: "alpha(opacity=60)";
}
iframe {
	width: 100%;
	height: 400px;
}
.googlemaps iframe,
.googlemaps object,
.googlemaps embed {
	-webkit-filter: grayscale(100%);
	-moz-filter: grayscale(100%);
	-ms-filter: grayscale(100%);
	-o-filter: grayscale(100%);
	filter: grayscale(100%);
	-webkit-transition: all 0.7s ease;
	-moz-transition: all 0.7s ease;
	-o-transition: all 0.7s ease;
	transition: all  0.7s ease;
}
.googlemaps iframe:hover,
.googlemaps object:hover,
.googlemaps embed:hover {
	-webkit-filter: grayscale(0%);
	-moz-filter: grayscale(0%);
	-ms-filter: grayscale(0%);
	-o-filter: grayscale(0%);
	filter: grayscale(0%);
}
.googlemaps .button {
	display: none;
}
.br-sp {
	display: none;
}
@media (min-width: 769px) {
	a[href*="tel:"] {
		pointer-events: none;
		cursor: default;
		text-decoration: none;
	}
}
@media screen and (max-width: 768px){
	.googlemaps .button {
		display: block;
	}
	.br-pc {
		display: none;
	}
	.br-sp {
		display: block;
	}
}

/*ページのフェードイン*/
body {
	animation: fadeIn 2s ease 0s 1 normal;
	-webkit-animation: fadeIn 2s ease 0s 1 normal;
}
@keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}
@-webkit-keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}


/* ------------------------
	リンクボタン
------------------------ */
.button {
	text-align: center;
}
.button a {
	min-width: 496px;
	display: inline-block;
	padding: 18px 0 17px;
	color: #5fc1c7;
	border: 2px #5fc1c7 solid;
	border-radius: 5px;
	background: rgba(255, 255, 255, 0);
	text-align: center;
	font-weight: bold;
	letter-spacing: 0.03em;
}
.button a:hover {
	background: #5fc1c7;
	color: #fff;
}
@media screen and (max-width: 768px){
	.button a {
		min-width: 85%;
		padding: 10px 0;
		color: #fff;
		background: #5fc1c7;
	}
}


/* ------------------------
	ヘッダー
------------------------ */
header {
	position: fixed;
    width: 100%;
    height: 73px;
	background-color: #fff;
	z-index: 10;
}
header .maintitle {
	display: block;
	background: #5fc1c7;
	width: 300px;
	height: 73px;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	transition: 0.5s;
}
header .maintitle img {
	display: block;
	margin: 17px auto 0 auto;
	height: 40.1px;
}
header .maintitle:hover {
	opacity: 0.8;
}
header .inner {
	padding: 0 3% 0 300px;
}
header .inner .main-nav {
	overflow: hidden;
	height: 73px;
	width: 100%;
	text-align: right;
}
header .inner .main-nav ul {
	display: inline-block;
}
header .inner .main-nav ul li {
	float: left;
	margin: 0 0 0 23px;
	padding: 26px 0 0 0;
}
header .inner .main-nav ul li a {
	display: block;
	color: #303030;
	position: relative;
	padding: 0 0 26px 0;
	font-weight: bold;
	letter-spacing: 0.03em;
}
header .inner .main-nav ul li a:after {
	background: #5fc1c7;
	content: '';
	display: block;
	position: absolute;
	z-index: 10;
	transition: all .3s ease;
	-webkit-transition: all .3s ease;
	bottom: 0;
	left: 0;
	width: 0px;
	height: 4px;
}
header .inner .main-nav ul li a:hover:after {
	width: 100%;
}
@media screen and (max-width: 1280px) {
	header .maintitle {
		width: 20%;
	}
	header .inner {
		padding-left: 20%;
	}
}
@media screen and (max-width: 768px){
	header {
		display: none;
	}
}

/*スマホヘッダー*/
.header {
	display: none;
}
.wrap {
	overflow: hidden;
	padding: 73px 0 100px;
}
@media screen and (max-width: 768px){
	.header {
		height: 70px;
		display: block;
		position: fixed;
		top: 0;
		right: 0;
		width: 100%;
		background: #fff;
		z-index: 2000;
	}
	.header > ul {
		display: flex;
		align-items: center;
		justify-content: flex-end;
		height: 70px;
		margin-right: 17%;
	}
	.header > ul a {
		display: block;
		width: 33px;
		padding-bottom: 2px;
	}
	.header > ul a > img {
		width: 100%;
	}
	.header .mob-title {
		position: absolute;
		/*width: 35%;*/
		width: 45%;
	}
	.header .mob-title a {
		display: block;
		height: 70px;
		background: #5fc1c7;
		text-align: center;
		overflow: hidden;
	}
	.header .mob-title a img {
		height: 70px;
		width: auto;
		display: block;
		margin: 0 auto;
		line-height: 0;
	}
	.wrap {
		padding-top: 70px;
	}
}

/*スマホメニュー*/
@media screen and (max-width: 768px){
	button {
		border: none;
		background: none;
		outline:none;
	}
	.menu,
	.menu span {
		display: inline-block;
		-webkit-transition:all .4s;
		transition: all .4s;
		box-sizing: border-box;
	}
	.menu {
		position: fixed;
		top: 24px;
		right: 5%;
		width: 26px;
		height: 22px;
		z-index: 10;
	}
	.menu span {
		position: absolute;
		left: 0;
		width: 100%;
		height: 2px;
		z-index: 10;
		background-color: #5fc1c7;
	}
	.menu span:nth-of-type(1) {
		top: 0px;
	}
	.menu span:nth-of-type(2) {
		top: 10px;
	}
	.menu span:nth-of-type(3) {
		bottom: 0px;
	}
	.menu.active span:nth-of-type(1) {
		-webkit-transform: translateY(10px) rotate(45deg);
		transform: translateY(10px) rotate(45deg);
	}
	.menu.active span:nth-of-type(2) {
		opacity: 0;
	}
	.menu.active span:nth-of-type(3) {
		-webkit-transform: translateY(-10px) rotate(-45deg);
		transform: translateY(-10px) rotate(-45deg);
	}
	#nav {
		position: fixed;
		top: 0;
		right: 0;
		z-index: 10;
		width: 100%;
		height: 100vh;
		opacity: 0;
		background-color: #fff;
		transition: all 0.3s ease-in-out;
		visibility: hidden;
	}
	#nav.active {
		right: 0;
		opacity: 1;
		-moz-transform: translateX(0);
		-webkit-transform: translateX(0);
		transform: translateX(0);
		visibility: visible;
	}
	#nav ul {
		margin-top: 70px;
		padding-bottom: 100px;
	}
	#nav ul li a {
		display: block;
		font-weight: 700;
		line-height: 47px;
		text-align: center;
		text-decoration: none;
		color: #2a2a2a;
	}
}


/* ------------------------
	右ナビ
------------------------ */
#tab {
	position: fixed;
	top: 73px;
	right: 0;
	z-index: 10;
}
#tab .bt-detail {
	height: 207px;
	text-align: center;
	text-justify: inter-ideograph;
	background: #5fc1c7;
	border-top-left-radius: 5px;
	-webkit-border-top-left-radius: 5px;
	-moz-border-radius-topleft: 5px;
	border-bottom-left-radius: 5px;
	-webkit-border-bottom-left-radius: 5px;
	-moz-border-radius-bottomleft: 5px;
	writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -webkit-writing-mode:vertical-rl;
	margin-top: 10px;
}
#tab .bt-detail a {
	display: block;
	letter-spacing: 0.03em;
	color: #fff;
	padding: 0 12px;
	font-weight: bold;
}
@media only screen and (max-width:768px){
	#tab {
		display: none;
	}
}


/* ------------------------
	フッター
------------------------ */
/*#contact*/
#contact .parallax-window {
	background: transparent;
	padding: 110px 0 120px;
}
#contact h2 {
	position: relative;
	font-size: 52px;
	letter-spacing: 0.03em;
	text-align: center;
	color: #fff;
	margin-bottom: 25px;
}
#contact h2 strong {
	display: block;
	font-size: 15px;
	padding-bottom: 25px;
}
#contact h2:after {
	content: "";
	position: absolute;
	width: 70px;
	height: 4px;
	background-color: #5fc1c7;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
}
#contact ul {
	max-width: 1164px;
	margin: 0 auto;
	padding: 0 30px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: center;
}
#contact ul li {
	width: 48.6%;
}
#contact ul li + li {
	margin-left: 2.8%;
}
#contact ul li .wrapper {
	background-color: #fff;
	padding: 40px 32px;
}
#contact ul li .wrapper h3 {
	position: relative;
	font-size: 24px;
	font-weight: bold;
	color: #5fc1c7;
	margin-bottom: 25px;
}
#contact ul li .wrapper h3:after {
	content: "";
	position: absolute;
	width: 30px;
	height: 1px;
	background-color: #5fc1c7;
	bottom: 0;
	left: 0;
}
#contact ul li .wrapper h3 span {
	display: block;
	padding-bottom: 20px;
}
#contact ul li .wrapper p {
	line-height: 1.7;
}
#contact ul li .bt-detail {
	position: relative;
	width: 207px;
	margin: -15px 0 0 32px;
	text-align: center;
	text-justify: inter-ideograph;
	background: #5fc1c7;
	border-radius: 5px;
}
#contact ul li .bt-detail a {
	display: block;
	letter-spacing: 0.03em;
	color: #fff;
	padding: 12px 0;
	font-weight: bold;
}
@media only screen and (max-width:768px){
	#contact .parallax-window {
		padding: 75px 0 95px;
	}
	#contact h2 {
		font-size: 30px;
	}
	#contact h2 strong {
		font-size: 12px;
	}
	#contact h2:after {
		width: 50px;
	}
	#contact ul {
		padding: 0 5%;
	}
	#contact ul li {
		width: 100%;
	}
	#contact ul li ~ li {
		margin-top: 30px;
	}
	#contact ul li .wrapper h3 {
		font-size: 20px;
		text-align: center;
	}
	#contact ul li .wrapper h3:after {
		position: static;
		display: block;
		margin: 0 auto;
	}
	#contact ul li .wrapper h3 span {
		padding-bottom: 10px;
	}
	#contact ul li .wrapper p {
		line-height: 1.6;
		font-size: 14px;
	}
}

/*.contact-box*/
footer .contact-box {
	text-align: center;
	padding: 40px 0;
	border-bottom: 1px solid #e7e7e7;
}
footer .contact-box .logo-footer {
	display: inline-block;
	margin-bottom: 20px;
}
footer .contact-box p {
	text-align: center;
}
footer .contact-box p.contact-box-text {
	font-size: 16px;
	letter-spacing: .065em;
}
footer .contact-box p.contact-box-tel {
	font-size: 40px;
	font-weight: 700;
	letter-spacing: .055em;
	margin: 15px auto 3px;
}
footer .contact-box p.contact-box-note {
	font-size: 12px;
	letter-spacing: .05em;
}
@media only screen and (max-width:768px){
	footer .contact-box {
		font-size: 14px;
	}
	footer .contact-box p.contact-box-text {
		font-size: 14px;
		line-height: 1.4;
	}
	footer .contact-box p.contact-box-tel {
		font-size: 24px;
		letter-spacing: .065em;
		margin: 18px auto 3px;
	}
	footer .contact-box p.contact-box-note {
		font-size: 10px;
	}
}

/*.footer-bottom*/
.footer-bottom {
	text-align: center;
	padding-top: 25px;
}
.footer-bottom ul {
	display: flex;
	justify-content: center;
}
.footer-bottom ul li a {
	font-weight: bold;
	letter-spacing: 0.03em;
	margin: 0 8px;
}
.footer-bottom ul.sub_menu {
	margin-top: 10px;
}
.footer-bottom ul.sub_menu li a {
	font-size: 12px;
	font-weight: normal;
	margin: 0 4px;
}
@media only screen and (max-width:768px){
	.footer-bottom {
		padding-bottom: 80px;
	}
	.footer-bottom ul {
		display: block;
	}
	.footer-bottom ul li a {
		margin: 0;
		line-height: 35px;
	}
}

/*.footercopy*/
.footercopy {
	font-size: 10px;
	padding: 25px 0;
}
@media only screen and (max-width:768px){}


/* ------------------------
	フローティングメニュー
------------------------ */
.footer-nav {
	display: none;
}
@media screen and (max-width: 768px){
	.footer-nav {
		display: block;
	}
	.footer-nav .footer-nav-list {
		display: none;
		width: 100%;
		background-color: rgba(0,0,0,0.65);
		position: fixed;
		bottom: 0;
		z-index:999;
		padding: 10px 0;
	}
	.footer-nav .footer-nav-list ul {
		width: 96.09375%;
		margin: 0 auto;
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	.footer-nav .footer-nav-list ul li {
		width: 49.0514905149%;
	}
	.footer-nav .footer-nav-list ul li + li {
		margin-left: 1.8970189702%;
	}
	.footer-nav .footer-nav-list ul li a {
		color: #fff;
		border: 2px #5fc1c7 solid;
		background: #5fc1c7;
		width: 100%;
	}
}


/* ------------------------
	画像を拡大
------------------------ */
.img_wrap {
	margin: 0 auto;
	overflow: hidden;
	background: #000;
}
.img_wrap img {
	width: 100%;
	transition-duration: 0.5s;
}
.img_wrap:hover img {
	transform: scale(1.2);
	transition-duration: 0.5s;
	opacity: 0.8;
}


/* ------------------------
	エフェクト
------------------------ */
.effect > .ef-fade02 {
	transition: .8s;
}
.ef-fade02 {
	opacity: 0;
	transform: translate(0, 60px);
	-webkit-transform: translate(0, 60px);
}
.fade02 {
	opacity: 1.0;
	transform: translate(0, 0);
	-webkit-transform: translate(0, 0);
}


/* ------------------------
	拡大する画像
------------------------ */
.imgWrap {
	overflow: hidden;
	width: 326px;
	height: 217px;
}
.imgWrap img {
	width: 326px;
	display: block;
	transition: 0.5s;
}
.imgWrap img:hover {
	transform: scale(1.1, 1.1);
}
@media screen and (max-width: 768px){}


/* ------------------------
	.tableBox
------------------------ */
.tableBox dl {
	width: 100%;
	padding: 8px 0;
	border-bottom: 1px solid #e7e7e7;
	display: table;
}
.tableBox dl:first-child {
	border-top: 1px solid #e7e7e7;
}
.tableBox dl dt {
	letter-spacing: .09em;
	width: 22.43%;
	display: table-cell;
	vertical-align: top;
	font-feature-settings: "palt";
	line-height: 2;
}
.tableBox dl dd {
	letter-spacing: .07em;
	display: table-cell;
	vertical-align: top;
	font-feature-settings: "palt";
	line-height: 2;
	text-align: justify;
	text-justify: inter-ideograph;
}
.tableBox dl dd a {
	color: #5fc1c7;
}
.tableBox dl dd a[target='_blank'] {
	padding-right: 21px;
	background-image: url("../images/icon_blank_black.png");
	background-position: 100% 50%;
	background-repeat: no-repeat;
}
.tableBox dl dd a:hover,
.tableBox dl dd a[target='_blank']:hover {
	text-decoration: underline;
}
.tableBox dl dd a.map {
	margin-left: 10px;
}
.tableBox dl dd li {
	line-height:2;
}
@media screen and (max-width: 768px){
	.tableBox dl {
		padding: 7.5px 0;
	}
	.tableBox dl dt {
		vertical-align: top;
		font-size: 14px;
		width: 32.23%;
	}
	.tableBox dl dd {
		vertical-align: top;
		font-size: 14px;
	}
}


/* ------------------------
	ページトップへ
------------------------ */
.pagetop {
	display: none;
	position: fixed;
	bottom: 25px;
	right: 3%;
	z-index: 1;
}
.pagetop a {
	display: block;
	width: 52px;
	height: 52px;
	background-color: #5fc1c7;
	border-radius: 50%;
	font-size: 62.5%;
	line-height: 1.15;
}
.pagetop a:before {
	content: url(../images/arrow.svg);
	display: inline-block;
	width: 10px;
	height: 10px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	-webkit- transform: translateY(-50%) translateX(-50%);
}
@media screen and (max-width: 768px){
	.pagetop {
		bottom: 81px;
		right: 20px;
	}
	.pagetop a {
		width: 42px;
		height: 42px;
	}
}


/* ------------------------
	Hero
------------------------ */
.hero .imgfield {
	height: 150px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	text-align: center;
	display: table;
	width: 100%;
	margin-bottom: 70px;
}
.hero .subpart {
	display: table-cell;
	vertical-align: middle;
}
.hero .subpart h1 > span {
	display: inline-block;
	background: #5fc1c7;
	color: #fff;
	font-size: 24px;
	line-height: 1.25;
	padding: 7px 15px 6px;
	font-weight: bold;
}
@media screen and (max-width: 768px){
	.hero .imgfield {
		height: 130px;
		margin-bottom: 40px;
	}
	.hero .subpart h1 > span {
		font-size: 20px;
	}
}


/* ------------------------
	記事一覧
------------------------ */
.archive .wrapper {
	max-width: 1320px;
	margin: 0 auto;
	padding: 0 30px;
}
.articlecard {
	display: flex;
	flex-wrap: wrap;
}
.articlecard article {
	width: 31.74%;
	margin-right: 2.39%;
	margin-bottom: 70px;
}
.articlecard article:nth-of-type(3n) {
	margin-right: 0;
}
.articlecard article a {
	display: block;
	letter-spacing: 0.03em;
}
.articlecard article a:hover {
	opacity: 0.8;
}
.articlecard article a .img_wrap {
	border: 1px solid #e7e7e7;
}
.articlecard article a h3 {
	position: relative;
	width: 75%;
	margin: -22px 0 0 0;
	text-align: justify;
	text-justify: inter-ideograph;
	background: #5fc1c7;
	font-size: 15px;
	font-weight: bold;
	padding: 0;
}
.articlecard article a h3 span {
	display: inline-block;
	color: #fff;
	padding: 10px 15px;
}
.articlecard article a p {
	display: block;
	line-height: 1.7;
	padding-top: 15px;
}
@media screen and (max-width: 768px){
	.articlecard ul {
		display: block;
	}
	.articlecard article {
		width: 100%;
		margin-right: 0;
		margin-bottom: 35px;
	}
	.articlecard article a h3 {
		width: 90%;
		margin: -15px 0 0 0;
	}
	.articlecard article a p {
		line-height: 1.6;
		padding-top: 10px;
		font-size: 14px;
	}
}

/*Hero*/
.articlehero .imgfield {
	height: 150px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.articlehero .subpart {
	margin-bottom: 70px;
}
.articlehero .subpart h1 {
	margin: -30px 0 0 100px;
}
.articlehero .subpart h1 span {
	display: inline-block;
	background: #5fc1c7;
	color: #fff;
	font-size: 24px;
	line-height: 1.25;
	padding: 7px 15px 6px;
	font-weight: bold;
	width: 646px;
	text-align: justify;
	text-justify: inter-ideograph;
}
@media screen and (max-width: 1280px){
	.articlehero .subpart h1 {
		margin-left: 25px;
	}
}
@media screen and (max-width: 768px){
	.articlehero .imgfield {
		height: 130px;
	}
	.articlehero .subpart {
		margin-bottom: 20px;
	}
	.articlehero .subpart h1 {
		margin-left: 3%;
	}
	.articlehero .subpart h1 span {
		font-size: 20px;
		width: 97%;
	}
}

/*ページネーション*/
.pagination {
	display: block;
	width: 100%;
	text-align: center;
	margin: 20px 0 0;
}
.pagination .nav-links a.page-numbers {
	color: #0d0d0d;
}
@media screen and (max-width: 768px){
	/*.pagination .page-numbers {
		padding-left: 8px;
		padding-right: 8px;
	}*/
}


/* ------------------------
	記事詳細
------------------------ */
#single img {
	width: 100%;
}
#single .block {
	max-width: 800px;
	margin: 0 auto;
}
#single .date-category {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	margin-bottom: 30px;
}
#single .date-category span {
	margin-right: 35px;
}
#single .date-category > ul.post-categories > li a {
	min-width: 150px;
	background: #5fc1c7;
	display: inline-block;
	margin-right: 10px;
	font-size: 12px;
	text-align: center;
	padding: 5px 10px;
	color: #fff;
}
#single .description {
	padding-top: 30px;
	border-top: 1px solid #e7e7e7;
}
#single .description img {
	margin-bottom: 70px;
}
#single .tag {
	font-size: 14px;
	margin-top: 20px;
}
#single .tag a:after {
	content: ",";
}
#single .tag a:last-of-type:after {
	content: none;
}
@media screen and (max-width: 768px){
	#single .date-category {
		display: block;
	}
	#single .date-category span {
		font-size: 12px;
	}
	#single .date-category > ul.post-categories > li a {
		min-width: 120px;
		margin: 5px 5px 0 0;
		font-size: 10px;
	}
	#single .description img {
		margin-bottom: 50px;
	}
	#single .tag {
		font-size: 12px;
	}
}

/*お知らせ（single-1.php）*/
.notice {
	max-width: 860px;
	margin: 0 auto;
	padding: 0 30px;
}
.notice > section {
	margin-bottom: 55px;
}
.notice > section:first-of-type {
	padding-top: 30px;
	border-top: 1px solid #e7e7e7;
}
.notice > section > img {
	margin-bottom: 55px;
}
.notice > section > h2 {
	font-size: 20px;
	font-weight: bold;
	line-height: 1.25;
	margin-bottom: 25px;
}
.notice > section > p {
	font-size: 14px;
	line-height: 2;
	margin: 0 0 1.75em;
}
@media screen and (max-width: 768px){
	.notice {
		padding: 0 5%;
	}
	.notice > section {
		margin-bottom: 45px;
	}
	.notice > section > img {
		margin-bottom: 45px;
	}
	.notice > section > h2 {
		font-size: 16px;
	}
}

/*事例紹介（single-2.php）*/
.works {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 30px;
}
.works img {
	border: 1px solid #e7e7e7;
}
.works .description h2 {
	font-size: 20px;
	font-weight: bold;
	line-height: 1.8;
	margin-bottom: 22px;
}
.works .description p {
	line-height: 2;
	margin-bottom: 24px;
}
.works .tableBox dl dt {
	font-size:14px;
}
.works .tableBox dl dd {
	font-size:14px;
}
.works section {
	margin-top: 40px;
}
.works section > ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.works section > ul > li {
	width: 48.2692307692%;
}
@media screen and (max-width: 768px){
	.works {
		padding: 0 5%;
	}
	.works .description h2 {
		font-size: 16px;
	}
}

/*セミナー（single-3.php）*/
.seminar {
	max-width: 860px;
	margin: 0 auto;
	padding: 0 30px;
}
.seminar > section {
	margin-bottom: 55px;
}
.seminar .tableBox dl dt {
	position: relative;
}
.seminar .tableBox dl dt:after {
	content: ":";
	position: absolute;
	top: 50%;
	right: 3px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.seminar > section > img {
	margin-bottom: 55px;
}
.seminar > section:nth-of-type(2) > img {
	margin-bottom: 25px;
}
.seminar > section > h2 {
	font-size: 26px;
	font-weight: bold;
	line-height: 1.25;
	margin-bottom: 25px;
}
.seminar > section > p {
	line-height: 2;
	margin: 0 0 1.75em;
}
.seminar #map address {
	font-style: normal;
	margin-bottom: 15px;
}
.seminar #map address span {
	font-weight: bold;
}
.seminar #map address span:after {
	content: "：";
}
.seminar .contact-box {
	text-align: center;
	margin-top: 100px;
}
.seminar .contact-box > p {
	margin: 0;
	line-height: 1.5;
	text-align: center;
}
.seminar .contact-box > p.catch-text {
	font-size: 26px;
	font-weight: bold;
	line-height: 1.25;
	margin-bottom: 25px;
}
.seminar .contact-box > p.contact-box-text {
	font-size: 16px;
	letter-spacing: .065em;
	padding-left: 10px;
}
.seminar .contact-box > p.contact-box-tel {
	font-size: 28px;
	font-weight: 700;
	letter-spacing: .055em;
	margin: 15px auto 3px;
	padding-right: 20px;
}
.seminar .contact-box > p.contact-box-note {
	font-size: 12px;
	letter-spacing: .05em;
	padding-right: 15px;
}
.seminar .contact-box > a.button {
	background: #0067b2;
	color: #fff;
	display: block;
	font-size: 24px;
	font-weight: bold;
	letter-spacing: 0.03em;
	padding: 20px;
	margin: 0 auto 50px;
	border-radius: 5px;
	line-height: 1.8;
	max-width: 352px;
}
@media screen and (max-width: 768px){
	.seminar {
		padding: 0 5%;
	}
	.seminar > section {
		margin-bottom: 45px;
	}
	.seminar > section > img {
		margin-bottom: 45px;
	}
	.seminar > section > h2 {
		font-size: 20px;
	}
	.seminar > section > p {
		font-size: 14px;
		line-height: 1.75;
	}
	.seminar .contact-box {
		margin-top: 70px;
	}
	.seminar .contact-box > p.catch-text {
		font-size: 20px;
	}
	.seminar .contact-box > p.contact-box-text {
		font-size: 14px;
		padding-left: 0;
		line-height: 1.4;
	}
	.seminar .contact-box > p.contact-box-tel {
		font-size: 24px;
		letter-spacing: .065em;
		margin: 18px auto 3px;
		padding-right: 0;
	}
	.seminar .contact-box > p.contact-box-note {
		font-size: 10px;
		padding: 0 0 0 2px;
	}
	.seminar .contact-box > a.button {
		margin-bottom: 60px;
		max-width: 100%;
	}
}

/*この記事を書いた人*/
.detail-profile {
	max-width: 860px;
	margin: 70px auto 0;
	padding: 0 30px;
}
.detail-profile > ul {
	display: flex;
	max-width: 100%;
	margin: 0 auto;
	padding: 50px 0;
	border-bottom: 1px solid #e7e7e7;
	border-top: 1px solid #e7e7e7;
}
.detail-profile > ul .eyecatch {
	display: block;
	width: 120px;
	height: 120px;
	overflow: hidden;
	margin-right: 30px;
	border-radius: 50%;
}
.detail-profile > ul > li h2 {
	font-size: 16px;
	font-weight: bold;
	line-height: 1.5;
	margin-bottom: 15px;
}
.detail-profile > ul > li h2 a {
	text-decoration: underline;
	color: #303030;
}
.detail-profile > ul > li p {
	width: 650px;
	line-height: 1.75;
}
@media screen and (max-width: 896px){
	.detail-profile {
		margin-top: 20px;
	}
	.detail-profile > ul {
		padding-bottom: 30px;
		padding-top: 30px;
	}
	.detail-profile > ul .eyecatch {
		width: 100px;
		height: 100px;
		margin-right: 20px;
	}
	.detail-profile > ul li.text {
		width: calc(100% - 120px);
	}
	.detail-profile > ul li h2 {
		font-size: 14px;
		margin-bottom: 10px;
	}
	.detail-profile > ul li p {
		width: 100%;
		font-size: 12px;
	}
}

/*ページネーション*/
.center-nav {
	text-align: center;
	padding: 40px 0 80px;
}
.center-nav span.nav-line {
	margin: 0 8px;
}
.center-nav span.nav-line a {
	text-decoration: none;
	color: #1a1a1a;
}
.center-nav span.nav-line ul.post-categories,
.center-nav span.nav-line ul.post-categories li {
	display: inline-block;
}
@media screen and (max-width: 768px){
	.center-nav {
		padding-bottom: 60px;
	}
}

/*関連記事*/
.related > h3 {
	font-size: 20px;
	font-weight: bold;
	line-height: 1.8;
	text-align: center;
	margin-bottom: 22px;
}
.related .yarpp-related {
	max-width: 1260px;
	margin: 0 auto;
	padding: 0 3%;
}
@media screen and (max-width: 768px){
	.related > h3 {
		font-size: 16px;
	}
}


/* ------------------------
	アンカーリンク
------------------------ */
ul.anchor {
	display: flex;
}
ul.anchor > li {
	margin: 0 35px 20px 0;
}
ul.anchor > li > a {
	padding: 0 0 0 30px;
	position: relative;
	display: block;
	font-size: 14px;
}
ul.anchor > li > a:after {
	position: absolute;
	content: "";
	top: 3px;
	left: 5px;
	width: 9px;
	height: 9px;
	border-top: #5fc1c7 2px solid;
	border-left: #5fc1c7 2px solid;
	-webkit-transform: rotate(-135deg);
	-ms-transform: rotate(-135deg);
	transform: rotate(-135deg);
	transition: 0.5s;
}
ul.anchor > li > a:hover {
	text-decoration: underline;
}
@media screen and (max-width: 768px){
	ul.anchor {
		display: block;
	}
	ul.anchor > li:last-of-type {
		margin-bottom: 0;
	}
}


/* ------------------------
	よくある質問
------------------------ */
.faq > dl {
	word-wrap: break-word;
}
.faq > dl + dl {
	padding-top: 60px;
}
.faq > dl > dt,
.faq > dl > dd {
	text-align: justify;
	text-justify: inter-ideograph;
}
.faq > dl > dt {
	font-size: 18px;
	font-weight: bold;
	color: #5fc1c7;
	margin-bottom: 10px;
}
.faq > dl > dt:before {
	content: 'Q.';
	margin-right: 4px;
}
.faq > dl > dd {
	line-height: 1.75;
}
.faq > dl > dd a {
	color: #5fc1c7;
}
.faq > dl > dd a:hover {
	text-decoration: underline;
}
.faq > dl > dd small {
	display: block;
	font-size: 13px;
	margin-top: 2px;
}
@media screen and (max-width: 768px){
	.faq > dl + dl {
		padding-top: 35px;
	}
	.faq > dl > dt {
		font-size: 16px;
	}
}


/* ------------------------
	フォーム共通
------------------------ */
#inquiry {
	max-width: 860px;
	margin: 0 auto;
	padding: 0 30px;
}
#inquiry > p {
	line-height: 2;
	text-align: center;
	padding-bottom: 70px;
}
#inquiry > p a {
	color: #5fc1c7;
}
#inquiry > p a:hover {
	text-decoration: underline;
}
#inquiry > section > .mw_wp_form_complete > p {
	line-height: 2;
	text-align: center;
}
@media screen and (max-width: 768px){
	#inquiry {
		padding: 0 5%;
	}
	#inquiry > p {
		line-height: 1.75;
		text-align: justify;
		text-justify: inter-ideograph;
		padding-bottom: 40px;
		font-size: 14px;
	}
}

/*input*/
#inquiry input[type="date"],
#inquiry input[type="time"],
#inquiry input[type="datetime-local"],
#inquiry input[type="week"],
#inquiry input[type="month"],
#inquiry input[type="text"],
#inquiry input[type="email"],
#inquiry input[type="url"],
#inquiry input[type="password"],
#inquiry input[type="search"],
#inquiry input[type="tel"],
#inquiry input[type="number"],
#inquiry textarea {
	background: #f3f3f3;
	border: none;
	border-radius: 0;
	color: #1a1a1a;
	padding: 15px;
	font-size: 15px;
}
@media screen and (max-width: 768px){
	#inquiry input[type="date"],
	#inquiry input[type="time"],
	#inquiry input[type="datetime-local"],
	#inquiry input[type="week"],
	#inquiry input[type="month"],
	#inquiry input[type="text"],
	#inquiry input[type="email"],
	#inquiry input[type="url"],
	#inquiry input[type="password"],
	#inquiry input[type="search"],
	#inquiry input[type="tel"],
	#inquiry input[type="number"],
	#inquiry textarea {
		padding: 10px;
		font-size: 16px;
	}
}

/*.contact-tableBox*/
.contact-tableBox {
	margin-bottom: 35px;
}
.contact-tableBox dl {
	width: 100%;
	padding: 15px 0;
	border-bottom: 1px solid #e7e7e7;
	display: table;
}
.contact-tableBox dl:first-child {
	border-top: 1px solid #e7e7e7;
}
.contact-tableBox dl dt {
	letter-spacing: .09em;
	width: 33.3333333333%;
	display: table-cell;
	vertical-align: middle;
	font-feature-settings: "palt";
	line-height: 2;
	position: relative;
}
.contact-tableBox dl dt span {
	position: absolute;
	top: 50%;
	right: 0;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	display: block;
	background-color: #f3f3f3;
	font-size: 12px;
	line-height: 1;
	padding: 3px 12px;
	margin-right: 15px;
}
.contact-tableBox dl dt span.required {
	background-color: #5fc1c7;
	color: #fff;
}
.contact-tableBox dl dd {
	letter-spacing: .07em;
	display: table-cell;
	vertical-align: top;
	font-feature-settings: "palt";
	line-height: 2;
}
.contact-tableBox dl dd > div {
	text-align: justify;
	text-justify: inter-ideograph;
	padding-bottom: 8px;
}
.contact-tableBox dl dd > div:nth-of-type(2) {
	padding-top: 20px;
}
@media screen and (max-width: 768px){
	.contact-tableBox dl dt {
		letter-spacing: 0;
		width: 100%;
		display: block;
		vertical-align: top;
	}
	.contact-tableBox dl dt span {
		margin-right: 0;
	}
	.contact-tableBox dl dd {
		letter-spacing: 0;
		display: block;
		font-size: 16px;
		margin-top: 3px;
	}
	.contact-tableBox dl dd .mwform-checkbox-field-text,
	.contact-tableBox dl dd .mwform-radio-field {
		font-size: 15px;
		line-height: 2;
	}
	.contact-tableBox dl dd > div {
		font-size: 14px;
	}
}

/*.contact-tableBox-select*/
.contact-tableBox-select {
	position: relative;
	display: inline-block;
	width: 100%;
}
.contact-tableBox-select::after {
	position: absolute;
	top: 46%;
	right: 20px;
	content: "";
	border-top: 5px solid #0d0d0d;
	border-right: 5px solid transparent;
	border-bottom: 5px solid transparent;
	border-left: 5px solid transparent;
	display: block;
}
.contact-tableBox-select select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	padding: 15px;
	font-size: 15px;
	border: none;
	background-color: #f3f3f3;
	width: 100%;
	outline: none;
}
.contact-tableBox-select select::-ms-expand {
    display: none;
}
.contact-tableBox-select select option {
	background: #fff;
}
@media screen and (max-width: 768px){
	.contact-tableBox-select select {
		font-size: 16px;
	}
}

/*送信ボタン*/
#inquiry form > p {
	display: flex;
	justify-content: center;
}
#inquiry form > p > input[type="submit"] {
	width: 207px;
	margin: 0 5px;
	text-align: center;
	text-justify: inter-ideograph;
	background: #5fc1c7;
	border-radius: 5px;
	letter-spacing: 0.03em;
	color: #fff;
	padding: 11px 0;
	font-weight: bold;
	line-height: 1.5;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all  0.3s ease;
}
#inquiry form > p > input[type="submit"]:hover {
	opacity: 0.6;
	filter: alpha(opacity=60);
	-ms-filter: "alpha(opacity=60)";
}
@media screen and (max-width: 768px){}
