.line-area{
	text-align: center;
}
.topics-area{
	background:#feecec;
	color:#ff156c;
	
}
.topics-area span{
	position: absolute;
    width: 22px;
    top: -22px;
    left: -28px;
}
.topics-area ul{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 10px 0;
}
.topics-area li{
	line-height: 1.5;
	font-size: 22px;
	position: relative;
}
.topics-area li:first-child{
	text-align: center;

}
.topics-area li:last-child{
	border-left:1px solid #ff156c;
	padding-left: 20px;
	margin-left: 20px;
}
.topics-area li b{
	font-size:120%;
}
.topics-area li a{
	color: #ff156c;
}
body{
	font-family: "Hiragino Kaku Gothic ProN","メイリオ", sans-serif;
}
ul,li{
	list-style: none;
}
.wrapper{
	width: 1100px;
	margin-left: auto;
	margin-right: auto;
}

.block-flex{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-wrap: wrap;
}
.red{
	color:#cc0000;
}

.align-center{
	text-align: center;
}
.align-right{
	text-align: right;
}

header .logo{
	text-align: center;
	line-height: 0;
	width: 300px;
}
header .block-flex{
	justify-content: space-between;
	align-items: center;
	padding: 20px 0;
	line-height: 0;
}

.area-service{
	padding: 80px 0;
	background: #f5f5f5;
}

.area-service dl{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
}
.area-service dl.rev{
	flex-direction: row-reverse;
}
.area-service dt{
	line-height: 0;
}
.area-service dd{
	background: #74a3e3;
	color: #fff;
	text-align: center;
	width: 550px;
	    padding-top: 80px;

	
}
.area-service dd p{
	font-size: 35px;
	margin-bottom: 10px;
}
.area-service dd span{
	display: block;
}
.area-area{
	padding: 80px 0;
}
.area-area p{
	font-size: 75px;
	font-weight: bold;
	color: #ff6400;
}
.area-area .map{
	text-align: center;
}
h1{
	text-align: center;
	color: #000;
	padding: 25px 0;
	font-size: 34px;
	position: relative;
}
h1:after{
	/*content:"";
	background:url(../img/arrow01.png) no-repeat;
	*/
	width: 80px;
	height: 40px;
	margin:0 auto;
	position: absolute;
    bottom: -39px;
    right: 0;
    left: 0;
}
h1 b{
	font-size: 130%;
	
}
h1 small{
	display: block;
}
.area01{
	text-align: center;
	background: #c8ebfa;
	line-height: 0;
}
.cv .container{
	background: #ffebeb;
} 
.cv .wrapper{
	position: relative;
	text-align: center;
	padding: 60px 0;
}
.cv .icon{
	position: absolute;
	bottom: 160px;
    right: -10px;
}
.cv .subttl{
	display: block;
	font-size: 35px;
	margin: 30px 0;
}
.ttl{
	text-align: center;
}
.ttl h2{
color: #003b8c;
font-size: 40px;
text-align: center;
margin-bottom: 30px;
line-height: 1;
}
.ttl h2 span{
	display: inline-block;
    color: #999;
    font-size: 16px;
    width: 250px;
    padding-top: 20px;
    border-top: 1px solid #003b8c;
    margin-top: 15px;
    font-weight: normal;
}
.area03{
		background:#e8f5ff;
}
.area03 .container{
	

	text-align: center;
	padding: 80px 0 70px;
}
.area03 .block{
	margin: 50px 0 0;
}
.area03 .price{
	margin: 20px 0 0;
	line-height: 0;
}
.area03 .map{
	padding: 20px 0 0;
	background: #fff;
}
.area03 h4{
	text-align: center;
	color: #ff6c00;
	margin-bottom: 10px;
}
.area04{
	padding: 60px 0;
	text-align: center;
}

.area05{
	background: #e4e3e9;
	padding:0 0 40px 0;
}
.area05 h2{
	color: #303030;
}
.area05 dl{
	border-right:5px solid #d5d5d5;
	border-bottom:5px solid #d5d5d5;
	background: #fff;
	padding: 20px;
	color: #303030;
	margin-top: 30px;
	width: 70%;
}
.area05 dt{
	font-size: 30px;
	font-weight: bold;
}
.area05 dd{
	font-size: 20px;
}
.area05 .container{
	background:url(../img/pic03.png) no-repeat bottom right;
	padding: 30px 0;
}
.area06{
	text-align: center;
	padding: 50px 0;
	background: #74a3e3;
}
.area06 h2{
	color: #fff;
	
}
.area06 .ttl h2 span {
    color: #fff;

    border-top: 1px solid #fff;

}
.area06 img{
	margin: 15px 0;
}
.area06 p{
	font-weight: bold;
	margin-bottom: 40px;
}
h3{
color: #fff;
font-size: 35px;
text-align: center;
font-weight: normal;
margin-bottom: 20px;	
}
.area-summary h3{
	color: #000;
}
.area07{
	text-align: center;
	padding: 20px 0;
	background:url(../img/bg02.png) no-repeat;
	background-size:cover;
}


