


/*************************
*******Typography******
**************************/




body {
  background: #fff;
  font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
  line-height:180%;
  font-size:15px;
  color:#111;
}
@media (min-width: 768px) {
body {
  background: #fff;
 font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
  line-height:170%;
  font-size:16px;
  color:#111;
  letter-spacing: 0.05em;	
}
}


/*ol,ul {list-style:none;}*/

/* bootstrapcss修正
----------------------------------------------------------*/
.table thead th {
    vertical-align: middle; 
    border-bottom: 2px solid #dee2e6;
    text-align: center;
    padding: 0.75rem 0.5rem;
}
.table td {
    text-align: center;
    padding: 0.75rem 0.5rem;
}


/*ol,ul{
	margin:0px;
	padding:0px;
	list-style:none;
}*/
p {
  margin: 0 0 0px;
}

h1{
    line-height: 100%;
}

h1{
	margin:0px;
	padding:0px;
	float:none;
}
h2{
	margin:0px ;
	padding:0px;
}
h3{
	margin:0px ;
	padding:0px;
}
h4{
	margin:0px ;
	padding:0px;
}


/* 汎用
----------------------------------------------------------*/
a {
	outline:none;
	color:#0c4ebb;
	text-decoration:underline
}
a:link,a:visited {
	color:#0c4ebb;
	text-decoration:underline
}
a:hover {
	color:#999;
	text-decoration:none
}

.clear {clear:both;}
.middle{vertical-align:middle;}

.bold{
	font-weight:bold;
}


.fs11px{
	font-size:11px;
}

.fs13px{
	font-size:13px;
	line-height: 140%
}




.fs90{
	font-size:90%;
}
.fs110{
	font-size:110%;
	line-height:130%;
}
.fs120{
	font-size:120%;
	line-height:150%;
}
.fs130{
	font-size:130%;
	line-height:130%;
}
.fs140{
	font-size:140%;
	line-height:130%;
}
.fs150{
	font-size:150%;
	line-height:160%;
}
.fs160{
	font-size:160%;
	line-height:140%;
}
.fs180{
	font-size:180%;
	line-height:120%;
}
.large_text{
	font-size:15px;	
}
@media (min-width: 992px) {
.large_text{
	font-size:22px;
	line-height:170%;
}	
}


.sp_fs15_sm_fs18{
	font-size:15px;
}
@media (min-width: 768px) {
.sp_fs15_sm_fs18{
	font-size:18px;
	line-height:150%;
}	
}

.sp_fs15_sm_fs20{
	font-size:15px;
}
@media (min-width: 768px) {
.sp_fs15_sm_fs20{
	font-size:20px;
	line-height:150%;
}	
}

.sp_fs15_sm_fs25{
	font-size:15px;
}
@media (min-width: 768px) {
.sp_fs15_sm_fs25{
	font-size:25px;
	line-height:140%;
}	
}




