@charset "utf-8";
* {
  letter-spacing: 0.002em;
  line-height: 1.6em;
}


body {
   font-family: 'Kosugi Maru', sans-serif;
  /*'Noto Sans JP', sans-serif*/
  /*'Kosugi Maru', sans-serif*/
  /*  font-size: 1.6rem;font-family: '游ゴシック体',YuGothic,'游ゴシック Medium','Yu Gothic Medium','游ゴシック','Yu Gothic',sans-serif */
	 /*font-size:1rem;*/
	line-height:1.85;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%; 
	word-wrap: break-word;
}


h2,h3 {
  font-family: 'Kosugi Maru', sans-serif;
  font-weight: 600;
}
img,
iframe {
  max-width: 100%;
}

img {
  height: auto;
}

a{color:#1e9760}

a.anchor {
    display: block;
    padding-top: 200px;
    margin-top: -200px;
}

header {
  width: 100%;            /* 要素を幅いっぱいにする */
   /* background: #555;      背景色を濃いグレーに指定。半透明の「rgba(0,0,0,0.5)」でもいいかも */
  display: none;          /* ページ読み込み時は非表示にする */
  position: fixed;        /* ヘッダーを絶対位置にする。スクロールしても固定 */
  top: 0;                 /* 上から0pxに指定 */
  left: 0;                /* 左から0pxに指定 */
  padding: 10px 20px;     /* ちょっと余白をとっとくと綺麗 */
  box-sizing: border-box; /* paddingを含んで幅100%ちょうどにするため */
}

li {
	list-style-type: none;
}

.wrapper{}
#contents{background: #fff;
 } /* f5a200 ff6600 ff9900  */
.white{background: #fff;}
.orange{background: #f5a200;}
.green{background-color: #1e9760}
.green-1{background-color: #87c78d}

#contents h2{}
#contents h2 span { 
	display: block;
	font-size: 14px;	
	color: #000;		
	letter-spacing: 0.3em;	
}

    
.inner{
  width: 90%; 
  max-width: 100%;
  margin: 0 auto;
  padding: 24px;
  }
  
  
@media (max-width: 767px) {
.inner{
  width: 99%; 
  max-width: 100%;
  margin: 0 auto;
  padding: 24px;
  }
}
  
.mv {
  width: 100vw;           /* ウィンドウサイズ横幅いっぱいに表示 */
          /*  height: 100vh;  ウィンドウサイズ縦幅いっぱいに表示 */
}

.mv img {
  width: 100%;           
  height: auto;      /* 100%;高さいっぱい 変更 */
  object-fit: cover; 
  object-position: center center;
}

.mv-fig {
  position: relative;
}
.mv-pos {
  position: absolute;
  left: 100px;
  bottom: -100px;  
  width:200px;
} 

.mv-fig a:hover {opacity: 0.8;
display: block;} /*mac */

@media (max-width: 767px) {.mv-pos {left:0;width:150px;}}
/*==================================
ヘッダー
==================================*/
#head_wrap {
  top: -100px;
  position: relative;
  width: 100%;
  margin: 100px auto 0;
  line-height: 1;
  z-index: 999;
  height: 0px;
  text-decoration: none;
  background-color: #fff;
  /*
 border-bottom: 3px solid #1e9760;
 */
 box-shadow: rgb(0 0 0 / 5%) 0px 10px 15px -3px, rgb(0 0 0 / 5%) 0px 4px 6px -2px;
}

#head_wrap a {
  text-decoration: none;
}

#head_wrap .inner {
  width: 100%;
  margin: 0 auto;
  position: relative;
}

#head_wrap .inner:after {
  content: "";
  clear: both;
  display: block;
}

#head_wrap .logo {
  float: left;
}

#global-nav {
  position: absolute;
  right: 0;
  top: 0;
}

#global-nav ul {
  list-style: none;
  font-size: 16px;
  margin-right: 10px;
  display: inline-flex;
}

@media (max-width: 767px) {
  #global-nav ul {
    display: block;
    margin-right: 0px;
    background-color: #86c68c;
  }
}

#global-nav ul li {
  padding: 20px 10px;
}

#global-nav ul li:last-child {
  border-right: none;
}

@media (max-width: 767px) {
  #global-nav ul li {
    border-right: none;
  }
}

