@charset "utf-8";



/*********** font setup ***********/
* { font-family:"メイリオ","ＭＳ Ｐゴシック", Osaka,sans-serif; }
.f10,
#credit {font-family:"ＭＳ Ｐゴシック", Osaka,sans-serif;}


/*********** defult setup ***********/
body,
h1,h2,h3,h4,h5,h6,p,
ul,ol,li,dl,dt,dd,span,img,
form,fieldset,legend,pre,blockquote {
	margin:0px;
	padding:0px;
	border:0px;
	list-style:none;
}



/*********** tag setup ***********/

/* body */
body { 
    font-size: 16px;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", arial, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
    line-height: 1.5;}
@media screen and (max-width:768px){
	body { font-size: 14px; }
}


/* heading */
h1 { }
h2 { }
h3 { }
h4 { }
h5 { }

/* ie用 images */
body img { vertical-align:top; font-size:0; }

/* link */
a { color:#ff6633; }
a:link { text-decoration:underline; }
a:hover { text-decoration:none; color:#29abe2; }
a:visited { }
a:active { }




/*********** PC/スマホで切り替え ***********/
.sp { display: none !important; } 
@media screen and (max-width:768px){
	.pc { display: none !important; }
	.sp { display: block !important; }
}


/*********** id setup ***********/

/* wrapper */
#wrapper { width: 100%; overflow-x: hidden; }

/* logo */
#header #logo { display: inline-block; width: 33.95%; float: left; }
#header #logo img { width:100%; height: auto; }
@media screen and (max-width:768px){
	#header #logo { width: 100%; text-align: center; float: none; }
	#header #logo img { height: 40px; width: auto; margin: 0 auto; }
}

/*  header  */
#header { width:100%; margin:0px auto 0px; position:relative; border-top: solid 25px #333;  }
#header .inner {
	width: 960px; margin: -25px auto 0;
	/* display: flex;
	justify-content: space-between;
	align-items: center; */
}

#header .inner h2 { 
	color: #fff; line-height: 25px; display: 100%;
	padding: 0; margin: 0 0 20px; font-size: 75%; font-weight: normal;
	 }

@media screen and (max-width:768px){
	#header .inner { max-width: 100%; }
	#header .inner h2 { text-align: center; background:#333; line-height: 1.2; padding: 5px 0; }
	#wrapper {margin: 0 0 15px;}
}


/* h_nav */
#nav {
	float: right;
}
#hnav li { float:left; padding-left: 10px; }
#hnav li img { width:246px; height: auto; }

#hnav img.htel{ width: 180px; height: auto; }
#hnav img.hmail { width: 150px; height: auto; }
#hnav img.hline { width: 150px; height: auto; }

/* g_nav */
#gnav {
	width: 100%;
	margin: 10px 0 0px;
	background: url("../images/bg_gnav.png") center top no-repeat;
}
#gnav ul { 
	width: 1100px; padding: 10px 0; margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content:space-around;
}
#gnav li {
    font-weight: bold;
    text-align: left;
    width: 16%;
    display: inline-block;
    background-color: #fff;
    border-radius: 5px;
    font-size: 112.5%;
    line-height: 0.9;
    opacity: 0.85;
    height: 10px;
    padding: 13px 0 17px;
    vertical-align: middle;
}

#gnav li:before,
#gnav li:after{
content: "";
display: block;
position: relative;
}

	#gnav li:before{

	}

#gnav li::after {

    width: 12px;
    height: 12px;
    border-right: 3px solid #002e4c;
    border-top: 3px solid #002e4c;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    right: -10px;
    top: -17px;
}

@media screen and (max-width:959px){
	#gnav ul { width: 100%; }
	#gnav li { width: 23%; }
}
@media screen and (max-width:640px){

	#gnav { background-repeat: repeat-y; }
	#gnav ul { justify-content: flex-start; }
	#gnav li { width: 48%; margin-left: 1%; margin-right: 1%; }
	#gnav li:nth-child(1),#gnav li:nth-child(2),
	#gnav li:nth-child(3),#gnav li:nth-child(4) { margin-bottom: 10px; }
	#gnav li::after {
    width: 10px;
    height: 10px;
    border-right: 3px solid #002e4c;
    border-top: 3px solid #002e4c;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    right: -10px;
    top: -14px;
}
	#gnav a {
    padding: 0 0 0 30px;
}
	#gnav li.gnav_line {
		background: #3aae36;
		border: solid 1px #fff;
		box-sizing: border-box;
		padding: 13px 0 17px; height: 40px;
		position: relative;
		margin-bottom: 10px;
	}
	#gnav li.gnav_line a {
		color: #fff !important;
		 padding: 0 0 0 40px;
	}	
	#gnav li.gnav_line::after {

		width: 30px;
		height: 28px;
		border-right: none;
		border-top: none;
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg);
		position: absolute; left: 8px; top: 5px;
		background-image: url("../images/gnav_line.png");
		background-size: cover;
	}
}