.red{color:#b41111;}
.gold{color:#cc9111;}
.blue{color:#104eba;}
.white{color:#fff;}


.kome{
	text-indent:-1em;
	margin-left:1em;
}

.border{
	padding-bottom:15px;
	border-bottom:1px dashed #e5d7be;
	margin-bottom:15px;
}
.sp_border{
	padding-bottom:10px;
	border-bottom:1px dashed #ccc;
	margin-bottom:10px;
}
@media (min-width: 768px) {
.sp_border{
	padding-bottom:0px;
	border:none;
	margin-bottom:0px;
}
}

.pc_center{
	text-align:left;
}
@media (min-width: 992px) {
.pc_center{
	text-align:center;
}
}

.pctab_center{
	text-align:left;
}
@media (min-width: 768px) {
.pctab_center{
	text-align:center;
}
}


.sp_center{
	text-align:center;
}
@media (min-width: 768px) {
.sp_center{
	text-align:left;
}
}

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

@media (min-width: 768px) {
.pc_textright {text-align:right;}	
}

.radius{border-radius:12px;}

.left02{
	float:left;
}
.right02{
	float:right;
}

.img-filter a:hover img {
	opacity: 0.7;
 filter: alpha(opacity=80);
 -moz-opacity: 0.7;
}

.img-radius img{
	border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
}
@media (min-width: 992px) {
.img-radius img{
	border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
}	
}


.list_none{list-style:none;}



a:hover img {
	opacity:0.7;
	filter: alpha(opacity=70);
}


@media (min-width: 768px) {
.pc_right{
	float:right;
}
}






/* 余白
----------------------------------------------------------*/
.space{
	padding:30px 0;
}

@media (min-width: 768px) {
.space{
	padding:70px 0;
}
}
@media (min-width: 992px) {
.space{
	padding:100px 0;
}
}

.space2{
	padding:0px 0 30px;
}

@media (min-width: 768px) {
.space2{
	padding:0px 0 70px;
}
}
@media (min-width: 992px) {
.space2{
	padding:0px 0 100px;
}
}

.space3{
	padding:30px 0;
}

@media (min-width: 768px) {
.space3{
	padding:60px 0;
}
}

	
	
	

/* btn
----------------------------------------------------------*/
.link_btn{
	border-radius:4px;
	text-align:center;
	background:#f983b2;
    display:inline-block;
    padding:10px 20px;
    color: #fff;
}
.link_btn:hover {
	background:#ffa1c6;
    display: inline-block;
    padding:10px 20px;
    color: #fff;
}
.link_btn a:link,.link_btn a:visited {
	color:#fff;
	text-decoration:none
}
.link_btn a:hover {
	color:#fff;
	text-decoration:none
}




/* list
----------------------------------------------------------*/
.list01 li{
	list-style:square;
	margin-left:-20px;
	margin-bottom:0px;
}
.list01 li span{font-weight:bold;}
.list02 li {
	list-style: disc;
	margin-left:-20px;
	padding-bottom:5px;
	border-bottom:1px dotted #ccc;
	margin-bottom:10px;
}
@media (min-width: 768px) {
.list02 li {
	list-style: disc;
	margin-left:-20px;
	padding-bottom:0px;
	border-bottom:none;
	margin-bottom:0px;
}
}



/* margin,padding
----------------------------------------------------------*/
.mt05{margin-top:5px;}
.mt10{margin-top:10px;}
.mt15{margin-top:15px;}
.mt20{margin-top:20px;}
.mt30{margin-top:30px;}
.mt40{margin-top:40px;}
.mb05{margin-bottom:5px;}
.mb10{margin-bottom:10px;}
.mb15{margin-bottom:15px;}
.mb20{margin-bottom:20px;}
.mb30{margin-bottom:30px;}
.mb40{margin-bottom:40px;}
.mb50{margin-bottom:50px;}
.mr20{margin-right:20px;}
.mr10{margin-right:10px;}
.mr15{margin-right:15px;}
.mr25{margin-right:25px;}
.mr30{margin-right:30px;}
.mr32{margin-right:32px;}
.mr05{margin-right:5px;}
.ml05{margin-left:5px;}
.ml10{margin-left:10px;}
.ml20{margin-left:20px;}



.sp_mb10{margin-bottom: 10px;}
@media print, screen and (min-width: 768px) {
	.sp_mb10{margin-bottom:0px;}
}

.spsm_mb10{margin-bottom: 10px;}
@media print, screen and (min-width: 992px) {
	.spsm_mb10{margin-bottom:0px;}
}

.sp_mb30{margin-bottom: 30px;}
@media print, screen and (min-width: 768px) {
	.sp_mb30{margin-bottom:0px;}
}



@media print, screen and (min-width: 992px) {
	.pc_mt10{margin-top: 10px;}
}

@media print, screen and (min-width: 992px) {
	.pc_mt20{margin-top: 20px;}
}

@media print, screen and (min-width: 992px) {
	.pc_mt30{margin-top: 30px;}
}

@media print, screen and (min-width: 992px) {
	.pc_mt40{margin-top: 40px;}
}



@media print, screen and (min-width: 768px) {
	.sm_pc_mb10{margin-bottom:10px;}
}

.sp_mb10pc_mb20{margin-bottom: 10px;}
@media print, screen and (min-width: 768px) {
	.sp_mb10pc_mb20{margin-bottom: 20px;}
}

.sp_mb10pc_mb30{margin-bottom: 10px;}
@media print, screen and (min-width: 768px) {
	.sp_mb10pc_mb30{margin-bottom: 30px;}
}


.sp_mb20pc_mb30{margin-bottom: 20px;}
@media print, screen and (min-width: 768px) {
	.sp_mb20pc_mb30{margin-bottom: 30px;}
}


.sp_mb30pc_mb50{margin-bottom: 30px;}
@media print, screen and (min-width: 768px) {
	.sp_mb30pc_mb50{margin-bottom: 50px;}
}



.pr15{padding-right: 15px;}




@media (min-width: 768px) {
.pc_pt10{
	padding-top: 10px;
}
}


/* padding消し
----------------------------------------------------------*/






/* box
----------------------------------------------------------*/
.text_box{
    background-color: rgba(255,255,255,1);
    padding: 10px;
}
@media print, screen and (min-width: 768px){
 .text_box{
    padding: 30px;
     margin-top: 50px;
}   
}
@media print, screen and (min-width: 992px){
 .text_box{
    padding: 40px;
     margin-top: 70px;
}   
}

.text_box2{
    background-color: rgba(255,255,255,1);
    padding: 10px;
}
@media print, screen and (min-width: 768px){
 .text_box2{
    padding: 30px;
}   
}
@media print, screen and (min-width: 992px){
 .text_box2{
    padding: 40px;
}   
}




/* table
----------------------------------------------------------*/
.table1{
	width:100%;
	border-collapse: collapse;
}
.table1 th{
	width:100%;
	padding:10px 10px;
	display: block;
    background: #f5f5f5;
}
.table1 td{
	width:100%;
	padding:10px;
	display: block;
	border-bottom: 1px solid #ddd;
}
@media print, screen and (min-width: 768px) {
	.table1 th{
		width:27%;
		padding:15px 12px;
		vertical-align:middle;
		text-align:center;
		display:table-cell;
		border-bottom: 1px solid #ddd;
		font-weight: normal;
	}
	.table1.detail_th th{
		width:1%;
		white-space: nowrap;
	}
	.table1 th .en{
		float: none;
		display: block;
	}
	.table1 td{
		width:100%;
		padding:15px;
		display:table-cell;
		vertical-align: middle;
	}
}

/*----*/

.table2{
	width:100%;
	border-collapse: collapse;
}
.table2 th{
	width:100%;
	padding:10px 10px;
	display: block;
    background: #f4efdf;
}
.table2 td{
	width:100%;
	padding:10px;
	display: block;
	border-bottom: 1px solid #e9e2cd;
}
@media print, screen and (min-width: 768px) {
	.table2 th{
		width:27%;
		padding:15px 12px;
		vertical-align:middle;
		text-align:center;
		display:table-cell;
		border-bottom: 1px solid #e9e2cd;
		font-weight: normal;
	}
	.table2.detail_th th{
		width:1%;
		white-space: nowrap;
	}
	.table2 th .en{
		float: none;
		display: block;
	}
	.table2 td{
		width:100%;
		padding:15px;
		display:table-cell;
		vertical-align: middle;
	}
}


.table3{
	width:100%;
	border-collapse: collapse;
    border: 1px solid #ccc;
}
.table3 th{
	padding:10px 5px;
}
.table3 td{
	padding:10px 5px;
}
@media print, screen and (min-width: 768px) {
	.table3 th{
		padding:15px;
		vertical-align:middle;
		text-align:center;
		font-weight: normal;
	}
	
	.table3 td{
		padding:15px;
		vertical-align: middle;
	}
}

.table4{
	width:100%;
	border-collapse: collapse;
    border: 1px solid #ddd;
}
.table4 th{
	padding:10px 5px;
    background: #eee;
    border-bottom: 1px solid #ddd;
    width:1%;
	white-space: nowrap;
    text-align: center;
    font-weight: normal;

}
.table4 td{
	padding:10px 5px;
    border-bottom: 1px solid #ddd;
}
@media print, screen and (min-width: 768px) {
	.table4 th{
		padding:15px 15px;
		vertical-align:middle;
		text-align:center;
		
	}
	
	.table4 td{
		padding:15px 15px;
		vertical-align: middle;
	}
}




/* 背景
----------------------------------------------------------*/

.bg_nami{
    background:url(../images/nami.jpg) no-repeat top center;
    padding: 100px 0 0;
}
@media print, screen and (min-width: 992px){
   .bg_nami{
    padding: 140px 0 0;
} 
}

.bg4{
    background: #f0f5f8; 
}
.bg5{
    background: #f8f6f0; 
}






/* title
----------------------------------------------------------*/
.link a:link,.link a:visited {
	color:#0c4ebb;
	text-decoration:none
}
.link a:hover {
	color:#0c4ebb;
	text-decoration:none
}

.en {
  font-family: 'Roboto', sans-serif;
	
}
.jp{font-family: 'Noto Serif JP', serif;}


.title1{
    background: url(../images/titicon.png) no-repeat bottom center;
	font-size: 130%;
	line-height: 140%;
    padding-bottom: 20px;
	margin-bottom: 15px;
}
@media (min-width: 768px) {
	.title1{
	font-size: 22px;
	line-height: 150%;
	margin-bottom: 30px;
    padding-bottom: 30px;
}
}
@media (min-width: 992px) {
	.title1{
	font-size:28px;
}
}

.title2{ 
    font-family: 'Roboto', sans-serif;
	font-size: 150%;
    font-weight: bold;
	line-height: 140%;
	margin-bottom: 10px;
    letter-spacing: 0.2em;
    text-align: center;
}
@media (min-width: 768px) {
	.title2{
	font-size: 35px;
}
}
@media (min-width: 992px) {
	.title2{
	font-size:48px;
    
}
}

.title3{ 
	font-size: 130%;
    font-weight: bold;
	line-height: 140%;
    color: #104eba
}
@media (min-width: 768px) {
	.title3{
	font-size: 20px;
	line-height: 150%;
    margin-bottom: 30px;
}
}
@media (min-width: 992px) {
	.title3{
	font-size:22px;
    
}
}

.title4{ 
	font-size: 120%;
    font-weight: bold;
	line-height: 140%;
    margin-bottom: 10px;
}

.title4 a:link,.title4 a:visited {
	color:#111;
}
.title4 a:hover {
	color:#888;
}


.title5{ 
	font-size: 130%;
    font-weight: bold;
	line-height: 140%;
    text-align: center;
    color: #104eba
}
@media (min-width: 768px) {
	.title5{
	font-size: 20px;
	line-height: 150%;
}
}
@media (min-width: 992px) {
	.title5{
	font-size:22px;
    
}
}

.title6{ 
	font-size: 140%;
    font-weight: bold;
	line-height: 140%;
    text-align: center;
    color: #104eba;
    margin-bottom: 15px;
}
@media (min-width: 768px) {
	.title6{
	font-size: 25px;
	line-height: 150%;
    margin-bottom: 30px;    
}
}
@media (min-width: 992px) {
	.title6{
	font-size:38px;
    margin-bottom: 40px;  
}
}

.title7{ 
	font-size: 120%;
    font-weight: bold;
	line-height: 130%;
    margin-bottom: 15px;
    border-bottom: 1px solid #111;
    padding-bottom: 10px;
}
@media (min-width: 768px) {
	.title7{
	font-size: 18px;
	line-height: 150%;
    margin-bottom: 15px;    
}
}
@media (min-width: 992px) {
	.title7{
	font-size:20px;
    margin-bottom: 20px;  
}
}

.title7 span{
    color: #cc9111;
    font-size: 14px;
    margin-left: 8px;
}

.title8{ 
	font-size: 140%;
    font-weight: bold;
	line-height: 140%;
    text-align: center;
    color: #cc9111;
    margin-bottom: 15px;
}
@media (min-width: 768px) {
	.title8{
	font-size: 25px;
	line-height: 150%;
    margin-bottom: 30px;    
}
}
@media (min-width: 992px) {
	.title8{
	font-size:38px;
    margin-bottom: 40px;  
}
}

.title9{ 
	font-size: 110%;
    font-weight: bold;
	line-height: 140%;
    text-align: center;
    color: #cc9111;
    margin-bottom: 15px;
}
@media (min-width: 768px) {
	.title9{
	font-size: 20px;
    margin-bottom: 15px;    
}
}
@media (min-width: 992px) {
	.title9{
	font-size:30px;
    margin-bottom: 20px;  
}
}

.title10{ 
	font-size: 140%;
    font-weight: bold;
	line-height: 140%;
    text-align: center;
    color: #104eba;
    margin-bottom: 5px;
}
@media (min-width: 768px) {
	.title10{
	font-size: 25px;
	line-height: 150%;
    margin-bottom: 10px;    
}
}
@media (min-width: 992px) {
	.title10{
	font-size:38px;
    margin-bottom: 15px;  
}
}

.title11{ 
	font-size: 110%;
    font-weight: bold;
	line-height: 140%;
    text-align: center;
    color: #143a6a;
    margin-bottom: 15px;
}
@media (min-width: 768px) {
	.title11{
	font-size: 20px;
    margin-bottom: 15px;    
}
}
@media (min-width: 992px) {
	.title11{
	font-size:30px;
    margin-bottom: 20px;  
}
}

.title12{ 
	font-size: 110%;
    font-weight: bold;
	line-height: 140%;
    color: #cc9111;
    margin-bottom: 10px;
}
@media (min-width: 768px) {
	.title12{
	font-size: 20px;
    margin-bottom: 10px;    
}
}
@media (min-width: 992px) {
	.title12{
	font-size:30px;
    margin-bottom: 10px;  
}
}


.title13{ 
	font-size: 120%;
    font-weight: bold;
	line-height: 130%;
    margin-bottom: 15px;
    border-bottom: 1px solid #111;
    padding-bottom: 10px;
}
@media (min-width: 768px) {
	.title13{
	font-size: 20px;
    margin-bottom: 15px;
        line-height: 150%;
}
}
@media (min-width: 992px) {
	.title13{
	font-size:25px;
    margin-bottom: 20px;  
}
}







/* sp header
----------------------------------------------------------*/
#sp_header{
	padding: 0px 0 10px;
    height: 60px;
	 z-index: 9999;
    position: fixed;
    top: 0;
	background: #fff;
	width: 100%;
}

/*
.navbar-toggler{z-index: 9999;}
.navbar-toggler-icon{z-index: 9999;}
*/



/* header
----------------------------------------------------------*/
.header_padding{
    padding: 10px 0px 10px 15px;
}

.logo_padding{
    padding: 5px 0 5px 0px;
}
@media print, screen and (min-width: 768px){
  .logo_padding{
    padding: 17px 0 5px 15px;
}  
}




/* tel
----------------------------------------------------------*/
.tel_link a:link,.tel_link a:visited {
	color:#104eba;
	text-decoration:none
}
.tel_link a:hover {
	color:#104eba;
	text-decoration:none
}

.tel_link2 a:link,.tel_link2 a:visited {
	color:#fff;
	text-decoration:none
}
.tel_link2 a:hover {
	color:#fff;
	text-decoration:none
}

.tel_link3 a:link,.tel_link3 a:visited {
	color:#111;
	text-decoration:none
}
.tel_link3 a:hover {
	color:#111;
	text-decoration:none
}


.header_tel{
	font-size: 16px;
    color:#104eba;
}
@media print, screen and (min-width: 992px) {
.header_tel{
	font-size: 18px;
}		
}
.header_telnum{
	font-size: 28px;
}
@media print, screen and (min-width: 768px) {	
	.header_telnum{
	font-size: 18px;
        font-weight: 600;
        color:#104eba;
}
}

@media print, screen and (min-width: 992px) {	
	.header_telnum{
	font-size: 21px;	
}
}

@media print, screen and (min-width: 1200px) {	
	.header_telnum{
	font-size: 25px;	
}
	
}

.header_tel .fa{margin-right: 10px;}

/*---*/

.bottom_telnum{
	font-size: 28px;
}
@media print, screen and (min-width: 768px) {	
	.bottom_telnum{
	font-size: 30px;
        font-weight: 600;
        color:#104eba;
}
}

@media print, screen and (min-width: 992px) {	
	.bottom_telnum{
	font-size: 22px;	
}
}

@media print, screen and (min-width: 1200px) {	
	.bottom_telnum{
	font-size: 28px;	
}
	
}





/* sp_tel
----------------------------------------------------------*/
.sp_telicon{
	font-size:35px;
	text-align:right;
	margin-top: 12px;
}
.sp_telicon a:link,.sp_telicon a:visited {
	color:#111;
	text-decoration:none
}
.sp_telicon a:hover {
	color:#111;
	text-decoration:none
}

.sp_telicon .fa{margin: 0;}

/* email
----------------------------------------------------------*/
.header_mail{
	background: #ea5ab3;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	padding: 5px;
	color: #fff;
	text-align: center;
	display:block;
	line-height: 130%;
}
.header_mail:hover {
	background: #635245;
}
.header_mail a:link,.header_mail a:visited {
	color:#fff;
	text-decoration:none;
}
.header_mail a:hover {
	color:#fff;
	text-decoration:none;
}

.header_mail .fa{margin: 0}

/* sp_mail
----------------------------------------------------------*/
.sp_mailicon{
	font-size:35px;
}
.sp_mailicon a:link,.sp_mailicon a:visited {
	color:#ea5ab3;
	text-decoration:none
}
.sp_mailicon a:hover {
	color:#ea5ab3;
	text-decoration:none
}

.sp_mailicon .fa{margin: 0;}


/* subnavi
----------------------------------------------------------*/
#subnavi_bg{
    background: -moz-linear-gradient(left, #2c5aac 50%, #1e3c72);
  background: -webkit-linear-gradient(left, #2c5aac 50%, #1e3c72);
  background: linear-gradient(to right, #2c5aac 50%, #1e3c72);

}

.subnavi_line{
    border-left: 1px solid #3c73d4;
}

.subnavi{text-align: center;}
.subnavi a:link,.subnavi a:visited {
	color:#fff;
	text-decoration:none;
    padding:17px 10px;
    display:block;
    font-size:0.80rem;
}
.subnavi a:hover {
    display:block;
   padding:17px 10px;
    color: #fed532;
	text-decoration:none
} 

.subnavi .active a:link,.subnavi .active a:visited {
	color:#fed532;
}


@media print, screen and (min-width: 1200px){
  .subnavi a:link,.subnavi a:visited {
    padding:18px 10px;
       font-size:0.9rem;
      
}
.subnavi a:hover {
    padding:18px 10px;
} 
  
}

/* 3個の場合 */
/* .subnavi>div{width: 33%;} */

/* 2個の場合 */
.subnavi>div{width: 50%;}



/* navi
---------------------------------------------------- */
/*boot打消し*/

.navbar {
  padding: 0rem 0.3rem;
    margin: 0 auto;
}

/*navi一つあたりの余白*/
.navbar-expand-md .navbar-nav .nav-link {
    padding-right: 0.5rem;
    padding-left: 0.5rem;
  }

@media print, screen and (min-width: 992px){
  .navbar-expand-md .navbar-nav .nav-link {
    padding-right: 1rem;
    padding-left: 1rem;
  }  
}
@media print, screen and (min-width: 1200px){
  .navbar-expand-md .navbar-nav .nav-link {
    padding-right: 2rem;
    padding-left: 2rem;
  }  
}


/*sp用*/

.navbar-toggler{
    margin: 5px 0px 0;
}
@media print, screen and (min-width: 576px){
  .navbar-toggler{
    margin: 0px 0px 0;
}  
}

.navbar-toggler {
  background-color: #104eba;
}

.navbar-dark .navbar-toggler {
  border: none;
}


.navbar-nav{
/*    padding: 55px 0 0;*/
    z-index: 9999;
}
@media print, screen and (min-width: 768px){
   .navbar-nav{
    padding: 0px 0 0;
} 
}

.navbar button:focus {
  outline: none;
  outline: 0px auto -webkit-focus-ring-color;
}


.padding-none .col-12{
    padding-right: 0;
    padding-left: 0;
}


/*---*/
.bg-dark {
  background-color: #fff !important;
}

@media print, screen and (min-width: 768px){
  .bg-dark {
    border-top: 1px solid #ccc;
}  
}

a.bg-dark:hover, a.bg-dark:focus,
button.bg-dark:hover,
button.bg-dark:focus {
  background-color: #fff !important;
}
/*---*/


.navbar-dark .navbar-brand {
  color: #111;
}

.navbar-dark .navbar-brand:hover, .navbar-dark .navbar-brand:focus {
  color: #111;
    
}

.navbar-dark .navbar-nav .nav-link {
  color: #111;
}

.navbar-dark .navbar-nav .nav-link:hover, .navbar-dark .navbar-nav .nav-link:focus {
  color: #104eba;
    
}

.navbar-dark .navbar-nav .nav-link.disabled {
  color: #111;
    
}

.navbar-dark .navbar-nav .show > .nav-link,
.navbar-dark .navbar-nav .active > .nav-link,
.navbar-dark .navbar-nav .nav-link.show,
.navbar-dark .navbar-nav .nav-link.active {
  color: #104eba;
}



.navbar-dark .navbar-text {
  color: #111;
}

.navbar-dark .navbar-text a {
 color: #111;
    text-decoration: none;
}

.navbar-dark .navbar-text a:hover, .navbar-dark .navbar-text a:focus {
  color: #111;
    text-decoration: none;
}

/*---*/







/*---*/

.navbar-nav li{
    border-bottom: 1px solid #ccc;
}

@media print, screen and (min-width: 768px){
  .navbar-nav li{    
    border-right: 1px solid #ccc;
    font-weight:bold;
      border-bottom:none;
      font-size:0.80rem;
      
}  
    .border_l{ border-left: 1px solid #ccc;}
    
    .navbar-dark .navbar-nav .nav-link {
    border-bottom: 5px solid #fff;
}

    
    .navbar-dark .navbar-nav .nav-link:hover, .navbar-dark .navbar-nav .nav-link:focus {
    border-bottom: 5px solid #104eba;
    }
    
}
    
@media print, screen and (min-width: 992px){
    .navbar-nav li{  
      font-size:1rem;
} 
.navbar-dark .navbar-nav .show > .nav-link,
.navbar-dark .navbar-nav .active > .nav-link,
.navbar-dark .navbar-nav .nav-link.show,
.navbar-dark .navbar-nav .nav-link.active {
  border-bottom: 5px solid #104eba;
}
    
}


@media print, screen and (min-width: 768px){    
.navbar-dark .navbar-nav .show > .nav-link,
.navbar-dark .navbar-nav .active > .nav-link,
.navbar-dark .navbar-nav .nav-link.show,
.navbar-dark .navbar-nav .nav-link.active {
  border-bottom: 5px solid #104eba;
}
    
}



.navbar-nav a:link,.navbar-nav a:visited {
	color:#111;
	text-decoration:none;
    padding:15px 40px;
    display:block;
}
.navbar-nav a:hover {
    display:block;
    padding:15px 40px;
    color: #fed532;
	text-decoration:none
} 


/* スクロールでナビ表示
---------------------------------------------------- */
#navibar{
		background-color:#fff;/*ナビ背景色*/
		width: 100%;
		/*height: 80px;*/
		z-index: 999;
}
.navibar_container{width:100%; margin:0 auto;}

.cb-header {
  position: fixed; /* ヘッダーバーを固定 */
  top: 0; /* 上から0の位置に固定 */
  left: 0; /* 左から0の位置に固定 */
  display: none; /* ヘッダーバーを非表示 */
}

@media print, screen and (min-width: 992px){
    .cb-header .navbar-nav li{  
      font-size:0.7rem;
} 
}
@media print, screen and (min-width: 1200px){
    .cb-header .navbar-nav li{  
      font-size:0.9rem;
} 
}

@media print, screen and (min-width: 992px){
  .cb-header .navbar-expand-md .navbar-nav .nav-link {
    padding-right: 0.8rem;
    padding-left: 0.8rem;
  }  
}
@media print, screen and (min-width: 1200px){
 .cb-header .navbar-expand-md .navbar-nav .nav-link {
    padding-right: 1rem;
    padding-left: 1rem;
  }  
}



/* h2
---------------------------------------------------- */
#company_h2{
	background: url(../images/company_h2.jpg) no-repeat scroll 50% 50% / cover;	
}
#list_h2{
	background: url(../images/list_h2.jpg) no-repeat scroll 50% 50% / cover;	
}
#life_h2{
	background: url(../images/life_h2.jpg) no-repeat scroll 50% 50% / cover;	
}

#voluntary_h2{
	background: url(../images/voluntary_h2.jpg) no-repeat scroll 50% 50% / cover;	
}

#reform_h2{
	background: url(../images/reform_h2.jpg) no-repeat scroll 50% 50% / cover;	
}

