@charset "utf-8";

/**********************************/
/*   ・共通設定                    */
/*   ・ヘッダーブロック            */
/*   ・グローバルナビ              */
/*   ・bodyブロック                */
/*   ・フッターブロック            */
/*   ・トップページ                */
/*   ・共通で使用するクラス        */
/*   ・タブレット用クラス          */
/**********************************/

/*----------------------------------
  共通設定
----------------------------------*/
html {
  font-size: 62.5%;
}

body {
  line-height:1;
  font-family: 'Lucida Grande', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
  margin: 0 auto; 
  font-size: 14px;
  font-size: 1.4rem;
  text-align: center;
  color: #444;
  /*
  -webkit-text-size-adjust: 100%;
  */
}

input, select {
  vertical-align:middle;
}

td {
  word-break: break-all;
}

a {
  text-decoration: none;
  display: block;
  color: #000;
}

a:hover {
  text-decoration: underline;
}

a:hover img {
  text-decoration:  none;
  background: transparent;
  opacity:0.9;
  filter/*\**/: alpha(opacity=90)\9; /* IE7,8 */
  -ms-filter/*\**/: "alpha(opacity=90)"\9; /* IE7,8 */
}

h1 {
  font-weight: 400;
}

h2 {
  width: 100%;
  margin: 0 auto;
  position: relative;
  display: inline-block;
  height: 120px;
  line-height: 70px;
  font-size:38px;
  font-size: 3.8rem;
  color: #fff;
  letter-spacing: .3em;
}

h2::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 1px;
  height: 40px;
  margin: auto;
  background-color: #fff;
}

h2.blue {
  width: 100%;
  margin: 0 auto;
  position: relative;
  display: inline-block;
  height: 120px;
  line-height: 70px;
  font-size:38px;
  font-size: 3.8rem;
  color: #004da0;
  letter-spacing: .3em;
}

h2.blue::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 1px;
  height: 40px;
  margin: auto;
  background-color: #004da0;
}

h3 {
  padding: 10px 0;
  margin: 50px auto 30px;
  font-size:35px;
  font-size: 3.5rem;
  font-weight: 600;
  color: #e50012;
}

/* container */
#container {
  width: 100%;
  height: auto;
  margin: 0 auto;
  padding: 0;
  overflow:hidden;
}

.fade-up {
  transition: opacity 1.3s;
  -moz-transition: opacity 1.3s;
  -webkit-transition: opacity 1.3s;
  -o-transition: opacity 1.3s;
  transition: transform 1.3s;
  -moz-transition: transform 1.3s;
  -webkit-transition: transform 1.3s;
  -o-transition: transform 1.3s;
}

h4 {
  padding: 0.25em 0.5em;/*上下 左右の余白*/
  color: #002745;/*文字色*/
  background: transparent;/*背景透明に*/
  border-left: solid 5px #002745;/*左線*/
  font-size:20px;
  font-size: 2rem;
  margin: 20px 0;
}
/*----------------------------------
  ヘッダーブロック
----------------------------------*/
#header_block {
  width: 100%;
  height: 0;
  margin:0 auto;
  z-index: 100;
  top:0;
  padding: 0;
  position: absolute;
  /*background-color: rgba(250,250,250,1);
  box-shadow: 0px 9px 3px -3px rgba(0,0,0,0.1);
  -webkit-box-shadow: 0px 9px 3px -3px rgba(0,0,0,0.1);
  -moz-box-shadow: 0px 9px 3px -3px rgba(0,0,0,0.1);*/
}

#header_block .headerbox {
  margin: 0 auto;
  text-align: center;
}

#header_block.fixed .headerbox {
  position: fixed;
  top: 0;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 75px;
  background-color: rgba(250,250,250,.7);
  box-shadow: 0px 9px 3px -3px rgba(0,0,0,0.1);
  -webkit-box-shadow: 0px 9px 3px -3px rgba(0,0,0,0.1);
  -moz-box-shadow: 0px 9px 3px -3px rgba(0,0,0,0.1);
}

#header_block .headerbox .header-fixed {
  width: 70%;
  float: right;
}

/*----------------------------------
  グローバルナビゲーション
----------------------------------*/
#gl-navi {
  width: 100%;
  height: auto;
  margin: 0 auto;
  list-style-type: none;
  text-align:center;
  position: relative;
  z-index: 20;
}

#gl-navi #glnavi-ul {
  width: auto;
  height: auto;
  margin: 0 auto;
  padding: 0;
  /*min-width: 1000px;*/
  display: flex;
  /*white-space: nowrap;*/
  position: absolute;
  right: 0;
}

