@charset "utf-8";

/*=====================================================
COMMON-LAYOUT
======================================================*/

#contest_po{
	padding-top: 20px;
	margin-top: -20px;
}
#s02{
	padding-top: 20px;
	margin-top: -20px;
}

/*sec01*/

.sec01{
	padding-top: 50px;
	padding-bottom: 70px;
	background-image: url(../images/common/secline.png);
	background-repeat: repeat-x;
	background-position: center bottom;
}

.sec01 .box01{
}
/*sec01*/


/*sec02*/
.sec02{
	padding-bottom: 70px;
	background-image: url(../images/common/secline.png);
	background-repeat: repeat-x;
	background-position: center bottom;
}

.sec02 .img_icon_wrap{
	position: relative;
}

.sec02 .img_icon_wrap{
	position: relative;
}

.sec02 .img_icon_wrap .img_icon01{
	position: absolute;
	top: -50%;
	right: -1%;
	width: 21.8%;
}

/*sec02*/



/*sec03*/

.sec03{
	padding-top: 50px;
	padding-bottom: 70px;
	background-image: url(../images/common/secline.png);
	background-repeat: repeat-x;
	background-position: center bottom;
}

.sec03 .table table{
	width: 100%;
	border-collapse: collapse;
}

.sec03 .table table tr{
	margin-bottom: 20px;
    display: block; 
}

.sec03 .table table tr th{
	width: 152px;
	vertical-align: top;
}

.sec03 .table table tr th span{
	display: block;
	width: 100%;
}

.sec03 .table table tr td{
	font-weight: bold;
	font-size: 20px;
	color: #3e4664;
	padding-left: 36px;
	line-height: 1.4;
}

.sec03 .table table tr td .mini{
	font-size: 16px;
}

.sec03 .table table tr td .hans{
	font-size: 18px;
}

.sec03 .table table tr td .bigs{
	font-size: 24px;
}

.sec03 .table table tr td .wakku span{
	display: inline-block;
	padding: 5px 15px;
	border: solid #3e4664 1px;
	border-top: 0;
	border-bottom: 0;
	position: relative;
	box-sizing: border-box;
}

.sec03 .table table tr td .wakku span:after{
	display: block;
	content: "";
	height: 100%;
	top: 0;
	bottom: 0;
	left: 0;
	width: 10px;
	border: solid #3e4664 1px;
	border-right: 0;
	border-left: 0;
	position: absolute;
	box-sizing: border-box;
}

.sec03 .table table tr td .wakku span:before{
	display: block;
	content: "";
	height: 100%;
	top: 0;
	bottom: 0;
	right: 0;
	width: 10px;
	border: solid #3e4664 1px;
	border-right: 0;
	border-left: 0;
	position: absolute;
	box-sizing: border-box;
}

.sec03 .table table tr td ul{
	margin-bottom: 20px;
}

.sec03 .table table tr td ul li{
    float: left;
    width: 20.3%;
    margin-right: 10%;
}


.sec03 .table .tels{
	margin-left: -11.6%;
}









/*sec03*/



/*sec04*/
.sec04{
	padding-top: 50px;
	padding-bottom: 70px;
    background-image: url(../images/common/secline.png);
    background-repeat: repeat-x;
    background-position: center bottom;
}

.sec04 .box{
	margin-bottom: 60px;
}
.sec04 .box:last-child{
	margin-bottom: 0;
	margin-top: -25px;
}
.sec04 .box:nth-last-child(2){
	margin-bottom: 0;
}
.sec04 .box .left{
	float: left;
	width: 12.72727272727273%;
}

.sec04 .box .right{
	float: right;
	width: 85%;
	padding-top: 4%;
}


.sec04 .box .center{
	float: left;
	width: 49%;
}
.sec04 .box .imgs{
	float: right;
	width: 48.2%;
}



.sec04 .box .rttl{
	color: #1d2088;
	font-size: 30px;
	font-weight: bold;
}
.sec04 .box .rttl span{
	font-size: 20px;
}


.sec04 .box .rtext{
	font-size: 14px;
	font-weight: bold;
	color: #525d67;
	line-height: 1.57;
}



