@charset "utf-8";

/*-------------------------------------------*/
/*	Base width
/*-------------------------------------------*/
.wrap {
	width: 100%;
	margin: 0 auto;
	position: relative;
}
.inner {
	max-width: 1000px;
	margin: 0 auto;
	position: relative;
	z-index: 2;
}
.inner.full {
	max-width: 100%;
}
@media screen and (max-width: 1536px){
}
@media screen and (max-width: 1366px) {
}
@media screen and (max-width: 1023px) {
	.inner {
		padding-left: 20px;
		padding-right: 20px;
	}
	.inner.full {
		padding-left: 0;
		padding-right: 0;
	}
}
@media screen and (max-width: 767px) {
}

/*-------------------------------------------*/
/*	Font setting
/*-------------------------------------------*/
body {
	font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
	font-size: 16px;
	letter-spacing: 0.055em;
	line-height: 1.75em;
	color: #000;
}
body:not(.nagoya) h1 {
	font-family: "Antonio", sans-serif;
  font-optical-sizing: auto;
	font-size: 4.375rem;
  font-weight: 700;
  font-style: normal;
	line-height: 1.4;
	margin-bottom: 80px;
}
body:not(.nagoya) h1 span {
	display: block;
	font-size: 1.625rem;
	position: relative;
	padding-left: 0.85em;
	line-height: 1.3;
}
body:not(.nagoya) h1 span::before {
	display: block;
	content: "";
	width: 4px;
	height: 100%;
	position: absolute;
	top: 0.1em;
	left: 0.25em;
	background: #000;
}
h2 {
	font-size: 1.625rem;
	font-weight: 700;
	line-height: 1.6;
	margin-bottom: 1.25em;
	word-break: keep-all;
}
h2 span {
	font-size: 2.125rem;
	position: relative;
	padding-right: 1em;
}
h2 span::after {
	display: block;
	content: "";
	width: 2px;
	height: 1em;
	position: absolute;
	top: 0.2em;
	right: 0.5em;
	background: #000;
}
h2.break span {
	display: block;
}
h2.break span::after {
	display: none;
	content: none;
}
h2 span,
.antonio {
  font-family: "Antonio", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}
h3 {
	font-size: 1.625rem;
	font-weight: 700;
	line-height: 1.6;
	margin-bottom: 3rem;
	position: relative;
}
h3::before,
h3::after {
	display: block;
	content: "";
	position: absolute;
	bottom: 0;
}
h3::before {
	width: 280px;
	height: 3px;
	left: 0;
	background: #e3d111;
}
h3::after {
	width: calc(100% - 280px);
	height: 1px;
	right: 0;
	background: #acacac;
}
h4 {
	font-size: 1.25rem;
	font-weight: 700;
	padding-left: 1.5em;
	margin-bottom: 3rem;
	position: relative;
}
h4::before {
	display: block;
	content: "";
	width: 1em;
	height: 1em;
	position: absolute;
	top: 0.15em;
	left: 0;
	background: #e3d111;
}
p {
	margin: 0 0 1.75em;
	line-height: 1.75;
}
a, a:hover {
	color: #000;
}
.fc_red {
	color: #ed1c24;
}
@media screen and (max-width: 1536px){
	body:not(.nagoya) h1 {
		margin: 0;
	}
}
@media screen and (max-width: 1366px) {
	body {
		font-size: 15px;
	}
}
@media screen and (max-width: 1023px) {
	body:not(.nagoya) h1 {
		font-size: 3.5rem;
	}
	body:not(.nagoya) h1 span {
		font-size: 1.35rem;
	}
	h2 {
		font-size: 1.25rem;
	}
	h2 span {
		font-size: 1.85rem;
	}
	h3 {
		font-size: 1.25rem;
		margin-bottom: 2rem;
	}
}
@media screen and (max-width: 767px) {
	body:not(.nagoya) h1 {
		font-size: 2.75rem;
	}
	body:not(.nagoya) h1 span {
		font-size: 1.25rem;
	}
	h2 {
		font-size: 1rem;
	}
	h2 span {
		font-size: 1.45rem;
	}
	h4 {
		font-size: 1.125rem;
		margin-bottom: 2rem;
		padding-left: 1.25em;
	}
	h4::before {
		width: 0.8em;
		height: 0.8em;
	}
}

/*-------------------------------------------*/
/*	Site setting
/*-------------------------------------------*/
@media screen and (max-width: 1536px){
}
@media screen and (max-width: 1366px) {
}
@media screen and (max-width: 1023px) {
}
@media screen and (max-width: 767px) {
}