#gl-navi #glnavi-ul .glnavi-li {
  float: left;
  text-align: center;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  position: relative;
  padding: 0;
  margin: 0;
  display: inline-block;
}

#gl-navi #glnavi-ul .glnavi-li a {
  font-size:105%;
  letter-spacing: .2em;
  display: block;
  padding: 30px;
}

#gl-navi #glnavi-ul .glnavi-li a:hover {
  text-decoration: none;
  color: #fff;
  background: #004da0;
}
/*----------------------------------
  bodyブロック
----------------------------------*/
/* メインブロック */
#top-main-block {
  width: 100%;
  height: auto;
  margin: 0 auto;
}

#main-block {
  width: 100%;
  height: auto;
  margin: 0 auto;
}
    
/* ページトップ */
#pagetop-box {
  width: 100%;
  text-align: right;
}

#pagetop-box #pagetop {
  display: block;
  width: 100px;
  height: 100px;
  /*background: url(../images/common/pagetop.png) no-repeat top center;*/
  background-color: transparent;
  position: fixed;
  bottom: 20px;
  right: 20px;
}

#pagetop-box #pagetop img {
  width: 100px;
  height: 100px;
}

#pagetop-box #pagetop:hover {
  text-decoration:  none;
  background: transparent;
  opacity:0.9;
  filter/*\**/: alpha(opacity=90)\9; /* IE7,8 */
  -ms-filter/*\**/: "alpha(opacity=90)"\9; /* IE7,8 */
}

/*----------------------------------
  フッターブロック
----------------------------------*/
#footer-block {
  width: 100%;
  height: auto;
  padding: 30px 0 0;
  margin: 0 auto;
  text-align: center;
  background: linear-gradient(90deg, rgb(0, 96, 175), rgb(0, 77, 160));
  min-width: 1200px;
  color: #fff;
}

#footer-block .ft-info {
  width: 1100px;
  height: auto;
  margin: 0 auto;
  padding: 70px 0;
}

#footer-block .ft-info .logo {
  color: #fff;
  font-size: 35px;
  font-size: 3.5rem;
  padding: 0;
}

#footer-block .ft-info .logo a {
  letter-spacing: .2em;
  display: block;
  color: #fff;
}

#footer-block .ft-info .logo a:hover {
  text-decoration: none;
}


#footer-block .ft-info .footer-add {
  font-size: 16px;
  font-size: 1.6rem;
  padding: 15px 0 0;
  line-height: 2;
}

/* コピーライトブロック */
#copyright-block {
  width: 100%;
  height: auto;
  padding: 20px 0;
  text-align: center;
  font-size: 12px;
  font-size: 1.2rem;
  color:#fff;
  background: linear-gradient(90deg, rgb(0, 96, 175), rgb(0, 77, 160));
  min-width: 1200px;
  position:relative;
  bottom:0;
}

/*----------------------------------
  トップページ
----------------------------------*/
/* background */
.top-bgbox {
  width: 100%;
  height: auto;
  margin: 0;
  padding: 100px 0 50px;
  background: linear-gradient(90deg, rgb(0, 96, 175), rgb(0, 77, 160));
  min-width: 1200px;
}

.top-bgbox2 {
  width: 100%;
  height: 81px;
  margin: 0 auto;
  min-width: 1200px;
  background:url(../images/common/bg_01.png) no-repeat top center;
}

.top-bgbox3 {
  width: 100%;
  height: 81px;
  margin: 0 auto;
  min-width: 1200px;
  background:url(../images/common/bg_02.png) no-repeat top center;
}

.top-bgbox4 {
  width: 100%;
  height: auto;
  margin: 0;
  padding: 70px 0 50px;
  background: #f0f0f0;
  min-width: 1200px;
}

.top-bgbox5 {
  width: 100%;
  height: 81px;
  margin: 0 auto;
  min-width: 1200px;
  background:url(../images/common/bg_03.png) no-repeat top center;
}

.top-bgbox6 {
  width: 100%;
  height: auto;
  margin: 0;
  padding: 100px 0 50px;
  background: #fffff7;
  min-width: 1200px;
}

.top-bgbox7 {
  width: 100%;
  height: 81px;
  margin: 0 auto;
  min-width: 1200px;
  background:url(../images/common/bg_04.png) no-repeat top center;
}

.top-bgbox8 {
  width: 100%;
  height: 81px;
  margin: 0 auto;
  min-width: 1200px;
  background:url(../images/common/bg_05.png) no-repeat top center;
}

