/* ----------------------------------------------------
 * All Design 
 ---------------------------------------------------- */
.main-header .logo,
h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
p,
ul,
li,
a,
th,
td,
body {
	letter-spacing: 1px;

	/* -- 丸文字
	font-family:"ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO";
	-- */

	/* -- ゴシック体
	font-family:"游ゴシック体",YuGothic,"游ゴシック Medium","Yu Gothic Medium","游ゴシック","Yu Gothic","Yu Gothic local","Hiragino Sans","ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
	font-family:"游ゴシック体",YuGothic,"游ゴシック","Yu Gothic","Yu Gothic local","Hiragino Sans","ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
	-- */

	/* -- 明朝体 -- */
	font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

#header .header_logo {
	width: 35%;
}

#header .header_menu {
	width: 65%;
}

#container {
	overflow: unset;
}

.inner-content {
	max-width: 1170px;
	width: 95%;
	margin: 0 auto;
}

.inner-sub-content {
	padding: 100px 0;
}

.sub-page-contents {
	padding: 100px 0;
}

.text-left {
	text-align: left;
}

.text-right {
	text-align: right;
}

.text-center {
	text-align: center;
}

.font-bold {
	font-weight: bold;
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
p,
a,
th,
td {
	margin: 0 auto;
}

a[href^="tel:"] {
	pointer-events: none;
}

a:hover {
	text-decoration: none;
}

.f-10 {
	font-size: 10px;
}

.f-12 {
	font-size: 12px;
}

.f-14 {
	font-size: 14px;
}

.f-16 {
	font-size: 16px;
}

.f-18 {
	font-size: 18px;
}

.f-20 {
	font-size: 20px;
}

.f-22 {
	font-size: 22px;
}

.f-24 {
	font-size: 24px;
}

.f-26 {
	font-size: 26px;
}

.f-40 {
	font-size: 40px;
}


.fc-wh {
	color: var(--wp--preset--color--white);
}

.fc-bk {
	color: var(--wp--preset--color--black);
}

.metaslider .slides img {
	width: 100%;
	display: block;
	height: 100%;
	max-height: 450px !important;
	object-fit: cover;
	object-position: center;
}

.flexslider .flex-control-nav li a:not(.flex-active) {
	/*
	background: #FFF !important;
	border: 1px solid #000;
	box-shadow: 0 0 4px 1px #999 !important;
*/
}

.flexslider .flex-control-nav li a.flex-active {
	/*
	background: #2f8f98 !important;
	border: 1px solid #2f8f98;
*/
}

.ms-is-small.metaslider.ms-theme-blend .flexslider ol.flex-control-nav:not(.flex-control-thumbs) {
	bottom: -40px !important;
}

.breadcrumbs a:active,
.breadcrumbs a:hover,
.breadcrumbs a:link,
.breadcrumbs a:visited {
	color: #2f8f98;
}

.breadcrumbs {
	margin-bottom: 0;
	font-size: 14px;
	color: #777;
}


.responsive-nav .menu>.menu-item>a,
.header--transparency.header--fixed--is_scrolled .responsive-nav .menu>.menu-item>a {
	background-color: transparent;
	padding: 0px 15px !important;
	display: flex;
	flex-direction: column;
	justify-content: space-evenly;
	align-items: center;
	height: 80px;
	line-height: inherit;
}

.responsive-nav .menu>.current-menu-item>a,
.responsive-nav .menu>.current-menu-item>a i {
	text-shadow: none !important;
	color: #2f8f98 !important;
}

.responsive-nav .menu>.menu-item>a i {
	font-size: 30px;
	color: #fff;
	text-shadow: 0px 0px 4px #333;
	line-height: inherit;
	animation: shake-1 5s infinite;
}

.responsive-nav li:last-child {
	background: #ffa200;
	border-left: 3px solid #2f8f98;
	border-bottom: 3px solid #2f8f98;
	margin-left: 15px;
}

.responsive-nav li:last-child a {
	color: #fff !important;
}

.responsive-nav .menu>li.current-menu-item:last-child>a,
.responsive-nav .menu>li.current-menu-item:last-child>a i {
	color: #fff !important;
}

@media (max-width: 767px) {

	#header .header_logo {
		width: 80%;
		display: none;
	}

	#header .header_menu {
		width: 20%;
	}

	#header.header {
		height: 50px;
	}

	#header .site-branding {
		height: 50px;
		padding: 0;
	}

	#responsive-btn {
		border: none;
	}

	#responsive-btn:hover {
		background-color: transparent !important;
	}

	.global-nav {
		background: #2f8f98;
		border-top: 1px solid #2f7898;
		border-bottom: 1px solid #aaa;
	}

	.global-nav>*>ul {
		border-bottom: 1px solid #2f7898;
	}

	.global-nav li {
		border-top: 1px solid #2f7898;
		border-bottom: 1px solid #2f7898;
	}

	.global-nav .current-menu-item>a {
		background: #004147;
	}

	#container {
		transition: transform 0.2s ease-out;
		-ms-transition: transform 0.2s ease-out;
		-moz-transition: transform 0.2s ease-out;
		-webkit-transition: transform 0.2s ease-out;
	}

	.breadcrumbs {
		font-size: 12px;
	}

	.sub-page-contents {
		padding: 50px 0;
	}

	.inner-sub-content {
		padding: 50px 0;
	}

	a[href^="tel:"] {
		pointer-events: auto;
	}

	.off-canvas-nav--dark a i {
		display: none;
	}

	#wpfront-scroll-top-container img {
		width: 30px !important;
	}

	.metaslider .slides img {
		width: 100%;
		height: 300px !important;
		display: block;
	}

	.f-18 {
		font-size: calc(18px * 0.8);
	}

	.f-20 {
		font-size: calc(20px * 0.8);
	}

	.f-22 {
		font-size: calc(22px * 0.8);
	}

	.f-24 {
		font-size: calc(24px * 0.8);
	}

	.f-26 {
		font-size: calc(26px * 0.8);
	}

	.f-40 {
		font-size: calc(40px * 0.8);
	}

}

/* ----------------------------------------------------
 * Padding
 ---------------------------------------------------- */
.pt-10 {
	padding-top: 10px;
}

.pt-15 {
	padding-top: 15px;
}

.pt-20 {
	padding-top: 20px;
}

.pt-40 {
	padding-top: 40px;
}


.pt-50 {
	padding-top: 50px;
}

.pb-10 {
	padding-bottom: 10px;
}

.pb-15 {
	padding-bottom: 15px;
}

.pb-20 {
	padding-bottom: 20px;
}

.pb-50 {
	padding-bottom: 50px;
}