#gnav a { color: #000; text-decoration: none; padding: 0 0 0 35px;}

#gnav a:hover { opacity: 0.45; }

/*メニュー部分*/
@media screen and (max-width:768px){
	#header { 
		width: 100%; 
		position:relative; z-index:9999; }

	#header #hnav { display: none; }
	
}







/* main */
#main { width:100%; margin:0 auto; line-height:1.5; }

/* side */
#side { width:200px; float:left; }

/* content */
#content { width:600px; float:right; line-height:1.5; }


/*---------------------------------------------------------------------------
　各社バナー
---------------------------------------------------------------------------*/

.Bnr_box{
	width:1040px;
	margin:30px auto 35px;
	text-align:center;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.Bnr_box li {
	/* width: 31.4%; */
	width: 23.4%;
	margin-left: 1%; margin-right: 1%;
}

.Bnr_box li:first-child{
	margin-left: 0; margin-right: 1%;
}

.Bnr_box li:last-child{
	margin-left: 1%; margin-right: 0;
}

.Bnr_box li img { width: 100%; height: auto; }


.Bnr_box a:hover{
	color:#FFF;
	filter: alpha(opacity=75);
	opacity: 0.75;
	-moz-opacity: 0.75;
}






@media only screen and (max-width: 959px) {
	.Bnr_box{
	width:100%;
	padding: 0 20px; box-sizing: border-box;	
	margin:30px auto 35px;
	text-align:center;
	display: flex;
	justify-content: space-around;
	flex-wrap: wrap;
	}
}
@media only screen and (max-width: 480px) {
	.Bnr_box {
		display: block;
	}
	.Bnr_box li {
		margin: 0 auto 10px;
		width: 310px !important; max-width: 100%;
	}
	.Bnr_box li:first-child{
		margin: 0 auto 10px;
	}

	.Bnr_box li:last-child{
		margin: 0 auto 10px;
	}
}



/* f_nav */
#fnav { padding:10px 0 0; margin:0 auto; color:#000000; clear:both; text-align:center; font-size:10px; }
#fnav a { color:#000000; text-decoration:underline; }
#fnav a:hover { color:#565656; text-decoration:none; }


/* footer */
#footer { width:100%; margin:0 auto; font-size:12px; line-height:1.5;  background: #e95517; text-align: center; }
#footer .flogo { width: 960px; margin: 0 auto; padding: 1em 0; }
#footer .flogo img {
	width: 29%; height: auto;
}
#footer .copy { text-align: center; background: #3e3a39; color: #fff; padding:5px 0; }
#footer .fnav { background: #fff; padding: 8px 0; list-style: none; overflow: hidden; }
#footer .fnav ul { width: 1040px; margin: 0 auto;}
#footer .fnav ul li { text-align: center; float: left; margin: 0 30px; }
#footer .fnav ul li a { text-decoration: none; color: #3e3a39;; font-weight: bold; vertical-align: middle; }

@media screen and (max-width:959px){
	#footer .flogo { width: 100%; }
}
@media screen and (max-width:480px){
	#footer .flogo img { width: 40%; }
}
@media screen and (max-width:641px){
#footer .fnav ul { width: 100%; list-style: none; overflow: hidden; margin: 0 auto; }
}
@media screen and (max-width:641px){
#footer .fnav ul li { width: 50%; height: 30px; margin: 0 auto; }
}

/*********** pagetop ***********/
.totop {
  position: fixed;
  right: 15px;
  bottom: 15px;
  z-index: 9990;
  display: block;
  width: 120px;
	cursor: pointer;
}

.totop img { width: 100%; height: auto; }