/* welcomeスライダー */
#welcomebox {
  position: relative;
  z-index: 2;
  width: 100%;
  margin: 50px auto 0;
  vertical-align: bottom;
  background: linear-gradient(90deg, rgb(0, 96, 175), rgb(0, 77, 160));
}

.mainimg-box img {
  width: 100%;
  min-width: 1200px;
  vertical-align: bottom;
  display: block; 
}

.top-contebox {
  width: 1100px;
  height: auto;
  margin: 0 auto;
}

/* 政策 */
.seisaku {
  width: 100%;
  margin: 0 auto;
}

.seisaku-l {
  width: 50%;
  margin:0 auto;
  display: table-cell;
  vertical-align: middle;
  float: left;
}

.seisaku-r {
  width: 50%;
  margin:0 auto;
  display: table-cell;
  vertical-align: middle;
  float: right;
}

.seisaku-box {
  width: 90%;
  margin: 20px auto 0;
  padding: 0 10px;
  height: auto;
  display:-webkit-box;
  display:-moz-box;
  display:-ms-box;
  display:-webkit-flexbox;
  display:-moz-flexbox;
  display:-ms-flexbox;
  display:-webkit-flex;
  display:-moz-flex;
  display:-ms-flex;
  display:flex;
  -webkit-box-lines:multiple;
  -moz-box-lines:multiple;
  -webkit-flex-wrap:wrap;
  -moz-flex-wrap:wrap;
  -ms-flex-wrap:wrap;
  flex-wrap:wrap;
}

.seisaku-box dd {
  width: 100%;
  margin:0 auto 40px;
  padding: 0 2rem 3rem;
  display: table-cell;
  vertical-align: middle;
  float: left;
  border-radius: 10px;
}

.seisaku-box dd .seisaku {
  margin: 20px auto;
  padding: 1rem;
  text-align: left;
}

.seisaku-box dd .seisaku .s-icon {
  width: 18%;
  float: left;
}

.seisaku-box dd .seisaku p {
  width: 75%;
  float: right;
  font-size: 2.4rem;
  line-height: 1.5;
  font-weight: 600;
  margin-top: 7px;
}

.seisaku-box dd .se-conte {
  width: 93%;
  margin:0 auto;
  padding: 0;
  vertical-align: middle;
  line-height: 1.7;
  text-align: left;
  list-style: none;
  font-size: 1.6rem;
}

.se-conte li{
  display: flex; /* 点とリストを横並びに */
  align-items: top; /* 垂直方向に中央揃い */
}

.se-conte li::before{
 content: "⚫︎";
 font-size: 1.9rem; 
 margin-right: .8em; 
}

.s_01::before {
 color: #ea6000;
}

.s_02::before {
 color: #009fe8;
}

.s_03::before {
 color: #1eaa39;
}

.s_04::before {
 color: #e7373e;
}

.s_05::before {
 color: #009d95;
}

.s_06::before {
 color: #90529c;
}

.s_07::before {
 color: #e85f9d;
}

.bg_01 {
  background: #fce4bd;
}

.bg_02 {
  background: #bce3f8;
}

.bg_03 {
  background: #e5f0d4;
}

.bg_04 {
  background: #f3aca7;
}

.bg_05 {
  background: #b7dfe4;
}

.bg_06 {
  background: #e4d3e6;
}

.bg_07 {
  background: #f9dae8;
}

/* ごあいさつ */
.greeting {
  margin: 50px auto;
  width: 88%;
  font-size:16px;
  font-size: 1.6rem;
  line-height: 1.9;
  text-align: left;
}

.name {
  margin: 50px auto 80px;
  width: 90%;
  text-align: right;
}

/* プロフィール */
.profile-box {
  width: 95%;
  margin: 0 auto;
  padding: 0;
}

.pr-l {
  width: 40%;
  margin: 70px auto 0;
  display: table-cell;
  vertical-align: middle;
  float: left;
  text-align: center; 
}

.pr-l img {
  width: 90%;
}

.pr-r {
  width: 50%;
  margin:0 auto;
  display: table-cell;
  vertical-align: middle;
  float: right;
  border-radius: 10px;
  background: #fff;
  padding: 25px 0;
}

.profile {
  width: 85%;
  margin: 0 auto;
  padding: 0 10px;
  text-align: left;
}