.pl-10 {
	padding-left: 10px;
}

.pl-15 {
	padding-left: 15px;
}

.pl-20 {
	padding-left: 20px;
}

.pl-40 {
	padding-left: 40px;
}

.pr-10 {
	padding-right: 10px;
}

.pr-15 {
	padding-right: 15px;
}

.pr-20 {
	padding-right: 20px;
}

/* ----------------------------------------------------
 * Margin
 ---------------------------------------------------- */
.mt-10 {
	margin-top: 10px;
}

.mt-15 {
	margin-top: 15px;
}

.mt-20 {
	margin-top: 20px;
}

.mb-10 {
	margin-bottom: 10px;
}

.mb-15 {
	margin-bottom: 15px;
}

.mb-20 {
	margin-bottom: 20px;
}

.ml-10 {
	margin-left: 10px;
}

.ml-15 {
	margin-left: 15px;
}

.ml-20 {
	margin-left: 20px;
}

.mr-10 {
	margin-right: 10px;
}

.mr-15 {
	margin-right: 15px;
}

.mr-20 {
	margin-right: 20px;
}

/* ----------------------------------------------------
 * Flex
 ---------------------------------------------------- */
.flex-space-center {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	margin: 0 auto;
	margin-bottom: 0;
}

.flex-start-center {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
	margin: 0 auto;
	margin-bottom: 0;
}

.flex-space-center {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	margin: 0 auto;
	margin-bottom: 0;
}

.flex-gap-5 {
	gap: 5%;
}

.flex-inner-75 {
	width: 75%;
}

.flex-inner-50 {
	width: calc(100% / 2);
}

.flex-inner-45 {
	width: 45%;
}

.flex-inner-40 {
	width: 40%;
}

.flex-inner-33 {
	width: calc(100% / 3);
}

.flex-inner-25 {
	width: calc(100% / 4);
}

/* ----------------------------------------------------
 * Animation
 ---------------------------------------------------- */
@keyframes shake {
	0% {
		transform: translateY(5px);
	}

	50% {
		transform: translateY(-5px);
	}

	100% {
		transform: translateY(5px);
	}
}

@keyframes shake-1 {
	0% {
		transform: rotate(10deg);
	}

	50% {
		transform: rotate(-10deg);
	}

	100% {
		transform: rotate(10deg);
	}
}

@keyframes fadein_animation {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
		transform: translate(0);
	}
}

.fadein {
	opacity: 0;
	transform: translate(0, 50px);
	transition-duration: 0.5s;
	transition-property: opacity, transform;
}

.fadein.scrollin {
	opacity: 1;
	transform: translate(0, 0);
}

.fadein_animation_start {
	animation-name: fadein_animation;
	animation-delay: .5s;
	animation-duration: 2s;
	animation-fill-mode: both;
}

.scroll_fadein {
	opacity: 0;
}

.slideup {
	transform: translateY(50px);
}

.slidedown {
	transform: translateY(-50px);
}

.slideright {
	transform: translateX(50px);
}

.slideleft {
	transform: translateX(-50px);
}

/* ----------------------------------------------------
 * TOP Header
 ---------------------------------------------------- */
#top_header {
	height: 50px;
	background-color: #2f8f98;
}

#top_header .site_ttl {
	width: 50%;
}

#top_header a.tel i {
	margin-right: 5px;
	animation: shake-1 5s infinite;
}

#header .flex-space-center-2,
#top_header-sp {
	display: none;
}

.site-branding {
	height: 80px;
}

.site-branding img {
	width: 50px;
	clip-path: circle(46% at 50% 50%);
}

.header {
	position: relative;
	height: 80px;
	width: 100%;
}

.fixed2 {
	position: fixed;
	top: 0;
	background-color: rgb(255 255 255 / 80%) !important;
	backdrop-filter: blur(3px);
}

.top-page-header {
	position: relative;
	height: calc(100vh - 130px);
}

.top-page-header img {
	height: 100%;
	width: 100vw;
	object-fit: cover;
	object-position: top;
}

.top-page-header .main_slogan {
	position: absolute;
	top: 50px;
	left: 50px;
	background: rgb(255 255 255 / 80%);
	padding: 20px;
	position: absolute;
	top: 50px;
	left: 50px;
	background: rgb(255 255 255 / 80%);
	padding: 20px;
	top: 25%;
	left: 50%;
	transform: translate(-50%, -50%);
	max-width: 930px;
	width: 100%;
}

.top-page-header .main_slogan .main_ttl {
	font-size: 40px;
	color: #2f8f98;
	font-weight: bold;
	letter-spacing: 5px;
}

.top-page-header .main_slogan .main_ttl span.main {
	color: #fff;
	padding: 10px;
	background: #2f8f98;
	margin-right: 15px;
	/*
	box-shadow: 0px 0px 0px 5px rgba(170, 170, 170, 1), 0px 0px 4px 6px rgb(103 103 103);
	*/
}

.top-page-header .main_slogan .main_ttl span.small {
	font-size: 22px;
}

.view_pc {
	display: block;
}

.view_sp {
	display: none;
}

@media (max-width: 767px) {

	.view_pc {
		display: none;
	}

	.view_sp {
		display: block;
	}

	.sp-phone .flex-space-center {
		width: calc(100% - 40px);
		display: flex;
		flex-direction: row;
		justify-content: flex-start;
		align-items: center;
		margin: 0;
		margin-left: 0;
	}

	#header .flex-space-center-2 {
		width: 100%;
		height: 50px;
		display: flex;
		flex-direction: row;
		justify-content: flex-start;
		align-items: center;
		margin: 0;
		margin-left: 0;
		margin-right: 40px;
	}

	#header .tel {
		font-size: 18px;
		line-height: 18px;
		color: #ffa200;
	}

	#header .tel i {
		margin-right: 5px;
		animation: shake-1 2s infinite;
	}

	#header .info {
		font-size: 12px;
		padding: 5px 0;
		color: #999;
		width: 50%;
	}

	#top_header {
		display: none;
	}

	#top_header-sp {
		height: 50px;
		background-color: #2f8f98;
		display: block;
	}

	#top_header-sp .site-branding {
		height: 50px;
		padding: 0;
	}

	#top_header-sp .site-branding img {
		width: 70%;
		padding: 0;
		margin: 0 auto;
	}


	#top_header .site_ttl {
		display: none;
	}

	#top_header .site_info {
		width: 100%;
		margin: 0 auto !important;
	}

	.top-page-header {
		height: 300px;
	}

	.site-branding img {
		clip-path: unset;
	}

	.top-page-header .main_slogan {
		top: 50%;
		width: 80%;
	}

	.top-page-header .main_slogan .main_ttl {
		font-size: 24px;
	}

	.top-page-header .main_slogan .main_ttl span.small {
		font-size: 16px;
	}
}

