/* CSS Document */

/*
Theme Name: 岩手トラックターミナル
Author URI: 
Description: 岩手トラックターミナルスタイル
Author: MC
Version: 1.0
*/

@charset "utf-8";

	*, *:before, *:after {
	    -webkit-box-sizing: border-box;
	       -moz-box-sizing: border-box;
	         -o-box-sizing: border-box;
	        -ms-box-sizing: border-box;
	            box-sizing: border-box;
	}
/* ------------------------------------ YUI */
body {font:15px/1.22 arial,helvetica,clean,sans-serif;*font-size:small;*font:x-small;}
table {font-size:inherit;font:100%;}
/**
* Bump up IE to get to 13px equivalent
*/
pre,code,kbd,samp,tt {font-family:monospace;*font-size:108%;line-height:99%;}

/* ------------------------------------ YUI_END */


body {
	line-height:1;
}
body {
-webkit-text-size-adjust: 100%;
}
h1, h2, h3, h4, h5, h6,.header,a,dt,dd{
	font-family: 'Noto Sans JP', sans-serif;
}
h1, h2, h3, h4, h5, h6,footer{
	clear: both;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
	display:block;
}
#wrapper{
	width: 100%;
	margin: 0 auto;
}
nav ul {
	list-style:none;
}
.pc-on{
	display: block;
}
.pc-tb-on{
	display: block;
}
.sp-tb-on{
	display: none;
}
.sp-on{
	display: none;
}
h3{
	margin: 10px 0 0;
	font-size: 120%;
}
.float-left{
	float: left;
}
.float-right{
	float: right;
}
.t-right-1{
	margin-left: 14em;
}
.t-right-2{
	margin-left: 14em;
}
.t-right-3{
	margin-left: 10em;
}
.t-center{
	text-align: center;
}
.margin-top{
	margin-top: 50px;
}
a:hover{
	  opacity: 0.8;
}
a[href$=".pdf"]::before{
    content:"";
    display: inline-block;
    width: 24px;
    height: 24px;
    background: url(/img/icon_1r_24.png) no-repeat;
}
/* header */
.title-blue{
	width: 100%;
	background: #005BAC;
	color: #fff;
	height: auto;
	line-height: 3;
	text-align: center;
}
.title-blue .title-blue-in{
	width: 1100px;
	margin: 0 auto;
}
.title-logo{
	position: relative;
}
.title-logo h1 a{
	display: block;
	width: 623px;
	height: 46px;
	margin: 30px auto 30px;
	background:url("/img/title.gif") no-repeat;
	background-size: 623px 46px;
              text-indent:-9999em;

}

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}
/* gnav */
.gnav {
	width: 100%;
	height: auto;
	display:block;
	margin: 0 auto;
	clear: both;
	overflow: hidden;
	border-top: solid 1px #DCDCDC;
	border-bottom: solid 1px #DCDCDC;
}

.gnav ul {
	width: 1100px;
	height: auto;
	display:block;
	margin: 0 auto;
}
.gnav li {
	float: left;
	width: 100%;
	height: 70px;
	margin: 0 1px 0 0;
	list-style: none;
	text-align: center;
	position:  relative;
	display: inline-block;
	border-left: solid 1px #DCDCDC;
}
.gnav li a {
	display: block;
	padding: 27px 0 27px 40px;
	width: 100%;
	text-decoration: none;
	color: #444;
}
.gnav li.li-1{
	width: 139px;
}
.li-1::before{
	content: "";
	background: url("/img/nav-icon-1.png") no-repeat;
	background-size: 35px 35px;
	display: inline-block;
	width: 35px;
	height: 35px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 15px;
	margin: auto 0;
	z-index: -20;
}
.gnav li.li-2{
	width: 145px;
}
.li-2::before{
	content: "";
	background: url("/img/nav-icon-2.png") no-repeat;
	background-size: 35px 35px;
	display: inline-block;
	width: 35px;
	height: 35px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 15px;
	margin: auto 0;
	z-index: -20;
}
.gnav li.li-3{
	width: 160px;
}
.li-3::before{
	content: "";
	background: url("/img/nav-icon-3.png") no-repeat;
	background-size: 35px 35px;
	display: inline-block;
	width: 35px;
	height: 35px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 15px;
	margin: auto 0;
	z-index: -20;
}
.gnav li.li-4{
	width: 175px;
}
.gnav li.li-4 a{
	padding: 15px 0 15px 40px;
	line-height: 1.3;
}
.li-4::before{
	content: "";
	background: url("/img/nav-icon-4.png") no-repeat;
	background-size: 35px 35px;
	display: inline-block;
	width: 35px;
	height: 35px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 13px;
	margin: auto 0;
	z-index: -20;
}
.gnav li.li-5{
	width: 169px;
}
.li-5::before{
	content: "";
	background: url("/img/nav-icon-5.png") no-repeat;
	background-size: 35px 35px;
	display: inline-block;
	width: 35px;
	height: 35px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 15px;
	margin: auto 0;
	z-index: -20;
}
.gnav li.li-6{
	width: 155px;
	border-right: solid 1px #DCDCDC;
}
.li-6::before{
	content: "";
	background: url("/img/nav-icon-6.png") no-repeat;
	background-size: 35px 35px;
	display: inline-block;
	width: 35px;
	height: 35px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 15px;
	margin: auto 0;
	z-index: -20;
}
.gnav li.li-7{
	width: 150px;
}
.li-7::before{
	content: "";
	background: url("/img/nav-icon-7.png") no-repeat;
	background-size: 35px 35px;
	display: inline-block;
	width: 35px;
	height: 35px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 15px;
	margin: auto 0;
	z-index: -20;
}
.gnav li.li-7 a {
	display: block;
	/*padding: 27px 0 27px 40px;*/
	width: 100%;
	text-decoration: none;
}
/*
	position: absolute;
	top: -5px;
	right: 50%;
	left: 50%;
	margin-left:378px; 
	background: ;
	border: none;
	height: 50px;
	background: #fff;
	box-shadow:0 0 2px 2px rgba(0,0,0,0.1);
	 z-index: 10; 
}
.li-7::before{
	content: "";
	background: url("/img/nav-icon-7.png") no-repeat;
	background-size: 35px 35px;
	display: inline-block;
	width: 35px;
	height: 35px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 20px;
	margin: auto 0;
	z-index: -10;
}
.li-7::after{
	content: "";
	background: #fff;
	display: block;
	position: absolute;
	top: 0;
	left: 0px;
	 z-index: -20; 
}
.gnav .li-7 a {
	padding: 20px 0 20px 10px;
}
*/
.gnav li:hover,.gnav li a.selected {
	background: #eee;
    opacity: 0.9;
}