#contact_h2{
	background: url(../images/contact_h2.jpg) no-repeat scroll 50% 50% / cover;	
}












.h2_tit {
    z-index: 100;
    /*top: 150px;*/
	 text-align: center;
	padding: 50px 0 50px;
	color: #fff;
	font-size: 18px;
    line-height: 140%;
}

.h2_sub {
  font-family: 'Roboto', sans-serif;
	font-weight: 400;
	font-size: 16px;
	letter-spacing: 0.8em;
}

@media print, screen and (min-width: 768px) {
	.h2_tit {
    z-index: 100;
    /*top: 250px;*/
	padding: 80px 0;
	color: #fff;
	font-size: 32px;
}
    .h2_sub {
	font-size: 20px;
    letter-spacing: 1.0em;
}
}

@media print, screen and (min-width: 992px) {
	.h2_tit {
	font-size: 40px;
}    
}





/* text_box
---------------------------------------------------- */
.text_box1 {
  border: 5px solid #009f3b;
  padding: 20px;	
  background:#fff;	
}
@media print, screen and (min-width: 768px)  {
.text_box1 {
  padding: 50px;
}
}







/* btn
---------------------------------------------------- */

.btn1{
	text-align:center;
    display:block;
    color: #fff;
}

.btn1 a:link,.btn1 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px;
    display:block;
    background: url(../images/btnicon.png) no-repeat right center #104eba;
    border-radius: 30px;
}
.btn1 a:hover {
	background: url(../images/btnicon.png) no-repeat right center #111;
    display:block;
    padding:15px;
    color: #fff;
	text-decoration:none;
    border-radius: 30px;
} 

