@charset "utf-8";

.below-visual {
	padding: 30px 0 0;
	background-color: #EBEBEB;
}

.below-visual .lead {
	text-align: center;
	font-size: 22px;
}

@media screen and (max-width:740px) {
	.below-visual {
		padding: 20px 0 0;
	}

	.below-visual .lead {
		font-size: 16px;
		line-height: 1.625;
		font-weight: normal;
	}
}

@media screen and (max-width:340px) {
	.below-visual .lead {
		font-size: 15px;
	}
}

/* -------------------------------------------------
	.cont-nav
------------------------------------------------- */

.cont-nav.mc {
	padding-top: 130px;
	margin: -70px 0 0;
	position: relative;
	z-index: 10;
}
.cont-nav.pas {
	padding-top: 130px;
	padding-bottom: 40px;
	/*padding-bottom: 104px;*/
	margin: -65px 0 0;
	position: relative;
	z-index: 5;
}

.cont-nav .headline {
	padding: 0 0 15px 140px;
	font-weight: bold;
	border-bottom: solid 5px #8AA5E8;
	position: relative;
}
.cont-nav.pas .headline {
	border-bottom: solid 5px #66BA89;
}
.cont-nav .headline img {
	display: inline-block;
	position: absolute;
	left: 0;
	bottom: 6px;
}
.cont-nav.mc .headline img {
	width: 116px;
}
.cont-nav.pas .headline img {
	width: 120px;
}
.cont-nav .headline .large {
	font-size: 24px;
	vertical-align: baseline;
	display: inline-block;
}
.cont-nav .headline .small {
	font-size: 20px;
	vertical-align: baseline;
	display: inline-block;
}

@media screen and (max-width:740px) {
	.cont-nav.mc {
		padding-top: 80px;
		margin: -30px 0 0;
	}
	.cont-nav.pas {
		padding-top: 80px;
		padding-bottom: 30px;
		margin: -10px 0 0;
	}
	
	.cont-nav .headline {
		padding: 0 5% 10px calc(5% + 100px);
	}
	.cont-nav .headline img {
		left: 5%;
		bottom: 10px;
	}
	.cont-nav.mc .headline img {
		width: 87px;
	}
	.cont-nav.pas .headline img {
		width: 87px;
	}
	.cont-nav .headline .large {
		font-size: 20px;
		display: block;
	}
	.cont-nav .headline .small {
		margin-top: 0.1em;
		font-size: 16px;
		display: block;
	}
}

/* -------------------------------------------------
	.btn-wrap
------------------------------------------------- */

.btn-wrap {
	text-align: right;
}
.btn-wrap .btn-type1 {
	display: inline-flex;
	align-items: center;
	position: relative;
}

@media print, screen and (min-width:741px) {
	.btn-wrap {
		height: 20px;
	}
	.btn-wrap .btn-type1 {
		position: relative;
		top: -61px;
	}
}

@media screen and (max-width:740px) {
	.btn-wrap {
		padding: 18px 0;
	}
}

/* -------------------------------------------------
	.cont-nav .conts
------------------------------------------------- */

.cont-nav .conts {
	display: flex;
	flex-wrap: wrap;
}
.cont-nav .conts a {
	padding: 1px;
	display: block;
	background: #fff;
	color: #2C2C2C;
	box-sizing: border-box;
}
.cont-nav .conts a .texts {
	padding: 13px 4% 10px;
}
.cont-nav .conts a .texts .text1 {
	font-weight: bold;
	line-height: 1.4;
	font-size: 18px;
}
.cont-nav .conts a .texts .text2 {
	margin-top: 0.3em;
	font-weight: bold;
	line-height: 1;
	font-size: 15px;
}

@media print, screen and (min-width:741px) {
	.cont-nav .conts a {
		width: calc(238 / 1000 * 100%);
		margin-right: calc(16 / 1000 * 100%);
	}
	.cont-nav .conts a:nth-child(4n) {
		margin-right: 0;
	}
	.cont-nav .conts a > * {
		transition: opacity 0.2s ease-out;
	}
	.cont-nav .conts a:hover > * {
		opacity: 0.6;
	}
	
	.cont-nav .conts a .texts .text1.ib {
		display: inline-block;
		vertical-align: baseline;
	}
	.cont-nav .conts a .texts .text2.ib {
		display: inline-block;
		vertical-align: baseline;
	}
}

@media screen and (max-width:740px) {
	.cont-nav .conts {
		justify-content: space-between;
	}
	.cont-nav .conts a {
		width: calc(164 / 338 * 100%);
	}
	.cont-nav .conts a:nth-child(2) ~ a {
		margin-top: 33px;
	}
	.cont-nav .conts a .texts .text1 {
		font-size: 16px;
	}
	.cont-nav .conts a .texts .text2 {
		font-size: 14px;
	}
}

/* -------------------------------------------------
	#contact-area
------------------------------------------------- */

#contact-area {
	border-top: solid 6px #fff;
}

p.caution{
font-size: 14px;
text-align: right;
padding-bottom: 20px;
}

@media screen and (max-width:740px) {
p.caution{
font-size: 14px;
text-align: left;
padding: 0 25px 30px;
}
}