.gnav li a.selected {
	color: #F28255;
}
.gnav li.home {
	width: 154px;
}

/* ================ slide */

.bg-slider {
	width: 100%;
	height: 630px;
	background-position:center center;
	background-size: cover;
	display: flex;
	align-items: center;
	position:  relative;
	justify-content: center;
}
.bg-slider__title{
	position:  absolute;
	bottom: 50px;
	right: 50px;
	text-shadow: 1px 1px 1px #000;
}
.bg-slider__title img{
	width: 529px;
	height: 60px;
}
/* パン屑 */
.breadcrumb {
  padding-left:0;
  margin-left:0;
	width: 100%;
	max-width: 1100px;
	margin: 10px auto;
	
}

.breadcrumb li{
  display:inline;/*横に並ぶように*/
  list-style: none;
}

.breadcrumb li:after {/* >を表示*/
  content: '>';
  padding: 0 3px;
  color: #555;
	font-family: 'Noto Sans JP', sans-serif;
}

.breadcrumb li:last-child:after {
  content: '';
}

.breadcrumb li a {
  text-decoration: none;
  color: #005BAC;/*色*/
}

.breadcrumb li a:hover {
  text-decoration: underline;
}
/* topic 画像 */
.ti-2{
	background: url(/img/topic-img-1.jpg) no-repeat;
}
.ti-3{
	background: url(/img/topic-img-3.jpg) no-repeat;
}
.ti-4{
	background: url(/img/topic-img-4.jpg) no-repeat;
}
.ti-5{
	background: url(/img/topic-img-5.jpg) no-repeat;
}
.ti-6{
	background: url(/img/topic-img-6.jpg) no-repeat;
}
.ti-7{
	background: url(/img/topic-img-7.jpg) no-repeat;
}
.main-img{
    background-size:cover;                      /* 画像のサイズを指定    */
	background-position:center center;
    width:100%;
	height: 100%;
	/*min-height: 400px;*/
	min-height: 300px;
	
}
.main-title{
	width: 100%;
	text-align: center;
}
.main-title h1{
	padding: 10px 30px 10px 80px;
	margin:115px 0 0;
	background: #fff;
    display: inline-block;
	font-size: 250%;
	color: #005BAC;
	position: relative;
}
.ti-2 h1::before{
	content:'';
	background: url(/img/nav-icon-2.png) no-repeat;
	background-size: 55px 55px;
	display: inline-block;
	width: 55px;
	height: 55px;
	position: absolute;
	top: 3px;
	left: 15px;
}
.ti-3 h1::before{
	content:'';
	background: url(/img/nav-icon-3.png) no-repeat;
	background-size: 55px 55px;
	display: inline-block;
	width: 55px;
	height: 55px;
	position: absolute;
	top: 3px;
	left: 15px;
}
.ti-4 h1::before{
	content:'';
	background: url(/img/nav-icon-4.png) no-repeat;
	background-size: 55px 55px;
	display: inline-block;
	width: 55px;
	height: 55px;
	position: absolute;
	top: 3px;
	left: 15px;
}
.ti-5 h1::before{
	content:'';
	background: url(/img/nav-icon-5.png) no-repeat;
	background-size: 55px 55px;
	display: inline-block;
	width: 55px;
	height: 55px;
	position: absolute;
	top: 3px;
	left: 15px;
}
.ti-6 h1::before{
	content:'';
	background: url(/img/nav-icon-6.png) no-repeat;
	background-size: 55px 55px;
	display: inline-block;
	width: 55px;
	height: 55px;
	position: absolute;
	top: 3px;
	left: 15px;
}
.ti-7 h1::before{
	content:'';
	background: url(/img/nav-icon-7.png) no-repeat;
	background-size: 55px 55px;
	display: inline-block;
	width: 55px;
	height: 55px;
	position: absolute;
	top: 3px;
	left: 15px;
}
.404{
	position: absolute;
	top: 0px;
	left: 0px;
	
}
.topic{
	width: 100%;
	max-width: 1100px;
	/*margin: -100px auto 50px;*/
	margin: 50px auto 50px;
	background: #fff;
	box-shadow: 2px 2px 2px 2px rgba(0,0,0,0.1);
	box-shadow: 0px 0px 2px 2px rgba(0,0,0,0.1);

	padding: 20px 50px 40px;
}
.topic h2{
	margin: 30px 0 20px;
	padding-left: 20px;
	font-size: 180%;
	  border-left: 3px solid #005BAC;
	line-height: 2;
	font-weight:lighter;
}
.topic p{
	padding: 15px 0;
	line-height: 1.8;
}
.topic ol{
	padding-left: 1em;
}
.topic li{
	line-height: 1.8;
}
.topic li a{
	text-decoration: none;
	color:  #005BAC;
}
.map{
  position:relative;
}
.topic .map ul li{
	list-style:none;
}
.topic .map ul li::before{
	content: "◎";
}
.topic .img-100 img{
	max-width: 100%;
	margin: 20px 0;
}
.topic .img-60{
	max-width: 60%;
	margin: 0px ;
}
.topic .img-60 img{
	max-width: 100%;
}
.topic .p-40{
	width: 40%;
}
.topic .terminal-p{
  position: absolute;
	top: 320px;
	left: -130px;
    right: 100px;
}