@media print, screen and (min-width: 768px)  {
.btn1{
	text-align:center;
    display:block;
    color: #fff;
}

.btn1 a:link,.btn1 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px 20px;
    display:block;
    background: #104eba;
    background: url(../images/btnicon.png) no-repeat right center #104eba;
}
.btn1 a:hover {
	background: url(../images/btnicon.png) no-repeat right center #111;
    display:block;
    padding:15px 20px;
    color: #fff;
	text-decoration:none
}    
	
}

/*------*/

.btn2{
	text-align:center;
    display:block;
    color: #fff;
}

.btn2 a:link,.btn2 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px;
    display:block;
    background: url(../images/btnicon.png) no-repeat right center #104eba;
    border-radius: 30px;
}
.btn2 a:hover {
	background: url(../images/btnicon.png) no-repeat right center #111;
    display:block;
    padding:15px;
    color: #fff;
	text-decoration:none;
    border-radius: 30px;
} 

@media print, screen and (min-width: 768px)  {
.btn2{
	text-align:center;
    display:block;
    color: #fff;
    width: 300px;
}

.btn2 a:link,.btn2 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px 20px;
    display:block;
    background: #104eba;
    background: url(../images/btnicon.png) no-repeat right center #104eba;
}
.btn2 a:hover {
	background: url(../images/btnicon.png) no-repeat right center #111;
    display:block;
    padding:15px 20px;
    color: #fff;
	text-decoration:none
}    
	
}