/*-------------------------------------------*/
/*	Button
/*-------------------------------------------*/
.btn {
	display: block;
	margin-top: 40px;
}
.btn a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 120px;
	height: 28px;
	padding: 0 1.75em;
	font-size: 0.875rem;
	font-weight: 500;
	color: #000;
	background: none;
	border: 1px solid #000;
	border-radius: 14px;
	position: relative;
	transition: .3s all;
}
a.btn2 {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 400px;
	height: 70px;
	color: #000;
	background: #e3d111;
	border-radius: 10px;
	margin: 0 auto;
	transition: 0.3s all;
}
a.btn2:hover {
	opacity: 0.8;
}
.view_more {
	font-family: "Antonio", sans-serif;
  font-optical-sizing: auto;
	font-size: 1rem;
  font-weight: 700;
  font-style: normal;
	position: relative;
	padding-right: 3em;
}
.view_more::after {
	display: block;
	content: "";
	width: 2rem;
	height: 2rem;
	position: absolute;
	top: calc(50% - 1rem);
	right: 0;
	background-image: url(./images/icon_arrow01_yel.svg);
	background-size: contain;
	background-repeat: no-repeat;
	z-index: 2;
}
.view_more.blk {
	color: #000;
}
.view_more.blk::after {
	background-image: url(./images/icon_arrow01.svg);
}
.view_more.wht {
	color: #fff;
}
.view_more.wht::after {
	background-image: url(./images/icon_arrow01.svg);
	filter: invert(100%) sepia(4%) saturate(7%) hue-rotate(351deg) brightness(117%) contrast(100%);
}
.btn_pagetop {
	display: none;
	width: 92px;
	height: 55px;
	z-index: 3;
}
.btn_pagetop.absolute {
	position: absolute;
	right: 0;
}
.btn_pagetop.fixed {
	position: fixed;
	right: 0 !important;
	bottom: 60px !important;
}
.btn_pagetop a {
	width: 100%;
	height: 100%;
	background-image: url(./images/btn_pagetop.svg);
	background-size: contain;
	background-position: top right;
	background-repeat: no-repeat;
}
.btn_float {
	width: 44px;
	height: 150px;
	position: fixed;
	top: calc(50vh - 75px);
	right: 0;
	z-index: 99;
}

@media screen and (max-width: 1536px){
}
@media screen and (max-width: 1366px) {
}
@media screen and (max-width: 1023px) {
}
@media screen and (max-width: 767px) {
	.btn_float {
		display: none;
	}
}
/*-------------------------------------------*/
/*	Header
/*-------------------------------------------*/
.site-header {
	position: fixed;
	top: 0;
	width: 100%;
	max-width: 1920px;
	z-index: 999;
	background: none;
	transition: 0.3s all ease;
}
.site-header.change-color {
	background: #fce62a;
}
.header_main {
	display: flex;
	justify-content: space-between;
	width: 100%;
	height: 80px;
	padding: 0 40px;
}
.header_logo {
	max-width: 280px;
	height: 100%;
}
.header_logo h1,
.header_logo p,
.header_logo a {
	height: 100%;
	margin-bottom: 0;
}
.header_logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.header_menu {
	display: flex;
	align-items: center;
}
.header_menu .btn {
	margin: 0 2rem 0 0;
}
.header_menu span.antonio {
	margin-right: 0.5rem;
}
nav.toggle_menu {
	display: none;
	position: absolute;
	top: 0;
	right: 0;
	width: 420px;
	height: 100vh;
	padding: 80px 40px;
	background: #eac830;
	border-radius: 10px 0 0 10px;
}
nav.toggle_menu ul {
}
nav.toggle_menu li {
	padding: 1em 0;
	border-bottom: 1px solid #000;
}
nav.toggle_menu li a {
	font-weight: 700;
}
.menu-toggle {
	display: block;
	width: 40px;
	height: 30px;
	margin: 0;
	padding: 0;
	border: none;
	background: none;
	position: relative;
	z-index: 999;
}
.menu-toggle::before,
.menu-toggle::after {
	display: block;
	content: '';
	width: 100%;
	height: 4px;
	position: absolute;
	top: 0;
	left: 0;
	background: #000;
	transition: transform .3s ease, top .3s linear;
	transform: scaleY(0.5) translateY(1px);
}
.menu-toggle::before {
	margin: 0 auto;
	box-shadow: 0 20px 0 0 #000;
}
.menu-toggle::after {
	margin: 0 auto;
	top: 20px;
}
.menu-toggle:hover,
.menu-toggle:focus {
	border: none;
	color: #000 !important;
	outline: none;
}
.menu-toggle.toggled-on,
.menu-toggle.toggled-on:hover,
.menu-toggle.toggled-on:focus {
	background: none;
}
.menu-toggle.toggled-on::before,
.menu-toggle.toggled-on::after {
	height: 3px;
	transition: transform .2s ease, top .2s linear .1s, box-shadow .2s linear;
	background: #000 !important;
}
.menu-toggle.toggled-on::before {
	transform: rotate(45deg);
	top: 12px;
	box-shadow: 0 0 0 0 #000 !important;
}
.menu-toggle.toggled-on::after {
	transform: rotate(-45deg);
	top: 12px;
}


@media screen and (max-width: 1536px){
}
@media screen and (max-width: 1366px) {
}
@media screen and (max-width: 1023px) {
	.header_main {
		padding: 0 20px;
	}
	.header_menu .btn {
		display: none;
	}
}
@media screen and (max-width: 767px) {
	.header_main {
		height: 60px;
	}
	.header_logo {
		max-width: 65%;
	}
	.header_menu span.antonio {
		display: none;
	}
	nav.toggle_menu {
		width: 100%;
		padding-top: 60px;
	}
}