.topic .network-p{
  position: absolute;
	top: 280px;

}
.topic .member li{
	padding: 15px 0 0 25px;
	border-bottom: dotted 1px #005BAC;
  position:relative;
	list-style: none;
}
.topic .member li::after {
	content: '';
  position: absolute;
  left: -0.2em;
  top:17px;
  width: 20px;
  height: 20px;
  background-color: #005BAC;
  border-radius: 50%;
}
.topic .member li::before{
	content: '';
  z-index: 2;
  position: absolute;
  left: 4px;
  top: 25px;
  width: 4px;
  height: 4px;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.topic .efforts li{
	padding: 10px 0 0 0;
}
.topic .efforts li::before{
	content: '◎';
	color:  #005BAC;
}
.topic .efforts h3{
	margin: 30px 0 20px 0;
}
.topic .efforts h3::before{
	content: '■';
}
.border-box{
	border: 2px solid #005BAC;
	padding: 10px;
}
.border-box p{
	float: left;
	width: 470px;
}
/*.box-img {
	float: right;
}*/
.box-img img{
	background: #eee;
}
.table01{
	text-align: left;
	width: 100%;
}
.table01 th{
	background: #eee;
	padding: 5px 10px;
	line-height: 1.5;
	font-size: 1em;
	  border-top: 1px solid #666;
	  border-bottom: 1px solid #666;
	  border-right: 1px solid #666;
}
.table01 td{
	padding: 5px 10px;
	line-height: 1.5;
	font-size: 1em;
	  border-top: 1px solid #666;
	  border-bottom: 1px solid #666;
}
.table02{
	text-align: left;
	width: 900px;
	margin: 0 auto;
}
.table02 th{
	background: #eee;
	padding: 5px 10px;
	line-height: 1.5;
	  border: 1px solid #666;
	text-align: center;
}
.table02 td{
	padding: 5px 10px;
	line-height: 1.5;
	  border: 1px solid #666;
}
.table02 .b-1{
	background: #0098d9;
	color: #fff;
}
.table02 .b-2{
	background: #bae2f8;
}
.table02 .b-3{
	background: #54c2f1;
	color: #fff;
}
.table02 .b-4{
	background: #d3ecfb;
}
.table02 .g-1{
	background: #5dc1cf;
	color: #fff;
}
.table02 .g-2{
	background: #d3ecf3;
}

.scroll-img{
	width: 900px;
	display: block;
	margin: 0 auto;
}

.dl01{
	line-height: 1.5;
	width: 40%;
	height: auto;
	float: left;
	margin: 0px 0 10px;
}
.dl01 dl{
	padding: 10px 0;
}
.dl01 dt{
	color: #005BAC;
}
.dl01 dd{
	padding-left: 1em;
}

.efforts-boxes{
	display:block;
	margin: 10px 10px 5px;
}
.efforts-box {
    padding: 2.2em 0;
    margin: 0 2px;
	width: 24%;
    font-weight: bold;
    color: #000;/*文字色*/
    border: solid 6px #8cc66c;/*線*/
    border-radius: 25px;/*角の丸み*/
	float: left;
	text-align: center;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 130%;
}
.efforts-box-ex{
    padding: 3.1em 0.5em;
}


.efforts-box p {
    margin: 0; 
    padding: 0;
}

.j-credit{
	width: 200px;
	margin-top: -20px;
	margin-left: 40px;
		display: inline-block;
}
.j-credit img{
	width: 200px;
}
.j-btns{
	clear: both;
	width: 100%;
	height: auto;
	display: block;
	text-align: center;
}
.j-btns a{
	display: block;
	text-decoration: none;
	padding: 20px;
    z-index: 100;
	color: #333;
	font-size: 110%;
	line-height: 2.4;
}

.j-btns a:after {
	display: inline-block;
    content: "";
	margin-left: 10px;
    border: 5px solid transparent;        /*top right bottom を透明化 */
    border-left: 5px solid #333;
}

.btn-box-1c{
		display: inline-block;
		width: 50%;
	margin: 10px auto 20px;
}
.btn-box-2c{
		display: inline-block;
		width: 50%;
		float:left;
	margin: 20px auto 20px;
}
.j-btn{
	width: 80%;
	height: auto;
	margin: 0 auto 0 ;
    border: solid 2px #aaa;
}
.j-btn-1{
	width: 80%;
	height: auto;
	margin: 0 5px 0 auto;
    border: solid 2px #aaa;
}
.j-btn-2{
	width: 80%;
	height: auto;
	margin: 0 auto 0 5px;
    border: solid 2px #aaa;
}

@media screen and (max-width:770px) { 
	.efforts-boxes{
		margin: 10px auto 5px;
		width: 100%;
	}
	.efforts-sp{
		display: inline-block;
		width: 50%;
		float:left;
	}
	.efforts-box{
    padding: 1.3em 0;
		float: none;
		width: 160px;
		height: 160px;
	font-size: 120%;
	}
	.efforts-box-ex{
	    padding: 2.3em 0.5em;
	}
	.efforts-box-1{
		margin: 0 2px 2px auto;
	}
	.efforts-box-2{
		margin: 0 auto 2px 0;
	}
}
@media screen and (max-width:500px) { 
	.efforts-box{

		width: 130px;
		height: 130px;
	font-size: 100%;
	}
}
.efforts li{
	list-style: none;
}
.arrow{
  width: 0px;
  border-color: #005BAC;
  border-style: solid;
  border-width: 60px;
  border-left-color: transparent;
  border-bottom-color: transparent;
  border-right-color: transparent;
	margin: 10px 0 -60px 428px;
}
@media screen and (max-width:1100px) { 
	.arrow{
		margin: 10px auto -50px ;
	}
}
@media screen and (max-width:770px) { 
	.arrow{
	margin: 10px auto -50px ;
	}
}

.b-font{
	font-size: 160%;
	color: #005BAC;
	margin-left: 335px;
	font-weight: bold;
	font-family: 'Noto Sans JP', sans-serif;
}

@media screen and (max-width:1100px) { 
	.b-font{
		margin-left: 0;
		text-align: center;
	}
}

@media screen and (max-width:770px) { 
	.b-font{
		margin-left: 0;
		text-align: center;
	}
}

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

#main .info-back{
	background: url(/img/info-img.jpg) no-repeat;/* 画像の表示位置を指定 */
    background-size:cover;/* 画像のサイズを指定    */
	background-position:center center;
    width:100%;
	height: 100%;
	padding: 10px 0;
	position: relative;
}