#global-nav ul li a {
  padding: 0 5px;
  padding: 2px;
  transition: all .6s ease 0s;
  box-sizing: border-box;
  font-weight: bold;
}

#global-nav ul li a:hover {
text-decoration-line: underline;
 text-decoration-color:#1e9760;
text-decoration-thickness: 3px; 
text-underline-offset: 15px;
}

/* Fixed */
#head_wrap.fixed {
  margin-top: 0;
  top: 0;
  position: fixed;
  height: 100px;
  transition: top 0.65s ease-in;
  -webkit-transition: top 0.65s ease-in;
  -moz-transition: top 0.65s ease-in;
  z-index: 9999;
}

#head_wrap.fixed .logo {
  font-size: 36px;
  color: #333;
}

#head_wrap.fixed #global-nav ul li a {
  color: #333;
  padding: 0 20px;
}

/* Toggle Button */
#nav-toggle {
  display: none;
  position: absolute;
  right: 12px;
  top: 14px;
  width: 34px;
  height: 36px;
  cursor: pointer;
  z-index: 101;
}

#nav-toggle div {
  position: relative;
}

@media (max-width: 767px) {
  #head_wrap {
    top: 0;
    position: fixed; 
    margin-top: 0;
    width: 100%;
    padding: 0;
    /* Fixed reset */
  }
  #head_wrap .inner {
    width: 100%;
    padding: 0;
  }
  #head_wrap .fixed {
    padding-top: 0;
    background: transparent;
  }
  #mobile-head {
    background: rgba(255, 255, 255, 0.9);
    width: 100%;
    height: 56px;
    z-index: 999;
    position: relative;
  }
  #head_wrap.fixed .logo,
  #head_wrap .logo {
    position: absolute;
    left: 13px;
    top: 13px;
    color: #333;
    font-size: 26px;
  }
  #global-nav {
    position: absolute;    
    top: -500px;
    background: rgba(255, 255, 255, 0.9);
    width: 100%;
    text-align: center;
    -webkit-transition: .5s ease-in-out;
    -moz-transition: .5s ease-in-out;
    transition: .5s ease-in-out;
  }
  #global-nav ul {
    list-style: none;
    position: static;
    right: 0;
    bottom: 0;
    font-size: 14px;
    margin-top: 20px;
  }
  #global-nav ul li {
    float: none;
    position: static;
  }
  #head_wrap #global-nav ul li a,
  #head_wrap.fixed #global-nav ul li a {
    width: 100%;
    display: block;
    padding: 5px 0;
  }
  

  #nav-toggle {
    display: block;
  }
  /* #nav-toggle  */
  #nav-toggle span {
    display: block;
    position: absolute;
    height: 4px;
    width: 100%;
    background: #666;
    left: 0;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
  }
  #nav-toggle span:nth-child(1) {
    top: 0;
  }
  #nav-toggle span:nth-child(2) {
    top: 11px;
  }
  #nav-toggle span:nth-child(3) {
    top: 22px;
  }
  .open #nav-toggle span:nth-child(1) {
    top: 11px;
    -webkit-transform: rotate(315deg);
    -moz-transform: rotate(315deg);
    transform: rotate(315deg);
  }
  .open #nav-toggle span:nth-child(2) {
    width: 0;
    left: 50%;
  }
  .open #nav-toggle span:nth-child(3) {
    top: 11px;
    -webkit-transform: rotate(-315deg);
    -moz-transform: rotate(-315deg);
    transform: rotate(-315deg);
  }

  /* #global-nav  */
  .open #global-nav {
    /* #global-nav top + #mobile-head height */
    -moz-transform: translateY(556px);
    -webkit-transform: translateY(556px);
    transform: translateY(556px);
  }
}


/*==================================
概要
==================================*/


.list-g dl {
display: flex;
flex-flow: row wrap;
width: 100%;
}
.list-g dt {
flex-basis: 15%;
padding: 20px;
background-color: #fff;
border-bottom: 1px solid #ccc;
}
.list-g dt.gr {
flex-basis: 20%;
padding: 20px;
background-color: #86c68c;
border-bottom: 1px solid #ccc;
}
.list-g dd {
flex-basis: 80%;
padding: 20px;
background-color: #fff;
border-bottom: 1px solid #ccc;
}
.list-g dd.date {
	font-weight: bold;
    font-size: 30px;
}
.list-g dd.date span {
    display: inline-block;
    font-size: 15px;
    border-bottom:none;
}
@media screen and (max-width: 460px) {
.list-g dl {
flex-flow: column;
}
}   