.totop .button {
  visibility: hidden;
  display: block;
  width: 44px;
  height: 44px;
  margin: 0 0 0 auto;
  background: rgba(232, 232, 232, 0.7);
  -ms-border-radius: 3px;
  border-radius: 3px;
  text-align: center;
  font-size: 30px;
  font-size: 3rem;
  line-height: 44px;
  color: #3a3a3a;
}

/*〜641px　以下では見えないようにする*/
@media screen and (max-width:641px){
	.totop {
  right: 15px;
  bottom: 100px;
  z-index: 10000;
  display: block;
  width: 100px;
}
}
@media screen and (max-width:480px){
	.totop {
		right: 5px;
		bottom: 65px;
		z-index: 10000;
		display: block;
		width: 80px;
		display: none;
	}
}

/*********** フッター固定 ***********/

/*641px～PC　PC上では見えないようにする*/
@media screen and (min-width:641px){
	.footer_area{
		display: none;
}	
}

/*スマホ～641pxの幅サイズまで*/
@media screen and (max-width:640px){
.footer_area {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: rgba( 68, 68, 68, 0.9 );
	z-index: 10000;
}
	.footer_area ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
		margin: 0px auto;
		box-shadow: 0 -2px 4px 0 rgba(0,0,0,.5);
		background: #333;
		padding-top: 2px;
	}
	.footer_area li {
		display: inline-block;
	}
	.footer_area .fnav_head { width: 100%; }  .footer_area .fnav_head img { width: 100%; height: auto; }
	.footer_area .fnav_tel { width: calc( 100% / 2 ); height: auto; background: #e95517; }  .footer_area .fnav_tel img { width: 100%; height: auto; }
	.footer_area .fnav_form { width: calc( 100% / 2 ); height: auto; background: #187fc4; } .footer_area .fnav_form img { width: 100%; height: auto; }
	.footer_area .fnav_line { width: calc( 100% / 3 ); height: auto; background: #3AAE36; } .footer_area .fnav_line img { width: 100%; height: auto; }
	
.footer_area .footer_area_inner {
    position: relative;
    width: 80%;
    margin: 0px auto;
    padding: 10px 0;
	margin-right: 0px;
}
.footer_area .footer_area_inner .footer_area_inner_btn {
    width: 85%;
    padding: 11px 0;
    font-size: 20px;
    font-weight: bold;
    margin-left: 15px;
	line-height: 1.3;
    
}
.inquiry_btn {
    background-color: #068BF1;
    -webkit-border-radius: 3px;
    display: inline-block;
    text-align: center;
    text-decoration: none;
	width: 80%;
    padding: 5px 0;
    font-size: 18px;
    font-weight: bold;
}
.inquiry_btn:link, .inquiry_btn:visited {
    color: #FFFFFF !important;
}
.footer_area_inner span{
	color: #fff;
}
#footer{
	margin-bottom: 75px;
}
}
@media screen and (max-width:480px){
#footer{
	margin-bottom: 58px;
}
}

#pageTop {
    position: fixed;
    right: 15px;
    bottom: 15px;
    z-index: 10000;
    display: block;
    width: 120px;
    cursor: pointer;
}
     
#pageTop a {
    display: block;
    z-index: 999;
}
	
#pageTop img {
    width: 100%;
    height: auto;
}

#pageTop a:hover {
      text-decoration: none;
      opacity: 0.7;
}
	
@media only screen and (max-width : 767px ){
	
	#pageTop {
	right: 5px;
	bottom: 65px;
	z-index: 10000;
	display: block;
	width: 80px;
	}

	#pageTop img {
    width: 100%;
	}


}

.privacy{
	width: 960px;
	height: auto;
	margin: auto;
	margin-top: 60px;
}

@media screen and (max-width:641px){
	.privacy{
		width: 90%;
		margin-bottom: 60px;
	}	
}

.privacy h4{
	font-size: 28px;
	width: 630px;
	text-align: center;
	border-bottom: solid 3px #e95517;
	margin: auto;
	margin-bottom: 30px;
}

@media screen and (max-width:641px){
.privacy h4{
	width: 100%;
	font-size: 16px;
	font-weight: bold;
}	
}

.privacy_section{
	font-size: 20px;
	text-align: left;
	font-weight: bold;
	margin: 40px 0 15px 0;
}

@media screen and (max-width:641px){
.privacy_section{
	font-size: 16px;
	text-align: left;
	font-weight: bold;
	margin: 40px 0 15px 0;
}
}