#main .info-back::before{
	content:'';
	background-image:linear-gradient(-45deg, rgba(220,220,220, 0.25) 3%, rgba(255,255,255, 0.05) 3%, rgba(255,255,255, 0.05) 50%, rgba(220,220,220, 0.25) 50%, rgba(220,220,220, 0.25) 53%, rgba(255,255,255, 0.05) 53%, rgba(255,255,255, 0.05));
    background-size: 6px 6px;
	display: inline-block;
	width: 100%;
	height: 100%;
	
	position: absolute;
	top: 0px;
	left: 0;
}
@media screen and (-webkit-min-device-pixel-ratio:0){
#main .info-back::before{
	background-image:linear-gradient(-45deg, rgba(220,220,220, 0.15) 3%, rgba(255,255,255, 0.05) 3%, rgba(255,255,255, 0.05) 50%, rgba(220,220,220, 0.15) 50%, rgba(220,220,220, 0.15) 53%, rgba(255,255,255, 0.05) 53%, rgba(255,255,255, 0.05));
}
}
@-moz-document url-prefix(){
#main .info-back::before{
	background-image:linear-gradient(-45deg, rgba(220,220,220, 0.35) 3%, rgba(255,255,255, 0.05) 3%, rgba(255,255,255, 0.05) 50%, rgba(220,220,220, 0.35) 50%, rgba(220,220,220, 0.35) 53%, rgba(255,255,255, 0.05) 53%, rgba(255,255,255, 0.05));
}
}
.info{
	width: 100%;
max-width: 1100px;
margin: auto;
	position: relative;
}

#main .info-cgi{
	width: 100%;
	max-width: 940px;
	height: 100%;
	padding: 50px 50px 0 80px;
	margin: 100px auto 100px 160px;
	background: #fff;
	min-height: 300px;
}
#main .info-title{
	width: 180px;
	height: 180px;
	position: absolute;
	top: -50px;
	left: 0px;
	background: #005BAC;
	padding: 75px 0 0 0;
	color: #fff;
	font-weight:bold;
	text-align: center;
	font-style: oblique;
	font-size: 120%;
	line-height: 1.5;
}
#main .info-title::after { /* この要素が内向きのシャドウを写真に落とす */
	position: absolute;
	display: block;
	content: "";
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	box-shadow: inset 0 0 50px rgba(255,255,255, 0.1),
	inset 0 0 100px rgba(255,255,255, 0.1);
}
#main .news-list{
	line-height: 2.4;
	  border-top: 1px solid #111;
}
#main .news-list dt{
	clear: both;
	width: 25%;
	padding: 15px 20px 15px 10px;
	  border-bottom: 1px solid #111;
	float: left;
}
.data_new{
	padding: 2px 5px;
	background: #005BAC;
	color: #fff;
	font-size: 11px;
	border-radius: 5px;
}
.news-list.hbn .data_new{
	margin: 0 5px 0 0;
}
#main .news-list dd{
	padding: 15px 0px 15px 0;
	  border-bottom: 1px solid #111;
	width: 75%;
	float: left;
}
#main .news-list dd a{
/*text-decoration: none;*/
	color: #111;
}
#main .info-cgi .prev-next{
	clear: both;
	text-align: center;
	padding: 40px 0 ;
  position: relative;
}

#main .info-cgi .prev-next::before{    
    content: "＞";
	padding-right: 10px;
	font-family: 'Noto Sans JP', sans-serif;
}
#main .info-cgi .prev-next a{
	color: #111;
}
.text-blue{
	color: #005BAC;
	font-weight: bold;
}