/*------*/

.btn3{
	text-align:center;
    display:block;
    color: #fff;
}

.btn3 a:link,.btn3 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px;
    display:block;
    background:#666;
    border-radius: 30px;
}
.btn3 a:hover {
	background:#888;
    display:block;
    padding:15px;
    color: #fff;
	text-decoration:none;
    border-radius: 30px;
} 

@media print, screen and (min-width: 768px)  {
.btn3{
	text-align:center;
    display:block;
    color: #fff;
}

.btn3 a:link,.btn3 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px 20px;
    display:block;
    background:#666;
}
.btn3 a:hover {
	background:#888;
    display:block;
    padding:15px 20px;
    color: #fff;
	text-decoration:none
}    
	
}

/*------*/


.btn4{
	text-align:center;
    display:block;
    color: #fff;
}

.btn4 a:link,.btn4 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px;
    display:block;
    background: url(../images/btnicon.png) no-repeat right center #111;
    border-radius: 30px;
}
.btn4 a:hover {
	background: url(../images/btnicon.png) no-repeat right center #888;
    display:block;
    padding:15px;
    color: #fff;
	text-decoration:none;
    border-radius: 30px;
} 

@media print, screen and (min-width: 768px)  {
.btn4{
	text-align:center;
    display:block;
    color: #fff;
    width: 300px;
}

.btn4 a:link,.btn4 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px 20px;
    display:block;
    background: #111;
    background: url(../images/btnicon.png) no-repeat right center #111;
}
.btn4 a:hover {
	background: url(../images/btnicon.png) no-repeat right center #888;
    display:block;
    padding:15px 20px;
    color: #fff;
	text-decoration:none
}    
	
}

/*------*/

.btn5{
	text-align:center;
    display:block;
    color: #fff;
}

.btn5 a:link,.btn5 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px;
    display:block;
    background: url(../images/btnicon.png) no-repeat right center #cc9111;
    border-radius: 30px;
}
.btn5 a:hover {
	background: url(../images/btnicon.png) no-repeat right center #111;
    display:block;
    padding:15px;
    color: #fff;
	text-decoration:none;
    border-radius: 30px;
} 

@media print, screen and (min-width: 768px)  {
.btn5{
	text-align:center;
    display:block;
    color: #fff;
}

.btn5 a:link,.btn5 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px 20px;
    display:block;
    background: #cc9111;
    background: url(../images/btnicon.png) no-repeat right center #cc9111;
}
.btn5 a:hover {
	background: url(../images/btnicon.png) no-repeat right center #111;
    display:block;
    padding:15px 20px;
    color: #fff;
	text-decoration:none
}    
	
}

/*------*/





/* header
---------------------------------------------------- */

#header_navi {
    margin: 0;
    position: relative;
    z-index: 9999;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
}

.right{float: right;}

#header_logo {
    margin: 0;
    z-index: 9999;
    top: 0;
    left: 20px;
    right: 0;
}


#header_rightbox {
    margin: 0;
    z-index: 9999;
    top: 0;
    right: 100px;
	position: fixed;
}

.tel_box{
	background: #111;
	color: #fff;
	text-align: center;
	padding:10px 15px;
	line-height: normal;
	height: 86px;
}
@media print, screen and (min-width: 768px)  {
.tel_box{
	padding:15px 15px 10px;
}	
}
@media print, screen and (min-width: 992px)  {
.tel_box{
	padding:15px 15px 10px;
}		
	
}

.fs14{
	font-size: 14px;
}



/* top
---------------------------------------------------- */
/* sp header分余白---*/
#main_mt{margin-top: 55px;}

@media print, screen and (min-width: 768px){
    #main_mt{margin-top: 0px;}
}

/* main---*/
#main_bg{background:url(../images/main_bg.jpg) no-repeat scroll 50% 50% / cover;}

/*---------*/

#top_bg1{
	background: url(../images/top_bg1.jpg) no-repeat top center;
    background-position: center;
}