/*-------------------------------------------*/
/*	Footer
/*-------------------------------------------*/
body:not(.nagoya) .content_bottom {
	margin-top: 120px;
}
body.requirements .content_bottom {
	margin-top: 200px;
}
.content_bottom .inner {
	display: flex;
	justify-content: space-between;
	column-gap: 20px;
	position: relative;
	z-index: 3;
}
.content_bottom a {
	display: flex;
	align-items: flex-end;
	width: calc(50% - 10px);
	height: 280px;
	position: relative;
	padding: 15px 30px;
	border-radius: 10px;
	overflow: hidden;
}
.content_bottom a::before {
	display: block;
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background-size: cover;
	background-repeat: no-repeat;
	transition: 0.3s;
}
.content_bottom a.recruit::before {
	background-image: url(./images/footer_recruit-min.jpg);
}
.content_bottom a.contact::before {
	background-image: url(./images/footer_contact-min.jpg);
}
.content_bottom a::after {
	display: block;
	content: "";
	width: 2rem;
	height: 2rem;
	position: absolute;
	bottom: 20px;
	right: 30px;
	background-image: url(./images/icon_arrow01.svg);
	background-size: contain;
	background-repeat: no-repeat;
	filter: invert(100%) sepia(4%) saturate(7%) hue-rotate(351deg) brightness(117%) contrast(100%);
}
.content_bottom a:hover::before {
	transform: scale(1.1);
}
.content_bottom h2 {
	color: #fff;
	margin: 0;
	position: relative;
}
.content_bottom h2 span::after {
	background: #fff;
}
.site-footer {
	margin-top: -140px;
}
.site-footer .wrap {
	padding: 240px 11% 20px;
}
.site-footer .bg_yel::after {
	top: -70%;
	left: -55%;
}
.site-footer .inner {
}
.site-footer .footer_info {
	width: 45%;
	padding-right: 40px;
}
.site-footer .footer_info p {
	margin-top: 1.5em;
}

/*
.site-footer .footer_info ul {
	max-width: 280px;
}
.site-footer .footer_info li {
	padding: 1em 0 0.9em;
	border-bottom: 1px solid #000;
}
.site-footer .footer_info li a {
	width: 100%;
	font-weight: 700;
	position: relative;
	padding-right: 2em;
}
.site-footer .footer_info li a::after {
	display: block;
	content: "";
	width: 1em;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
	background-image: url(./images/icon_arrow02.svg);
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}*/


.site-footer .footer_nav {
	width: 55%;
}
.site-footer .footer_nav ul {
	display: flex;
	flex-wrap: wrap;
}
.site-footer .footer_nav li {
	width: 50%;
}
.site-footer .footer_nav li:nth-child(odd) {
	padding-right: 1.5rem;
}
.copyright {
	font-size: 0.75rem;
	text-align: right;
}

@media screen and (max-width: 1536px){
}
@media screen and (max-width: 1366px) {
	.site-footer .wrap {
		padding-left: 0;
		padding-right: 0;
	}
}
@media screen and (max-width: 1023px) {
	.content_bottom .inner {
		padding-left: 20px;
		padding-right: 20px;
	}
	.content_bottom a {
		height: 200px;
	}
}
@media screen and (max-width: 767px) {
	body:not(.nagoya) .content_bottom {
		margin-top: 60px;
	}
	.content_bottom .inner {
		display: block;
	}
	.content_bottom a {
		width: 100%;
    height: 180px;
	}
	.content_bottom a.recruit {
		margin-bottom: 10px;
	}
	.site-footer {
		margin-top: -90px;
	}
	.site-footer .wrap {
		padding-top: 130px;
	}
	.site-footer .flex {
		display: block;
	}
	.site-footer .footer_info {
		width: 100%;
		padding: 0;
	}
	.site-footer .footer_nav {
		width: 100%;
		margin-bottom: 40px;
	}
	.site-footer .footer_nav li:nth-child(odd) {
		width: 55%;
	}
	.site-footer .footer_nav li:nth-child(even) {
		width: 45%;
	}
	.site-footer .footer_nav li a {
		font-synthesis: 0.875rem;
	}
	.site-footer .link_list {
		border-top: 1px solid #000;
    margin: 0 auto 30px;
	}
}

