@charset "UTF-8";

.mainvisual {
    position: relative;
    margin: 0 0 40px;
    padding: 0 0 56.25%;
}
.mainvisual .mainvisual-video,
.mainvisual .mainvisual-img {
	position: absolute;
	top: 0;
	left: 0;
}
.mainvisual .mainvisual-img {
	z-index: -1;
}
.mainvisual .mainvisual-img.finished {
	opacity: 1;
}

.videoskip {
    position: absolute;
	bottom: calc(30 / 1280 * 100vw);
	right: calc(30 / 1280 * 100vw);
    margin: 0;
    padding: 0;
	font-size: 1.2rem;
	line-height: 1;
	cursor: pointer;
}

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

	.mainvisual {
		margin: 0 0 30px;
	}
}


.title {
	position: relative;
	max-width: 870px;
	margin: 0 auto;
	padding: 0;
	text-align: center;
	font-size: 2.4rem;
	font-weight: 700;
}
.title span {
	display: inline-block;
	position: relative;
	width: 438px;
	margin: 0;
	padding: 0 0 10px;
	border-bottom: 1px solid #000;
}
.title span::before,
.title span::after {
	position: absolute;
	left: -215px;
	top: 12px;
	content: '';
	width: 215px;
	height: 1px;
	background: #000;
}
.title span::after {
	left: auto;
	right: -215px;
}

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

	.title {
		font-size: 1.8rem;
	}
	.title span {
		width: 65%;
		max-width: 438px;
		margin: 0;
	}
	.title span::before,
	.title span::after {
		position: absolute;
		left: calc(-17.5% - 20px);
		top: 12px;
		width: calc(17.5% + 20px);
	}
	.title span::after {
		left: auto;
		right: calc(-17.5% - 20px);
	}

}


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

　コンテンツ

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

.philosophy {
	margin: 0;
	padding: 0;
}

.philosophy-content {
	margin: 0 auto;
	padding: 0 0 60px;
}
.philosophy-content-inner {
	margin: 0 auto;
	padding: 10px 0 15px;
	background: url("../images/top/philosophy_bg.svg") center top / auto auto repeat;
}
.philosophy-content h1 {
	position: relative;
	margin: 0 0 40px;
	padding: 0;
	text-align: center;
	font-size: 2.4rem;
	line-height: 1;
}
.philosophy-content h1::after {
	position: absolute;
	right: calc(50% + 305px);
	top: 0;
	content: '';
	width: 140px;
	height: 145px;
	background: url("../images/top/philosophy_img01.png") left top / 100% auto no-repeat;
	transform: translate(0, -50%);
}
.philosophy-content p {
	max-width: 610px;
	margin: 0 auto;
	padding: 0;
	font-size: 1.8rem;
	line-height: 2;
}


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

	.philosophy-content {
		padding: 0 30px 30px;
	}
	.philosophy-content-inner {
		padding: 10px 0 15px;
	}
	.philosophy-content h1 {
		margin: 0 0 20px;
		font-size: 1.6rem;
	}
	.philosophy-content h1::after {
		top: -20px;
		left: -30px;
		right: auto;
		width: 70px;
		height: 73px;
	}
	.philosophy-content p {
		font-size: 1.2rem;
	}

}


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

　業務内容

=================================================*/
.business {
	margin: 0;
	padding: 0;
}

.business-content {
	position: relative;
	margin: 0 auto;
	padding: 50px 0 40px;
	background-color: #FFF596;
}
.business-content::before,
.business-content::after {
	position: absolute;
	right: calc(50% + 439px);
	top: 50%;
	content: '';
	width: 139px;
	height: 192px;
	background: url("../images/top/business_img05.svg") left top / 100% auto no-repeat;
	transform: translate(0, -70px);
}
.business-content::after {
	left: auto;
	right: calc(50% - 525px);
	top: auto;
	bottom: 0;
	width: 151px;
	height: 142px;
	background: url("../images/top/business_img06.svg") left top / 100% auto no-repeat;
	transform: translate(0, 0);
}
.business-content-box-title {
	position: relative;
	text-align: center;
}
.business-content-box-title::before,
.business-content-box-title::after {
	position: absolute;
	left: calc(50% - 434px);
	top: 0;
	content: '';
	width: 49px;
	height: 49px;
	background: url("../images/top/business_title_img01.svg") left top / 100% auto no-repeat;
	transform: translate(0, -36px);
}
.business-content-box-title::after {
	left: calc(50% + 430px);
	width: 59px;
	height: 59px;
	background: url("../images/top/business_title_img02.svg") left top / 100% auto no-repeat;
	transform: translate(0, 0);
}

