@charset "utf-8";
/* グローバルナビゲーション ------------------------------ */
.hamburger_set{display: none;}
.menu{
  display: block;
  width: calc(1150px - 15%);
  position: absolute;
  padding: 1.5rem 1.5rem;
  top: 0rem;
  left: 18%;
  border-radius: 0 0 5px 5px;
  background: #ffffff99;
}
.menu a {
  font-size: 150%;
  flex-direction: row;
  padding: 2.5rem;
  padding: 0.5rem 0.5rem 3rem;
  border-right: 1px solid #f0f0f0;
}
.gnav {
  display: flex;
  margin: 0 auto;
}
.gnav > li { 
  width: 22%;/*親階層のみ幅を設定する*/
}
.gnav > li:first-child { 
  width: 10%;/*TOPの幅を設定する*/
}
/*全てのリスト・リンク共通*/
.gnav li {
  list-style: none;
  position: relative;
}
.gnav li a {
  background: #2789ff;
  color: #fff;
  display: block;
  height: 3.9rem;
  padding: 1rem 0.5rem 1.25rem 0.3rem;
  text-align: center;
  text-decoration: none;
}
.gnav li a:hover {
  background: #197bd499
}
/*子階層以降共通*/
.gnav li li {
  height: 0;
  overflow: hidden;
  transition: .5s;
}
.gnav li:hover > ul:hover {
    border-top: 1px solid #ffffff55;
}
.gnav li:hover > ul > li {
    height: 4rem; /*高さ調整*/
    overflow: visible;
    border-bottom: 1px solid #ffffff55;
}


/*　ハンバーガーメニューボタン SP　---------------------*/
@media screen and (max-width: 768px) {
.menu{ display: none;}
.tts_logo{ width: 50%;}
/*　ハンバーガーメニューボタン　*/
.hamburger_set {
  display: block;
  /*z-index: 100;*/
}
.hamburger {
  display : block;
  position: fixed;
  z-index : 3;
  right : 1rem;
  top   : 1rem;
  width : 4.2rem;
  height: 3.9rem;
  cursor: pointer;
  text-align: center;
  background: #00000077;
}
.hamburger span {
  display : block;
  position: absolute;
  width   : 30px;
  height  : 2px ;
  left    : 6px;
  background : #f0f0f0;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition   : 0.3s ease-in-out;
  transition        : 0.3s ease-in-out;
}
.hamburger span:nth-child(1) {
  top: 9px;
}
.hamburger span:nth-child(2) {
  top: 18px;
}
.hamburger span:nth-child(3) {
  top: 27px;
}

/* スマホメニューを開いてる時のボタン */
.hamburger.active span:nth-child(1) {
  top : 17px;
  left: 6px;
  background :#fff;
  -webkit-transform: rotate(-45deg);
  -moz-transform   : rotate(-45deg);
  transform        : rotate(-45deg);
}
.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
  top: 17px;
  background :#fff;
  -webkit-transform: rotate(45deg);
  -moz-transform   : rotate(45deg);
  transform        : rotate(45deg);
}

/* メニュー背景　*/
nav.globalMenuSp {
  position: fixed;
  z-index : 2;
  top  : 0;
  left : 0;
  color: #fff;
  background: rgba( 71,70,73,0.6 );
  text-align: center;
  width: 100%;
  opacity: 0;
  display: none;
  transition: opacity .6s ease, visibility .6s ease;
}
nav.globalMenuSp ul {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  font-size: 150%;
}
nav.globalMenuSp ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
  transition: .4s all;
}
nav.globalMenuSp ul li:last-child {
  padding-bottom: 0;
}
nav.globalMenuSp ul li:hover{
  background :#ddd;
}
nav.globalMenuSp ul li a {
  display: block;
  color: #fff;
  padding: 1em 0;
  text-decoration :none;
}
/* クリックでjQueryで追加・削除 */
nav.globalMenuSp.active {
  opacity: 100;
  display: block;
}