/*-------------------------------------------*/
/*	Animation
/*-------------------------------------------*/
@media screen and (min-width: 768px) {
	.fadeUp {
		animation-name: fadeUpAnime;
		animation-duration: 0.5s;
		animation-delay: 0.4s;
		animation-fill-mode: forwards;
		opacity: 0;
	}
}
@keyframes fadeUpAnime{
  from {
    opacity: 0;
		transform: translateY(50px);
  }

  to {
    opacity: 1;
		transform: translateY(0);
  }
}
/*-------------------------------------------*/
/*	TOP page
/*-------------------------------------------*/
body.nagoya #fv .bg_yel::after {
	top: -70%;
	right: -40%;
}
body.nagoya #fv .inner {
	width: 100%;
	height: calc(100vh - 80px);
	overflow: hidden;
	padding: 0 60px 40px 0;
	position: relative;
}
body.nagoya #fv .main_copy {
	position: absolute;
	bottom: 60px;
	left: 4%;
	z-index: 2;
}
body.nagoya #fv .main_img {
	width: 76%;
	height: 100%;
	margin: 0 0 0 auto;
}
body.nagoya #fv .main_img div {
	height: 100%;
}
body.nagoya #fv .slider.sp {
	display: none;
}
body.nagoya #fv .main_img .slick-slide {
	display: flex;
	justify-content: flex-end;
	padding: 10px;
	overflow: hidden;
}
body.nagoya #fv .main_img .slick-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
	border-radius: 10px;
	box-shadow: 0px 0px 15px -5px #000;
}
body.nagoya #company .wrap {
	padding: 130px 11% 100px;
	background-image: url(./images/top_company-min.jpg);
	background-size: cover;
	background-position: center bottom;
	background-repeat: no-repeat;
}
body.nagoya #company h2 {
	color: #fff;
}
body.nagoya #company h2 span::after {
	background: #fff;
}
body.nagoya #company p {
	color: #fff;
}
body.nagoya #company h2 + p {
	line-height: 1.6;
}
body.nagoya #company strong {
	font-size: 2.1875rem;
	font-weight: 500;
}
body.nagoya #company .view_more {
	position: absolute;
	bottom: 0;
	right: 0;
}
body.nagoya #service .wrap {
	padding: 120px 0 90px;
}
body.nagoya #service .flex {
	align-items: center;
}
body.nagoya #service .flex .img {
	width: 54%;
	padding: 10px 10px 10px 0;
	overflow: hidden;
}
body.nagoya #service .flex .img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	border-radius: 0 10px 10px 0;
	box-shadow: 0px 0px 15px -5px #000;
}
body.nagoya #service .flex .txt {
	width: 46%;
	padding-left: 5%;
}
body.nagoya #service p {
	font-size: 1.25rem;
}
body.nagoya #strength .wrap {
	padding: 150px 0;
	background-image: url(./images/top_strength-min.jpg);
	background-size: cover;
	background-position: center bottom;
	background-repeat: no-repeat;
}
body.nagoya #strength .inner .bg_yel {
	width: 43.3%;
	padding: 60px 90px;
	position: relative;
	overflow: hidden;
	border-radius: 0 10px 10px 0;
}
body.nagoya #strength .inner .bg_yel::after {
	width: 110%;
	top: -60%;
	left: -30%;
}
body.nagoya #news .wrap {
	padding: 120px 11%;
}
body.nagoya #news .flex {
	
}
body.nagoya #news .head {
	width: 35%;
	padding-right: 40px;
}
body.nagoya .post_latest {
	width: 65%;
}

@media screen and (max-width: 1536px){
}
@media screen and (max-width: 1366px) {
	body.nagoya #company strong {
		font-size: 1.75rem;
	}
	body.nagoya #service p {
		font-size: 1.125rem;
	}
	body.nagoya #strength .inner .bg_yel {
		width: 50%;
		padding: 60px 40px;
	}
}
@media screen and (max-width: 1023px) {
	.bg_yel::after {
		display: none !important;
	}
	body.nagoya #fv .inner {
		padding-right: 0;
	}
	body.nagoya #fv .main_copy {
		max-width: 50%;
	}
	body.nagoya #fv .main_img {
		height: 70vh;
	}
	body.nagoya #fv .slider.pc {
		display: none;
	}
	body.nagoya #fv .slider.sp {
		display: block;
	}
	body.nagoya #fv .main_img .slick-slide {
		padding: 0;
	}
	body.nagoya #fv .main_img .slick-slide img {
		border-radius: 10px 0 0 10px;
	}
	body.nagoya #news .wrap {
		padding-left: 20px;
		padding-right: 20px;
	}
	body.nagoya #news .head h2 span {
		display: block;
		padding: 0;
	}
	body.nagoya #news h2 span::after {
		display: none;
	}
}
@media screen and (max-width: 767px) {
	body.nagoya #fv .inner {
		height: calc(100vh - 60px);
	}
	body.nagoya #fv .main_copy {
		bottom: 11%;
	}
	body.nagoya #company .wrap {
		padding: 50px 20px;
	}
	body.nagoya #company strong {
		font-size: 1.125rem;
	}
	body.nagoya #company .view_more {
		display: block;
		position: relative;
    margin: 80px 0 0 auto;
    text-align: right;
	}
	body.nagoya #service .wrap {
		padding: 50px 0;
	}
	body.nagoya #service .flex {
		display: block;
	}
	body.nagoya #service .flex .img {
		width: 100%;
		padding-right: 25px;
	}
	body.nagoya #service .flex .txt {
		width: 100%;
    padding: 0 20px;
    margin-top: 30px;
	}
	body.nagoya #strength .wrap {
		padding: 80px 0;
	}
	body.nagoya #strength .inner .bg_yel {
		width: 85%;
    padding: 40px 20px;
	}
	body.nagoya #news .wrap {
		padding-top: 50px;
		padding-bottom: 100px;
	}
	body.nagoya #news .flex {
		display: block;
	}
	body.nagoya #news .head {
		width: 100%;
		padding: 0;
	}
	body.nagoya #news .flex + div {
		text-align: center;
		margin-top: 30px;
	}
	body.nagoya .post_latest {
		width: 100%;
		padding: 0;
	}
	
}
/*-------------------------------------------*/
/*	Page common
/*-------------------------------------------*/
.breadcrumbs {
	margin-top: 60px;
	margin-bottom: 120px;
}
.bg_yel {
	position: relative;
	overflow: hidden;
	background: linear-gradient(0deg,rgba(234, 200, 48, 1) 0%, rgba(252, 230, 42, 1) 100%);
}
.bg_yel::after {
	display: block;
	content: "";
	width: 100%;
	aspect-ratio: 1 / 1;
	position: absolute;
	background-image: url(./images/bg_circle.svg);
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	z-index: 1;
}
.bg_yel > * {
	position: relative;
	z-index: 2;
}
.wrap > .bg_gray {
	display: block;
	width: calc(100% - 150px);
	height: calc(100% - 50px);
	position: absolute;
	top: 150px;
	left: 0;
	background: #f7f7f7;
	z-index: 1;
}
.table {
}
.table .tr {
	display: flex;
}
.table .th,
.table .td {
	border: none;
	padding: 1.15em 1.5em 1.25em;
}
.table .th {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 250px;
	font-weight: 700;
	border-bottom: 3px solid #e3d111;
}
.table .td {
	width: calc(100% - 250px);
	padding-left: 3em;
	border-bottom: 1px solid #acacac;
}
.table2col {
	display: flex;
	justify-content: space-between;
}
.table2col .table {
	width: 48%;
}
.table2col .th {
	width: 120px;
}
.table2col .td {
	width: calc(100% - 120px);
}

