
main {
	padding-top: 0;
}

header.header {
	display: none;
}

header.header.appear {
	display: block;
}

.btn {
	width: 16.188vw;
	height: 3.75vw;
	background: #199B02;
	display: flex;
	justify-content: center;
	align-items: center;
	color: white;
	font-size: 1.25vw;
	font-weight: 500;
	letter-spacing: 0.12em;
	position: relative;
}

.btn::after {
	position: absolute;
	top: 0.813vw;
	right: 1.269vw;
	content: '>';
	font-size: 1.25vw;
}

div.relative {
	position: relative;
	width: 100%;
	height: 100%;
}

section#fv {
	width: 100vw;
	height: 53.125vw;
	background: url('../image/top/fv-bg.png');
	background-size: cover;
	padding-top: 1.563vw;
}

section#fv .fv-header {
	width: 87.5vw;
	height: 6.25vw;
	background: rgba(255,255,255, 0.9);
	margin: 0 auto 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-left: 2.063vw;
	padding-right: 2.313vw;
}

section#fv .fv-header .fv-logo {
	width: 23.332vw;
	height: 2.178vw;
}

section#fv .fv-header ul.fv-menu {
	list-style: none;
	width: 34.938vw;
	height: 1.563vw;
	display: flex;
	justify-content: space-between;
	font-size: 1.063vw;
	font-weight: 500;
	letter-spacing: 0.06em;
}

section#fv .fv-header ul.fv-menu a {
	color: #151515;
}

section#fv .fv-title {
	position: absolute;
	top: 26.75vw;
	left: 16.25vw;
	font-size: 2.375vw;
	font-weight: bold;
	letter-spacing: 0.16em;
	color: white;
}

section#fv .fv-sub-title {
	position: absolute;
	top: 32.344vw;
	left: 20.994vw;
	font-size: 1.5vw;
	font-weight: 500;
	letter-spacing: 0.1em;
	color: #151515;
}

section#fv .fv-back01 {
	position: absolute;
	top: 25.46vw;
	left: 11.063vw;
	width: 34.75vw;
	height: 6.13vw;
	background-image: url('../image/top/fv-back01.png');
	background-size: contain;
	opacity: 0.7;
}

section#fv .fv-back02 {
	position: absolute;
	top: 31.6vw;
	left: 17.769vw;
	width: 25.92vw;
	height: 3.89vw;
	background-image: url('../image/top/fv-back02.png');
	background-size: contain;
}

section#main {
	width: 100vw;
	height: 168.063vw;
	position: relative;
}

section#main div.bg01 {
	width: 100vw;
	height: 21.063vw;
	position: absolute;
	top: 94.75vw;
	left: 0;
}

section#main div.bg02 {
	width: 100vw;
	height: 14.75vw;
	position: absolute;
	top: 153.313vw;
	left: 0;
}

section#main div.box01 {
	width: 22.625vw;
	height: 36.438vw;
	position: absolute;
	top: 6.125vw;
	left: 15vw;
	background-image: url('../image/top/box01.png');
	background-size: contain;
}

section#main div.box02 {
	width: 23.125vw;
	height: 17.875vw;
	position: absolute;
	top: 6.125vw;
	left: 38.188vw;
	background-image: url('../image/top/box02.png');
	background-size: contain;
}

section#main div.box03 {
	width: 23.125vw;
	height: 17.875vw;
	position: absolute;
	top: 6.125vw;
	left: 61.875vw;
	background-image: url('../image/top/box03.png');
	background-size: contain;
}

section#main div.box04 {
	width: 23.125vw;
	height: 17.875vw;
	position: absolute;
	top: 24.688vw;
	left: 38.188vw;
	background-image: url('../image/top/box04.png');
	background-size: contain;
}

section#main div.box05 {
	width: 23.125vw;
	height: 17.875vw;
	position: absolute;
	top: 24.688vw;
	left: 61.875vw;
	background-image: url('../image/top/box05.png');
	background-size: contain;
}