/* 入れ子 */
.sp_nav_ul li{
  font-size: 1.6rem;
  text-indent: 1rem;
}

}



/*  information　― おしらせ ―　----------------------------- */

#news_wrap{
  height: 25rem;
  width: 95%;
  overflow-y: scroll;
  margin: 1rem 2rem 3rem;
  background-color: #FFFFFF;
  padding: 1rem 2rem;
}

#news_wrap::-webkit-scrollbar {
  width: 15px;
  height: 25%;
  background: #c2ecff;
}
 
#news_wrap::-webkit-scrollbar-track {
border-radius: 5px;
box-shadow: 0 0 4px #ccc inset;
}

#news_wrap::-webkit-scrollbar-thumb {
  background: #2789FF88;
  border-radius: 7px;
}

.news_list{
  list-style: none outside;
  margin: 0;
  padding: 0;
}
.news_list .n_item{
  display: flex;
  padding: 1rem; 
  border-bottom: 1px solid #f3f3f3;
  flex-wrap: nowrap;
}
.n_item a{
  text-decoration: none;
}
.news_list .n_item .n_date{
  /*display: flex;
  flex-wrap: wrap;*/
  color: #333;
  padding: 1rem;
}

.news_list .n_item .n_date{
  margin: 0;
  min-width: 10%;
  color: #999;
  font-size: 85%;
  padding: 0.3rem 0.2rem 0 0;
  margin-right: 1.5rem;
}

.news_list .n_item .n_category{
  margin: 0;
  min-width: 18%;
  padding: 0 1rem 0 0;
  flex-wrap: nowrap;
}