.pr-name,ruby {
  width: 100%;
  height: auto;
  font-size:27px;
  font-size: 2.7rem;
  color: #004da0;
  position: relative;
  padding: 1.5rem 0;
  text-align: center;
  margin: 20px auto;
  letter-spacing: .2em;
}

.pr-blue {
  color:#004da0;
}

.profile .pr1 {
  line-height: 1.7;
  font-size:16px;
  font-size: 1.6rem;
}

.profile .pr2 {
  line-height: 2;
  font-size:16px;
  font-size: 1.6rem;
  color: #004da0;
}

.profile .profile-inner {
  width: 100%;
  margin: 0 auto;
}

.profile-inner li {
  margin: 0 auto;
  font-size:16px;
  font-size: 1.6rem;
  line-height: 1.7;
  text-indent: .5em;
  display: flex; /* 点とリストを横並びに */
  align-items: top; /* 垂直方向に中央揃い */
}

.profile-inner li::before{
 content: "⚫︎";
 font-size: 1.9rem; 
 margin-right: .3em;
 color: #004da0;
}

/* 応援 */
.support {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 2.8rem;
  font-weight: 600;
  text-align: center;
  margin: 30px auto 50px;
  color: #e50012;
}

.support::before,
.support::after {
	content: '';
	width: 3px;
	height: 40px;
	background-color: #e50012;
}

.support::before {
	margin-right: 30px;
	transform: rotate(-35deg)
}
.support::after {
	margin-left: 30px;
	transform: rotate(35deg)
}

.support-ul {
  width: 100%;
  margin: 0 auto 50px;
  padding: 0;
  height: auto;
  display:-webkit-box;
  display:-moz-box;
  display:-ms-box;
  display:-webkit-flexbox;
  display:-moz-flexbox;
  display:-ms-flexbox;
  display:-webkit-flex;
  display:-moz-flex;
  display:-ms-flex;
  display:flex;
  -webkit-box-lines:multiple;
  -moz-box-lines:multiple;
  -webkit-flex-wrap:wrap;
  -moz-flex-wrap:wrap;
  -ms-flex-wrap:wrap;
  flex-wrap:wrap;
}

.support-ul li {
  width: 23%;
  margin:0 auto;
  padding: 0 1%;
  display: table-cell;
  vertical-align: middle;
  float: left;
}

.support-ul li p {
  width: 100%;
  margin: 17px auto 0;
}

.support-box {
  width: 95%;
  margin: 0 auto;
  background: #FFF;
  border-radius: 10px;
  padding: 30px 30px 40px;
  box-shadow: 0 0 15px #f2f2f2;
}

.suisen-box {
  width: 100%;
  margin: 0 auto;
  padding: 10px 0;
}

.suisen-box .support-l {
  width: 30%;
  margin: 0 auto;
  display: table-cell;
  vertical-align: middle;
  float: left;
  font-size: 2rem;
  font-weight: 600;
  color: #e50012;
  text-align: left;
  letter-spacing: 0.1em;
}

.suisen-box .support-r {
  width: 70%;
  margin:0 auto;
  display: table-cell;
  vertical-align: middle;
  float: right;
  font-size: 1.9rem;
  text-align: right;
  letter-spacing: 0.1em;
}

.suisen-box .support-r span {
  font-size: 1.6rem;
  margin-right: 30px;
}

.suisen {
  width: 100%;
  margin: 20px auto 0;
  text-align: left;
  font-size: 1.6rem;
  line-height: 1.7;
}

/*----------------------------------
  お問い合わせ
----------------------------------*/
.contact {
  width: 100%;
  height: auto;
  margin: 30px auto;
  font-size: 30px;
  font-size: 3rem;
  color: #1E65B0;
}

.tel-box {
  margin: 0 auto;
  width: 100%;
  text-align: center;
}

.contact-div {
  width: 100%;
  height: auto;
  margin: 50px auto;
  font-size: 18px;
  font-size: 1.8rem;
}

.contact-div2 {
  width: 100%;
  height: auto;
  margin: 50px auto 20px;
  line-height: 1.7;
  font-size: 17px;
  font-size: 1.7rem;
}

.inquirybox {
	margin:30px auto;
	padding:0;
	width:90%;
	line-height:1.5;
	text-align:left;
}

.inquirybox p {
	text-align:right;
}

.inquirybox span {
	color: red;
}

.mailmaga {
  margin: 100px auto 30px;
  width: 100%;
  text-align: center;
  font-size: 1.5rem;
}

#mailform {
	margin:0;
	padding:0;
	text-align:left;
}

#mailform table {
	margin: 20px 0;
	padding:0;
	width:100%;
}