.sec04 .box .rcopy{
	font-size: 18px;
	font-weight: bold;
	color: #036eb8;
	line-height: 1.44;
}

.sec04 .box .rttl_s{
	font-size: 20px;
	font-weight: bold;
	color: #1d2088;
	line-height: 1.44;
}

.sec04 .box.ol_piont001{
	position: relative;
}

.sec04 .box.ol_piont001 .ol_icons001{
	position: absolute;
	left: -27%;
	bottom: 0;
	width: 100%;
	max-width: 42%;
}


/*sec04*/


/*sec05*/
#s05{
	position: relative;
	padding-bottom: 30px;
	margin-top: 60px;
}

#s05:after{
	width: 400%;
    height: 100%;
    z-index: -1;
    position: absolute;
    top: 0;
    left: -100%;
    right: -100%;
    content: "";
    display: block;
    background-color: #d3edfb;
	opacity: 0.46;
	
}
.sec05 .in_conw{
	padding-top: 90px;
}

.sec05 .in_conw .lists{
	max-width: 930px;
	margin: 0 auto;
}

.sec05 .in_conw .lists .list{
	max-width: 48%;
}

.sec05 .in_conw .lists .list.left{
	float: left;
}

.sec05 .in_conw .lists .list.right{
	float: right;
}

/*sec04*/





@media screen and (max-width: 1400px){
	.sec03 .table .tels{
		margin-left: 0;
		padding-left: 152px;
	}
}


@media screen and (max-width: 1160px){
	
	#s05{
		margin-top: 30px;
	}
#s05:after{
   width: calc(100% + 0px);
   left: 0;
   right: 0;
}
}


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


@media screen and (max-width: 1000px){
	.sec04 .box .text_box .ttl_text {
		font-size: 35px;
	}
	.sec04 .box .text_box .read_text {
		font-size: 24px;
	}
	.sec04 .box .text_box .text {
		font-size: 14px;
	}
	.sec04 .boxs .box .text_box .ttl_text {
		font-size: 26px;
	}
	.sec04 .boxs .box .text_box .read_text {
		font-size: 20px;
	}
	.sec04 .boxs .box .text_box .text {
		font-size: 14px;
	}
}



@media screen and (max-width: 880px){
	.sec04 .box:last-child{
		margin-bottom: 0;
		margin-top: 5px;
	}
	.sec04 .box:nth-last-child(2){
		margin-bottom: 20px;
	}
}



@media screen and (max-width: 860px){
	
	
/*
	.sec04 .box{
		margin: 0 auto;
		max-width: 750px;
	}
	.sec04 .box01 {
		margin-bottom: 40px;
	}
	.sec04 .box02 {
		margin-bottom: 40px;
	}
	.sec04 .box03 {
		margin-bottom: 40px;
	}
	
	
	.sec04 .boxs .box:nth-child(2n+1) {
		float: none;
		width: 100%;
	}
	
	.sec04 .boxs .box:nth-child(2n) {
		float: none;
		width: 100%;
	}
	
	
	.sec04 .boxs .box .img_box {
		float: right;
		width: 36.36363636363636%;
		position: static;
	}
	
	.sec04 .boxs .box .text_box {
		float: left; 
		width: 59.36363636363636%; 
	}

	.sec04 .boxs .box .text_box .text {
		width: 100%;
	}
*/
}



@media screen and (max-width: 800px){
	.sec04 .box .text_box .ttl_text {
		font-size: 30px;
	}
	.sec04 .box .text_box .read_text {
		font-size: 22px;
	}
}




@media screen and (max-width: 750px){
	
	
	
	
	
	
	
/*
	.sec01 .box01 {
		background-image: url(../images/contest/bg01_sp.png);
		background-size: 100% 100%;
		padding: 30px;
	}
*/
	
	.sec01 .box01 .img_box {
		float: none;
		width: 100%;
		margin: 0 auto 5%;
		text-align: center;
		padding: 0 40px;
	}
	
	.sec01 .box01 .text_box {
		float: none;
		width: 100%;
		text-align: center;
	}
	.sec01 .box01 .text_box p:nth-child(1) {
		margin-top:0;
		width: 100%;
	}
	
	
	
	
	
	.sec04 .box .center{
		width: 100%;
		float: none;
	}
	.sec04 .box .imgs{
		width: 100%;
		float: none;
	}
	
	
	#s05 {
		padding-bottom: 30px;
	}
	
	.sec05 .in_conw {
		padding-top: 30px;
		
	}
	
	
	.sec04 .box.ol_piont001 .ol_icons001{
		position: static;
		max-width: 57%;
		margin-top: 2%;
	}
	
	
}