@media print, screen and (min-width: 768px){
#top_bg2{
	background: url(../images/top_bg2.jpg) no-repeat top center;
    background-position: 50%;
}
}

.top_box1{
    background: linear-gradient(to bottom, #f5f8fb 0%, #f5f8fb 30%, #e5edf4 30%, #e5edf4 100%);
}

.top_midashi{
    font-size: 110%;
}
@media print, screen and (min-width: 768px){
  .top_midashi{
    font-size: 100%
}  
}
@media print, screen and (min-width: 992px){
  .top_midashi{
    font-size: 110%
}  
}

.top_text1{
    background: url(../images/1.jpg) no-repeat top center #e5edf4;
    padding: 10px;
}
@media print, screen and (min-width: 992px){
  .top_text1{
    padding:20px;
}  
}

.top_text2{
    background: url(../images/2.jpg) no-repeat top center #e5edf4;
    padding: 10px;
}
@media print, screen and (min-width: 992px){
  .top_text2{
    padding:20px;
}  
}

.top_text3{
    background: url(../images/3.jpg) no-repeat top center #e5edf4;
    padding: 10px;
}
@media print, screen and (min-width: 992px){
  .top_text3{
    padding:20px;
}  
}

.top_text4{
    background: url(../images/4.jpg) no-repeat top center #e5edf4;
    padding: 10px;
}
@media print, screen and (min-width: 992px){
  .top_text4{
    padding:20px;
}  
}
/*-----*/

#top_bg3{background:url(../images/top_bg3.jpg) no-repeat scroll 50% 50% / cover;}

/*--賃貸-*/
#bg1{background:url(../images/bg1.jpg) no-repeat scroll 50% 50% / cover;
    padding: 30px 0;

}

@media print, screen and (min-width: 992px){
#bg1{background:url(../images/bg1.jpg) no-repeat scroll 50% 50% / cover;
    padding:0;
    }    
}


.rent{
    background: #104eba;
    padding: 10px;
    text-align: center;
    color: #fff;
    font-weight: bold;
    margin-bottom: 20px;
}

@media print, screen and (min-width: 992px){
  .rent{
    background: url(../images/midashi1.png) no-repeat top center;
    padding:35px 0px 0 18px;
    font-size: 22px;
      height: 214px;
      margin-bottom:0px;
/*      text-align: left;*/
}  
    /*IE*/
    _:-ms-fullscreen, :root .rent{
    padding:0px 0px 0 18px;
}
    
}

.rent h3{
    font-size: 130%;
}


/*-----*/

/* 縦横比固定 */
.photo-ofi {
	 height: 0;
	 display: block;
	padding-bottom: 75%; /* 高さを指定（ボックスの横幅を基準） */
	/*background-color: #EFEFEF;*/
	overflow: hidden;
	position: relative;
	/*margin-bottom: 10px;*/
}
.photo-ofi img {
	 max-width: inherit;
	 max-height: inherit;
	width: 100%;
	height: 100%;
	 object-fit: scale-down;
	 font-family: 'object-fit: scale-down;';
	 position: absolute;
	 left: 0;
	 top: 0;
}

.photo-ofi a{cursor: pointer;}
/*---------------------------*/

.item_box{
    background: #fff;
    padding: 10px;
}
@media print, screen and (min-width: 768px){
    .item_box{
    padding: 20px;
}    
}
@media print, screen and (min-width: 992px){
    .item_box{
    padding: 40px;
}    
}

.box_border{
    border-bottom: 1px solid #ccc;
    padding-bottom: 15px;
    margin-bottom: 15px;
}

/*
.item_space{
	padding:30px 0;
}

@media (min-width: 768px) {
.item_space{
	padding:70px 0;
}
}
*/
@media (min-width: 992px) {
.item_space{
	padding-top:80px;
    padding-bottom:80px;
}
}


/*--売買-*/
#bg2{background:url(../images/bg2.jpg) no-repeat scroll 50% 50% / cover;
    padding: 30px 0;

}

@media print, screen and (min-width: 992px){
#bg2{background:url(../images/bg2.jpg) no-repeat scroll 50% 50% / cover;
    padding:0;
    }    
}

.sale{
    background: #104eba;
    padding: 10px;
    text-align: center;
    color: #fff;
    font-weight: bold;
    margin-bottom: 20px;
}

@media print, screen and (min-width: 992px){
  .sale{
    background: url(../images/midashi2.png) no-repeat top center;
    padding:35px 0px 0 18px;
    font-size: 22px;
      height: 214px;
      margin-bottom:0px;
/*      text-align: left;*/
}  
     /*IE*/
    _:-ms-fullscreen, :root .sale{
    padding:0px 0px 0 18px;
}
    
}

.sale h3{
    font-size: 130%;
}



@media print, screen and (min-width: 992px){
.tate{-webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  -o-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
}
.ml45{margin-left: 45px;}
}
/*-----*/

@media print, screen and (min-width: 768px){
#top_bg4{
    background: url(../images/top_bg5.jpg) no-repeat;
	background-size:48% auto;
}  
}
@media print, screen and (min-width: 992px){
#top_bg4{
    background: url(../images/top_bg4.jpg) no-repeat;
	background-size:48% auto;
}  
}

/*-お問い合わせ--*/
#bg3{
    background: #f0f5f8; 
    padding: 30px 10px;
}
@media print, screen and (min-width: 768px){
 #bg3{
    background: #f0f5f8; 
    padding: 80px 0px;
}   
}

.white_box{
    background: #fff;
    padding: 10px;
}
@media print, screen and (min-width: 768px){
 .white_box{
    background: #fff;
    padding: 60px;
}   
}


@media print, screen and (min-width: 992px){
.pc_border_r{border-right: 1px solid #ccc;}
}

@media print, screen and (min-width: 768px){
    .pc_pt10{padding:10px 0 0; }    
}

.sptab_mb10{ margin-bottom: 10px;}  
@media print, screen and (min-width: 992px){
    .sptab_mb10{ margin-bottom: 0px;}    
}



/*-----*/





/* voluntary
---------------------------------------------------- */
@media print, screen and (min-width: 768px){
   .voluntary_bg1{
    background: url(../images/voluntary1.jpg) no-repeat left top;
	background-size:70% auto;
    min-height: 300px;
}
}

@media print, screen and (min-width: 992px){
   .voluntary_bg1{
    min-height: 480px;
}
}

@media print, screen and (min-width: 768px){
   .voluntary_bg2{
    background: url(../images/voluntary2.jpg) no-repeat right top;
	background-size:70% auto;
    min-height: 300px;
}
}

@media print, screen and (min-width: 992px){
   .voluntary_bg2{
    min-height: 480px;
}
}




.merit_box{
    background: #f8f6f0;
    padding: 10px;
}
@media print, screen and (min-width: 768px){
 .merit_box{
    padding: 30px;
}   
}
@media print, screen and (min-width: 992px){
 .merit_box{
    padding: 40px;
}   
}

.demerit_box{
    background: #f0f0f0;
    padding: 10px;
}
@media print, screen and (min-width: 768px){
 .demerit_box{
    padding: 30px;
}   
}
@media print, screen and (min-width: 992px){
 .demerit_box{
    padding: 40px;
}   
}


/* life
----------------------------------------------------------*/
.table_bg {background: #d2e2f0;
    text-align: center
    }


.circle{
    background: #cc9111;
    position: relative;
  display: inline-block;
  width: 120px;
  height: 120px;
  border-radius: 50%;
    color: #fff;
    font-size: 22px;
}
.circle span {
  position: absolute;
  display: inline-block;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width :120px;
  text-align:center;
}

.step_tit{
   background: #cc9111;
    color: #fff;
    font-size:130%;
    padding:8px 10px;
    margin-bottom: 15px;
}


@media print, screen and (min-width: 992px){
   #step_bg{
    background: url(../images/tateline.jpg) repeat-y; 
    background-position: 60px top;
} 
}