.column-back{
	clear:both;
	width: 100%;
	height: 100%;
	padding: 30px 0;
  position: relative;
}
.column-back::before{
	content:'';
	  background: -moz-linear-gradient(top, #9EC1FB, #FFF);
  background: -webkit-linear-gradient(top, #9EC1FB, #FFF);
  background: linear-gradient(to bottom, #9EC1FB, #FFF);
    background-size:cover;           
	display: inline-block;
	width: 100%;
	height: 450px;
	
	position: absolute;
	top: 0px;
	left: 0;
	z-index:-50;
}
.column{
	clear: both;
	width: 100%;
	max-width: 1320px;
	height: 100%;
	display: block;
	margin: 10px auto ;
}
.column div.column-3{
	width: 100%;
	max-width: 440px;
	height: 100%;
	padding: 0px;
	float: left;
	margin-bottom: 60px;
  position: relative;
}
.column .column-a .column-pic{
	width: 100%;
	max-width: 400px;
	height: 260px;
	background: url(/img/column_1.jpg) no-repeat 0 0;
	background-position:center center;
	background-size: cover;
	display:block;
	margin: 0 auto;
	
}
.column .column-b .column-pic{
	width: 100%;
	max-width: 400px;
	height: 260px;
	background: url(/img/column_2.jpg) no-repeat 0 0;
	background-size: 400px 260px;
	display:block;
	margin: 0 auto;
	
}
.column .column-c .column-pic{
	width: 100%;
	max-width: 400px;
	height: 260px;
	background: url(/img/column_3.jpg) no-repeat 0 0;
	background-size: 400px 260px;
	display:block;
	margin: 0 auto;
	
}
.column .column-sen{
	width: 100%;
	max-width: 360px;
	height: 100%;
	min-height: 285px;
	padding: 20px;
	background: #fff;
	box-shadow:0px 0px 2px 2px rgba(0,0,0,0.1);
	margin: -80px auto 0;
}
.column .column-sen h3{
	font-size: 130%;
	text-align:center;
	padding: 10px;
  display: block;
  position: relative;
	font-weight:lighter;
  left: 50%;
  -moz-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translate(-50%); /*位置調整*/
}
.column .column-sen h3:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -10px; /*下線の上下位置調整*/
  display: inline-block;
  width: 50px; /*下線の幅*/
  height: 2px; /*下線の太さ*/
  -moz-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translate(-50%); /*位置調整*/
  background-color: #005BAC; /*下線の色*/
	
}
.column .column-sen p{
	padding: 30px 10px 10px;
	line-height: 1.5em;
}
.column .column-btn {
	width: auto;
	max-width: 180px;
	background: #005BAC;
	color: #fff;
	font-weight:bold;
	text-align: center;
	line-height: 3em;
  position: absolute;
	bottom: 30px;
	left: 130px;
	right:130px;
}
.column .column-btn:hover {
	
	  opacity: 0.8;
}

@media all and (-ms-high-contrast: none){
	.column .column-btn{
		left: 130px;
		right: 130px;
	}
}

.column .column-btn a{
	text-decoration: none;
	color: #fff;
	display: block;
}
.column .column-btn a::before{    
    content: "＞";
	padding-right:10px;
	font-family: 'Noto Sans JP', sans-serif;
}

/*.service-3{
	float: left;
	width: 50%;
	margin: 10px auto;
	
}
.service-3 figure{
	width: 400px;
	margin: 0px auto;
}
.service-3 img{
	width: 400px;
}
.service-3 figcaption{
	margin: 0 0 10px 0;
}*/

/*===施設のご案内====
  構内サービス施設のご案内*/
figure.wp-block-image.ph_2colum {
	padding: 30px 0 0;
	position: relative;
}

figure.wp-block-image.ph_2colum img{
	margin: 0 auto;
	width: 420px;
	display: block;
}

figure.wp-block-image.ph_2colum figcaption{
	position: absolute;
    top: 0;
    left: 32px;
}


.top-map{
	clear:both;
	width: 100%;
	max-width: 1320px;
	height: 100%;
	text-align: center;
	margin: 0px auto 80px;
	display: block;
}
.top-map .map-sen{
	width: 100%;
	max-width: 700px;
	height: 100%;
	text-align: left;
	padding: 40px;
	line-height: 1.5em;
	background: #fff;
	margin: -180px auto 0;
    display: block;
	box-shadow:0 0 2px 2px rgba(0,0,0,0.1);
	position: relative;

}
.top-map .map-li{
	padding: 30px 0 20px;
}
.top-map .map-li li{
              padding-left:20px;
              position:relative;
	list-style: none;
}

.top-map .map-li li::before{
	color: #005BAC;
	padding-right: 10px;
              width: 10px;
              height: 10px;
             position: absolute;
              top: 0;
              bottom:0;
              left: 0;
              z-index: 2;
              content: '';
              width: 10px;
              height: 10px;
              margin:auto 0;
              background-color: #005BAC;
              -webkit-transform: rotate(45deg);
              transform: rotate(45deg);
}
.top-map .map-det{
	text-align: center;
	padding: 20px 0 10px;
}
.top-map .map-det::before{
	content:'[';
}
.top-map .map-det::after{
	content:']';
}
iframe{
	width: 100%;
	max-width: 1100px;
	height: 530px;
	margin: 10px 0 20px;
}

#footer{
	text-align: center;
	margin: 20px 0;
}
#footer .footer-t{
	font-size: 120%;
	margin: 10px 0;
	font-weight: bold;
}
#footer p{
	font-size: 95%;
	line-height: 1.4em;
}
.copy{
	font-size: 90%;
	margin: 30px 0 30px;
}


.to-top{
  position: fixed;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
  right: 0;
  bottom: 0;
  font-size: 50px;
  font-weight: bold;
  color: #fff;
  background: #000;
  cursor: pointer;
}
/* ================ back-top-wrap */
.to-top {
	position: fixed;
	width: 60px;
	height: 60px;
	bottom: 20px;
	right: 20px;
	z-index: 999;
    background: #005BAC;
    text-decoration: none;
    color: #fff;
    padding: 22px 0;
    text-align: center;
    display: block;
    border-radius: 40px;
	font-size: 110%;
}
.to-top a:hover {
    text-decoration: none;
    background: #999;
}

/*===３つの取り組み*/
.wp-block-columns.efforts{
	margin-bottom:0;
}