/* ----------------------------------------------------
 * Sub Page Header
 ---------------------------------------------------- */
.sub-page-header {
	/*
	position: relative;
	height: 300px;
	background-image: url(img/bk_contact.jpg);
	background-size: cover;
	background-position: bottom;
*/
	position: relative;
	height: 500px;
}

.sub-page-header h1.ttl {
	/*
	font-size: 32px;
	width: 100%;
	text-align: center;
	position: absolute;
	top: 50%;
	left: 150px;
	transform: translate(-50%,-50%);
	color: #fff;
	letter-spacing: 10px;
	text-shadow: 0px 1px 6px #000;
*/
	font-size: 32px;
	font-weight: bold;
	width: auto;
	text-align: left;
	letter-spacing: 10px;
	line-height: 28px;
	margin-left: 0;
	color: #2f8f98;
	height: 60px;
	display: flex;
	flex-direction: column;
	justify-content: space-around;
}

.sub-page-header h1.ttl span.small {
	text-transform: uppercase;
	font-size: 16px;
	letter-spacing: 2px;
	font-weight: bold;
	color: rgb(50 142 151 / 75%);
}

.sub-page-header_inner {
	/*
	width: 100vw;
	height: 300px;
	position: absolute;
	top: 0;
	left: 0;
	background: rgb(0 0 0 / 30%);
*/
	width: 60vw;
	height: 500px;
	position: absolute;
	background-image: url(img/bk_contact.jpg);
	background-size: cover;
	background-position: bottom;
	top: 0;
	right: 0;
	box-shadow: -10px 10px 5px rgb(229 229 229 / 50%);
}

.sub-header-flex {
	display: flex;
	justify-content: space-around;
	flex-direction: column;
	align-items: flex-start;
	position: absolute;
	top: 50%;
	left: 50px;
	transform: translate(0px, -50%);
	gap: 20px;
	z-index: -1;
	background: rgb(235 235 235 / 20%);
	width: 50vw;
	padding: 150px 0px 150px 30px;
}

#contact-header .sub-page-header_inner {
	background-image: url(img/contact-bk-image.jpg);
}

#service-header .sub-page-header_inner {
	background-image: url(img/service-bk-image.jpg);
}

#consultation-header .sub-page-header_inner {
	background-image: url(img/consultation-bk-image.jpg);
}

#company-header .sub-page-header_inner {
	background-image: url(img/company-bk-image.jpg);
}

#privacy-header .sub-page-header_inner {
	background-image: url(img/contact-bk-image.jpg);
}

@media (max-width: 767px) {

	.sub-page-header {
		height: 300px;
	}

	.sub-page-header_inner {
		height: 300px;
		width: 80vw;
	}

	.sub-header-flex {
		z-index: 1;
		left: 10px;
		background: rgb(255 255 255 / 90%);
		padding: 5px 10px;
		width: 80vw;
	}

	.sub-page-header h1.ttl {
		font-size: 24px;
		letter-spacing: 3px;
	}

}

/*====================================

privacy-policy.php 

==================================== */
#privacy-wrapper {}

#privacy-wrapper section.privacy {
	max-width: 980px;
	margin: 0 auto 10%;
}

#privacy-wrapper section.privacy section {
	margin: 4em 0 0;
}

#privacy-wrapper section.privacy section h4 {
	margin-top: 2em;
	margin-left: 1em;
	margin-bottom: 10px;
}

#privacy-wrapper section.privacy section p {
	margin-bottom: 1em;
	margin-left: 3em;
}

#privacy-wrapper section.privacy section ol {
	list-style: none;
	counter-reset: number;
}

#privacy-wrapper section.privacy section li {
	margin-left: 2em;
}

#privacy-wrapper section.privacy section li::before {
	counter-increment: number;
	content: counter(number) '）';
}

#privacy-wrapper section.privacy section a {
	color: #0000ff;
}

#privacy-wrapper section.privacy section a:hover {
	color: #0055ff;
}

.privacy_content h2 {
	margin-bottom: 20px;
}

.privacy_content p,
.privacy_content li {
	font-size: 16px;
}



@media screen and (max-width:768px) {
	#privacy-wrapper section.privacy {
		max-width: 980px;
		margin: 0;
	}

	#privacy-wrapper section.privacy section h4 {
		margin-left: 0;
	}

	#privacy-wrapper section.privacy section p {
		margin: 0 .5em 1em;
	}

	#privacy-wrapper section.privacy section li {
		margin-left: -1em;
	}

	.privacy_content h2,
	.privacy_content h3 {
		font-size: 18px;
	}

	.privacy_content p,
	.privacy_content li {
		font-size: 14px;
	}

}


/* ----------------------------------------------------
 * Footer
 ---------------------------------------------------- */