@media screen and (max-width: 650px){
	
	
	.sec01 {
		padding-top: 30px;
		padding-bottom: 40px;
	}
	.sec02 {
		padding-bottom: 40px;
	}
	
	.sec03	 {
		padding-top: 30px;
		padding-bottom: 40px;
	}
	.sec04 {
		padding-top: 30px;
		padding-bottom: 40px;
	}
	
	
	
	
	
	.sec03 .table table tr th {
		width: 102px;
	}
	
	.sec03 .table table tr td {
		font-size: 16px;
	}
	.sec03 .table table tr td .hans {
		font-size: 15px;
	}
	.sec03 .table table tr td .mini {
		font-size: 14px;
	}
	.sec03 .table table tr td .bigs {
		font-size: 20px;
	}
	
	.sec03 .table .tels{
		padding-left: 0;
	}
	.sec03 .table table tr td .wakku span{
		width: 100%;
		margin-top: 5px;
		margin-bottom: 5px;
	}
	.sec03 .table table tr td .wakku span br{
		display: none;
	}
	
	.sec04 .box .left{
		float: none;
		width: 100%;
		margin: 0 auto;
		max-width: 100px;
		margin-bottom: 5%;
	}
	.sec04 .box .right {
		float: none;
		width: 100%;
		padding-top: 0;
	}
	
	.sec04 .box .center{
		max-width: 400px;
		margin: 0 auto 20px;
	}
	
	.sec04 .box .imgs{
		text-align: center;
		
	}
	
	
	
	
	
	
	
	.sec04 .box .img_box {
		float: none;
		width: 65%;
		text-align: center;
		margin: 0 auto 20px;
	}
	
	.sec04 .box .text_box {
		float: none;
		width: 100%;
	}
	
	
	.sec04 .boxs .box .img_box {
		float: none;
		width: 45%;
		text-align: center;
		margin: 0 auto 20px;
	}
	
	.sec04 .boxs .box .text_box{
		float: none;
		width: 100%;
	}
	
	
	.sec04 .box .text_box .ttl_text {
		font-size: 22px;
	}
	.sec04 .box .text_box .read_text {
		font-size: 16px;
	}
	.sec04 .box .text_box .text {
		font-size: 12px;
	}
	
	.sec04 .boxs .box .text_box .ttl_text {
		font-size: 20px;
	}
	.sec04 .boxs .box .text_box .read_text {
		font-size: 15px;
	}
	.sec04 .boxs .box .text_box .text {
		font-size: 12px;
	}
	
	
	.sec05 .in_conw .lists {
		max-width: 400px;
		margin: 0 auto;
		padding: 0 20px;
	}
	
	.sec05 .in_conw .lists .list {
		max-width: 100%;
	}
	
	.sec05 .in_conw .lists .list.left {
		float: none;
		margin-bottom: 50px	;
	}
	
	.sec05 .in_conw .lists .list.right {
		float: none;
	}
	
	
	
	

	.sec04 .box:last-child{
		margin-bottom: 0;
		margin-top: 5px;
	}
	.sec04 .box:nth-last-child(2){
		margin-bottom: 60px;
	}
	
}




@media screen and (max-width: 600px){
	.sec04 .box .rttl {
		font-size: 24px;
	}
	
	.sec04 .box .rttl span {
		font-size: 16px;
	}
	.sec04 .box .rcopy {
		font-size: 15px;
	}
	
	.sec04 .box .imgs {
		padding: 0 40px;
	}
}




@media screen and (max-width: 550px){
	
	.sec03 .table table tr td {
		display: block;
		padding-left: 0;
		padding: 5px 2px;
	}
}




