.wp-block-columns.nowrap{
	margin-bottom:0;
}


/* ================ お知らせ一覧 */
.topic dl.news-list {
    line-height: 2.4;
    border-top: 1px solid #111;
}

.topic .news-list dt {
    width: 20%;
    padding: 15px 20px 15px 10px;
    border-bottom: 1px solid #111;
	float: left;
}

.topic .news-list dd {
    padding: 15px 0px 15px 0;
    border-bottom: 1px solid #111;
    width: 80%;
    float: left;
}

.topic dl.news-list:before,
.topic dl.news-list:after {
	content:"";
	display:block;
	overflow:hidden;
}
.topic dl.news-list:after {
	clear:both;
}



/* ================ お知らせ詳細 */
p.news-date{
    margin: 0 0 15px;
    padding: 0;
	border-bottom: solid 1px #aaa;
}

.btn{
	margin:  0 auto;
	width: auto;
    max-width: 180px;
    background: #005BAC;
    font-weight: bold;
    text-align: center;
    line-height: 3em;
}

.btn a{
    color: #fff;
	text-decoration: none;
	display: block;
}

.btn a::before {
    content: "＞";
    padding-right: 10px;
    font-family: 'Noto Sans JP', sans-serif;
}

/* ================ wp-pagenavi */

.wp-pagenavi{
	padding: 15px 0 0 0; 
}

.wp-pagenavi a, 
.wp-pagenavi span{
	border: none;
	padding: 0;
	margin: 0;
}

span.pages{
	display: none;
}

span.current{
	margin:0 10px;
	border-bottom: solid 1px;
    padding: 2px;
}

a.page.smaller,
a.page.larger,
a.previouspostslink,
a.nextpostslink{
	margin:0 10px;
	color: #333;
	text-decoration: none;
}




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


	.column-back{
		width: 100%;
		
	}
	.column{
		width: 100%;
		margin: 0 auto;
	}
	.column div.column-3{
		display:inline-block;
		width: 33%;
		max-width: 440px;
		height: 100%;
		padding: 5px;
		margin-bottom: 30px;
	}
	.column .column-btn{
		max-width: 180px;
	  position: static;
		margin: 10px auto;
		
	}
	.column-a{
			display: block;
		margin: 0 auto;
	}
	.column-b{
			display: block;
		margin: 0 auto;
	}
	.column-c{
			display: block;
		margin: 0 auto;
	}


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

	.pc-on{
		display: none;
	}
	.pc-tb-on{
		display: block;
	}
	.sp-tb-on{
		display: block;
	}
	.sp-on{
		display: none;
	}
.float-left{
	float: none;
}
.float-right{
	float: none;
}
a[href$=".pdf"]::before{
	background-size: 18px 18px;
    width: 18px;
    height: 18px;
}
/*      ハンバーガー     */

/*============
nav
=============*/
	nav {
	  display: block;
	  position: fixed;
	  top: 0;
	  left: -300px;
	  bottom: 0;
	  width: 300px;
	  background: #ffffff;
	  overflow-x: hidden;
	  overflow-y: auto;
	  -webkit-overflow-scrolling: touch;
	  transition: all .5s;
	  z-index: 3;
	  opacity: 0;
	}
	.open nav {
	  left: 0;
	  opacity: 1;
	}
	nav .gnav {
	  padding: 25px 25px 25px 20px;
	border-bottom: none;
	}
	nav .gnav ul {
	width: 100%;
	  list-style: none;
	  margin: 0;
	  padding: 0;
	}
	nav .gnav ul li {
	  position: relative;
	  margin: 0;
	height: auto;
	border-left: none;
	  border-bottom: 1px solid #005BAC;
	text-align: left;
	}
	nav .gnav ul li a {
	  display: block;
	  color: #005BAC;
	  font-size: 14px;
	  padding: 1em;
	padding-left: 40px;
	  text-decoration: none;
	  transition-duration: 0.2s;
	}
	.gnav li.li-4 a{
		padding: 1em 0 1em 40px;
		line-height: 1.0;
	}
	.gnav li.li-6{
		border-right: none;
	}
	.gnav li.li-1,
	.gnav li.li-2,
	.gnav li.li-3,
	.gnav li.li-4,
	.gnav li.li-5,
	.gnav li.li-6,
	.gnav li.li-7{
		width: 100%;
		background: none;
	}