#footer {
	/*
	background-color: #2f8f98;
*/
	background-color: #ffffff;
	background-color: #2f8f98;
	padding: 40px 0 20px;
	background-image: linear-gradient(180deg, rgb(255 255 255), rgb(46 143 152 / 80%), #2f8f98);
	background-image: linear-gradient(360deg, rgb(255 255 255), rgb(46 143 152 / 80%), #2f8f98);
}

.footer-info_area {
	padding: 50px 0 0;
}

.footer-info_area img {
	width: 400px;
	margin-bottom: 20px;
}

.footer-menu_area {
	width: 100%;
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-start;
	margin: 30px 0 15px;
	flex-direction: row;
	align-items: center;
}

.footer-menu_area a {
	width: 50%;
	padding-left: 25px;
	position: relative;
	line-height: 15px;
}

.footer-menu_area a span.small {
	font-size: 10px;
	padding-left: 5px;
}

.footer-menu_area a:before {
	content: "―";
	position: absolute;
	top: 0;
	left: 5px;
}

.copyright_area {}

.copyright_flex {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
}

.copyright_flex img.footer_logo {
	width: 250px;
}

.footer_text {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: space-between;
}

.footer_text a {
	margin: unset;
	color: #666;
}

hr.footer_hr {
	border-top: 2px dotted #fff;
	max-width: 1170px;
	width: 95%;
	margin: 0 auto;
	margin-top: 40px;
	margin-bottom: 0;
}

#footer .google_map_area {}

.company_info_area {}

.company_info_area p.address {
	font-size: 18px;
	letter-spacing: 3px;
}

.company_info_area a.tel {
	font-size: 40px;
	color: #fff;
}

.company_info_area a.tel i {
	font-size: 28px;
	padding-right: 15px;
}

.contact_area {
	max-width: 900px;
	width: 95%;
	margin: 50px 0 0;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	margin: 0 auto;
	margin-bottom: 50px;
}

.contact_area p {
	font-size: 18px;
	color: #2E8F98;
	margin-bottom: 30px;
}

.contact_area .info-tel,
.contact_area .info-mail {
	width: 50%;
	text-align: center;
}

.contact_area .info-tel .tel {}

.contact_area .info-tel .tel a {
	font-size: 40px;
	color: #000;
}

.contact_area .info-tel .tel a i {
	font-size: 30px;
	color: #fff;
	text-shadow: 0 0 4px #000;
	margin-right: 10px;
	animation: shake-1 2s infinite;
}

.contact_area .info-tel p.small {
	font-size: 12px;
	color: #666;
	margin-bottom: 0;
}


.contact_area .info-mail .mail {}

.contact_area .info-mail .mail a {
	display: block;
	width: 300px;
	padding: 20px;
	border-radius: 5px;
	background-color: #ffa200;
	color: #fff;
	font-size: 20px;
	box-shadow: 0 0 4px rgb(0 0 0 / 80%);
	transition-duration: 1s;
}

.contact_area .info-mail .mail a:hover {
	box-shadow: none;
}

.contact_area .info-mail .mail a i {
	color: #fff;
	margin-right: 10px;
	animation: shake-1 2s infinite;
}


.contact_info {
	max-width: 450px;
	width: 95%;
	text-align: center;
	background: #FFA200;
	border-radius: 10px;
	box-shadow: 0 3px 6px rgb(0 0 0 / 80%);
	transition-duration: 1s;
}

.contact_info a {
	display: block;
	width: 100%;
	height: 100%;
	padding: 30px 0;
}

.contact_info a i {
	padding-right: 15px;
}

.contact_info a:focus,
.contact_info a:active,
.contact_info a:hover {
	color: #fff !important;
}

.contact_info:focus,
.contact_info:active,
.contact_info:hover {
	box-shadow: none;
}


@media screen and (max-width:768px) {

	#footer .flex-space-center {
		flex-direction: column-reverse !important;
	}

	#footer .footer-info_area {
		padding: 0;
	}

	#footer .footer-info_area img {
		width: 80%;
	}

	#footer .company_info_area {
		width: 100%;
		text-align: center;
		margin-top: 0;
	}

	#footer .company_info_area p.address {
		font-size: 16px;
		letter-spacing: 1px;
		font-weight: normal;
	}

	#footer .footer-menu_area {
		text-align: left;
	}

	#footer .footer-menu_area a {
		font-size: 14px;
	}

	#footer .google_map_area {
		width: 100%;
		margin-top: 20px;
		height: 200px;
	}

	#footer .google_map_area iframe {
		height: 200px;
	}

	#footer .contact_area {
		width: 100%;
		flex-direction: column;
		gap: 30px;
	}

	#footer .contact_area .info-tel,
	#footer .contact_area .info-mail {
		width: 100%;
		text-align: center;
	}

}

/* ----------------------------------------------------
 * TOP Page
 ---------------------------------------------------- */
.top-page-contents {
	padding: 100px 0;
	height: 100%;
}

.top-page-contents .sub-ttl {
	text-align: center;
}

.top-page-contents .sub-ttl h2 {
	font-size: 34px;
	letter-spacing: 5px;
	margin-top: 10px;
}

.top-page-contents .sub-ttl h3 {
	font-size: 26px;
	color: #2f8f98;
	letter-spacing: 5px;
}

#about .about-text {
	width: 50%;
}

#about .about-text p {
	font-size: 18px;
	line-height: 36px;
}

#about .about-text p.name {
	font-size: 20px;
}

#about .about-image {
	width: 45%;
}


#features .top-page-contents {
	background-image: url(img/features-bk-image.png);
	background-size: cover;
	background-position: bottom;
	background-attachment: fixed;
}

#contact .top-page-contents {
	background-image: url(img/contact-bk-image.png);
	background-size: cover;
	background-position: bottom;
	background-attachment: fixed;
}

#features .features-content-3 {
	width: 30%;
	text-align: center;
	padding: 40px 20px;
	background: #fff;
	border-radius: 5px;
	box-shadow: 1px 3px 6px rgb(0 0 0 / 80%);
	display: flex;
	flex-direction: column;
	justify-content: space-evenly;
	height: 500px;
	overflow-y: hidden;
}

#features .features-content-2 {
	width: 48%;
	text-align: center;
	margin-top: 50px;
	padding: 40px 20px;
	background: #fff;
	border-radius: 5px;
	box-shadow: 1px 3px 6px rgb(0 0 0 / 80%);
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	height: 300px;
	overflow-y: hidden;
}

#features .features-content-2_sub {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 40%;
}

#features .features-content-3 .feature-icon,
#features .features-content-2 .feature-icon {
	font-size: 70px;
	line-height: normal;
	color: #ffffff;
	text-shadow: 0px 0px 5px #000000;
}

#features .features-content-3 .feature-icon,
#features .features-content-2 .feature-icon {
	animation: shake 3s infinite;
}

#features .features-content-3 .feature-ttl,
#features .features-content-2 .feature-ttl {
	font-size: 20px;
	letter-spacing: 3px;
	color: #2f8f98;
}

#features .features-content-3 .feature-comment {
	font-size: 16px;
	line-height: 30px;
	letter-spacing: 2px;
}

#features .features-content-2 .feature-comment {
	width: 55%;
	font-size: 16px;
	line-height: 30px;
	letter-spacing: 2px;
}

#flow {}

#flow::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -30px;
	transform: translateX(-50%);
	width: 2px;
	height: 30px;
	background-color: #2f8f98;
}

#flow .flow_comment {
	text-align: center;
}

#flow .flow_comment p {
	font-size: 16px;
	letter-spacing: 3px;
}

#flow .flow_bk_image {
	/*
	background-image: url(img/flow_line.png);
	background-size: contain;
	background-position: top;
	background-repeat: no-repeat;
	background-position-x: 68%;
*/
	padding-bottom: 100px;
	margin-top: 100px;
	position: relative;
}

#flow .flow_bk_image::before {
	content: "";
	position: absolute;
	left: 68%;
	top: 5%;
	transform: translateX(-50%);
	width: 1%;
	height: 100%;
	background-color: #2f8f98;
	background-image: linear-gradient(360deg, rgb(255 255 255), rgb(46 143 152 / 80%), #2f8f98);
	background-image: linear-gradient(180deg, rgb(255 255 255), rgb(46 143 152 / 80%), #2f8f98);
}


#flow .flow_bk_image:last-of-type {
	margin-top: 160px;
}