/*==================================
NEWS
==================================*/
#news{
	position: relative;
    padding: 3px 0 100px 0;/* 50pxに戻す */
    margin: 0 0 100px 0;
}

@media screen and (max-width:767px) {
#news{
    margin:0;
    padding: 50px 0;
    }
}

#news:after{
	position: absolute;
	z-index: -1;
	content:'';
	top:10px;
	left:-30%;
	width:150%;
	height: 500px;
	background: #1e9760;
	transform: rotate(-5deg);
}

#news .news-area{
    background:#1e9760;
    padding: 40px;
	box-shadow: 10px 10px 0 rgba(0,0,0,0.4);
    width:90%;
    margin: 0 auto;
    border-radius:10px;
}

/* list */
#news .new-list{
  list-style: none outside;
  margin: 0;
  padding: 0;  
}

#news .new-list .item a{
  display: flex;
  flex-wrap: wrap;
  flex-wrap: nowrap;
  text-decoration: none;
  padding: 2px 10px;
  border-bottom: 1px solid #ddd;  
  color: #fff;
}

#news .new-list .item span{
  display: flex;
  flex-wrap: wrap;
  flex-wrap: nowrap;
  text-decoration: none;
  padding: 2px 10px;
  border-bottom: 1px solid #ddd;  
  color: #fff;
}

#news .new-list .item .date{
  margin: 0;
  min-width: 110px;
  font-size: 18px;
  color: #fff;
  padding: 0 5px 0 0;
}
#news .new-list .item .category{
  margin: 0;
  min-width: 100px;
  padding: 0 5px 0 0;
}
#news .new-list .item .category span{
  background: #999;
  color: #FFF;
  text-align: center;
  display: inline-block;
  padding: 5px 10px;
  font-size: 10px;
  line-height: 1;
}
#news .new-list .item .title{
  margin: 0;
  width: 100%;
  font-size: 18px;
  line-height: 2;
  
}
#news .new-list .item a:hover .title{
  opacity:0.4;
}


@media screen and (max-width: 767px){

#news .new-list .item a{
  flex-wrap: wrap;
}

#news .new-list .item span{
  flex-wrap: wrap;
}

#news .new-list .item .date{
  min-width: 100px;
}
#news .new-list .item .title{
  margin-top: 10px;
}

}

/* ==================================
イベント Box
================================== */

.border-top-g{
    border-top: 5px solid #1e9760;
    padding: 10px;
    background: #f2f2f2;
}

.eventBox:last-child {
  margin-bottom: 0;
}


.eventBox .box_inner {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    position: relative;
}



.eventBox .box_inner .box-area{
     width:50%;
     padding: 0 20px 0 0;
   
}


.eventBox:nth-child(even) .box_inner {
  flex-direction: row-reverse;
}

.eventBox .title {
  grid-column: 1;
  grid-row: 1 / 2;
  padding: 0 15px;
  margin-bottom: 0.1em;
}

.eventBox .title h3{
color:#1e9760;
font-size: 30px;}

.eventBox .title .subtitle {
  font-size: 25px;
  color:#1e9760;
  line-height: 1.6;
  margin: 0.5em 0;
}

.eventBox .title .name {
  font-size: 20px;
  color:#000;
  line-height: 1.6;
  margin: 0.5em 0;
}

.eventBox .tagArea {
  font-size: 1.8rem;
  display: flex;
  gap: 1em;
  margin-bottom: 0.25em;
}

.eventBox .text {  
  padding: 0 15px;
}

.eventBox .image {
  position: relative;
  padding: 0;
  float: right;
  grid-column: 2;
  grid-row: 1 / 4;
}

.eventBox .bgImage {
  width: 100%;
  height: 100%;
}

.eventBox .bgImage img {
  width: 100%;
  display: block;
  border-radius:10px;
}

@media screen and (max-width:767px) {

.eventBox .box_inner .box-area{
     width:100%;
    margin: 0 0 100px 0;
}
 
}

@media screen and (max-width:767px) {

.eventBox .box_inner .image{
    width:100%;
    margin: 0 0 10px 0;
    padding: 0 3% 0 3%;
    
    }
}