/*
	.gnav li.li-7{
		position:  relative;
		top: 0;
		right: auto;
		left: 0;
		margin-left:0; 
		background: #fff;
		border: none;
		width: 100%;
		height: 100%;
		  font-size: 14px;
		line-height: 1.0;
		filter: none;
		  border-bottom: 1px solid #005BAC;
	}
	.gnav li.li-7 a{
		padding: 0;
		width: 100%;
		height: 100%;
		  padding: 1em;
		padding-left: 40px;
	}

	.gnav li.li-7:hover{
		background: none;
		width: 100%;
		height: 100%;
		
	}
*/
	/*====i podのサイズ追加*/
	@media screen and (max-width: 768px) {
	 	
		/*===施設のご案内*/

		figure.wp-block-image.ph_2colum figcaption{
			left:0;
		}
		
		/*====アクセス*/
		.wp-block-column.flex100{
		    flex-basis: 100%!important;	
		}
		
		.wp-block-column.map{
			margin: 0;
			flex-basis: 100%!important;	
		}
		
		
		/*===３つの取り組み*/

		.wp-block-columns.nowrap{
				flex-wrap: nowrap;
		}

		.wp-block-column.j-credit{
			flex-basis:100%!important;
		}

		.wp-block-columns.column-reverse .wp-block-column{
			flex-basis:100%!important;
		}
		
	}
	

	@media screen and (max-width: 767px) {
	  nav {
	    left: -270px;
	    width: 270px;
	  }
		
	}
	/*============
	.toggle_btn
	=============*/
	.toggle_btn {
	  display: block;
	  position: absolute;
	  top: 10px;
	  right: 10px;
	  width: 50px;
	  height: 50px;
	  transition: all .5s;
	  cursor: pointer;
	  z-index: 3;
	  background-color: #005BAC;
	}
	.toggle_btn span {
	  display: block;
	  position: absolute;
	  left: 10px;
	  width: 30px;
	  height: 2px;
	  background-color: #fff;
	  border-radius: 4px;
	  transition: all .5s;
	}
	.toggle_btn span:nth-child(1) {
	  top: 14px;
	}
	.toggle_btn span:nth-child(2) {
	  top: 24px;
	}
	.toggle_btn span:nth-child(3) {
	  bottom: 14px;
	}
	.open .toggle_btn span {
	  background-color: #fff;
	}
	.open .toggle_btn span:nth-child(1) {
	  -webkit-transform: translateY(10px) rotate(-315deg);
	  transform: translateY(10px) rotate(-315deg);
	}
	.open .toggle_btn span:nth-child(2) {
	  opacity: 0;
	}
	.open .toggle_btn span:nth-child(3) {
	  -webkit-transform: translateY(-10px) rotate(315deg);
	  transform: translateY(-10px) rotate(315deg);
	}
	/*============
	#mask
	=============*/
	#mask {
	  display: none;
	  transition: all .5s;
	}
	#header{
		padding: 5px;
	}
	.breadcrumb{
		padding: 5px;
	}
	.open #mask {
	  display: block;
	  position: fixed;
	  top: 0;
	  left: 0;
	  width: 100%;
	  height: 100%;
	  background: #000;
	  opacity: .8;
	  z-index: 2;
	  cursor: pointer;
	}
	.bg-slider {
		width: 100%;
		height: 80vh;
	}
	.title-blue .title-blue-in{
		width: 100%;
	}
	.li-1,
	.li-2,
	.li-3,
	.li-4,
	.li-5,
	.li-6,
	.li-7{
		padding: 0px;
	}
	.li-1::before,
	.li-2::before,
	.li-3::before,
	.li-4::before,
	.li-5::before,
	.li-6::before,
	.li-7::before{
		left: 0;
	}
.gnav li.li-7{
	box-shadow:none;
}

	#main .info-back{
	    width:100%;                              /* 横幅のサイズを指定    */
	    height:100%; 
	}

	#main .info{
		clear: both;
		width: 100%;
		height: auto;
		display: block;
		margin: 0 auto;
		position:  relative;
	}
	#main .info-cgi{
		width: 95%;
		height: 100%;
		padding: 30px 15px 0px;
		margin: 90px auto 50px;
	min-height: 250px;
	}

	#main .info-title{
		width: auto;
		height: auto;
		position: absolute;
		padding: 10px 0;
		top: -70px;
		left: 30vw;
		right: 30vw;
	}

	#main .news-list{
	 border-top: 1px solid #111;
	line-height: 1.0;
	}
	#main .news-list dt,
	.news-list.hbn dt{
		clear: both;
		width: 100%;
		padding: 15px 0px 5px 5px;
		  border-bottom: none;
		float: none;
		line-height: 1;
	}
	#main .news-list dd,
	.news-list.hbn dd{
		padding: 5px 0px 15px 5px;
		  border-bottom: 1px solid #111;
		width: 100%;
		float: none;
		line-height: 1.25;
	}
	#main .news-list dd a,
	.news-list.hbn dd a{
	    text-decoration: none;
		color: #111;
	}
	#main .info-cgi .prev-next{
		clear: both;
		text-align: center;
		padding: 30px 0 ;
	}

	#main .info-cgi .prev-next a{
		color: #111;
	}
	.title-blue{
		background: #fff;
		color: #005BAC;
		font-weight:lighter;
		font-size: 85%;
		height: auto;
		line-height: 1.1em;
		padding: 30px 80px 10px 10px;
	}
.border-box p{
	float: none;
	width: 100%;
}
.box-img{
	float: none;
	display: block;
	margin: 0 auto;
}
.box-img img{
	max-width: 100%;
	display: block;
	margin: 0 auto;
}

	.topic{
		width: 95%;
		padding: 20px 20px;
	}
	.topic h2{
		margin: 20px 0 15px;
		padding-left: 15px;
		font-size:160%;
	}
.topic .img-60{
	width: 100%;
	max-width: 600px;
	margin: 0px auto;
}
.topic .img-60 img{
	max-width: 100%;
}
.topic .p-40{
	width: 100%;
	margin: 10px 0;
}
.topic .terminal-p{
  position: static;
}
.topic .network-p{
  position: static;
	padding-right: 0px;
}

	.top-map{
		width: 100%;
		height: auto;
		margin: 30px auto 50px;
	}
	.scroll{
		overflow: scroll;
	}
	.dl01{
		width: 50%;
	}

	iframe{
		width: 100%;
	}
	.top-map .map-sen{
		width: 80vw;
		height: 100%;
		background: #fff;
		z-index: 999;
		margin: -120px auto 0;
	}
	.service-3{
		float: left;
		width: 50%;
		padding: 2px;
	}
	.service-3 figure{
		width: auto;
		max-width: 100%;
	}
	.service-3 img{
		max-width: 100%;
	}