#flow .flow_bk_image h4 {
	text-align: center;
	/* background: linear-gradient(#00000000 50%, #ffa200 50%); */
	width: fit-content;
	border-bottom: 3px solid #2f8f98;
	margin-bottom: 20px;
}

#flow .flow_info {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	gap: 40px;
	padding-top: 100px;
	position: relative;
}

#flow .flow_info .flow_info_comment_none,
#flow .flow_info .flow_info_comment {
	width: 100%;
	max-width: 350px;
}

#flow .flow_info .flow_info_comment {
	position: relative;
	display: inline-block;
	margin-right: 20px;
	padding: 16px;
	border: 4px solid #ffa200;
	border-radius: 8px;
	background-color: #ffffff;
	text-align: left;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.5;
	color: #000000;
}

#flow .flow_info .flow_info_comment::before {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	border-style: solid;
	border-width: 15px 0 15px 25px;
	border-color: transparent transparent transparent #ffa200;
	translate: 100% -50%;
	transform: skew(0, 15deg);
	transform-origin: left;
}

#flow .flow_info .flow_info_comment::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	border-style: solid;
	border-width: 9px 0 9px 16px;
	border-color: transparent transparent transparent #ffffff;
	translate: 100% calc(-50% + 0.4px);
	transform: skew(0, 15deg);
	transform-origin: left;
}


#flow .flow_info .flow_info_ttl_area {
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	width: 100%;
	max-width: 500px;
	box-shadow: 0px 0px 4px #000;
	border-radius: 5px;
	position: relative;
	background: #ffffff;
}

/*
#flow .flow_info .flow_info_ttl_area:after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -30px;
	transform: translateX(-50%);
	width: 2px;
	height: 30px;
	background-color: #2f8f98;
}
*/

#flow .flow_info .flow_info_ttl_area .flow_info_no {
	background-color: #2f8f98;
	color: #fff;
	padding: 10px 10px;
	font-size: 20px;
	margin-right: 15px;
	display: inline-block;
}

#flow .flow_info .flow_info_ttl_area .flow_info_ttl {
	width: 100%;
	font-size: 16px;
	font-weight: bold;
}

#contact .text-linear {
	background: linear-gradient(transparent 55%, rgb(255 162 0 / 80%) 45%);
	display: inline-block;
	line-height: 1;
}

#contact .inner-contact {
	padding: 100px 0;
	background: #2f8f98;
	background: rgb(46 143 152 / 60%);
	border-radius: 10px;
	box-shadow: 0 0 20px rgb(255 255 255 / 80%);
}

#contact .inner-contact .sub-ttl,
#contact .inner-contact .sub-ttl h3 {
	color: #fff;
}

#contact .inner-sub-contact {
	max-width: 900px;
	width: 95%;
	text-align: center;
	margin: 0 auto;
	background: #fff;
	padding: 40px 0;
	margin-top: 50px;
	display: flex;
	flex-direction: column;
	justify-content: space-around;
	align-items: center;
	border-radius: 10px;
	box-shadow: 0 0 4px rgb(0 0 0 / 80%);
}

#contact .inner-sub-contact .info-text {
	font-size: 16px;
}

#contact .inner-sub-contact .info-contact {
	width: 100%;
	margin: 50px 0 0;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: flex-start;
}

#contact .inner-sub-contact .info-contact p {
	font-size: 18px;
	color: #2f8f98;
	margin-bottom: 30px;
}

#contact .inner-sub-contact .info-contact .info-tel,
#contact .inner-sub-contact .info-contact .info-mail {
	width: 50%;
}

#contact .inner-sub-contact .info-contact .info-tel .tel {}

#contact .inner-sub-contact .info-contact .info-tel .tel a {
	font-size: 40px;
	color: #000;
}

#contact .inner-sub-contact .info-contact .info-tel .tel a i {
	font-size: 30px;
	color: #fff;
	text-shadow: 0 0 4px #000;
	margin-right: 10px;
	animation: shake-1 2s infinite;
}

#contact .inner-sub-contact .info-contact .info-tel p.small {
	font-size: 12px;
	color: #666;
}


#contact .inner-sub-contact .info-contact .info-mail .mail {}

#contact .inner-sub-contact .info-contact .info-mail .mail a {
	display: block;
	width: 300px;
	padding: 20px;
	border-radius: 5px;
	background-color: #ffa200;
	color: #fff;
	font-size: 20px;
	box-shadow: 0 0 4px rgb(0 0 0 / 80%);
	transition-duration: 1s;
}

#contact .inner-sub-contact .info-contact .info-mail .mail a:hover {
	box-shadow: none;
}

#contact .inner-sub-contact .info-contact .info-mail .mail a i {
	color: #fff;
	margin-right: 10px;
	animation: shake-1 2s infinite;
}


#qa {}

#qa .bk-color {
	background-color: #2f8f98;
}

#qa .fc-black {
	color: #000;
	text-shadow: 0 0 4px #FF7700;
}

#qa .fc-orange {
	color: #FF7700;
	text-shadow: 0 0 4px #FFFFFF;
}

#qa hr.qa_hr {
	margin: 15px 0;
	border-bottom: 2px dotted #fff;
	width: 93%;
	margin-left: 65px;
}

#qa hr.qa_hr_black {
	margin: 15px 0;
	border-bottom: 2px dotted #000;
	width: 93%;
	margin-left: 65px;
}

#qa .sub-commnet {
	margin: 40px 0;
}

#qa .sub-commnet p {
	text-align: center;
	font-size: 16px;
}

#qa .qa_content {
	margin-top: 50px;
	padding: 40px 40px;
	border-radius: 5px;
	box-shadow: 0 0 4px rgb(0 0 0 / 80%);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
}

#qa .question_content {
	display: flex;
	align-items: flex-end;
	flex-direction: row;
	font-size: 18px;
	width: 100%;
}

#qa .answer_content {
	display: flex;
	align-items: flex-start;
	flex-direction: row;
	font-size: 18px;
	width: 100%;
}

#qa .question_content p.ttl,
#qa .answer_content p.ttl {
	font-size: 65px;
	font-family: Baskerville Old Face;
	width: 65px;
	line-height: 60px;
}

#qa .question_content p.comment,
#qa .answer_content p.comment {
	width: calc(100% - 70px);
	margin: 0 auto;
}