.link_list {
	max-width: 300px;
}
.link_list li {
	padding: 1em 0 0.9em;
	border-bottom: 1px solid #000;
}
.link_list li a {
	width: 100%;
	font-weight: 700;
	position: relative;
	padding-right: 2em;
}
.link_list li a::after {
	display: block;
	content: "";
	width: 1em;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
	background-image: url(./images/icon_arrow02.svg);
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}

#fv .wrap {
	padding-top: 80px;
}
/*main.child #fv {
	margin-bottom: 100px;
}*/
main.child #fv .bg_yel::after {
	top: -60%;
	right: -30%;
}
main.child #fv .inner {
	width: 100%;
	height: calc(100vh - 80px);
	overflow: hidden;
	padding-left: 15%;
	position: relative;
}
main.child #fv .inner .title {
	position: relative;
	z-index: 2;
}
main.child #fv .inner .title p {
	margin: 2rem 0 0;
	font-size: 1.25rem;
	font-weight: 700;
}
main.child #fv .img {
	width: 64%;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 1;
}
main.child .section:not(#fv) .wrap {
	padding: 120px 0 0;
}

@media screen and (max-width: 1536px){
	.breadcrumbs {
		margin-bottom: 80px;
	}
	main.child #fv .inner {
		padding-left: calc((100% - 1000px) / 2);
	}
}
@media screen and (max-width: 1366px) {
}
@media screen and (max-width: 1023px) {
	.wrap > .bg_gray {
		width: 100%;
	}
	.breadcrumbs {
		margin-bottom: 0;
	}
	#fv .wrap {
		padding-top: 60px;
	}
	main.child #fv .inner {
		height: 500px;
		padding-left: 20px;
	}
	main.child #fv .img {
		top: auto;
		bottom: 0;
	}
	main.child #fv .inner .title p {
		font-size: 1.125rem;
	}
}
@media screen and (max-width: 767px) {
	.wrap > .bg_gray {
		top: 80px;
		height: calc(100% - 20px);
	}
	.table .th, .table .td {
		padding: 0.75em 1em;
		font-size: 0.85rem;
	}
	.table .th {
		width: 100px;
		min-width: 100px;
	}
	.table .td {
		width: 100%;
	}
	.table2col {
		display: block;
	}
	.table2col .table {
		width: 100%;
	}
	main.child .section:not(#fv) .wrap {
		padding-top: 60px;
	}
	main.child #fv .inner {
		/*height: 580px;*/
		height: auto;
	}
	main.child #fv .inner .title p {
		font-size: 1rem;
	}
	main.child #fv .img {
		/*width: 75%;*/
		display: flex;
		justify-content: flex-end;
		width: 100%;
		padding-top: 15px;
		position: static;
	}
}

/*-------------------------------------------*/
/*	Page
/*-------------------------------------------*/
body.company #block01 p {
	max-width: 60%;
}
body.company #block01 p.right {
	max-width: 100%;
	text-align: right;
}
body.company #block03 .wrap {
	padding-top: 170px !important;
}
body.company #block04 p {
	font-size: 1.25rem;
	margin-top: 100px;
}
body.company #block04 .inner + div {
	width: 42%;
	position: absolute;
	top: 170px;
	right: 0;
}
body.company #block05 .wrap {
	padding-top: 170px !important;
}
body.company #block05 iframe {
	width: 100%;
	height: 300px;
	filter: grayscale(1);
	margin-bottom: 15px;
}

body.service #block01 ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
body.service #block01 ul li {
	width: 48%;
	margin-bottom: 90px;
}
body.service #block01 ul li:nth-child(5),
body.service #block01 ul li:nth-child(6) {
	margin-bottom: 0;
}
body.service #block01 ul li .flex {
	justify-content: space-between;
	align-items: flex-end;
	margin-bottom: 10px;
}
body.service #block01 ul li p {
	font-size: 1.75rem;
	font-weight: 700;
	line-height: 1.2;
	margin: 0;
}
body.service #block01 ul li p span {
	display: block;
	font-size: 0.875rem;
	font-weight: 500;
	color: #acacac;
}
body.service #block01 ul li > a {
	border-radius: 10px;
	overflow: hidden;
}
body.service #block01 ul li > a img {
	transition: 0.3s all;
}
body.service #block01 ul li > a:hover img {
	transform: scale(1.1);
}