section#main div.box .line {
	border-right: 3px solid white;
	height: 6.125vw;
	width: 0.063vw;
	position: absolute;
	top: 0;
	left: 2.063vw;
}

section#main div.box .en {
	color: white;
	position: absolute;
	top: 1.5vw;
	left: 3.5vw;
	letter-spacing: 0.05em;
	font-size: 1.375vw;
}

section#main div.box .name {
	color: white;
	position: absolute;
	top: 3.75vw;
	left: 3.5vw;
	font-size: 1.875vw;
	font-weight: bold;
	letter-spacing: 0.18em;
}

section#main .link {
	border: 2px solid white;
	border-radius: 1.563vw;
	width: 3.125vw;
	height: 3.125vw;
	position: absolute;
	top: 1.5vw;
	right: 1.563vw;
	color: white;
	font-size: 1.75vw;
	padding-left: 0.625vw;
	padding-top: 0.125vw;
}

section#main h2.title01 {
	background-image: none;
	position: absolute;
	top: 44.375vw;
	left: 43.125vw;
	width: 39.313vw;
	height: 13.875vw;
	color: rgba(25, 155, 2, 0.3);
	letter-spacing: 0.05em;
	font-size: 9.375vw;
	font-weight: 500;
	padding: 0;
}

section#main h2.title02 {
	background-image: none;
	position: absolute;
	top: 88.188vw;
	left: 14.5vw;
	width: 20vw;
	height: 13.875vw;
	color: rgba(25, 155, 2, 0.3);
	letter-spacing: 0.05em;
	font-size: 9.375vw;
	font-weight: 500;
	padding: 0;
}

section#main .business {
	width: 70vw;
	height: 30.625vw;
	position: absolute;
	top: 55.125vw;
	left: 15vw;
	background-image: url('../image/top/business-bg.png');
	background-size: contain;
}

section#main .business .box {
	width: 25.688vw;
	height: 24.813vw;
	background: rgba(255, 255, 255, 0.9);
	margin-top: 3.438vw;
	margin-left: 1.25vw;
	position: relative;
	padding-top: 16.188vw;
}

section#main .business .box .line {
	position: absolute;
	top: 0;
	left: 3.063vw;
	border-right: 3px solid #199B02;
	height: 7.375vw;
}

section#main .business .box .name {
	position: absolute;
	top: 4.188vw;
	left: 4.75vw;
	color: #199B02;
	font-size: 2.375vw;
	font-weight: bold;
	letter-spacing: 0.2em;
}

section#main .business .box .text {
	position: absolute;
	top: 9.375vw;
	left: 4.75vw;
	font-size: 1.375vw;
	font-weight: 500;
	letter-spacing: 0.06em;
	line-height: 1.636;
}

section#main .business .box .btn {
	margin: 0 auto 0;
}

section#main .case {
	width: 70vw;
	height: 32.75vw;
	position: absolute;
	top: 99.063vw;
	left: 15vw;
	background-image: url('../image/top/case-bg.png');
	background-size: contain;
	position: relative;
	padding-top: 20.625vw;
}

section#main .case .title {
	position: absolute;
	top: 8.5vw;
	left: 29.563vw;
	font-size: 2.375vw;
	font-weight: bold;
	color: white;
	letter-spacing: 0.2em;
	text-shadow: 3px 3px 8px rgba(80, 80, 80, 0.75);
}

section#main .case .text {
	position: absolute;
	top: 13.625vw;
	left: 28.5vw;
	font-size: 1.375vw;
	font-weight: 500;
	color: white;
	text-shadow: 3px 3px 8px rgba(80, 80, 80, 0.75);
	text-align: center;
	line-height: 1.636;
	letter-spacing: 0.06em;
}

section#main .case .btn {
	margin: 0 auto 0;
}

section#main .news {
	border: 2px solid #1F9B13;
	background: white;
	width: 44.188vw;
	height: 21vw;
	position: absolute;
	top: 138.813vw;
	left: 15vw;
}