@media (max-width: 767px) {

	.top-page-contents .sub-ttl h2 {
		font-size: 22px;
		letter-spacing: 2px;
	}

	.top-page-contents .sub-ttl h3 {
		font-size: 16px;
		letter-spacing: 2px;
	}

	#about .flex-space-center {
		flex-direction: column;
	}

	#about .about-text {
		width: 100%;
	}

	#about .about-text p {
		font-size: 14px;
		line-height: 26px;
		text-align: justify;
	}

	#about .about-text p:first-child,
	#about .about-text p:nth-child(2) {
		text-align: right;
	}


	#about .about-image {
		width: 100%;
		margin-top: 15px;
		margin-bottom: 60px;
	}

	#features .features-content-2,
	#features .features-content-3 {
		width: 100%;
		padding: 20px 10px;
		background: #fff;
		flex-direction: column;
		height: auto;
		margin-bottom: 30px;
		margin-top: 0;
	}

	#features .features-content-3 .feature-ttl,
	#features .features-content-2 .feature-ttl {
		font-size: 18px;
		margin-bottom: 15px;
	}

	#features .features-content-2 .feature-comment,
	#features .features-content-2_sub {
		width: 100%;
	}

	#features .features-content-3 .feature-comment,
	#features .features-content-2 .feature-comment {
		font-size: 14px;
		line-height: 26px;
	}

	#flow .flow_bk_image {
		padding-bottom: 0px;
		padding-top: 20px;
		margin-top: 50px;
		background-position-x: center;
	}

	#flow .flow_bk_image:last-of-type {
		margin-top: 100px;
	}

	#flow .flow_bk_image::before {
		top: 14%;
		left: 50%;
		width: 5px;
		height: 89%;
	}

	#flow .flow_info {
		display: flex;
		flex-direction: column-reverse;
		gap: 20px;
		padding-top: 30px;
		position: relative;
	}

	#flow .flow_info .flow_info_comment {
		margin-right: 0;
		padding: 25px 10px;
		text-align: center;
		font-size: 14px;
		letter-spacing: 3px;
	}

	#flow .flow_info .flow_info_comment::before {
		content: "";
		position: absolute;
		top: -11px;
		left: 0;
		right: unset;
		border-style: solid;
		border-width: 21px 5px 0px 14px;
		border-color: transparent transparent transparent #ffa200;
		translate: 100% -50%;
		transform: skew(0, 0deg);
		transform-origin: left;
	}

	#flow .flow_info .flow_info_comment::after {
		display: none;
	}

	#contact .top-page-contents {
		padding: 0;
		background-image: none;

	}

	#contact .inner-content {
		width: 100%;
	}

	#contact .inner-contact {
		padding: 50px 0;
		background: #2f8f98;
		border-radius: 0;
		box-shadow: none;
	}

	#contact .inner-sub-contact .info-contact {
		flex-direction: column;
	}

	#contact .inner-sub-contact .info-contact .info-tel,
	#contact .inner-sub-contact .info-contact .info-mail {
		width: 100%;
	}

	#qa .qa_content {
		padding: 20px 10px;
	}

	#qa .question_content p,
	#qa .answer_content p {
		font-size: 14px;
	}

	#qa .question_content p.ttl,
	#qa .answer_content p.ttl {
		font-size: 40px;
		font-family: Baskerville Old Face;
		width: 40px;
		line-height: 40px;
	}

	#qa hr.qa_hr_black,
	#qa hr.qa_hr {
		width: 100%;
		margin-left: 0px;
	}

}

/* ----------------------------------------------------
 * Consultation Page
 ---------------------------------------------------- */
#consultation_page {}

.consultation_content {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	gap: 30px;
}

.consultation_content .consultation_content_flow {
	max-width: 330px;
	width: 100%;
}

.consultation_content .consultation_content_flow .flow_inner_ttl {
	position: sticky;
	top: 100px;
	left: 0;
}

.consultation_content .consultation_content_flow .flow_inner_ttl ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.consultation_content .consultation_content_flow .flow_inner_ttl ul li.flow_li {
	margin-bottom: 30px;
}

.consultation_content .consultation_content_flow .flow_inner_ttl ul li.flow_li a {
	font-size: 18px;
	font-weight: bold;
	color: #666;
}

.consultation_content .consultation_content_flow .flow_inner_ttl .flow_li.active a:active,
.consultation_content .consultation_content_flow .flow_inner_ttl .flow_li.active a:hover,
.consultation_content .consultation_content_flow .flow_inner_ttl .flow_li.active a:visited,
.consultation_content .consultation_content_flow .flow_inner_ttl .flow_li.active a:focus {
	text-decoration: none;
}

.consultation_content .consultation_content_flow .flow_inner_ttl ul li.flow_li a>span.ttl_no {
	background-color: #aee1e5;
	color: #fff;
	border-radius: 50px;
	padding: 3px 7px;
	font-size: 22px;
	width: 40px;
	height: 40px;
	margin-right: 15px;
	display: inline-block;
	position: relative;
	transition-duration: 0.5s;
}

.consultation_content .consultation_content_flow .flow_inner_ttl .flow_li.active a {
	color: #000;
}

.consultation_content .consultation_content_flow .flow_inner_ttl .flow_li.active a>span.ttl_no {
	background-color: #2f8f98;
	box-shadow: 1px 1px 3px 2px #aaa;
}

.consultation_content .consultation_content_flow .flow_inner_ttl .flow_li.active a>span.ttl_no::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -30px;
	transform: translateX(-50%);
	width: 2px;
	height: 30px;
	background-color: #2f8f98;
}

.consultation_content .consultation_content_flow .flow_inner_ttl .flow_li.active:last-child a>span.ttl_no::after {
	width: 0px;
}

.consultation_content .consultation_content_detail {
	max-width: calc(1170px - 300px);
	width: 100%;
}

.consultation_content .consultation_content_detail .detail_flow {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	gap: 5%;
	background-color: #fff;
	box-shadow: 0 0 4px #333;
	padding: 20px 25px;
	border-radius: 5px;
	margin-top: 50px;
}

.consultation_content .consultation_content_detail .detail_flow:first-child {
	margin-top: 0px;
}

.consultation_content .consultation_content_detail .detail_flow .detail_flow--content {
	width: 70%;
}

.consultation_content .consultation_content_detail .detail_flow .detail_flow--content h2 {
	font-size: 22px;
	margin-bottom: 15px;
}

.consultation_content .consultation_content_detail .detail_flow .detail_flow--content h2 span.ttl_no {
	background-color: #2f8f98;
	color: #fff;
	border-radius: 50px;
	padding: 10px 10px;
	font-size: 36px;
	width: 60px;
	height: 60px;
	margin-right: 15px;
	display: inline-block;
	box-shadow: 1px 1px 3px 2px #aaa;
}