#mailform th.inq-l {
	padding: 15px 20px;
	width:30%;
	font-weight: normal;
	vertical-align: middle;
	border-bottom: 1px dotted #8E8E8E;
}

#mailform td {
	width:65%; 
	padding: 15px 20px;
	vertical-align:middle;
	border-bottom: 1px dotted #8E8E8E;
}

#mailform .inq-bottom {
	vertical-align:middle;
	padding: 20px;
	text-align: center;
	border: none;
}

#mailform label {
	display: inline-block;
	margin-right: 30px;
}

#mailform input,
#mailform textarea {
	padding: 12px;
}

#mailform textarea {
	font-size: 90%;
	font-family:'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
}

#mailform input {
  margin-right: 10px;
}

#mailform td select {
  /*width: 20%;*/
  height: auto;
  margin-bottom: 10px;
  padding: 5px;
  font-size: 14px;
  font-size: 1.4rem;
}

#mailform td .inq-inner {
  margin: 15px 0;
}

#mailform td .inq-inner li {
  padding: 7px 0;
  width: auto;	
}

#mailform td .inq-inner p {
  margin: 0;
  text-align: left;
}

#mailform td textarea {
  width: 90%;
  height: auto;
  margin-top: 10px;
  padding: 7px;
  font-size: 14px;
  font-size: 1.4rem;
}

#mailform td .inner-p {
  margin: 0;
  text-align: left;
}

#mailform td .inner-p a {
  text-decoration:none;
  display:inline;
  color: red;
}

#mailform td .inner-p a:hover {
  text-decoration: none;
  color: #0084b9;
}

input::placeholder {
  color: #CFCFCF;
}

/* 新着情報 */
.news-box {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  width: 55%;
  height: auto;
  float: left;
  margin: 30px auto 0;
}

/*.news-box .news-ul {
  width: 100%;
  height: auto;
  margin: 10px auto 20px;
  list-style-type: none;
}

.news-box .news-ul li {
  width: 100%;
  height: auto;
  padding: 30px 0 30px;
  text-align: left;
  border-bottom: 1px dotted #fff;
}

.news-box .news-ul li a {
  width: 100%;
  height: auto;
  display: block;
  text-align: left;
  text-decoration: none;
  color: #fff;
}

.news-box .news-ul li a:hover {
  text-decoration: none;
  color: #0084b9;
}

.news-box .news-ul li .date {
  width: 26%;
  height: auto;
  padding-left: 10px;
  float: left;
  color: #fff;
}

.news-box .news-ul li .summary {
  width: 72%;
  height: auto;
  float: right;
  word-break: normal;
  word-wrap: break-word;
}*/

/* RSS */
#feed {
  padding:0 0 10px 20px;
  width: 95%;
  margin: 20px auto 0;
  text-align: left;
}

/*#feed dl {
  padding:0 0 5px;
  line-height:2;
}*/

#feed p {
  width: 95%;
  border-bottom: 1px dotted #fff;
  padding: 25px 0;
  text-indent: 1.5em;
  letter-spacing: .1em;
}

#feed a {
  text-decoration:none;
  color:#fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding-right: 1em;
}

#feed a:hover {
  text-decoration:none;
  color:#B3D3EB;
}

/* Facebook */
#likebox_container {
  width: 40%;
  /*height: 350px;*/
  float: right;
  text-align: center;
  margin: 70px 0 0;
}

#likebox_container img {
  width: 90%;
}

/* 矢印 */
.arrow {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 1px;
  margin-top: 6.4px;
  margin-right: 10px;
  border-radius: 9999px;
  background-color: #fff;
}

.arrow::before {
  content: "";
  position: absolute;
  top: calc(50% - 0.5px);
  right: 0;
  width: 10px;
  height: 1px;
  border-radius: 9999px;
  background-color: #fff;
  transform: rotate(45deg);
  transform-origin: calc(100% - 0.5px) 50%;
}

/* view more */
.link-box {
  width: 53%;
  margin: 50px 0 0;
  text-align: right;
}

.link-box a {
  text-decoration:none;
  color:#fff;
  display: inline-block;
}

.link-box a:hover {
  text-decoration:none;
  color:#0084b9;
}

.button {
  display: inline-block;
  padding: 2rem 5rem;
  border-radius: 10rem;
  color: #000;
  text-transform: uppercase;
  font-size: 1.5rem;
  transition: all .3s;
  position: relative;
  overflow: hidden;
  z-index: 1;
  margin-top: 50px;
}