main.service_child #fv .inner,
body.entry #fv .inner,
body.archive #fv .inner,
body.single #fv .inner {
	height: auto;
	padding-bottom: 50px;
}
main.service_child #page_nav .wrap {
	padding: 2rem 0 !important;
  margin-top: 120px;
	background: #000;
}
main.service_child #page_nav ul {
	display: flex;
	justify-content: center;
}
main.service_child #page_nav li {
	color: #fff;
	padding-right: 1em;
}
main.service_child #page_nav li:last-child {
	padding-right: 0;
}
main.service_child #page_nav a {
	color: #fff !important;
}
main.service_child #page_nav a.active {
	color: #b3b3b3 !important;
}

main.service_child .main_img p {
	margin-top: 15px;
	margin-bottom: 3em;
}
main.service_child .facility_list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
main.service_child .facility_list li {
	width: 48%;
	margin-top: 60px;
}
main.service_child .facility_list li:nth-child(1),
main.service_child .facility_list li:nth-child(2) {
	margin-top: 0;
}
main.service_child .facility_list li p {
	margin-top: 15px;
	margin-bottom: 1em;
}
main.service_child .facility_list li p .title {
	display: block;
	font-size: 1.125rem;
	font-weight: 700;
	border-bottom: 1px solid #000;
}
main.service_child .facility_list li p .detail {
	display: block;
}
main.service_child .detail_table {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
main.service_child .detail_table img {
	width: 48%;
}

body.service03 .detail_table,
body.service05 .detail_table {
	display: block;
}
body.service03 .detail_table img,
body.service05 .detail_table img {
	width: 100%;
}
body.service04 .section .flex,
body.service05 .section .flex {
	display: flex;
	flex-direction: row-reverse;
	justify-content: flex-end;
	align-items: center;
	margin-bottom: 60px;
}
body.service04 .section .flex > p,
body.service05 .section .flex > p {
	font-size: 1.125rem;
	padding-left: 3rem;
}
body.service04 .section .flex .img,
body.service05 .section .flex .img {
	max-width: 37%;
}
body.service04 #block01 .facility_list {
	margin-top: 80px;
}
body.service04 #block02 .notice {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 60px;
	padding: 0.6em 2em 0.5em;
	background: #e3d111;
}
body.service04 #block02 .notice p {
	margin-bottom: 0;
	font-size: 1.25rem;
	text-align: center;
}
body.service05 #block01 .facility_list {
	align-items: flex-end;
}
body.service05 #block01 .facility_list.mb100 {
	margin-bottom: 100px;
}
body.service06 #block01 .flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 120px 0;
}
body.service06 #block01 .flex > p {
	width: 50%;
	padding-right: 40px;
	font-size: 2rem;
	font-weight: 700;
	margin: 0;
}
body.service06 #block01 .flex div {
	width: 50%;
	margin-bottom: 80px;
}
body.service06 #block01 .flex div p {
	margin: 15px 0 0;
	text-align: right;
}
body.service06 #block01 .flex img:nth-child(3),
body.service06 #block01 .flex img:nth-child(4) {
	width: 48%;
}

/*body.strength #fv .inner .title p {
	font-size: 1rem;
}*/
body.strength #block01 .flex {
	margin-bottom: 120px;
}
body.strength #block01 .flex:last-child {
	margin-bottom: 0;
}
body.strength #block01 .flex .img {
	width: 48%;
}
body.strength #block01 .flex .txt {
	width: 52%;
	padding-left: 7.6%;
}
body.strength #block01 .flex:nth-child(even) {
	flex-direction: row-reverse;
}
body.strength #block01 .flex:nth-child(even) .txt {
	padding-right: 7.6%;
	padding-left: 11%;
}
body.strength #block01 .flex .txt .point {
	line-height: 1.6;
}
body.strength #block01 .flex .txt .point .yel {
	display: block;
	font-size: 2.125rem;
	font-weight: 700;
	color: #e3d111;
}
body.strength #block01 .flex .txt .point .gray {
	font-size: 1.75rem;
	font-weight: 700;
	line-height: 1.5;
}
body.strength #block01 .flex .txt .point .gray span {
	display: inline-block;
	position: relative;
	z-index: 2;
}
body.strength #block01 .flex .txt .point .gray span::after {
	display: block;
	content: "";
	width: 102%;
	height: 0.4em;
	position: absolute;
	bottom: 4px;
	left: 0;
	background: #e6e6e6;
	z-index: -1;
}
body.strength #block01 .flex .txt .big {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: 0.6em;
}

