
/* --------------------------------------------------- */
#mainvisual {
	width: 100%;
	position: relative;
	height: 100vh;
	margin-bottom: 60px;
	background: url("../images/common/mv-back.png") no-repeat center;
	background-size: 160%;
	background-color: #3467A8;
}
#mainvisual canvas {
  position: absolute;
  bottom: -1px;
  left: 0;
	width: 100%;
	height: 200px;
	z-index: 0;
	z-index: 2;
}
#mainvisual .waveCanvas {
}
#mainvisual .img {
	position: absolute;
	z-index: 0;
	width: 40%;
	right: 1%;
	top: 50%;
	transform: translate(0%, -50%);
}
#mainvisual .ttl {
	position: absolute;
	z-index: 1;
	left: 5%;
	width: 65%;
	top: 43%;
	transform: translate(0%, -50%) rotate(-12deg);
}
@media screen and (max-width: 828px) {
	#mainvisual {
		height: 700px;
		margin-bottom: 0px;
	}
	#mainvisual canvas {
		height: 150px;
	}
}
@media screen and (max-width: 680px) {
	#mainvisual {
		height: 550px;
	}
	#mainvisual canvas {
		height: 100px;
	}
	#mainvisual .img {
        width: 90%;
        right: 5%;
        top: auto;
		bottom: 50px;
        transform: translate(0%, 0%);
    }
    #mainvisual .ttl {
        width: 90%;
        top: 120px;
        transform: translate(0%, -50%) rotate(-12deg);
    }
}
/* --------------------------------------------------- */
#area1 {
	max-width: 1700px;
	width: 100%;
	margin: 0 auto 100px;
	position: relative;
	padding: 100px 0;
}
#area1 .img1 {
	position: absolute;
	z-index: 0;
	max-width: 480px;
	width: 50%;
	left: -5%;
	bottom: 0;
}
#area1 .img2 {
	position: absolute;
	z-index: 0;
	max-width: 360px;
	width: 30%;
	right: -5%;
	top: 0;
}
#area1 .inner {
	width: 90%;
	margin: 0 auto;
	text-align: center;
	position: relative;
	z-index: 1;
	margin: 0 auto;
}
#area1 .ttl1 {
	text-align: center;
	font-size: 1.2em;
	font-weight: 600;
	color: #3467A8;
	margin-bottom: 30px;
}
#area1 .ttl1 span {
	display: block;
	text-align: center;
	font-size: 1.8em;
	margin-bottom: 20px;
	font-weight: 700;
	letter-spacing: 3px;
}
#area1 .ttl2 {
	text-align: center;
	font-size: 1.3em;
	font-weight: 600;
	color: #3467A8;
	margin-bottom: 40px;
}
#area1 p {
	text-align: center;
	margin-bottom: 30px;
}
#area1 .btn-style01 {
	margin: 0 auto;
	transition: .3s;
}
@media screen and (max-width: 828px) {
	#area1 {
        padding: 20px 0;
		margin-bottom: 80px;
    }
	#area1 .inner {
		padding: 5%;
		background-color: rgba(255,255,255,.7);
	}
	#area1 .ttl1 {
		text-align: left;
	}
	#area1 .ttl1 br,
	#area1 .ttl2 br {
		display: none;
	}
	#area1 .ttl1 span {
	}
	#area1 .ttl2 {
		text-align: left;
	}
	#area1 p {
		text-align: left;
	}
}
@media screen and (max-width: 680px) {
	#area1 {
        padding: 0px 0 20px;
		margin-bottom: 40px;
    }
	#area1 .inner {
		width: 95%;
	}
	#area1 .ttl1 {
        font-size: 1em;
        margin-bottom: 20px;
    }
    #area1 .ttl1 span {
        font-size: 1.5em;
        margin-bottom: 10px;
    }
	#area1 .ttl2 {
        font-size: 1.1em;
    }
	#area1 p {
        margin-bottom: 20px;
    }
}
/* --------------------------------------------------- */
#area2 {
	max-width: 1800px;
	width: 100%;
	margin: 0 auto 80px;
}
#area2 .ttl-style01 {
	max-width: 1500px;
	width: 90%;
	margin: 0 auto 40px;
}
#area2 .block {
	margin-bottom: 60px;
	position: relative;
}
#area2 .block .ph {
	display: block;
	height: 700px;
	width: 55%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
#area2 .block .ph-r {
	margin: 0 0 0 auto;
	background-image:  url("../images/top/ph01.jpg");
	border-radius: 500px 0 0 500px;
}
#area2 .block .ph-l {
	margin: 0 auto 0 0;
	background-image:  url("../images/top/ph02.jpg");
	border-radius: 0 500px 500px 0;
}
#area2 .block .box {
	width: 60%;
	background-color: #fff;
	border-radius: 400px;
	position: absolute;
	bottom: 0;
	padding: 5% 10%;
	transition-delay: .2s;
}
#area2 .block .box-l {
	left: 0;
}
#area2 .block .box-r {
	right: 0;
}
#area2 .block .box .ttl {
	position: relative;
	z-index: 1;
	color: #3467A8;
	font-size: 1.7em;
	font-weight: 700;
}
#area2 .block .box p {
	position: relative;
	z-index: 1;
	max-width: 420px;
	width: 90%;
	margin-bottom: 30px;
	padding: 10px 0;
	background-color: rgba(255,255,255,.7);
}
#area2 .block .img1 {
	max-width: 530px;
	width: 52%;
	position: absolute;
	z-index: 0;
	left: 15%;
	top: 0;
	margin-top: -200px;
}
#area2 .block .img2 {
	max-width: 390px;
	position: absolute;
	width: 45%;
	z-index: 0;
	right: 2%;
	top: -100px;
}
#area2 .block .box .btn-style01 {
	position: relative;
	z-index: 1;
}
@media screen and (max-width: 828px) {
	#area2 {
        margin: 0 auto 40px;
    }
	#area2 .block {
        margin-bottom: 50px;
		height: 700px;
    }
    #area2 .block .ph {
        height: 500px;
    }
	#area2 .block .box {
        width: 75%;
        border-radius: 100px;
        padding: 5% 10% 5% 7%;
    }
	#area2 .block .box .ttl {
        font-size: 1.5em;
    }
	#area2 .block .img1 {
        width: 52%;
        margin-top: -180px;
    }
    #area2 .block .img2 {
        max-width: 350px;
		width: 40%;
    }
}
@media screen and (max-width: 680px) {
	#area2 {
        margin: 0 auto 20px;
    }
	#area2 .block {
		height: auto;
        margin-bottom: 50px;
    }
    #area2 .block .ph {
        height: 200px;
        width: 97%;
    }
    #area2 .block .box {
        width: 100%;
        border-radius: 20px;
        position: relative;
        padding: 30px 7% 0;
		margin-top: -20px;
    }
    #area2 .block .box .ttl {
        font-size: 1.4em;
		margin-bottom: 15px;
    }
    #area2 .block .box p {
        max-width: none;
        width: 100%;
        margin: 0 auto 30px;
        padding: 0;
    }
    #area2 .block .img1,
    #area2 .block .img2 {
		display: none;
    }
	#area2 .block .box .btn-style01 {
		margin: 0 auto;
	}
}
/* --------------------------------------------------- */

@media screen and (max-width: 828px) {
}
@media screen and (max-width: 680px) {
}
/* --------------------------------------------------- */