.consultation_content .consultation_content_detail .detail_flow .detail_flow--content p {
	font-size: 16px;
	padding-left: 15px;
}

.consultation_content .consultation_content_detail .detail_flow .detail_flow--image {
	width: 30%;
}

.consultation_content .consultation_content_detail .detail_flow .detail_flow--image img {
	height: 200px;
	object-fit: cover;
	object-position: center;
	border-radius: 5px;
	box-shadow: 1px 1px 3px 2px #aaa;
}

@media (max-width: 767px) {

	.consultation_content .consultation_content_flow {
		display: none;
	}

	.consultation_content .consultation_content_detail .detail_flow {
		flex-direction: column;
		padding: 20px 10px;
	}

	.consultation_content .consultation_content_detail .detail_flow .detail_flow--content {
		width: 100%;
	}

	.consultation_content .consultation_content_detail .detail_flow .detail_flow--content h2 {
		font-size: 20px;
	}

	.consultation_content .consultation_content_detail .detail_flow .detail_flow--content p {
		font-size: 14px;
		padding: 0;
		margin-bottom: 20px;
	}

	.consultation_content .consultation_content_detail .detail_flow .detail_flow--image {
		width: 100%;
	}

	.consultation_content .consultation_content_detail .detail_flow .detail_flow--image img {
		width: 100%;
	}


}


/* ----------------------------------------------------
 * Company Page
 ---------------------------------------------------- */
#comapny_page {}

.company_content {
	display: flex;
	flex-direction: row;
	justify-content: space-around;
	align-items: center;
	gap: 5%;
}

.company_content .comapny_map {
	width: 50%;
	height: 600px;
	box-shadow: 1px 1px 3px 2px #aaa;
}

.company_content .company_info {
	width: 50%;
	margin: 0 auto;
}

.company_content .company_info .info_ttl {
	width: 100px;
	padding: 40px 0;
	font-size: 16px;
	letter-spacing: 3px;
	border-bottom: 2px solid #2f8f98;
}

.company_content .company_info .info_text {
	width: calc(100% - 100px);
	padding: 40px 0;
	font-size: 16px;
	letter-spacing: 3px;
	border-bottom: 2px solid #ddd;
}

@media (max-width: 767px) {

	.company_content {
		flex-direction: column-reverse;
		gap: 50px;
	}

	.company_content .comapny_map {
		width: 100%;
		height: 300px;
	}

	.company_content .company_info {
		width: 100%;
	}

	.company_content .company_info .info_ttl {
		padding: 10px 0;
		font-size: 16px;
		letter-spacing: 1px;
		width: 100%;
		display: inline-block;
		border: none;
	}

	.company_content .company_info .info_text {
		padding: 5px 0 15px 10px;
		font-size: 16px;
		width: 100%;
		letter-spacing: 1px;
		display: inline-block;
		border-bottom: 2px solid #2f8f98;
	}

}

/* ----------------------------------------------------
 * Service Page
 ---------------------------------------------------- */
#service_page {}

.service_inner_content {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	gap: 40px;
}

.service_inner_content .service_comment {
	width: calc(90% - 350px);
	padding: 0 20px;
}

.service_inner_content .service_comment h2 {
	margin-bottom: 20px;
	font-size: 24px;
}

.service_inner_content .service_comment h3 {
	font-size: 12px;
	letter-spacing: 4px;
	margin-bottom: 5px;
}

.service_inner_content .service_comment p {
	font-size: 16px;
}

.service_inner_content .service_image {
	width: 350px;
	min-height: 350px;
}

.service_inner_content .service_image img {
	width: 100%;
	min-height: 350px;
	object-fit: cover;
	border-radius: 5px;
	box-shadow: -6px 8px 6px #ddd;
}

.service_inner_price {
	display: flex;
	flex-direction: column;
	width: 95%;
	margin: 0 auto;
	margin-top: 50px;
	margin-bottom: 150px;
}

.service_inner_price .service_price_ttl {
	width: 100%;
	text-align: center;
	background: #2e8f98;
	color: #fff;
	padding: 35px 20px;
	font-size: 30px;
	font-weight: bold;
	letter-spacing: 3px;
}

.service_inner_price .service_price {
	display: flex;
	align-items: center;
	justify-content: space-around;
	padding-bottom: 50px;
	background: #ebebeb;
}

.service_inner_price .service_price_ttl+.service_price {
	padding-top: 50px;
}

.service_inner_price .service_price_inner_note {
	margin-top: 10px;
}

.service_inner_price .service_price .service_price_left {
	width: 40%;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-around;
	background: #fff;
	padding: 40px 10px;
}

.service_inner_price .service_price .service_price_center {
	width: 10%;
	text-align: center;
	width: 0;
	height: 0;
	border-style: solid;
	border-top: 50px solid transparent;
	border-bottom: 50px solid transparent;
	border-left: 45px solid #2f8f98;
	border-right: 0;
}

.service_inner_price .service_price .service_price_right {
	width: 40%;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-around;
	background: #fff;
	padding: 40px 10px;

	>span {
		font-size: 20px;
		letter-spacing: 3px;
		color: #2e8f98;
		font-weight: bold;
	}
}

.service_inner_price .service_price .service_price_inner_ttl {
	font-size: 20px;
	letter-spacing: 3px;
	color: #2e8f98;
	font-weight: bold;
}

.service_inner_price .service_price .service_price_inner_price {
	font-size: 60px;
	letter-spacing: 3px;
	color: #ffa200;
	font-weight: bold;
}

.service_inner_price .service_price .service_price_inner_price span.small {
	font-size: 20px;
	padding-left: 10px;
	color: #000;
}

@media (max-width: 767px) {

	.service_inner_content {
		flex-direction: column;
		gap: 20px;
	}

	.service_inner_content .service_comment {
		width: 100%;
		padding: 0;
		text-align: center;
	}

	.service_inner_content .service_comment h2 {
		font-size: 20px;
	}

	.service_inner_content .service_comment p {
		font-size: 14px;
	}

	.service_inner_content .service_image {
		width: 100%;
		min-height: 250px;
	}

	.service_inner_content .service_image img {
		min-height: 250px;
	}

	.service_inner_price {
		width: 100%;
		margin-bottom: 75px;
	}

	.service_inner_price .service_price_ttl {
		padding: 15px 0px;
		font-size: 20px;
	}

	.service_inner_price .service_price {
		flex-direction: column;
		padding-top: 25px;
	}

	.service_inner_price .service_price .service_price_left,
	.service_inner_price .service_price .service_price_right {
		width: 95%;
		padding: 5px 10px;
	}

	.service_inner_price .service_price .service_price_center {
		border-right: 30px solid transparent;
		border-left: 30px solid transparent;
		border-top: 30px solid #2f8f98;
		border-bottom: 0;
		margin: 10px 0;
	}

	.service_inner_price .service_price .service_price_inner_ttl {
		font-size: 18px;
	}

	.service_inner_price .service_price .service_price_inner_price {
		font-size: 36px;
	}



}