.j-credit{
	margin: 10px 0 0;
	display: block;
	width: 100%;
}
.j-credit img{
	margin: 0 auto;
	display: block;
	width: 200px;
}
.j-btns a{
	font-size: 100%;
	line-height: 1.8;
	padding: 10px;
}
.j-btn{
	width: 100%;
}
.j-btn-1{
	width: 95%;
}
.j-btn-2{
	width: 95%;
}
.service-3 figcaption{
	font-size: 90%;
}
	
	
	
@media screen and (max-width:650px) { 
	.pc-on{
		display: none;
	}
	.pc-tb-on{
		display: none;
	}
	.sp-tb-on{
		display: block;
	}
	.sp-on{
		display: block;
	}
	.toggle_btn {
	  top: 0px;
	  right: 0px;
	}
	.bg-slider {
		width: 100vw;
		height: 50vh;
	}
	.bg-slider__title{
		bottom: 20px;
		left: 0px;
	}
	.bg-slider__title img{
		width: 80vw;
		height: auto;
	}
	.main-title h1{
		padding: 10px 10px 10px 50px;
		margin: 80px 0 0;
	    display: inline-block;
		font-size: 170%;
		line-height: 1.3;
		position: relative;
	}

	.main-img {
		min-height: 250px;
	}
	.main-img .ti-2 h1::before{
		content:'';
		background: url(/img/nav-icon-2.png) no-repeat;
		background-size: 45px 45px;
		display: inline-block;
		width: 45px;
		height: 45px;
		position: absolute;
		top: 3px;
		left: 3px;
	}
	.ti-2 h1::before,
	.ti-3 h1::before,
	.ti-4 h1::before,
	.ti-5 h1::before,
	.ti-6 h1::before,
	.ti-7 h1::before{
		background-size: 48px 48px;
		display: inline-block;
		width: 48px;
		height: 48px;
		position: absolute;
		top: 2px;
		left: 1px;
	}
	.topic{
		/*margin: -180px auto 10px;*/
		margin: 20px auto 10px;
		padding: 20px ;
	}
	#header{
		box-shadow:0px 0px 2px 2px rgba(0, 0, 0, 0.1);
	}
	.title-logo h1 a {
	width: 100%;
	max-width: 411px;
	height: 64px;
	margin: 15px auto 6px;
	background:url("/img/title_sp.gif") no-repeat;
	background-size: contain;
	}
	.top-map{
		margin: 10px auto 50px;
	}
	#main .info-title{
		top: -70px;
		left: 3%;
		right: 3%;
	}

	#main .info-back{
	    width:100%;                              /* 横幅のサイズを指定    */
	    height:100%; 
	}
	#main .info-cgi{
		width: 94%;
		height: 100%;
		margin: 90px auto 20px;
	}
	#main .info{
		clear: both;
		width: 100%;
		height: auto;
		display: block;
		margin: 0 auto;
		position:  relative;
	}
	iframe{
		height: 500px;
	}
	.top-map .map-sen{
		padding: 30px 20px 20px;
		margin: -120px auto 0;
		height: 100%;
		width: 94vw;
	}
	.top-map .map-li{
		padding: 30px 0 10px;
	}

	.top-map .map-det{
		text-align: center;
		padding: 20px 0 20px;
	}
	.title-blue{
		padding: 12px 60px 10px 10px;
		text-align: left;
	}

.topic .img-100 img{
	margin: 10px 0;
}
.table01{
	width: 700px;
}

.table01 th{
	padding: 4px;
	line-height: 1.3;
}
.table01 td{
	padding: 4px;
	line-height: 1.3;
}
.table02{
	width: 400px;
}
.scroll-img{
	width: 500px;
}
.table02 th{
	padding: 4px;
	line-height: 1.3;
}
.table02 td{
	padding: 4px;
	line-height: 1.3;
}
.dl01 dl{
	padding: 7px;
}

	.dl01{
		width: 100%;
		float: none;
	line-height: 1.3;
	}

	#footer{
		text-align: center;
		margin: 50px 0 20px;
	}
	#footer p{
		line-height: 1.2em;
	}
	#footer a{
		text-decoration: none;
	}
	
/*===施設のご案内====
  構内サービス施設のご案内*/
	.wp-block-columns.service_2colum{
		flex-wrap: nowrap;
		margin: 0;
	}
	.wp-block-columns.service_2colum .wp-block-column:first-child{
		padding-right: 2px;
	}
	
	.wp-block-columns.service_2colum .wp-block-column:last-child{
		padding-left: 2px;
	}
	
	figure.wp-block-image.ph_2colum figcaption{
		left: 0;
	}
	
	/*===３つの取り組み====*/
	
	.wp-block-columns.efforts .wp-block-column{
		margin: 0 10px 0;
	}

	.wp-block-columns.nowrap{
		margin-bottom: 5px;
		flex-wrap: nowrap;
	}
	
	.wp-block-columns.nowrap.column-reverse{
		flex-direction: column-reverse;
	}
	
	.wp-block-columns.efforts  .wp-block-column.efforts-box{
		margin: 0 2px;
	}

	.wp-block-columns.column-reverse{
		margin-bottom: 0;
		flex-direction: column-reverse;
	}
}
		
	

@media screen and (max-width:750px) { 
	.column{
		height: 100%;
	}
	.column div.column-3{
		width: 100%;
		float: none;
		height: 100%;
		display:block;
	}
	.column .column-sen{
		width: 80%;
		max-width: 360px;
		min-height: 0px;
		height: 100%;
		padding: 10px 5px;
	}
}

@media all and (-ms-high-contrast: none){




.column .column-sen h3{
	font-size: 130%;
	text-align:center;
	padding: 10px;
	display: block;
	margin: 0 auto;
	position: static;
	font-weight:lighter;
	-ms-transform: none;
	}
	
	.column .column-sen h3:before {
	  content: none;
		
	}

}