.boxballoon-right {
  position: relative;
  display: inline-block;
  margin: 1.5em 15px 1.5em 0;
  padding: 7px 10px;
  min-width: 120px;
  max-width: 100%;
  color: #555;
  font-size: 16px;
  background: #edfae5;
}

.boxballoon-right:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 100%;
  margin-top: -50px;
  border: 50px solid transparent;
  border-left:50px solid #edfae5;
}

.boxballoon-right p {
  margin: 0;
  padding: 0;
}

/* ==================================
btn
================================== */

.linkButtonArea {
  grid-column: 1;
  grid-row: 3 / 4;
  padding: 0 15px;
  margin-top: 1.5em;
}
.btn_01 a {
	font-size: 16px;
	color: #FFF;
	text-align: center;
	text-decoration: none;
	display: inline-block;
	background-color: #1e9760;
	margin-top: 20px;
	margin-right: auto;
	margin-bottom: 30px;
	margin-left: auto;
	line-height: 22px;
	 padding: 1rem 4rem;
  cursor: pointer;
	clear: both;
     letter-spacing: 0.1em;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
}

.btn_01 span {
	font-size: 16px;
	color: #FFF;
	text-align: center;
	text-decoration: none;
	display: inline-block;
	background-color: #1e9760;
	margin-top: 20px;
	margin-right: auto;
	margin-bottom: 30px;
	margin-left: auto;
	line-height: 22px;
	 padding: 1rem 4rem;
  cursor: pointer;
	clear: both;
     letter-spacing: 0.1em;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
}



.btn_01 a i {
	padding-left: 20px;
}
.btn_01 a:hover {
	color: #fff;
	background-color: #86c68c;
}

.btn_01 span:hover {
	color: #fff;
	background-color: #86c68c;
}


.btn_02 a {
	font-size: 16px;
	color: #FFF;
	text-align: center;
	text-decoration: none;
	display: block;
	width: 240px;
	background-color: #666;
	margin-top: 20px;
	margin-right: auto;
	margin-bottom: 30px;
	margin-left: auto;
	line-height: 22px;
	padding-top: 10px;
	padding-bottom: 10px;
	clear: both;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
}
.btn_02 a i {
	padding-right: 10px;
}
.btn_02 a:hover {
	color: #666;
	background-color: #ccc;
}

.btn_02.rt a {
	float: right;
	max-width: 220px;
	margin-right: 10px;
}

.btn_03 a {
	font-size: 16px;
	color: #1e9670;
	text-align: center;
	text-decoration: none;
	display: block;
	width: 240px;
	background-color: #fff;
	margin-top: 20px;
	margin-right: auto;
	margin-bottom: 30px;
	margin-left: auto;
	line-height: 22px;
	padding-top: 10px;
	padding-bottom: 10px;
	clear: both;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
}
.btn_03 a i {
	padding-right: 10px;
}
.btn_03 a:hover {
	color: #666;
	background-color: #ccc;
}

.btn_04 a {
	font-size: 16px;
	color: #000;
	text-align: center;
	text-decoration: none;
	display: block;
	width: 240px;
	background-color: #ffee5c;
	margin-top: 20px;
	margin-right: auto;
	margin-bottom: 30px;
	margin-left: auto;
	line-height: 22px;
	padding-top: 10px;
	padding-bottom: 10px;
	clear: both;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
}
.btn_04 a i {
	padding-right: 10px;
}
.btn_04 a:hover {
	color: #666;
	background-color: #fff;
}
/* ==================================
table 
================================== */
/* イベント詳細 */	
.table-01{ 
 border-collapse: collapse;
 width:90%;
 margin-left: 10px;
}
th {
text-align: center;
 padding: 10px;
 background: #21ad65;
 border-bottom: solid 2px #1e9760;
 width: 30%;
 color:#1e9760;
}
td {
text-align: left;
 padding: 0 0 0 10px;
}

th.s {
text-align: center;
 padding: 10px;
 background: #efeaea;
 border-bottom: dotted 1px #86c68c;
 width: 30%;
}

/* 総研大詳細 */	
.table-02{ 
 border-collapse: collapse;
 width:100%;
 margin-left: 10px;
}
th {
text-align: center;
 padding: 10px;
 background: #fff;
 border-bottom: solid 2px #fff;
 width: 30%;
 color:#1e9670;
}
td {
text-align: left;
 padding: 0 0 0 10px;
 border: solid 1px #fff;
 background: #fff;
 color:#1e9670;
}