.life_midashi{
    background: #104eba;
    padding: 10px 10px;
    text-align: center;
    color: #fff;
    font-size: 130%;
}
@media print, screen and (min-width: 768px){
  .life_midashi{
    padding: 15px 10px;
    font-size: 22px;
}  
}

@media print, screen and (min-width: 992px){
  .life_midashi{
    font-size: 25px;
      padding: 20px 10px;
}  
}

.life_box1{
    background: #fff;
    padding: 5px;
    border: 2px solid #104eba;
    text-align: center;
    line-height:  normal;
}
@media print, screen and (min-width: 768px){
  .life_box1{
    padding: 20px;
       border: 10px solid #104eba;
}  
    .life_box1 span{
        font-size: 25px;
    }    
}

@media print, screen and (min-width: 992px){
  .life_box1{
    padding: 30px;
}  
    .life_box1 span{
        font-size: 35px;
    }    
}


/* reform
---------------------------------------------------- */
@media print, screen and (min-width: 768px){
   .reform_bg1{
    background: url(../images/reform1.jpg) no-repeat left top;
	background-size:70% auto;
    min-height: 300px;
}
}

@media print, screen and (min-width: 992px){
   .reform_bg1{
    min-height: 480px;
}
}

@media print, screen and (min-width: 768px){
   .reform_bg2{
    background: url(../images/reform2.jpg) no-repeat right top;
	background-size:70% auto;
    min-height: 300px;
}
}

@media print, screen and (min-width: 992px){
   .reform_bg2{
    min-height: 480px;
}
}







/* list
---------------------------------------------------- */

.list_btn1{
	text-align:center;
    display:block;
    color: #fff;
}

.list_btn1 a:link,.list_btn1 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px;
    display:block;
    background: url(../images/btnicon.png) no-repeat right center #104eba;
    border-radius: 30px;
}
.list_btn1 a:hover {
	background: url(../images/btnicon.png) no-repeat right center #111;
    display:block;
    padding:15px;
    color: #fff;
	text-decoration:none;
    border-radius: 30px;
} 

@media print, screen and (min-width: 768px)  {
    .list_btn1{font-size: 22px;}
.list_btn1 a:link,.list_btn1 a:visited {
    padding:15px 20px;
}
.list_btn1 a:hover {
    padding:15px 20px;
} 
}

@media print, screen and (min-width: 992px)  {
    .list_btn1{font-size: 25px;}
.list_btn1 a:link,.list_btn1 a:visited {
    padding:20px 20px;
}
.list_btn1 a:hover {
    padding:20px 20px;
} 
}
/*------*/

.list_btn2{
	text-align:center;
    display:block;
    color: #fff;
}

.list_btn2 a:link,.list_btn2 a:visited {
	color:#fff;
	text-decoration:none;
    padding:15px;
    display:block;
    background: url(../images/btnicon.png) no-repeat right center #cc9111;
    border-radius: 30px;
}
.list_btn2 a:hover {
	background: url(../images/btnicon.png) no-repeat right center #111;
    display:block;
    padding:15px;
    color: #fff;
	text-decoration:none;
    border-radius: 30px;
} 

@media print, screen and (min-width: 768px)  {
    .list_btn2{font-size: 22px;}
.list_btn2 a:link,.list_btn2 a:visited {
    padding:15px 20px;
}
.list_btn2 a:hover {
    padding:15px 20px;
} 
}

@media print, screen and (min-width: 992px)  {
    .list_btn2{font-size: 25px;}
.list_btn2 a:link,.list_btn2 a:visited {
    padding:20px 20px;
}
.list_btn2 a:hover {
    padding:20px 20px;
} 
}
/*------*/

/*検索*/

.search_box{
    margin-bottom: 30px;
}
.search_box .form-control {
  display: inline-block;
}
.form-control.w500 {
    width:70%;
}
@media (min-width: 768px) {
.form-control.w500 {width:500px;}
}
/*--------*/


.list_tit1{
    background: #104eba;
    padding: 10px 10px;
    text-align: center;
    color: #fff;
    font-size: 130%;
}
@media print, screen and (min-width: 768px){
  .list_tit1{
    padding: 15px 10px;
    font-size: 25px;
}  
}

@media print, screen and (min-width: 992px){
  .list_tit1{
    font-size: 30px;
      padding: 20px 10px;
}  
}
/*----*/

.list_tit2{
    background: #cc9111;
    padding: 10px 10px;
    text-align: center;
    color: #fff;
    font-size: 130%;
}
@media print, screen and (min-width: 768px){
  .list_tit2{
    padding: 15px 10px;
    font-size: 25px;
}  
}

@media print, screen and (min-width: 992px){
  .list_tit2{
    font-size: 30px;
      padding: 20px 10px;
}  
}

.new{
    background: #b41111;
    padding:5px 10px;
    color: #fff;
    font-family: 'Roboto', sans-serif;
    margin-bottom: 8px;
    display: inline-block;
    line-height: 100%;
    font-size: 14px;
}

.foreigner{
    background: #111;
    padding:5px 10px;
    color: #fff;
    margin-bottom: 8px;
    display: inline-block;
    line-height: 100%;
    font-size: 14px;
}

/*-ページング--*/

div.paging { text-align: center; font-size: 90%; font-family: 'Lora', serif; margin-top: 20px; line-height: 1.4em;}
div.paging span.current,
div.paging span.paging-text{
	margin:0px 0.5px;
	color:#fff;
	border:1px solid #888;
	display:inline;
	zoom:1;
	display:inline-block;
	overflow:hidden;
	text-decoration:none;
}
div.paging span.paging-text a{
	padding:5px 8.5px;
	display:block;
	color: #888;
}
div.paging span.current{
	background: #888;
	border:1px solid #888;
	color:#fff;
	display:inline;
	zoom:1;
	padding:5px 8.5px;
	text-decoration:none;
	display:inline-block;
	cursor:pointer;
}
div.paging span.paging-text a:hover{
	background: #888;
	color:#fff;
	text-decoration:none;
	cursor:pointer;
	opacity: 1;
}


/* detail
----------------------------------------------------------*/
.smallbox{
    width: 45%;
    height: auto;
}
@media print, screen and (min-width: 768px){
 .smallbox{
    width: 18%;
    height: auto;
}   
}

.detailitem{
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
    justify-content: flex-start;
    margin-bottom: 30px;
}
.item{
      width: 30%;
    margin:0 5px 10px;
}

@media print, screen and (min-width: 768px){
    .detailitem{
    justify-content: space-between;
}
   .item{
  width: 18.4%;
       margin:0 5px 10px;
} 
}