.n_category span {
    flex-wrap: nowrap;
    color: #FFF;
    text-align: center;
    display: inline-block;
    padding: 0.3rem 2rem;
    font-size: 75%;
    line-height: 1.1;
    border-radius: 3px;
    white-space: nowrap;
}
.cat01 span{ background: #f37676; }
.cat02 span{ background: #6cafff; }
.cat03 span{ background: #837baf; }
.cat04 span{ background: #a98e57; }
.cat05 span{ background: #6c977d; }
.cat06 span{ background: #6c7997; }

.n_category span:hover { opacity: 0.7;}

.news_list .n_item .n_title{
  color: #666;
  font-size: 95%;
}
.news_list .n_item .n_title a:hover{ color: #2789FF; }
.more_info_btn {
  width: 97% ;
  text-align: right;
  padding-right: 2rem;
}
.more_info_btn span{
  padding: 0.5rem 3rem;
  border-radius: 5px;
  background: #c2ecff;
  color: #1b61b5;
  text-align: center;
  font-size: 80%;
  box-shadow: 1px 1px 1px #1b61b5;
}
.more_info_btn:hover{ 
  transform: translate3d(1px, 1px, 0);
  box-shadow: 0px 0px 0px;
}
.more_info_btn span:hover{ 
  transform: translate3d(1px, 1px, 0);
  box-shadow: 0px 0px 0px;
}

/*　文字　*/
.textlink {
  margin-bottom: 3rem;
  text-align: right;
  padding-right: 2rem;
}
.textlink a {
  position: relative;
  color: #2789FF;
  text-decoration: none;
}
.textlink a:hover {
  color: #235ea0;
}

.textlink_ya a {
  padding-right: 50px;
}

.textlink_ya a::before {
  content: '';
  position: absolute;
  top: calc(50% - 4px);
  right: 0;
  transform: rotate(30deg);
  width: 12px;
  height: 1px;
  background-color: #2789FF;
}

.textlink_ya a::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 40px;
  height: 1px;
  background-color: #2789FF;
}

.textlink_ya a:hover::before {
  background-color: #235ea0;
}

.textlink_ya a:hover::after {
  background-color: #235ea0;
}


@media screen and (max-width: 1000px){
.news_list .n_item{
  display: wrap;
  padding: 1rem; 
  border-bottom: 1px solid #CCC;
  flex-wrap: wrap;
}
.news_list .n_item .n_title{
  margin-top: 0.3rem;
  font-size: 90%;
}
}
@media screen and (max-width: 767px){
.news_list .n_item a{
  flex-wrap: wrap;
}
.news_list .n_item .n_title{
  margin-top: 0.8rem;
  line-height: 1.35;
}
}

/* お知らせのボタン */
div.oshirase_btn{
	text-align:center;
    margin-bottom: 2rem;
}
.oshirase_btn span{
    padding: 0.3rem 2rem;
    font-size: 75%;
    line-height: 1.1;
    border-radius: 3px;
}
div.oshirase_btn a{
	color:#FFF;
}

/* meanmenu.css マージ */


@media only screen and ( max-width : 768px ) {
  .fixed {
    position: fixed;
    width: 100%;
    height: 100%;
    z-index: 1;
  }
	#header .mask {
		background: rgba(22,34,42,.4);
    top: 60px;
    left: 0;
    z-index: 1;
    position: absolute;
    width: 100%;
    height: 100vh;
    opacity: 1;
    display: none;
	}
}

a.meanmenu-reveal{
  display:none;
}

.mean-container .mean-bar{
  width:100%;
  position:fixed;
  background:none;
  min-height:60px;
  z-index:999998;
  top:0;
  left:0;
}
.mean-container .mean-bar {
	width: 100%;
	position: fixed;
	background: none;
	min-height: 60px;
	z-index: 98;
	top: 0;
	left: 0;
}
.meanmenu-reveal-btn {
  position: absolute;
  display: block;
  z-index: 99999;
  box-sizing: border-box;
  width: 60px;
  height: 60px;
  right: 0;
  top: 0;
}
.meanmenu-reveal {
  width: 26px;
  height: 20px;
  margin: 13px 17px 27px 17px;
  display: block !important;
  position: relative;
}
.meanmenu-reveal:after {
	content: "MENU";
	position: absolute;
	bottom: -20px;
	color: #6bb5cb;
	font-size: 10px;
	width: 60px;
	left: -17px;
	text-align: center;
	display: block;
	font-family:serif;
}
.meanmenu-reveal.meanclose:after {
	content: "CLOSE";
}
.meanmenu-reveal span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box;
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  margin: 0 auto;
}
.meanmenu-reveal span:nth-of-type(1) {
  top: 0;
  background: #6bcbba;
}
.meanmenu-reveal span:nth-of-type(2) {
  top: 8px;
  background: #6bcacb;
}
.meanmenu-reveal span:nth-of-type(3) {
  top: 16px;
  background: #6bbacb;
}

.meanmenu-reveal  span:nth-of-type(1) {
  -webkit-animation: menu-ber01 .75s forwards;
  animation: menu-ber01 .75s forwards;
}
.meanmenu-reveal  span:nth-of-type(2) {
  transition: all .25s .25s;
  opacity: 1;
}
.meanmenu-reveal  span:nth-of-type(3) {
  -webkit-animation: menu-ber02 .75s forwards;
  animation: menu-ber02 .75s forwards;
}

.meanclose span:nth-of-type(1) {
  -webkit-animation: active-menu-ber01 .75s forwards;
  animation: active-menu-ber01 .75s forwards;
  top: -2px;
}
.meanclose span:nth-of-type(2) {
  opacity: 0;
}
.meanclose span:nth-of-type(3) {
  -webkit-animation: active-menu-ber03 .75s forwards;
  animation: active-menu-ber03 .75s forwards;
}

@-webkit-keyframes menu-ber01 {
  0% {
    -webkit-transform: translateY(8px) rotate(45deg);
  }
  50% {
    -webkit-transform: translateY(8px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0) rotate(0);
  }
}

@keyframes menu-ber01 {
  0% {
    transform: translateY(8px) rotate(45deg);
  }
  50% {
    transform: translateY(8px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}

@-webkit-keyframes menu-ber02 {
  0% {
    -webkit-transform: translateY(-8px) rotate(-45deg);
  }
  50% {
    -webkit-transform: translateY(-8px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0) rotate(0);
  }
}

@keyframes menu-ber02 {
  0% {
    transform: translateY(-8px) rotate(-45deg);
  }
  50% {
    transform: translateY(-8px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}

@-webkit-keyframes active-menu-ber01 {
  0% {
    -webkit-transform: translateY(0) rotate(0);
  }
  50% {
    -webkit-transform: translateY(10px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(10px) rotate(45deg);
  }
}

@keyframes active-menu-ber01 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(10px) rotate(0);
  }
  100% {
    transform: translateY(10px) rotate(45deg);
  }
}

@-webkit-keyframes active-menu-ber03 {
  0% {
    -webkit-transform: translateY(0) rotate(0);
  }
  50% {
    -webkit-transform: translateY(-8px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(-8px) rotate(-45deg);
  }
}

@keyframes active-menu-ber03 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(-8px) rotate(0);
  }
  100% {
    transform: translateY(-8px) rotate(-45deg);
  }
}
.mean-container .mean-nav{
	width:100%;
	margin-top:60px;
	max-height:100vh;
	overflow-y:auto;
}
.mean-container .mean-nav ul{
	padding: 0;
	margin: 0;
	width: 100%;
	list-style-type: none;
	overflow-y: scroll;
	-webkit-overflow-scrolling:touch;
	position: relative;
	z-index: 99;
	max-height: 100vh;
	max-height: calc(100vh - 60px);
  background: #eef7f9;
}
.mean-container .mean-nav ul ul{
	padding-bottom:0;
	margin-bottom:0;
}
.mean-container .mean-nav ul li{
	position:relative;
  width:100%;
	box-sizing: border-box;
}
.mean-container .mean-nav ul li.sp-only {
  display: none;
}
@media screen and (max-width: 767px){
  .mean-container .mean-nav ul li.sp-only {
    display: block;
  }
}
.mean-container .mean-nav ul li a,.mean-container .mean-nav ul li span.pre{
	display:block;
	width:100%;
	padding:1em;
	margin:0;
	text-align:left;
	text-decoration:none;
	text-transform:uppercase;
  color:#477684;
  box-sizing: border-box;
}
#gNav > ul > li.sp-btn {
  display: none;
}
.mean-container .mean-nav ul li.sp-btn a {
  padding: .3rem 0 1.5rem;
}
.mean-container .mean-nav ul li.sp-btn span {
  background: #fff;
  padding: 1rem;
  box-sizing: border-box;
  display: block;
  width: 70%;
  text-align: center;
  margin: 0 auto;
}
.mean-container .mean-nav ul li li a{
	width:100%;
	padding:1em 10%;
	text-shadow:none !important;
	visibility:visible;
}
.mean-container .mean-nav ul li.mean-last a{
	border-bottom:none;
	margin-bottom:0;
}
.mean-container .mean-nav ul li li li a{
	width:70%;
	padding:1em 15%;
}
.mean-container .mean-nav ul li li li li a{
	width:60%;
	padding:1em 20%;
}
.mean-container .mean-nav ul li li li li li a{
	width:50%;
	padding:1em 25%;
}
.mean-container .mean-nav ul li a:hover{
	background:#252525;
	background:rgba(255,255,255,0.1);
}
.mean-container .mean-nav ul li a.mean-expand{
	width:60px;
	text-align:center;
	position:absolute;
	right:0;
	top:0;
	z-index:2;
  padding: 0.2em;
  font-size: 24px;
  color: #6bb5cb;
}
.mean-container .mean-nav ul li a.mean-expand:hover {
  background:#a0c6d1;
  color: #fff;
}
.mean-container .mean-push {
  float:left;
  width:100%;
  padding:0;
  margin:0;
  clear:both;
}
.mean-nav .wrapper{
  width:100%;
  padding:0;
  margin:0;
}
.mean-container .mean-bar, .mean-container .mean-bar *{
  -webkit-box-sizing:content-box;
  -moz-box-sizing:content-box;
  box-sizing:content-box;
}
.mean-remove{
  display:none !important;
}