/* ----- sh table ----- */
.table-03 {
	font-size: 13px;
	border: 1px solid #cccccc;
	border-spacing: 0;
	border-collapse: separate;
	border-radius: 6px;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
}

.table-03 th, .table-03 td {
	padding: .6em 1.5em;
	border: 0.5px solid #ddd;
}

.table-03 th {
	width: 15%;
	text-align: center;
	color: #1B1A1A;
	background-color: #f5f5f5;
}
@media screen and (max-width: 480px) {
.table-03 {
		width: 95%;
	}

.table-03 th, .table-03 td {
		width: 100%;
		display: block;
		border-top: none;
		border: 0.5px  dashed #ddd;
	}

}


.table-04{ 
 border-collapse: collapse;
 width:100%;
}
.table-04 th {
text-align: center;
 padding: 10px;
 background: #1e9760;
 border: solid 1px #ccc;
 color:#fff;
}
.table-04 td {
text-align: left;
 padding: 0 0 0 10px;
 border: solid 1px #ccc; 
 color:#000;
}

.table-04 th.width30 {
        width: 30%;
    }
    
.table-04 th.width25 {
        width: 25%;
    }
    
.table-04 th.width20 {
        width: 20%;
    }    
.table-04 a{border-bottom: 1px solid; padding-bottom: 3px;}
.table-04 a:hover{color: #6cdedb;}   


/* acces Table */	
table.ac {
	width:80%;
	margin:5px auto;
	border:solid 1px #cccccc;
    border-collapse:collapse;
 }
td.ac {
	 border: solid 1px #cccccc;
	 padding:5px 5px 5px 5px;
     color:#000;
	  }	

/*==================================
リスト
==================================*/
/*　lhd　*/
.list8 li{
    list-style: disc;
	margin: 7px 7px 7px 30px;
    padding: 0px 0 10px 0px;
    text-indent: 1px;
    }
    
/* soken btn*/
.list-y {
	display: flex;
	flex-wrap: wrap;	
	margin: 0 auto;	
}

.list-y li {	
	width: 50%;	
	margin: 0 auto;		
	line-height: 1.5;	
	position: relative;
	font-size: 18px;
}

@media screen and (max-width: 460px){	
	.list-y li{width: 93%;}
	}

/*==================================
lhd 申込みCheck BOX
==================================*/ 
.checkB #link3 {
	color: #fff;
}
.checkB #link3 a {
	color: #000;
	background-color: #fff;
	padding: 3px 15px;
}
.checkB #link3 a:hover {
	background-color: #86c68c;
}    

/*==================================
footer
==================================*/
#footer{
    background: #1e9760;
    color: #fff;
}

#footer a{
    color: #fff;
}

#footer a:hover{
   opacity: 0.5;
}

.footer-area{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
}

.nifs-info{
    width:30%;
}

.nifs-info span{
    display: block;
    font-size:1.7rem;
    font-weight: bold;
    line-height: 1.5;
}

.nifs-info dt.footer-title,
.nifs-info li:first-of-type{
    margin: 0 0 10px 0;
}

.nifs-info li dt{
    margin:0 10px 0 0;
}

.nifs-info li dt,
.nifs-info li dd{
    display: inline-block;
}

.footer-sitemap{
    width:65%;
}

.footer-sitemap ul{
    display: flex;
    flex-wrap: wrap;
    margin: 0 0 50px 0;
    font-size: 0.9rem;
}

.footer-sitemap li{
    padding: 10px 20px;
}

.footer-sitemap li a{
	position: relative;
    padding: 0 10px;
}

.footer-sitemap li a:before{
	position: absolute;
	top:40%;
	left:-10px;
	content: '';
  width: 7px;
  height:7px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
}

small{
    display: block;
    text-align: center;
    margin: 50px 0 0 0;
}

@media screen and (max-width:1090px) {
    .footer-area{
        align-items: flex-start;
    }
.nifs-info{
    width:40%;
}
.footer-sitemap{
    width:56%;
}
    
}

@media screen and (max-width:940px) {
    small{
        text-align: center;
    }

    
}