.business-content-box-body ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	position: relative;
	max-width: 875px;
	margin:  0 auto;
	padding: 0;
}
.business-content-box-body ul li {
	width: 381px;
	margin: 50px 0 0;
	text-align: center;
}
.business-content-box-body ul li:nth-child(even) {
	width: 452px;
}
.business-content-box-body ul li:last-child {
	display: flex;
	align-items: center;
	padding: 0 48px;
}


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

	.business {
		margin: 0;
		padding: 0;
	}
	.business-content {
		position: relative;
		margin: 0 auto;
		padding: 40px 30px 40px;
	}
	.business-content::before,
	.business-content::after {
		left: 0;
		right: auto;
		top: 50%;
		width: 42px;
		height: 60px;
		transform: translate(0, 0px);
	}
	.business-content::after {
		left: auto;
		right: 0;
		top: auto;
		bottom: 0;
		width: 45px;
		height: 43px;
	}
	.business-content h2 {
		padding: 0 20px;
	}
	.business-content-box-body ul li {
		width: 43.542857%;
		margin: 30px 0 0;
		text-align: center;
	}
	.business-content-box-body ul li:nth-child(even) {
		width: 51.657143%;
	}
	.business-content-box-body ul li:last-child {
		display: flex;
		align-items: center;
		padding: 0 10px;
	}
}


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

　業務内容

=================================================*/
.timeschedule {
	padding: 40px 0;
}
.timeschedule-content {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
	padding: 40px 40px 0;
	border: 2px solid #000;
	border-bottom: 7px solid #000;
}
.timeschedule-content::before,
.timeschedule-content::after {
	position: absolute;
	left: 0;
	top: 0;
	content: '';
	width: 227px;
	height: 10px;
	background-color: #000;
}
.timeschedule-content::after {
	left: auto;
	right: 0;
	top: 0;
	width: 10px;
	height: 227px;
}
.timeschedule-content-box {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 870px;
	margin:  0 auto;
	padding: 0;
}
.timeschedule-content-box-am,
.timeschedule-content-box-pm {
	position: relative;
	width: 416px;
	margin: 25px 0 0;
	padding: 0;
}
.timeschedule-content-box-am::before,
.timeschedule-content-box-pm::before {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 5px;
	left: 0;
	content: '午前';
	width: 88px;
	height: 88px;
	color: #FFF;
	font-size: 2.3rem;
	line-height: 1;
	background-color: #F19500;
	border-radius: 50%;
}
.timeschedule-content-box-pm::before {
	content: '午後';
	background-color: #8FC31F;
}
.timeschedule-content-box ul li {
	padding: 25px 0;
	padding-left: 100px;
	border-bottom: 1px solid #878787;
}
.timeschedule-content-box ul li:first-child {
	margin: 0 0 0 90px;
	padding: 27px 0;
	padding-left: 10px;
}
.timeschedule-content-box ul li:nth-of-type(7) {
	width: 530px;
	border-bottom: none;
}
.timeschedule-content-box time {
	display: inline-block;
	width: 213px;
	padding: 5px 20px 7px 40px;
	color: #FFF;
	font-size: 2.2rem;
	font-weight: 700;
	background-color: #878787;
	border-radius: 4px;
}
.timeschedule-content-box p {
	display: inline-block;
	margin: 0 0 0 35px;
	padding-right: 18px;
	font-size: 2.2rem;
	font-weight: 700;
}
.timeschedule-content-box .timeschedule-content-sup {
	margin: -60px 0 0 65px;
	padding: 0 0 0 1em;
	text-indent: -1em;
	font-size: 2rem;
	line-height: 1.7;
}
.closing {
	width: 327px;
	height: 110px;
	margin: 25px auto 0;
	padding: 38px 0 0 135px;
	font-size: 1.9rem;
	font-weight: 700;
	line-height: 1.3;
	background: url("../images/top/closing_img01.svg") left top / 100% auto no-repeat;
}


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

	.timeschedule {
		padding: 20px;
	}
	.timeschedule-content {
		padding: 40px 30px 0;
	}
	.timeschedule-content::before,
	.timeschedule-content::after {
		width: 40%;
		height: 10px;
	}
	.timeschedule-content::after {
		width: 10px;
		height: 200px;
	}
	.timeschedule-content-box {
		width: 100%;
	}
	.timeschedule-content-box-am,
	.timeschedule-content-box-pm {
		width: 100%;
		margin: 100px 0 0;
	}
	.timeschedule-content-box-am::before,
	.timeschedule-content-box-pm::before {
		top: -80px;
		left: 50%;
		width: 75px;
		height: 75px;
		font-size: 1.8rem;
		transform: translate(-50%, 0);
	}
	.timeschedule-content-box ul li {
		padding: 15px 10px;
	}
	.timeschedule-content-box ul li:first-child {
		margin: 0;
		padding: 15px 10px;
	}
	.timeschedule-content-box ul li:nth-of-type(7) {
		width: auto;
		border-bottom: none;
	}
	.timeschedule-content-box time {
		width: 135px;
		padding: 5px 15px 7px;
		font-size: 1.6rem;
	}
	.timeschedule-content-box p {
		margin: 0 0 0 10px;
		padding-right: 0;
		font-size: 1.4rem;
	}
	.timeschedule-content-box .timeschedule-content-sup {
		margin: 10px 0 0 0;
		font-size: 1.5rem;
	}
	.closing {
		width: 262px;
		height: 88px;
		margin: 25px auto 0;
		padding: 30px 0 0 108px;
		font-size: 1.5rem;
	}

}


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