.button:after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 10rem;
  z-index: -2;
  text-decoration: none;
}

.button:after {
  background-color: #fff;
}

.button:before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0%;
  height: 100%;
  background-color: #000;
  transition: all .3s;
  border-radius: 10rem;
  z-index: -1;
}


.button:hover {
  color: #fff;
  text-decoration: none;
}

.button:hover:before {
  width: 100%;
}

/*----------------------------------
  共通で使用するクラス
----------------------------------*/
.left {
  float: left;
}

.right {
  float: right;
}

.align-l {
  text-align: left;
}

.align-c {
  text-align: center;
}

.align-r {
  text-align: right;
}

.margin-l20 {
  margin-left: 20px;
}

.margin-20 {
  margin: 20px 0;
}

.pb-40 {
  padding-bottom: 40px;
}

.pb-20 {
  padding-bottom: 20px;
}

/* clearfix */
.clearfix:after {
  clear: both;
  content: "";
  display: block;
}

/**********************************/
/*      タブレット用クラス         */
/**********************************/
/* container */
.td #container {
  width: 100%;
  height: auto;
  margin: 0 auto;
  padding: 0;
  overflow:hidden;
}

/*----------------------------------
  bodyブロック
----------------------------------*/
/* メインブロック */
.tb #top-main-block {
  width: 100%;
  height: auto;
  margin: 0 auto;
}

.tb #main-block {
  width: 100%;
  height: auto;
  margin: 0 auto;
}
    
/*----------------------------------
  フッターブロック
----------------------------------*/
.tb #footer-block {
  width: 100%;
  height: auto;
  padding: 30px 0 0;
  margin: 0 auto;
  text-align: center;
  background: #002745;
}

.tb #footer-block .ft-info {
  width: 95%;
  height: auto;
  margin: 0 auto;
  display: table;
  padding: 30px 0;
}

.tb #footer-block .ft-info .info-l {
  width: 40%;
  height: auto;
  padding:  20px 0;
  display: table-cell;
  vertical-align: top;
  text-align: left;
  float: left;
}


.tb #footer-block .ft-info .info-r {
  width: 60%;
  padding: 20px 0;
  height: auto;
  display: table-cell;
  vertical-align: top;
  float: right;
  text-align: right;
}

.tb #footer-block .ft-info .info-r .site-ul {
  width: 100%;
  height: auto;
  list-style: none;
}

.tb #footer-block .ft-info .info-r .site-ul li {
  width: 29%;
  padding: 0 0 0 20px;
  line-height: 2.5;
  float: left;
  text-align: left;
}

/*----------------------------------
  トップページ
----------------------------------*/
.tb .top-contebox{
  width: 100%;
  height: auto;
  margin: 0 auto;
}

.tb .textbox {
  text-align: left;
  line-height: 1.5;
}

/* welcomeスライダー */
.tb #welcomebox {
  position: relative;
  width: auto;
  z-index: 2;
  width: 100%;
  margin: 0 auto 0;
}

.tb .top-slider {
  width: auto;
  height: 377px;
  overflow: hidden;
  min-width: 1100px;
  margin: 0 auto;
}

.tb #welcomebox .welcome_h {
  width: auto;
  height: 377px;
  position: absolute;
  left: 0;
  min-width: 1100px;
  margin: 0 auto;
  overflow: hidden;
}

.tb .top-slider .bx-wrapper{
  width: 100%;
  height: auto;
  z-index: 0;
}

.tb .top-slider .bx-wrapper .bx-viewport {
  z-index: 1;
  overflow: hidden;
  background: transparent !important;
}

.tb .top-slider .bx-wrapper .bx-pager {
  *position: relative !important;
}

.tb .top-slider .bx-pager {
  position: relative !important;
  text-align: center;
  margin-top: 470px;
  top: 0 !important;
  width: auto !important;
  display: inline-block;
  z-index: 200;
}
.tb *+html .bx-pager {
  display: block;
  width: 80px !important;
}

.tb .top-slider .bx-pager-item {
  float: left;
}

.tb .top-slider .bx-pager-item .bx-pager-link {
  width: 13px;
  height: 13px;
  margin-left: 13px;
  padding: 0;
  text-align: center;
  border-radius: 50%;
  -moz-border-radius: 50%;
  -webkit-border-radius: 50%;
  text-indent: -9999px;
  float: left;
}

.tb .top-slider .bx-pager-item .bx-pager-link.hover,
.tb .top-slider .bx-pager-item .bx-pager-link.active {
  text-decoration: none;
}