@media print, screen and (min-width: 992px){
   .item{
  width: 18.7%;
       margin:0 5px 10px;
} 
}
@media print, screen and (min-width: 1200px){
   .item{
  width: 19%;
       margin:0 5px 10px;
} 
}



.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

/*--------------------------------------
file
--------------------------------------*/
.btn_pdf{
	color:#fff;
	background-color:#111;
    margin-left: 5px;
}
.btn_pdf:hover{
	color:#fff;
}
.btn_pdf.btn {
	border-radius: 50px;
	width: 30px;
	height: 30px;
	text-align: center;
	line-height: 30px;
	padding: 0;
	font-size: 90%;
}

.file a:link,.file a:visited {
	color:#111;
}
.file a:hover {
	color:#888;
}

.file{
    margin-bottom: 10px;
}
@media print, screen and (min-width: 768px){
  .file{
    margin-bottom: 0px;
}  
}



/* contact
----------------------------------------------------------*/
.contact_tel{
    font-size: 40px;
    margin-bottom: 10px;
}
.contact_tel .fa{
    font-size: 35px;
}
@media print, screen and (min-width: 768px){
 .contact_tel{
    font-size: 50px;
}
.contact_tel .fa{
    font-size: 40px;
}   
}
@media print, screen and (min-width: 992px){
 .contact_tel{
    font-size: 60px;
}
.contact_tel .fa{
    font-size: 50px;
}   
}


/*フォームのテーブル*/
.table_form{
	width:100%;
	border-collapse:collapse;
	border-top:1px solid #ccc;
}
.table_form th{
	width:100%;
	padding:10px 5px 3px 5px;
	display: block;
}
.table_form td{
	width:100%;
	border-bottom:1px solid #ccc;
	padding:3px 5px 10px 5px;
	display: block;
}
.table_form th span{/*必須*/
	font-size:70%;
	color:#fff;
	padding:0px 6px;
	float:right;
	border-radius:3px; 
	font-weight: normal;
	border-collapse: collapse;
	background: #b41111;
}
.table_form td.last {border-bottom:none;}


.table_form th.sen_none,
.table_form td.sen_none{
	border:0;
}

@media print, screen and (min-width: 768px) {
	.table_form th{
		width:40%;
		border-bottom:1px solid #ccc;
		padding:15px 20px;
		vertical-align:middle;
		text-align:left;
		display:table-cell;
	}
	.table_form td{
		width:100%;
		padding:15px 20px;
		display:table-cell;
	}
	
	.table_form.sen_none .last td{padding-bottom: 10px;}
	.table_form.sen_none th{
		padding:10px 20px 0 20px;
	}
	.table_form.sen_none td{
		padding:10px 25px 0 25px;
	}

}
@media print, screen and (min-width: 992px) {
	.table_form th{width:30%;}
}

/* フォーム関係 */


.required input[type="text"], .required input[type="password"], .required select, .required textarea{border:1px solid #c36;}
input[type="checkbox"], input[type="radio"] {vertical-align:middle; margin:5px 5px 5px 0;}
input{font-size:100%;vertical-align:middle; padding:9px}
input[type="file"]{width: 99%;}
input[type="text"], select{border:1px solid #ccc; border-radius:3px; color: #222;}
input[type="email"]{color: #222;}

input:focus[type="text"]{border:1px solid #06c;}
textarea{font-size:100%;border:1px solid #ccc;width:99%; border-radius:3px; }
input,textarea{ 
  /*display: inline-block; 
  font-family: FontAwesome; */
  font-style: normal; 
  font-weight: normal; 
  line-height: 1; 
  -Webkit-font-smoothing: antialiased; 
  -moz-osx-font-smoothing: grayscale;
} 
select {padding: 9px; color: #222;}

.form-control {color: #222;}
.form-control.w300 {width:200px;}
@media (min-width: 768px) {
.form-control.w300 {width:250px;}
}


.privacy_waku{
	background-color: #fff;
	padding:20px 20px;
	border-collapse: collapse;
	border: 1px solid #c9ccd0;
	margin-bottom: 30px;
}
@media print, screen and (min-width: 992px){
	.privacy_waku{	padding:20px;}
}


.privacy_scroll {
  max-height:200px;
  overflow-y: scroll;
  padding-right:10px;
	z-index: 1;
}
@media print, screen and (min-width: 768px) {
.privacy_scroll {max-height:400px;}
}


.btn-primary{
	border-radius:0;
	font-size: 100%;
	padding: 15px 0;
}

.btn-primary:hover{
	background-color: #888;
	opacity: 1;
	border-color: #888;
}


.form-control {
    height: 50px;
    padding: 12px 10px;
    font-size: 14px;
    line-height: 1.42857143;
    background-image: none;
    border: 1px solid #cccccc;
    border-radius: 4px;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    -webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
    -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
}










/* footer
----------------------------------------------------------*/
#foot_bg{
    background: #204777;
    padding: 30px 0;
    color: #fff;
    font-size:14px; 
}

.foot_text{
    border-bottom: 1px solid #3e628f;
    padding-bottom: 15px;
    margin-bottom: 15px;
}
@media print, screen and (min-width: 768px){
  .foot_text{
    border-bottom: 1px solid #3e628f;
    padding-bottom: 30px;
      text-align: center;
      margin-bottom: 30px;
      
}  
}

.foot_navi{
    list-style: none;
    font-size: 13px;
}

/*
.foot_navi li:before {
    content: "\f105";
    font-family: FontAwesome;
    padding-right: 8px;
}
*/


.foot_navi a:link,.foot_navi a:visited {
	color:#fff;
	text-decoration:none;
}
.foot_navi a:hover {
    color: #999;
	text-decoration:none;
} 




	
	

/* copy
---------------------------------------------------- */
#copy_bg{
    background: #0e2a4d;
    color: #fff;
    text-align: center;
    padding: 10px 0;
}


.copy_space{
	padding:30px 0;
}

.copy{
	text-align:center;
}

@media print, screen and (min-width: 768px) {
.copy{
	text-align:right;
	font-size: 14px;
}
}


/* pagetop
---------------------------------------------------- */
#pagetop { position: fixed; bottom:10px; right:10px; z-index: 100;}
@media (min-width: 768px) {
	#pagetop { position: fixed; bottom:20px; right:20px; z-index: 100;}
}



	


/* 印刷改行
----------------------------------------------------------*/
.page-break-before  {
    page-break-before:always
}


/* print
----------------------------------------------------------*/
@media print {
	#sp_header{display:none;}
	
	#header_rightbox{display:none;}
	
	#main_text img {width: 70%; height: auto; text-align: center;}
	
	.top_text1{
	font-size: 22px;
	line-height: 180%;
	text-align: center
}

	#main_text {top: 150px;}
	#main_text2 {top: 300px;}
    
    .sample01 li::after {
	display: none;
}

	.table .thead-dark th {
  background-color: #343a40 !important;
        color: #fff;
}
   /*印刷時matchHeight無効*/ 
   .mheight {height:100% !important;}
   .mheight2 {height:100% !important;}
    
    
/*detail.html*/
    .item{
  width: 18%;
       margin:0 5px 10px;
} 
    
	
	
/*印刷時非表示*/
.display_none{display:none !important;}



}