　ご利用までの流れ

=================================================*/
.flowo {
	padding: 40px 0;
	background-color: #8FC31F;
}
.flowo-content {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
	padding: 40px 0 0;
	border: 2px solid #000;
	border-bottom: 7px solid #000;
}
.flowo-content::before,
.flowo-content::after {
	position: absolute;
	left: 0;
	top: 0;
	content: '';
	width: 227px;
	height: 10px;
	background-color: #000;
}
.flowo-content::after {
	left: auto;
	right: 0;
	top: 0;
	width: 10px;
	height: 227px;
}
.flowo-content-box {
	margin: 0 auto 50px;
}
.flowo-content-box::before,
.flowo-content-box::after {
	position: absolute;
	left: -1px;
	top: 115px;
	content: '';
	width: 51px;
	height: 96px;
	background: url("../images/top/flowo_arrow01.svg") left top / 100% auto no-repeat;
	transform: translate(-50%, 0);
	z-index: 10;
}
.flowo-content-box::after {
	left: auto;
	right: -1px;
	top: 625px;
	background: url("../images/top/flowo_arrow02.svg") left top / 100% auto no-repeat;
	transform: translate(50%, 0);
}

.flowo-content h3 {
	margin: 40px 0 25px;
	color: #F2EB49;
	text-align: center;
	font-size: 4rem;
	font-weight: 700;
	line-height: 1;
}
.flowo-content h4 {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	padding: 0 20px 0 0;
	color: #FFF;
	text-align: center;
	font-size: 3.1rem;
	font-weight: 700;
	line-height: 1;
}
.flowo-content h4 strong {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 208px;
	height: 55px;
	margin: 0 5px;
	padding: 0 0 2px;
	color: #8FC31F;
	text-align: center;
	font-size: 3.1rem;
	line-height: 1;
	background-color: #FFF;
	border-radius: 5px;
}
.flowo-content h4 span {
	width: 100%;
	margin: 15px 0 30px;
	padding: 0;
	color: #FFF;
	text-align: center;
	font-size: 2.7rem;
}
.flowo-content ol {
	width: 600px;
	margin: 0 auto;
}
.flowo-content ol li {
	display: flex;
	align-items: center;
	margin: 0 0 28px;
}
.flowo-content ol li h5 {
	width: 180px;
	margin: 0 18px 0 0;
	padding: 5px 0 6px;
	color: #8FC31F;
	text-align: center;
	font-size: 2rem;
	background-color: #FFF;
	border-radius: 5px;
}
.flowo-content ol li p {
	margin: 0;
	padding: 0;
	color: #FFF;
	text-align: center;
	font-size: 2rem;
	font-weight: 700;
}
.flowo-content figure {
	text-align: center;
}
.flowo-content .closing {
	padding: 38px 0 0 125px;
}


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

	.flowo {
		padding: 20px;
	}
	.flowo-content {
		padding: 40px 30px 0;
	}
	.flowo-content::before,
	.flowo-content::after {
		width: 40%;
		height: 10px;
	}
	.flowo-content::after {
		width: 10px;
		height: 200px;
	}
	.flowo-content-box {
		margin: 0 auto;
	}
	.flowo-content-box::before,
	.flowo-content-box::after {
		left: -1px;
		top: 115px;
		width: 32px;
		height: 62px;
	}
	.flowo-content-box::after {
		left: auto;
		right: -1px;
		top: 625px;
	}

	.flowo-content h3 {
		margin: 25px 0;
		font-size: 2.8rem;
		line-height: 1.5;
	}
	.flowo-content h4 {
		padding: 0 10px 0 0;
		font-size: 2.1rem;
	}
	.flowo-content h4 strong {
		width: 41%;
		height: 35px;
		font-size: 2.2rem;
	}
	.flowo-content h4 span {
		margin: 15px 0 30px;
		padding: 0;
		color: #FFF;
		text-align: center;
		font-size: 2rem;
	}

	.flowo-content ol {
		width: calc(100% + 30px);
		margin-left: -15px
	}
	.flowo-content ol li {
		margin: 0 0 20px;
	}
	.flowo-content ol li h5 {
		width: 80px;
		margin: 0 10px 0 0;
		padding: 5px 0 6px;
		font-size: 1.4rem;
	}
	.flowo-content ol li p {
		margin: 0;
		padding: 0;
		text-align: left;
		font-size: 1.4rem;
		line-height: 1.5;
	}
	.flowo-content figure {
		text-align: center;
	}
	.flowo-content .closing {
		padding: 30px 0 0 90px;
	}

}


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