@media screen and (max-width:768px) {
.nifs-info,
.footer-sitemap{
    width:100%;
}
    
.nifs-info{
    text-align: center;
    margin:0 0 70px 0;
    padding: 0 0 70px 0;
    border-bottom:1px solid rgba(255,255,255,0.8);
}
    .nifs-info span{
        font-size:1.3rem;
    }    
}

/* sns */
.socialEffect__link {
  margin: .3em;
  display: block;
  width: 60px;
  height: 60px;
  line-height: 60px;
  border-radius: 50%;
  text-align: center;
  position: relative;
  z-index: 1;
  color: #bfbfbf;
  font-size: 1.6rem;
  background: rgba(255, 255, 255, 0.1);
  transition: transform ease-out 0.2s;
}

.socialEffect__box li {
  display: inline-block;
  margin-left: 20px;
}
/* facebook */
.icon-facebook::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  z-index: -1;
  transform: scale(0.9);
}
.fab.fa-facebook-f {
  display: inline-block;
  color: #fff;
}
.icon-facebook:hover {
  background: #3b5998;
  transform: scale(0.9);
}

/* tw */
.icon-twitter::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  z-index: -1;
  transform: scale(0.9);
}
.fab.fa-twitter {
  display: inline-block;
  color: #fff;
}
.icon-twitter:hover {
  background: #000; /*#00b0ed*/
  transform: scale(0.9);
}

.fa-twitter:before {
    content: '𝕏';
    font-family: unset;
    font-weight: bold;
}

/* youtube */
.icon-youtube::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  z-index: -1;
  transform: scale(0.9);
}
.fab.fa-youtube {
  display: inline-block;
  color: #fff;
}
.icon-youtube:hover {
  background: #ff0000;
  transform: scale(0.9);
}

/*==================================

@media screen SP

==================================*/

@media screen and (min-width: 768px) {
  .spOnly {
    display: none !important;
  }
}


@media screen and (max-width: 767px) {
  .pcOnly {
    display: none !important;
  }
  .sp_bk {
    display: block;
  }
}



.flexBox {
  display: flex;
}
@media (min-width: 768px) {
  .flexBox1 {
    display: flex;
    justify-content: space-between;
  }
}


.ai_c {
  align-items: center;
}

.jc_sb {
  justify-content: space-between;
}

.fw_wp {
  flex-wrap: wrap;
}

.inline-block{
  display:inline-block;
}
/*==================================
背景
==================================*/

.bg-01{
  background: url("../img/main_bg-1.jpg") center center / cover no-repeat fixed;
}

#news .bg02 {
  width: 100%;
  height: auto;
}

.bg-02 {
  background-color: #fff;
  background-size: 25px 25px;
}



/*==================================
トップページ右端 ツアー申込み
==================================*/

#lhd_box{
	background-color: rgba(14, 83, 186, 0.8);
	position: fixed;
	right: 0px;
    bottom:0;
	text-align: center;
	padding: 20px;
	list-style-type:none;
    font-weight: 800;
    z-index: 2;
	}

#lhd_box a{color:#fff;
text-decoration: none;}
#lhd_box a:hover{opacity: 0.8;}


/*==================================
トップページ右端 市民学術講演会　視聴ボタン
==================================*/

#Lecture_box{
	background-color: rgba(197, 31, 106, 1);
	position: fixed;
	right: 0px;
    bottom:0;
	text-align: center;
	padding:25px;
	list-style-type:none;
    font-weight: 800;
    font-size:25px;
    z-index: 2;
    border-radius:10px;
	}

#Lecture_box a{color:#fff;
text-decoration: none;}
#Lecture_box a:hover{opacity: 0.8;}

@media screen and (max-width: 767px) {
#Lecture_box{padding:10px;font-size:15px;}
}


/*==================================
end 挨拶
==================================*/

.box-end{
    padding: 8px 19px;
    margin: 2em 0;
    color: #2c2c2f;
    background: #fff;
    border-top: solid 5px #6ab579;
    border-bottom: solid 5px #6ab579;
    
}
.box-end p {
    margin: 0; 
    padding: 0;
    font-size:20px;
    line-height: 40px;
}

/*==================================
font 
==================================*/

.fsf10{font-size: 10px;}
.fsf20 {font-size:20px;}
.fsf30 {font-size:30px;}
.fsw900{font-weight: 900;}

.fs_center {text-align:center;}