.cv2{
	background: #2bcaa6;
	text-align: center;
	padding: 40px 0;
	color: #fff;
}
.cv2 .btn{
	margin: 30px auto 20px;
}
.cv2 .txt{
	font-size: 13px;
}
.cv2 .subttl{
	display: block;
	font-size: 34px;
}
.cv2 .block-flex{
	justify-content: center;
	padding: 20px 0 0;
}

.cv2 .block-flex ul{
	font-weight: bold;
}
.cv2 .block-flex li{
	color: #fff000;
	    font-size: 22px;
}
.cv2 .block-flex .num{
	font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
	font-size: 50px;
}
.sticky{
	display: none;
}
.area-faq{
	padding:0 0 30px 0;
}
.area-faq dl {
    margin-bottom: 50px;
    text-align: center;
}
.area-faq dt {
    margin-bottom: 20px;
    text-align: left;
    font-weight: bold;
}
.area-faq span {
    position: relative;
    top: 8px;
    display: inline-block;
    width: 90%;
    padding-left: 15px;
}
.area-faq dd {
    text-align: left;
}
.area-faq dt i {
    font-size: 23px;
    font-style: normal;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    flex-flow: column wrap;
    vertical-align: top;
    width: 40px;
    height: 40px;
    margin: 0 auto;
    border: 1px solid #003b8c;
    color: #003b8c;
}
.area-faq dd i {
    font-size: 23px;
    font-style: normal;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    flex-flow: column wrap;
    vertical-align: top;
    width: 40px;
    height: 40px;
    margin: 0 auto;
    background: #003b8c;
    color: #fff;
}
.contact {
	padding:0 0 40px 0;
	background: #d3eaf0;
}
.contact .pic{
	line-height: 0;
	text-align: center;
}

.contact input[type="text"],
.contact textarea{
	background: #fff;
    margin-bottom: 10px;
    padding: 10px;
    color: #666;
    font-size: 1rem;
    border: 1px solid #ccc;
    width: 80%;
}
.contact textarea{
	height: 220px;
}
.contact .block-flex span{
	display: block;
	font-weight: bold;
	width: 20%;
	background: #ccc;
	padding: 11px;
	margin-bottom: 10px;
}
.contact sup{
	color: #f00;
	padding-right: 5px;
}
.contact input[type="submit"] {
    display: block;
    color: #FFFFFF;
    padding: 20px;
    text-align: center;
    background: #ff3c64;
    text-decoration: none;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    margin: 0 auto;
    border: 0;
    font-size: 1rem;
    width: 500px;
    margin:30px auto;
    cursor: pointer;
}