　会社・施設案内

=================================================*/
.company-content {
	max-width: 870px;
	margin: 0 auto;
	padding: 100px 0 0;
}
.company-content .title span::before,
.company-content .title span::after {
	display: none;
}
.company-content-img {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 60px auto 0;
}
.company-content-img figure {
	width: 48%;
	margin: 0 0 25px;
}

.company-content table {
	position: relative;
	width: 100%;
	margin: 30px auto 50px;
	color: #231815;
	text-align: left;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.7;
}
.company-content table th {
	width: 160px;
	padding: 15px 8px;
	border-bottom: 1px solid #9FA0A0;
}
.company-content table td {
	padding: 15px 8px;
	border-bottom: 1px solid #9FA0A0;
}
.company-content table tr:nth-of-type(n+3):nth-child(-n+5) th,
.company-content table tr:nth-of-type(n+3):nth-child(-n+5) td,
.company-content table tr:nth-of-type(7) th,
.company-content table tr:nth-of-type(7) td,
.company-content table tr:nth-of-type(8) th,
.company-content table tr:nth-of-type(8) td {
	padding: 15px 8px 8px;
	border-bottom: none;
}
.company-content table tr:nth-of-type(n+4):nth-child(-n+5) th,
.company-content table tr:nth-of-type(n+4):nth-child(-n+5) td,
.company-content table tr:nth-of-type(8) th,
.company-content table tr:nth-of-type(8) td {
	padding: 0 8px 8px;
}
.company-content table tr:nth-of-type(6) th,
.company-content table tr:nth-of-type(6) td {
	padding: 0 8px 15px;
}

.company-content table td dl {
	display: table;
}
.company-content table td dl:nth-of-type(2) {
	margin: 15px 0 0;
}
.company-content table td dl dt {
	display: table-cell;
	width: 110px;
	margin: 0;
	padding: 0;
}
.company-content table td dl dd {
	display: table-cell;
}
.company-content table ul li {
	text-indent: -1em;
	padding: 0 0 0 1em;
}
.company-content-map {
	text-indent: -1em;
	padding: 0 0 0 1em;
}
.company-content-map:last-child {
	margin-top: 50px;
}
.company-content-map ul {
	margin: 20px 0 0 10px;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.5;
}


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

	.company-content {
		margin: 0 auto;
		padding: 50px 20px 0;
	}
	.company-content-img {
		margin: 30px auto 0;
	}
	.company-content-img figure {
		margin: 0 0 15px;
	}
	.company-content table {
		margin: 10px auto 30px;
		font-size: 1.2rem;
	}
	.company-content table th {
		width: 80px;
		padding: 10px 6px;
	}
	.company-content table td {
		padding: 10px 6px;
	}
	.company-content table tr:nth-of-type(n+3):nth-child(-n+5) th,
	.company-content table tr:nth-of-type(n+3):nth-child(-n+5) td,
	.company-content table tr:nth-of-type(7) th,
	.company-content table tr:nth-of-type(7) td,
	.company-content table tr:nth-of-type(8) th,
	.company-content table tr:nth-of-type(8) td {
		padding: 10px 6px 6px;
	}
	.company-content table tr:nth-of-type(n+4):nth-child(-n+5) th,
	.company-content table tr:nth-of-type(n+4):nth-child(-n+5) td,
	.company-content table tr:nth-of-type(8) th,
	.company-content table tr:nth-of-type(8) td {
		padding: 0 6px 6px;
	}
	.company-content table tr:nth-of-type(6) th,
	.company-content table tr:nth-of-type(6) td {
		padding: 0 6px 10px;
	}
	.company-content table td dl:nth-of-type(2) {
		margin: 10px 0 0;
	}
	.company-content table td dl dt {
		width: 5em;
	}
	.company-content-map:last-child {
		margin-top: 30px;
	}
	.company-content-map ul {
		margin: 10px 0 0;
		font-size: 1.2rem;
	}

}