body.contact #block01 .flex {
	justify-content: space-between;
	align-items: center;
	margin-top: 80px;
}
body.contact #block01 .flex .tel {
	width: 48%;
}
body.contact #block01 .flex .txt {
	width: 45%;
}
body.contact #block01 .flex .txt p {
	margin: 0;
}
body.contact #block01 .flex .txt p span {
	color: #e3d111;
}
body.contact #block01 a.btn2 {
	font-size: 1.625rem;
}
body.contact #block01 a.btn2 span {
	padding-left: 1.5em;
	position: relative;
}
body.contact #block01 a.btn2 span::before {
	display: block;
	content: "";
	width: 1.5em;
	height: 1.5em;
	position: absolute;
	top: -0.2em;
	left: 0;
	background-image: url(./images/icon_tel.svg);
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}
body.contact #block01 .tel p {
	margin: 0;
	font-size: 0.875rem;
	color: #4d4d4d;
	text-align: center;
}
body.contact #block02 .wrap {
	padding-top: 170px !important;
}
body.requirements #block01 .table {
	margin: 120px 0 80px;
}
body.requirements #block01 .table + p {
	text-align: center;
}
body.requirements #block01 a.btn2 span {
	position: relative;
	padding-right: 3em;
}
body.requirements #block01 a.btn2 span::after {
	display: block;
	content: "";
	width: 2rem;
	height: 2rem;
	position: absolute;
	top: 0;
	right: 0;
	background-image: url(./images/icon_arrow01.svg);
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}
body.requirements #block02 .inner {
	text-align: center;
	margin-top: 60px;
}
body.requirements #block02 .inner img {
	width: 100%;
	max-width: 600px;
}
body.requirements #block02 .inner a:last-child {
	margin-top: 50px;
}
body.entry #block01 .inner > p {
	font-size: 1.125rem;
	text-align: center;
}
body.entry .birth p:last-child span,
body.entry .graduation p:last-child span{
	display: inline-block;
	width: 90px;
	margin-right: 10px;
}
@media screen and (max-width: 1536px){
	main.service_child #fv .inner,
	body.entry #fv .inner,
	body.archive #fv .inner,
	body.single #fv .inner {
		padding-bottom: 80px;
	}
}
@media screen and (max-width: 1366px) {
	body.strength #block01 .flex .txt .point .yel {
		font-size: 1.85rem;
	}
	body.strength #block01 .flex .txt .point .gray {
		font-size: 1.5rem;
	}
}
@media screen and (max-width: 1023px) {
	main.service_child #page_nav ul {
		flex-wrap: wrap;
	}
	body.company #block04 .inner + div {
		width: 100%;
		position: static;
		text-align: right;
	}
	body.company #block04 .inner + div img {
		width: 80%;
	}
	body.company #block04 p {
		margin-top: 0;
	}
	body.service #block01 ul li p {
		font-size: 1.25rem;
	}
	body.service #block01 ul li p span {
		font-size: 0.675rem;
	}
	body.service06 #block01 .flex > p {
		font-size: 1.25rem;
	}
	body.strength #block01 .flex {
		display: block;
		margin-bottom: 80px;
	}
	body.strength #block01 .flex .img {
		width: 90%;
	}
	body.strength #block01 .flex .txt {
		width: 70%;
    padding: 2rem;
    background: #fff;
    margin: -80px 0 0 auto;
    position: relative;
	}
	body.strength #block01 .flex:nth-child(even) .txt {
		margin: -80px auto 0 0;
	}
	body.strength #block01 .flex:nth-child(even) .img {
		margin: 0 0 0 auto;
	}
}
@media screen and (max-width: 767px) {
	main.service_child .facility_list li {
		margin-top: 30px;
	}
	main.service_child .facility_list li p {
		font-size: 0.75rem;
	}
	main.service_child .facility_list li p .title {
		font-size: 0.75rem;
	}
	main.service_child .detail_table {
		display: block;
	}
	main.service_child .detail_table img {
		width: 100%;
		margin-bottom: 15px;
	}
	main.service_child #page_nav .wrap {
		margin-top: 60px !important;
	}
	
	body.company #block01 p {
		max-width: 100%;
	}
	body.company #block03 .wrap {
		padding-top: 100px !important;
	}
	body.company #block04 p {
		font-size: 1rem;
	}
	body.company #block05 .wrap {
		padding-top: 60px !important;
	}
	body.service #block01 ul {
		display: block;
	}
	body.service #block01 ul li {
		width: 100%;
		margin-bottom: 30px !important;
	}
	body.service04 .section .flex,
	body.service05 .section .flex {
		display: block;
		text-align: center;
	}
	body.service04 .section .flex > p,
	body.service05 .section .flex > p {
		font-size: 1rem;
		padding: 0;
	}
	body.service04 .section .flex .img,
	body.service05 .section .flex .img {
		max-width: 100%;
	}
	body.service04 #block01 .facility_list {
		margin-top: 0;
	}
	body.service04 #block02 .notice {
		margin-top: 30px;
	}
	body.service04 #block02 .notice p {
		font-size: 1rem;
	}
	body.service05 #block01 .facility_list.mb100 {
		margin-bottom: 60px;
	} 
	body.service06 #block01 .flex {
		display: block;
		margin-top: 0;
		margin-bottom: 60px;
	}
	body.service06 #block01 .flex > p {
		width: 100%;
    font-size: 1em;
    margin-bottom: 20px;
		padding: 0;
	}
	body.service06 #block01 .flex div {
		width: 100%;
	}
	body.service06 .main_img p {
		margin-bottom: 1.5rem;
	}
	body.strength #block01 .flex .txt {
		width: 90%;
		padding: 1rem 1.5rem;
		margin: -80px 0 0 auto;
	}
	body.strength #block01 .flex .txt .point {
		margin-bottom: 1.5em;
	}
	body.strength #block01 .flex .txt .point .yel {
		font-size: 1.35rem;
	}
	body.strength #block01 .flex .txt .point .gray {
		font-size: 1.125rem;
	}
	body.strength #block01 .flex .txt .big {
		font-size: 1rem;
	}
	body.strength #block01 .flex:nth-child(even) .txt {
		padding-left: 1.5rem;
	}
	body.contact #block01 .flex {
		display: block;
		margin-top: 30px;
	}
	body.contact #block01 .flex .tel {
		width: 100%;
    margin-bottom: 15px;
	}
	body.contact #block01 .flex .txt {
		width: 100%;
	}
	body.contact #block01 .flex .txt p {
		font-size: 0.875rem;
	}
	body.contact #block01 a.btn2 span::before {
		width: 1.125em;
	}
	body.contact #block02 .wrap {
		padding-top: 100px !important;
	}
	body.requirements #block01 .table {
		margin: 60px 0;
	}
	body.entry #block01 .inner > p {
		font-size: 0.875rem
	}
	body.entry .birth p:last-child span,
	body.entry .graduation p:last-child span{
		width: 60px;
		margin-right: 5px;
	}
	
}