section#main .news .line {
	height: 6.063vw;
	position: absolute;
	top: 0;
	left: 1.875vw;
	border-right: 3px solid #1F9B13;
}

section#main .news .en {
	position: absolute;
	font-size: 1.375vw;
	top: 1.438vw;
	left: 3.313vw;
	color: #1F9B13;
	font-weight: 500;
	letter-spacing: 0.05em;
}

section#main .news .name {
	position: absolute;
	top: 3.688vw;
	left: 3.313vw;
	font-size: 1.875vw;
	font-weight: bold;
	letter-spacing: 0.18em;
}

section#main .news .row {
	height: 2.826vw;
	width: 36.938vw;
	display: flex;
	align-items: center;
}

section#main .news .row1 {
	position: absolute;
	top: 9.744vw;
	left: 3.281vw;
}

section#main .news .row2 {
	position: absolute;
	top: 14.056vw;
	left: 3.281vw;
}

section#main .news .row .date {
	color: #199B02;
	font-size: 1.25vw;
	font-weight: 500;
	width: 8.313vw;
	height: 2.826vw;
	border-right: 1px solid #151515;
	display: flex;
	align-items: center;
}

section#main .news .row .text {
	width: 28.625vw;
	margin-left: 1.812vw;
	font-size: 1.125vw;
	font-weight: 500;
}

section#main .contact {
	width: 24vw;
	height: 21vw;
	position: absolute;
	top: 138.813vw;
	left: 61vw;
	background: #199B02;
}

section#main .contact .line {
	border-right: 3px solid white;
	height: 6.063vw;
	position: absolute;
	top: 0;
	left: 1.938vw;
}

section#main .contact .en {
	font-size: 1.375vw;
	color: white;
	position: absolute;
	top: 1.438vw;
	left: 3.438vw;
	letter-spacing: 0.05em
}

section#main .contact .name {
	position: absolute;
	top: 3.688vw;
	left: 3.438vw;
	color: white;
	font-size: 1.875vw;
	font-weight: bold;
	letter-spacing: 0.18em;
}

section#main .contact .tel_btn {
	font-family: 'Noto Sans JP', sans-serif;
	width: 19.688vw;
	height: 4.891vw;
	position: absolute;
	top: 8.275vw;
	left: 2.125vw;
	color: white;
	font-size: 1.875vw;
	font-weight: bold;
	padding-left: 5.156vw;
	padding-top: 0.963vw;
	background-image: url('../image/top/tel_btn.png');
	background-size: contain;
	white-space: nowrap;
	
	padding-top: 1vw;
}

section#main .contact .contact_btn {
	width: 19.688vw;
	height: 4.891vw;
	position: absolute;
	top: 14.056vw;
	left: 2.125vw;
	color: white;
	font-size: 1.25vw;
	font-weight: bold;
	padding-left: 5.344vw;
	padding-top: 1.525vw;
	background-image: url('../image/top/contact_btn.png');
	background-size: contain;

}

section#main .message {
	position: absolute;
	top: 162.375vw;
	left: 28.056vw;
	font-size: 1.375vw;
	font-weight: 500;
	letter-spacing: 0.02em;
}