.contact #acc dt{
	cursor: pointer;
	font-size: 13px;
}
.contact #acc dd{
	display: none;
	font-size: 11px;
	color: #777;
	padding-top: 10px;
}
.contact #acc dd h5 {
    margin: 10px 0;
}
.contact #acc dd p {
    margin-bottom: 10px;
}
.contact .close{
	cursor:pointer;
	font-weight: bold;
	background: #020a3a;
	color: #fff;
	padding: 5px 10px;
	text-align: center;
	display: inline-block;
}
footer{
	font-size: 14px;
	padding: 20px 0;
	border-top:5px solid #003b8c;
}
footer .logo{
	width: 220px;
}
footer .block-flex{
	justify-content: space-between;
	align-items: center;
}
footer .address{
	margin:0 30px 0 auto;
}
footer .copy{
	text-align: center;
	display: block;
	padding-top: 10px;
}
.pc-only{
	display: block;
}
.sp-only{
	display: none;
}
img{
	max-width: 100%;
}
.area-voice dl{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	align-items: center;
	margin-bottom: 40px;
	text-align: left;
}
.area-voice dt{
	margin-right: 40px;
	width: 140px;
}
.area-voice dd{
	width: 860px;
	font-size: 14px;
}
.area-voice dd h3 {

    color: #3c6aa7;
    font-size: 25px;
    text-align: left;
    font-weight: normal;
    margin-bottom: 10px;
    border-bottom: 1px solid #3c6aa7;
    padding-bottom: 6px;
}
.area-voice{
	text-align: center;
    padding: 50px 0 30px 0;
}
@media screen and (max-width:770px){
img{
	width: 100%;
}	
.area-service dd {

    padding-top: 25px;
}
.wrapper {
    width: 720px;
}	
header .logo {
    text-align: center;
    line-height: 0;
    width: 30%;
}
header .btn{
	width: 50%;
}
.area01 .wrapper {
    width: auto;
}
.cv a{
	width: 90%;
	display: block;
}
.cv .icon {
    position: absolute;
    bottom: 130px;
    right: -10px;
    width: 150px;
}
.area04 .ttl span,
.area05 .ttl span{
	width: 40%;
	margin:0 auto;
	display: block;
}
.ttl h2{
	font-size: 50px;
}
.area05 .container {
    background: url(../img/pic03.png) no-repeat bottom right;
    background-size: 36% auto;
}
footer .copy {
    padding: 0 10px;
}
footer .logo{
	width: 25%;
}
}
@media screen and (max-width:700px){
.topics-area ul{
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 10px 0;
}
.topics-area li{
	line-height: 1.5;
	font-size: 12px;
}

.topics-area li:last-child{
	padding-left: 5px;
	margin-left: 5px;
	text-align: center;
}
.topics-area span {
    position: absolute;
    width: 22px;
    top: -39px;
    left: -10px;
}
header .logo {
    width: 50%;
}	
.pc-only{
	display: none;
}
.sp-only{
	display: block;
}	

.wrapper {
    width: 95%;
}
.ttl h2 {
    font-size: 25px;
    margin-bottom: 20px;
}
.cv .wrapper {
    position: relative;
    text-align: center;
    padding: 30px 0;
}
.cv .subttl {
    display: block;
    font-size: 19px;
    margin: 20px 0;
}
.cv .subttl {
    display: block;
    font-size: 20px;
    margin: 10px 0;
}
.cv .icon {
    position: absolute;
    bottom: 67px;
    right: -10px;
    width: 75px;
}
h1 {
	line-height: 1.3;
    padding: 10px;
    font-size: 22px;
}
h1:after {
	/*
    content: "";
    background: url(../img/arrow01.png) no-repeat;
    */
    background-size: 100% auto;
    width: 40px;

}
.area-service dl{
	flex-wrap: wrap;
}
.area-service dt{
	width: 100%;
}
.area-service dd{
	width: 100%;
	padding: 20px;
}
.area-service dd p {
    font-size: 25px;
    margin-bottom: 10px;
}
.area03 .container {
    padding: 10px 0 20px 0;
}
.area03 .block {
    margin: 15px 0 0;
}
.area-service {
    padding: 30px 0;
}

.area-area p {
    font-size: 33px;
}
.area04 {
    padding: 20px 0;
}
.area05 {
    padding: 0;
}
.area05 dl {
    padding: 10px;
    margin-top: 20px;
    width: 100%;
}
.area05 dt {
    font-size: 20px;
    font-weight: bold;
}
.area05 dd {
    font-size: 17px;
}
.area05 .container{
	background: none;
}
.area06 {
    padding: 20px 0;
}
.area06 img {
    margin: 5px 0;
}
.area06 p {
    margin-bottom: 20px;
}
.area07 {
    padding: 20px 0;
}
.area-faq {
    padding: 20px 0;
}
.area-faq dl {
    margin-bottom: 30px;
    text-align: center;
}
.area-faq span {

    width: 87%;
}
.cv2 .block-flex {
    padding: 0;
}
.cv2 .btn {
    margin: 10px auto 10px;
}
.cv2 {
    padding: 20px 0;
}
.cv2 .subttl {
    font-size: 18px;
}
.cv2 .block-flex .num {
    width: 90%;
    margin:0 auto;
}
.cv2 .block-flex ul {
    font-size: 13px;
    line-height: 1.5;
}

.contact input[type="submit"]{
	width: 100%;
}
footer .logo {
    width: 40%;
    margin: 0 auto;
}
footer .address {
    margin: 10px auto;
    width: 100%;
}
footer .txt{
    width: 100%;	
}
footer .copy{
	text-align: center;
	margin-top: 10px;
}
.contact .block-flex span {
    width: 100%;
    margin-bottom: 0;
}
.contact input[type="text"], .contact textarea {
    margin-bottom: 10px;
    width: 100%;
    padding: 15px;
    border-radius: 0;
}
header .btn {
    width: 45%;
}
.cv a {
    width: 95%;
    display: block;
    margin:0 auto;
}
h3 {
    font-size: 20px;
    margin-bottom: 10px;
    padding-bottom: 10px;
}
.sticky{
	display: block;
	position: fixed;
	bottom:0;
	width: 100%;
	background: rgba(0,60,140,.85);
	padding: 20px 10px;
}
.sticky .tel ul{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content: center;
	font-size: 19px;
}
.sticky .tel a{
	color: #fff;
	text-decoration: none;
	padding: 8px 15px;
	background: rgba(255,60,100,1);
	font-weight: bold;
	border-radius:5px;
}
.sticky .tel i{
	padding-right: 4px;
}
.ttl img{
	width: 88%;
	margin:0 auto;
}
.cv2 .tel-num a{
	text-decoration: none;
	color: #000;
}
footer {
    margin-bottom: 40px;
}
.sticky .txt02{
	font-size: 15px;
	font-weight: bold;
	color: #fff;
}
.area-voice dl{
	flex-wrap: wrap;
}
.area-voice dt {
    margin:0 auto;
	width: 80px;
}
.area-voice dd{
	width: 100%;
}
.area-voice dd h3 {

    font-size: 18px;
}
.area-voice {
    padding: 20px 0;
}
.area-area {
    padding: 30px 0 0;
}
}
@media screen and (max-width:380px){

}
@media screen and (max-width:320px){
.sticky {
    padding: 14px 10px;
}	
.sticky .tel ul {	
    font-size: 17px;
}
.sticky .txt02 {
    font-size: 13px;
}
.topics-area li {
    font-size: 10px;
}
}