/*-------------------------------------------*/
/*	Archive
/*-------------------------------------------*/
.post_latest li {
	display: flex;
	padding: 1.25em 0 1.15em;
	border-bottom: 1px solid #c1c1c1;
}
.post_latest li p {
	margin: 0;
}
.post_latest li .date {
	width: 140px;
	min-width: 140px;
	text-align: center;
}
.post_latest li .date span {
	display: block;
	width: 110px;
	margin: 0 auto;
	font-size: 0.875rem;
	background: #e7e7e7;
}
.post_latest li .title {
	width: 100%;
	display: flex;
	padding: 0 1em;
}
.post_latest li .title a {
	width: 100%;
	padding-right: 30px;
	position: relative;
}
.post_latest li .title a::after {
	display: block;
	content: "";
	width: 20px;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
	background-image: url(./images/icon_arrow02.svg);
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}

@media screen and (max-width: 1536px){
}
@media screen and (max-width: 1366px) {
}
@media screen and (max-width: 1023px) {
}
@media screen and (max-width: 767px) {
}
/*-------------------------------------------*/
/*	Single
/*-------------------------------------------*/
.post_info {
	border-bottom: 1px solid #ccc;
	margin-bottom: 3rem;
}
.post_info p.date {
	margin: 0;
}
.post_info p.title {
	font-size: 1.25rem;
}
body.single .section h2 {
	font-size: 1.625rem;
	padding-left: 0.75em;
	position: relative;
}
body.single .section h2::after {
	display: block;
	content: "";
	width: 4px;
	height: 1em;
	position: absolute;
	top: 0.2em;
	left: 0;
	background: #e3d111;
}
body.single .section ol {
	padding-left: 1.5em;
	margin-bottom: 1.75em;
}
body.single .section ul {
	margin-bottom: 1.75em;
}
@media screen and (max-width: 1536px){
}
@media screen and (max-width: 1366px) {
}
@media screen and (max-width: 1023px) {
}
@media screen and (max-width: 767px) {
	body.single .section h2 {
		font-size: 1.35rem;
	}
}

/*-------------------------------------------*/
/*	Mail form
/*-------------------------------------------*/
input::placeholder {
  color: #aaa;
}
::placeholder{
  color: #aaa;
}
/* IE */
input:-ms-input-placeholder {
    color: #aaa;
}
:-ms-input-placeholder{
    color: #aaa;
}
input[type="text"], input[type="email"], input[type="tel"], textarea, select {
	background: #fff;
	border: none;
	border-radius: 4px;
	padding: 0.5em 1.5em;
}

.form_wrap {
	max-width: 800px;
  margin: 80px auto 0;
}
.form_wrap > div > p:first-child {
	margin: 0;
}
.form_wrap > div > p span.small {
	font-size: 0.875rem;
	color: #4d4d4d;
}
.form_wrap input,
.form_wrap textarea,
.form_wrap select {
	padding: 0.5em 1.5em;
	border: 1px solid #D6D6D6;
	border-radius: 4px;
	background: #f6f6f6;
}
.check_privacy .border {
	margin-bottom: 1em;
	padding: 1em;
	border: 1px solid #cccccc;
	border-radius: 5px;
}
.check_privacy .border a {
	position: relative;
}
.check_privacy .border a::after {
	display: block;
	content: "";
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: 0;
	left: 0;
	background: #aaa;
}
.check_privacy .border p {
	margin-bottom: 1.25em;
}
.check_privacy .border .bold {
	font-weight: 700;
}
.check_privacy .border + p {
	max-width: 580px;
  margin: 2em auto;
	font-size: 0.875rem;
	text-align: center;
}
a.btn2 input {
	width: 100%;
	height: 100%;
	border: none;
	background: none !important;
	border-radius: 10px;
	color: #000;
}
.wpcf7-spinner {
	display: none;
}
@media screen and (max-width: 1536px) {
}
@media screen and (max-width: 1366px) {
}
@media screen and (max-width: 1023px) {
	a.btn2 {
		width: 300px;
	}
}
@media screen and (max-width: 767px) {
	.form_wrap input,
	.form_wrap textarea,
	.form_wrap select {
		padding: 0.5em;
	}
	
}

/*-------------------------------------------*/
/*	404
/*-------------------------------------------*/
body.error404 {
}