@charset "UTF-8";
body {
    font-size: 18px;
	margin: 0;
	padding: 0;
	color: #333;
	font-family: 'M PLUS 1p',"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height:1.8em;
}

ul, ol, dl { 
	padding: 0;
	margin: 0;
}
ul li{
	list-style:none;
	padding:0;}

th,td,dt,dd{
	margin:0;
	padding:0;
	border-spacing:0;
	border-collapse:0;}
img {
	vertical-align:bottom;
    border: none;
}

p {
	margin:30px auto;
    max-width: 860px;
}
ul {
    max-width: 880px;
    margin: 0 auto;
}
a img {
	border: none;
}
a {
	text-decoration:none;
}
a:link,
a:visited {
	color:#303030;
	text-decoration: underline;
}

a:hover{
	color:#3aa49d;;
	transform: translateY(4px);
}
a:hover, a:active, a:focus {
	text-decoration:underline;
}

* {
    margin: 0 auto;
    box-sizing: border-box;
}

.sp {
    display: none;
}

@media screen and (max-width: 640px) {
    .pc {
        display: none;
    }
    .sp {
        display: block;
    }
    img {
        width: 100%;
    }
    p {
        width: 96%;
    }
}


/*===================== content ========================*/
section {
    padding: 70px 0;
}
.wrap {
	max-width:1060px;
    background: #fff;
    padding: 60px 0;
    box-shadow: 1px 1px 6px #999;
    border: solid 1px #e6e6e6;
}
h2 {
    font-size: 40px;
    line-height: 1.2em;
    font-family: 'M PLUS 1p', sans-serif;
    border-bottom: solid 5px #333333;margin: 120px auto 60px;
    text-align: center;
    padding-bottom: 10px;
    max-width: 920px;
    font-weight: 700;
}
section .wrap h2:first-child {
    margin-top: 0;
}

/*=============================================ヘッダー
*/
header{
	padding:8px 0;
	margin-bottom:10px;
    background: url("../img/back3.jpg") repeat;
    text-align: right;
}

	
/*========================フッター*/
footer{
	text-align:center;
	padding:60px 2% 40px;
    font-size: .8em;
    background: url("../img/back3.jpg") repeat;
}

footer li{
	display:inline-block;
	margin:0 ;
	}
footer li:after{
	content:'|';
	margin:0 0 0 5px;
}

footer p {
    margin: 15px auto;
}
@media screen and (max-width: 640px) {
    footer {
        padding: 30px 2% 10px;
    }
}

/*------ その他のページ -----*/
#other .wrap {
    background: none;
    padding: 40px 100px;
    margin: 0 auto 60px;
    border: none;
    box-shadow: none;
    font-size: 16px;
}

#other h2 {
    font-size: 30px;
    margin-top: 0;
}

#other header .wrap {
    margin: 0 auto;
    padding: 8px 2%;
}
	
#other .table {border-top:1px solid #aaa;border-left:1px solid #aaa;background-color:#fff;border-collapse:collapse;border-spacing:0px;empty-cells:show;margin:20px auto 20px;font-size:100%;line-height:180%;max-width:860px;}
#other .table th {border-right:1px solid #aaa;border-bottom:1px solid #aaa; background-color:rgba(180,163,156,.30);color:#414141;font-weight:normal;text-align:center;padding:10px;width:25%;}
#other .table th img{ margin:0 0 3px 5px;}
#other .table td {border-right:1px solid #aaa;border-bottom:1px solid #aaa;padding:10px;width:75%;text-align:left;}
#other .table td p{margin:0; padding:0;}
#other .table td input{ padding:5px 2px; border:1px solid #ccc; margin:0 20px 0 5px; font-size:16px}
#other .table td input[type="button"]{ background-color:#ffc66f;}
#other .table td button{ background-color:#eee;}
#other .table th.bgno{ background-image:none}

#other ul {
	margin: 0 auto 20px;
}

#other li {
	margin: 6px 0 6px 1em;
	padding-left: 1em;
	text-indent: -1em;
}
@media screen and (max-width: 640px) {
    #other .wrap {
        padding: 20px 3%;
        margin: 0 auto 60px;
    }
    #other h2 {
        font-size: 27px;
    }
    .map {
         width:100%;
         height:450px;
         frameborder:0;
         border:0;
    }
    #other .table th,
    #other .table td {
        width: 100%;
        display: block;
    }

}

.np {
 padding: 10px 15px;
}

.np_txt {
 border-top: 1px solid #efefef; padding: 10px 0 5px;
}


/*----------- modules -----------------*/
.alc {
	text-align:center !important;
}
.alr {
	text-align:right !important;
}



.f12{
	font-size:12px;}
.f14{
	font-size:14px;}
.f60{
	font-size:60%;}
.f70{
	font-size:70%;}
.f80{
	font-size:80%;}
.f90{
	font-size:90%;}
.f106{
	font-size:106%;}
.f110{
	font-size:110%;}
.f120{
	font-size:120%;}
.f130{
	font-size:130%;}
.f140{
	font-size:140%;}
.f150{
	font-size:150%;}
.f160{
	font-size:160%;}
.f190{
	font-size:190%;}
.b{
	font-weight:bold;
}
.red{
	color:#E50E1A;
}
.underline{
	text-decoration:underline;}
.hilight{
	background-color:#feee3e;}
.m20 { margin: 20px 0; }

.mt0{ margin-top:0 !important;}
.mt_5{ margin-top:5px!important;}
.mt_10{ margin-top:10px!important;}
.mt_20{ margin-top:20px!important;}
.mt_30{ margin-top:30px!important;}
.mt_40{ margin-top:40px!important;}
.mt_50{ margin-top:50px!important;}
.mt_60{ margin-top:60px!important;}
.mb_0{ margin-bottom:0 !important;}
.mb_10{ margin-bottom:10px!important;}
.mb_20{ margin-bottom:20px!important;}
.mb_30{ margin-bottom:30px!important;}
.mb_40{ margin-bottom:40px!important;}
.mb_50{ margin-bottom:50px!important;}


.text_c { text-align: center; }

.tex_r{ text-align:right;}

.fll {
	float:left;
}
.flr {
	float:right;
}

.clear_b{
	clear:both;}
	
	
.clearfix {zoom: 100%;}

.clearfix:after {
	content: ".";
	display: block;
	visibility: hidden;
	height: 0.1px;
	font-size: 0.1em;
	line-height: 0;
	clear: both;
}

.green {
    color: #3AA49D;
}

.pink{
	color:#df2f77;
}