@media screen and (max-width: 780px) {
	main {
		padding-top: 0;
	}
	
	header.header {
		display: block;
	}
	
	.btn {
		width: 16.188vw;
		height: 3.75vw;
		background: #199B02;
		display: flex;
		justify-content: center;
		align-items: center;
		color: white;
		font-size: 1.25vw;
		font-weight: 500;
		letter-spacing: 0.12em;
		position: relative;

		font-size: 4.8vw;
		width: 46vw;
		height: 6.95vw;
	}
	
	.btn::after {
		position: absolute;
		top: 0vw;
		right: 1.269vw;
		content: '>';
		font-size: 1.25vw;
		font-size: 4vw;
	}
	
	section#fv {
		width: 100vw;
		height: 53.125vw;
		background: url('../image/top/fv-bg.png');
		background-size: cover;
		padding-top: 1.563vw;
	}
	
	section#fv .fv-header {
		display: none;
	}
	
	section#fv .fv-title {
		position: absolute;
		top: 26.75vw;
		left: 16.25vw;
		font-size: 2.375vw;
		font-weight: bold;
		letter-spacing: 0.16em;
		color: white;

		font-size: 5vw;
		top: 28vw;
		left: 20vw;
	}
	
	section#fv .fv-sub-title {
		position: absolute;
		top: 32.344vw;
		left: 20.994vw;
		font-size: 1.5vw;
		font-weight: 500;
		letter-spacing: 0.1em;
		color: #151515;

		top: 40.5vw;
		left: 30vw;
		font-size: 3vw;
	}

	section#fv .fv-back01 {
		position: absolute;
		top: 25.46vw;
		left: 11.063vw;
		width: 34.75vw;
		height: 6.13vw;
		background-image: url('../image/top/fv-back01.png');
		background-size: contain;
		opacity: 0.7;

		width: 69.5vw;
		height: 12.26vw;
	}

	section#fv .fv-back02 {
		position: absolute;
		top: 31.6vw;
		left: 17.769vw;
		width: 25.92vw;
		height: 3.89vw;
		background-image: url('../image/top/fv-back02.png');
		background-size: contain;

		top: 39vw;
		left: 23vw;
		width: 51.84vw;
		height: 7.78vw;

	}
	
	section#main {
		width: 100vw;
		height: 168.063vw;
		position: relative;

		height: 860vw;
	}
	
	section#main div.bg01 {
		width: 100vw;
		height: 21.063vw;
		position: absolute;
		top: 94.75vw;
		left: 0;

		top: 520vw;
	}
	
	section#main div.bg02 {
		width: 100vw;
		position: absolute;
		top: 820vw;
		left: 0;
		height: 40vw;
	}
	
	section#main div.box01 {
		position: absolute;
		background-image: url('../image/top/box01.png');
		top: 10vw;
		left: 5.34vw;
		width: 89.33vw;
		height: 71.93vw;
		background-size: cover;
	}
	
	section#main div.box02 {
		width: 23.125vw;
		height: 17.875vw;
		position: absolute;
		top: 6.125vw;
		left: 38.188vw;
		background-image: url('../image/top/box02.png');
		background-size: contain;

		top: 90vw;
		left: 5.34vw;
		width: 89.33vw;
		height: 71.93vw;
	}
	
	section#main div.box03 {
		position: absolute;
		background-image: url('../image/top/box03.png');
		background-size: contain;

		top: 170vw;
		left: 5.34vw;
		width: 89.33vw;
		height: 71.93vw;
	}
	
	section#main div.box04 {
		position: absolute;
		background-image: url('../image/top/box04.png');
		background-size: contain;
		top: 250vw;
		left: 5.34vw;
		width: 89.33vw;
		height: 71.93vw;
	}
	
	section#main div.box05 {
		position: absolute;
		background-image: url('../image/top/box05.png');
		background-size: contain;

		top: 330vw;
		left: 5.34vw;
		width: 89.33vw;
		height: 71.93vw;
	}
	
	section#main div.box .line {
		border-right: 3px solid white;
		position: absolute;
		top: 0;
		left: 7.97vw;
		height: 24.72vw;
	}
	
	section#main div.box .en {
		color: white;
		position: absolute;
		top: 1.5vw;
		left: 3.5vw;
		letter-spacing: 0.05em;
		font-size: 1.375vw;

		left: 16vw;
		font-size: 6vw;
	}
	
	section#main div.box .name {
		color: white;
		position: absolute;
		font-weight: bold;
		letter-spacing: 0.18em;
		top: 10vw;
		left: 16vw;
		font-size: 10vw;
	}
	
	section#main .link {
		border: 2px solid white;
		position: absolute;
		color: white;
		padding-left: 3vw;
		padding-top: 0vw;
		font-size: 10vw;
		top: 5vw;
		right: 3vw;
		width: 16vw;
		height: 16vw;
		border-radius: 8vw;
	}
	
	section#main h2.title01 {
		background-image: none;
		position: absolute;
		top: 44.375vw;
		left: 43.125vw;
		width: 39.313vw;
		height: 13.875vw;
		color: rgba(25, 155, 2, 0.3);
		letter-spacing: 0.05em;
		font-size: 9.375vw;
		font-weight: 500;
		padding: 0;

		font-size: 22vw;
		top: 410vw;
		left: 0;
	}
	
	section#main h2.title02 {
		background-image: none;
		position: absolute;
		top: 88.188vw;
		left: 14.5vw;
		width: 20vw;
		height: 13.875vw;
		color: rgba(25, 155, 2, 0.3);
		letter-spacing: 0.05em;
		font-size: 9.375vw;
		font-weight: 500;
		padding: 0;

		font-size: 22vw;
		top: 500vw;
		left: 0;
	}
	
	section#main .business {
		width: 70vw;
		height: 30.625vw;
		position: absolute;
		top: 55.125vw;
		left: 15vw;
		background-image: url('../image/top/business-bg.png');
		background-size: contain;

		width: 100vw;
		height: 43.75vw;
		top: 445vw;
		left: 0;
	}
	
	section#main .business .box {
		width: 25.688vw;
		height: 24.813vw;
		background: rgba(255, 255, 255, 0.9);
		margin-top: 3.438vw;
		margin-left: 1.25vw;
		position: relative;
		padding-top: 16.188vw;

		margin: 3.4vw auto 0;
		width: 38.532vw;
		height: 37.22vw;

		width: 60vw;
	}
	
	section#main .business .box .line {
		position: absolute;
		top: 0;
		left: 3.063vw;
		border-right: 3px solid #199B02;
		height: 7.375vw;

		left: 5vw;
		height: 10vw;
	}
	
	section#main .business .box .name {
		position: absolute;
		top: 4.188vw;
		left: 4.75vw;
		color: #199B02;
		font-size: 2.375vw;
		font-weight: bold;
		letter-spacing: 0.2em;

		font-size: 4vw;
		left: 10vw;
	}
	
	section#main .business .box .text {
		position: absolute;
		top: 9.375vw;
		left: 4.75vw;
		font-size: 1.375vw;
		font-weight: 500;
		letter-spacing: 0.06em;
		line-height: 1.636;

		font-size: 3.5vw;
		top: 13vw;
	}
	
	section#main .business .box .btn {
		margin: 12vw auto 0;
	}
	
	section#main .case {
		position: absolute;
		background-image: url('../image/top/case-bg.png');
		background-size: contain;
		position: relative;
		padding-top: 27vw;
		top: 540vw;
		left: 0;
		width: 100vw;
		height: 46.79vw;
	}
	
	section#main .case .title {
		position: absolute;
		top: 6vw;
		font-weight: bold;
		color: white;
		letter-spacing: 0.2em;
		text-shadow: 3px 3px 8px rgba(80, 80, 80, 0.75);
		font-size: 6vw;
		left: 36vw;
	}
	
	section#main .case .text {
		position: absolute;
		font-weight: 500;
		color: white;
		text-shadow: 3px 3px 8px rgba(80, 80, 80, 0.75);
		text-align: center;
		line-height: 1.636;
		letter-spacing: 0.06em;
		font-size: 4vw;
		top: 16vw;
		left: 30vw;
	}	
	
	section#main .case .btn {
		margin: 9vw auto 0;
	}
	
	section#main .news {
		border: 2px solid #1F9B13;
		background: white;
		position: absolute;
		width: 89.33vw;
		height: 42.45vw;
		top: 600vw;
		left: 5.335vw;

		height: 120vw;
	}
	
	section#main .news .line {
		position: absolute;
		border-right: 3px solid #1F9B13;
		top: 0;
		left: 6vw;
		height: 18vw;
	}
	
	section#main .news .en {
		font-size: 4.4vw;
		position: absolute;
		color: #1F9B13;
		font-weight: 500;
		letter-spacing: 0.05em;

		top: 3vw;
		left: 12vw;
	}
	
	section#main .news .name {
		position: absolute;
		top: 3.688vw;
		left: 3.313vw;
		font-size: 1.875vw;
		font-weight: bold;
		letter-spacing: 0.18em;

		top: 10vw;
		left: 12vw;
		font-size: 6vw;
	}
	
	section#main .news .row {
		display: none;
		display: flex;
		align-items: center;
		flex-direction: column;
		width: 79vw;
		height: unset;
	}
	
	section#main .news .row1 {
		position: absolute;
		top: 25vw;
		left: 8vw;
		
	}
	
	section#main .news .row2 {
		position: absolute;
		top: 80vw;
		left: 8vw;
	}
	
	section#main .news .row .date {
		color: #199B02;
		font-weight: 500;
		height: 2.826vw;
		display: flex;
		align-items: center;
		font-size: 6vw;
		border-right: none;
		width: 100%;
	}
	
	section#main .news .row .text {
		margin-left: 1.812vw;
		font-weight: 500;
		margin-top: 6vw;
		font-size: 6vw;
		width: 100%;
	}
	
	section#main .contact {
		width: 24vw;
		height: 21vw;
		position: absolute;
		top: 138.813vw;
		left: 61vw;
		background: #199B02;

		top: 730vw;
		left: 5.335vw;
		width: 89.33vw;
		height: 78.16vw;
	}
	
	section#main .contact .line {
		border-right: 3px solid white;
		height: 6.063vw;
		position: absolute;
		top: 0;
		left: 1.938vw;

		top: 0;
		left: 6vw;
		height: 18vw;
	}
	
	section#main .contact .en {
		font-size: 4.4vw;
		color: white;
		position: absolute;
		top: 1.438vw;
		left: 3.438vw;
		letter-spacing: 0.05em;

		top: 3vw;
		left: 12vw;
	}
	
	section#main .contact .name {
		position: absolute;
		top: 3.688vw;
		left: 3.438vw;
		color: white;
		font-size: 1.875vw;
		font-weight: bold;
		letter-spacing: 0.18em;

		top: 10vw;
		left: 12vw;
		font-size: 6vw;
	}
	
	section#main .contact .tel_btn {
		width: 19.688vw;
		height: 4.891vw;
		position: absolute;
		top: 8.275vw;
		left: 2.125vw;
		color: white;
		font-size: 1.875vw;
		font-weight: bold;
		padding-left: 5.156vw;
		padding-top: 0.963vw;
		background-image: url('../image/top/tel_btn.png');
		background-size: cover;

		top: 26vw;
		left: 5vw;
		width: 80vw;
		height: 19.87vw;
		padding-top: 6vw;
		padding-left: 20vw;
		font-size: 5vw;
	}
	
	section#main .contact .contact_btn {
		position: absolute;
		color: white;
		font-size: 1.25vw;
		font-weight: bold;
		padding-left: 5.344vw;
		padding-top: 1.525vw;
		background-image: url('../image/top/contact_btn.png');
		background-size: cover;

		padding-top: 6vw;
		padding-left: 20vw;
		font-size: 5vw;
		top: 52vw;
		left: 5vw;
		width: 80vw;
		height: 19.87vw;
	}
	
	section#main .message {
		position: absolute;
		top: 162.375vw;
		left: 28.056vw;
		font-size: 1.375vw;
		font-weight: 500;
		letter-spacing: 0.02em;

		line-height: 1.5;
		font-size: 5vw;
		top: 832vw;
		left: 10vw;

	}

}