.fsc-white{color: #fff;}
.fsc-green{color:#1e9760;}
.fsc-red{color:#D10606;}
.fsc-orange{color:#F2571A;}


.fsmt20{margin-top:20px;}
.fsmt40{margin-top:40px;}

.fsmb20{margin-bottom:20px;}
.fsmb30{font-size: 30px;}
.fsmb50{margin-bottom: 50px;}
.fsmb100{margin-bottom: 100px;}

.fsmr40{margin-right :40px;}



/* 見出し */
.fsmid01 {
  position: relative;
  display: inline-block;
  margin: 0 0 1rem -10px;
  padding: 0.5rem 3rem;
  color: #fff;
  border-radius: 0 100vh 100vh 0;
  background: #0075a9;
  -webkit-box-shadow: 3px 3px 5px rgba(0, 0, 0, .2);
  box-shadow: 3px 3px 5px rgba(0, 0, 0, .2);
}

.fsmid01 :before {
  position: absolute;
  bottom: -10px;
  left: 0;
  width: 0;
  height: 0;
  content: '';
  border-top: 10px solid #005276;
  border-left: 10px solid transparent;
}

/* ==================================
マーカー
================================== */

.fsmarker{
  display: inline-block;
  border: solid 1px #eb9e16;
  padding: 0 0.9%;
  vertical-align: middle;
  margin: 0;
  background: #eb9e16;
  font-size: 20px;
  color: #fff;
}

.fsmarker-02{
  display: inline-block;
  border: solid 1px #86c68c;
  padding: 0 0.9%;
  vertical-align: middle;
  margin: 0;
  background: #86c68c;
  font-size: 17px;
  color: #fff;
}

.fsmarker-03{
  display: inline-block;
  border: solid 1px #0e53ba;
  padding: 0 0.9%;
  vertical-align: middle;
  margin: 0;
  background: #0e53ba;
  font-size: 17px;
  color: #fff;
}

.fsmarker-04 {
  text-decoration: underline; 
  text-decoration-thickness: 0.5em; 
  text-decoration-color: rgba(255, 228, 0, 0.4); /* 線の色 */
  text-underline-offset: -0.2em; /* 線の位置。テキストに重なるようにやや上部にする */
  text-decoration-skip-ink: none; /* 下線と文字列が重なる部分でも下線が省略されない（線が途切れない） */
}

/*==================================
title
==================================*/
.fs-title_001{
  margin-bottom: 1em;
  padding-top: 1.5em;
  padding-bottom: 1em;
  font-family: 'Kosugi Maru', sans-serif;;
  font-size: 2em;
  font-weight: 900;
  text-align: center;
  line-height: 1.4em;
  letter-spacing: 0.05em;
}

@media screen and (min-width: 768px) {
  .fs-title_001 {
    font-size: 1.875em;
  }
}
@media screen and (min-width: 1024px) {
  .fs-title_001 {
    font-size: 2.8125em;
  }
}

/*==================================
謎解き　ポップアップ
==================================*/
#popup {
  display: none; /* label でコントロールするので input は非表示に */
}

.popup-open {
  cursor: pointer; /* マウスオーバーでカーソルの形状を変えることで、クリックできる要素だとわかりやすいように */
}

.popup-overlay {
  display: none; /* input にチェックが入るまでは非表示に */
}

#popup:checked ~ .popup-overlay {
  display: block;
  z-index: 99999;
  background-color: #00000070;
  position: fixed;
  width: 100%;
  height: 100vh;
  top: 0;
  left: 0;
}

.popup-window {
  width: 90vw;
  max-width: 560px;
  padding: 20px;
  background-color: #ffffff;
  border-radius: 6px;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.popup-text {
  margin: 0;
}

.popup-text:not(:last-of-type) {
  margin-bottom: 1em
}

.popup-close {
  cursor: pointer;
  position: absolute;
  top: -26px;
  right: 0;
}

/*==================================
TOPへ
==================================*/
#pagetop {
    position: fixed;
    bottom: 150px;
    right: 30px;
}

@media screen and (max-width: 767px) {
#pagetop {
    position: fixed;
    bottom: 70px;
    right: 30px;
}
}

/*==================================
clfix
==================================*/

.clfix:after{
  content: "."; 
  display: block; 
  height: 0; 
  font-size:0;	
  clear: both; 
  visibility:hidden;
}