/* ----------------------------------------------------
 * Contact Page
 ---------------------------------------------------- */
#contact_page {}

#contact_page .contact_comment {
	padding: 50px 0;
	text-align: center;
}

#contact_page .contact_comment p {
	font-size: 18px;
}

#contact_page .conntact_tel {
	text-align: center;
	padding-bottom: 50px;
}

#contact_page .conntact_tel .text-linear {
	background: linear-gradient(transparent 55%, rgb(255 162 0 / 80%) 45%);
	display: inline-block;
	line-height: 1;
	font-size: 20px;
	color: #2f8f98;
	letter-spacing: 3px;
}

#contact_page .conntact_tel .tel {}

#contact_page .conntact_tel .tel a {
	font-size: 40px;
	color: #000;
}

#contact_page .conntact_tel .tel a i {
	font-size: 30px;
	margin-right: 10px;
	animation: shake-1 2s infinite;
}

#contact_page .conntact_tel p.small {
	font-size: 12px;
	color: #666;
}

/* Contact Form */
#contact_page .contact_form {
	max-width: 800px;
	width: 95%;
	margin: 0 auto;
	background: #eeeeee;
	box-shadow: 1px 1px 4px #666;
	padding: 30px 20px;
	border-radius: 5px;
}

#contact_page .contact_form table.form {
	width: 100%;
}

#contact_page .contact_form table.form th {
	width: 200px;
	padding: 30px 5px 0;
	vertical-align: middle;
	font-size: 16px;
	position: relative;
}

#contact_page .contact_form table.form th span.required::after {
	content: "必須";
	color: #ffffff;
	background: #cc0000;
	font-size: 0.8em;
	padding: 0.3em;
	border-radius: 0.5em;
	position: absolute;
	right: 5px;
}

#contact_page .contact_form table.form th span.any::after {
	content: "任意";
	color: #ffffff;
	background: #3939f9;
	font-size: 0.8em;
	padding: 0.3em;
	border-radius: 0.5em;
	position: absolute;
	right: 5px;
}

#contact_page .contact_form table.form td {
	width: calc(100% - 200px);
	padding: 30px 5px 0;
	font-size: 16px;
}

#contact_page .contact_form table.form td select,
#contact_page .contact_form table.form td textarea,
#contact_page .contact_form table.form td input {
	width: 100%;
	padding: 5px 10px;
	border: none;
	border-radius: 5px;
}

#contact_page .contact_form table.form td select:focus,
#contact_page .contact_form table.form td textarea:focus,
#contact_page .contact_form table.form td input:focus {
	outline: none;
	border: 2px solid #2f8f98;
}

#contact_page .contact_form .submit_form {
	text-align: center;
}

#contact_page .contact_form .submit_form input {
	padding: 5px 20px;
	line-height: normal;
	width: 150px;
	letter-spacing: 2px;
	background-color: #ffa200;
	border-radius: 5px;
	border: none;
	box-shadow: 1px 1px 4px #666;
	color: #fff;
	font-weight: bold;
	font-size: 16px;
	transition-duration: 0.5s;
}

#contact_page .contact_form .submit_form input:hover {
	box-shadow: none;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
	max-width: 800px;
	width: 95%;
	margin: 0 auto;
	margin-top: 30px;
	line-height: normal;
	padding: 5px 10px;
	text-align: center;
	font-weight: bold;
}

.wpcf7-spinner {
	display: none;
}

#contact_page .confirm_contact_form {
	max-width: 800px;
	width: 95%;
	margin: 0 auto;
	background: #e1e1e1;
	box-shadow: 1px 1px 4px #666;
	padding: 30px 20px;
	border-radius: 5px;
}


#contact_page .confirm_contact_form table.form {
	width: 100%;
}

#contact_page .confirm_contact_form table.form th {
	width: 200px;
	padding: 20px 5px 0;
	vertical-align: middle;
	font-size: 16px;
}

#contact_page .confirm_contact_form table.form td {
	width: calc(100% - 200px);
	padding: 20px 5px 0;
	font-size: 16px;
}

#contact_page .confirm_contact_form table.form td p {
	background: #fff;
	padding: 5px 10px;
	border-radius: 5px;
}

#contact_page .confirm_contact_form .submit_form {
	margin-top: 30px;
	text-align: center;
}

#contact_page .confirm_contact_form .submit_form input {
	padding: 5px 20px;
	line-height: normal;
	width: 150px;
	letter-spacing: 2px;
	background-color: #ffa200;
	border-radius: 5px;
	border: none;
	box-shadow: 1px 1px 4px #666;
	color: #fff;
	font-weight: bold;
	font-size: 16px;
	transition-duration: 0.5s;
}

#contact_page .confirm_contact_form .submit_form input:hover {
	box-shadow: none;
}

#contact_page .confirm_contact_form .submit_form input:first-child {
	margin-right: 15px;
}

@media (max-width: 767px) {

	#contact_page .contact_comment p {
		font-size: 14px;
	}

	#contact_page .contact_form {
		width: 100%;
	}

	#contact_page .contact_form table.form th {
		font-size: 16px;
		display: inline-block;
		width: 100%;
	}

	#contact_page .contact_form table.form th p {
		padding-left: 50px;
	}

	#contact_page .contact_form table.form th span.any::after,
	#contact_page .contact_form table.form th span.required::after {
		left: 5px;
		right: 0px;
		width: 40px;
		text-align: center;
	}

	#contact_page .contact_form table.form td {
		width: 100%;
		display: inline-block;
		padding: 10px 0;
	}

	#contact_page .confirm_contact_form table.form th {
		font-size: 16px;
		display: inline-block;
		width: 100%;
	}

	#contact_page .confirm_contact_form table.form td {
		width: 100%;
		display: inline-block;
		padding: 0;
	}

	#contact_page .confirm_contact_form .submit_form input {
		width: 40%;
		max-width: 120px;
	}

}

#error-wrapper .error {
	width: 82%;
	margin: 50px auto;
	text-align: center;
}

#error-wrapper .error_ttl {
	margin-bottom: 30px;
}
