@charset "utf-8";
/* CSS Document */


/* *************	01 : Commun      ***************************** */
body, div, table, th, td, caption, h1, h2, h3, h4, h5, h6, a, p, pre, ul, ol, li, dl, dt, dd, form, address, embed, object {
	margin: 0;
	padding: 0;
	font-size:100%;
	font-weight: normal;
	list-style-type: none;
}

body {
 background-color: #fff;
 font-family: Verdana, Arial, Helvetica, sans-serif, メイリオ, Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS P Gothic";
 font-size: 12px;
 color: #333;
 text-align: left;
 line-height: 20px;
	}
 
 table {
	border-collapse: collapse;
	border-spacing: 0;
}
	
img {
	border: 0;
	line-height: 0;
}

ol.normal {
	padding-left: 20px;
}

ol.normal li {
	list-style-type: decimal;
}

p {
	margin: 12px 0;
	font-family: Verdana, Arial, Helvetica, sans-serif, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS P Gothic";
}

.jp{
letter-spacing: 0.3mm;
	}

.green {
	color: #46ac68;
}

.red {
	color: #f55632;
}


a:link {
	color: #46ac68;
	text-decoration: none;
	outline: none;
}

a:visited {
	text-decoration: none;
	color:  #46ac68;
	outline: none;
}
a:hover {
	text-decoration: underline;
	color: #95b899;
	outline: none;
}

a:active {
	text-decoration: none;
	color: #46ac68;
	outline: none;
}

input[type="submit"]::-moz-focus-inner{
 border :0px;
}


a.more {
	display: block;
	float: right;
	height: 32px;
	width: 64px;
	text-indent: -9999em;
	background: url(../images/commun/more.gif) no-repeat;
	}
	
a.more:hover {
	display: block;
 background: url(../images/commun/more_gr.gif) no-repeat;
}

.pagetop {
 background: url(../images/commun/flechegreentop.gif) no-repeat 0 7px;
	width: 80px;
	height: 20px;
	margin: 50px 0 30px 800px;
	padding: 1px 0 0 15px;
	clear: both;
	}

.clear {
	clear: both;
	display: block;
	height: 1px;
}

.clearfix:after {
	visibility: hidden;
	display: block;
	font-size: 0;
	content: " ";
	clear: both;
	height: 0;
}
* html .clearfix {
	zoom: 1;
} /* IE6 */
*:first-child+html .clearfix {
	zoom: 1;
} /* IE7 */


#container {
	width: 980px;
	margin: 0 auto;
	padding: 0;
	}
	
/* *************	02 : Header      ***************************** */
#header {
	margin: 0px;
	padding: 0px;
	width: 980px;
	position: relative;
}

h1#logo {
	margin: 20px 0 0 30px;
}

.social-icons {
	display: block;
	text-align: right;
	position: absolute;
	top: 0;
	right: 20px;
}

.social-icons a  {
	display: inline-block;
	padding: .25rem;
	color: #999;
}

.social-icons a:hover, .social-icons a:focus {
	color: #ccc;
}

.social-icons a + a {
	margin-left: .5rem;
}


/* *************	 03 globalnavi   ***************************** */
#navi {
	width: 980px;
	height: 18px; 
 margin: 40px 0 0 0;
}
#navi ul {}

#navi li {
 float:left; 
 height:18px;
	margin: 0 35px;
}

#navi li a {
	display:block;
	height:18px; 
	background-repeat:no-repeat;
}
	
#navi li a:hover {background-position:0px -18px;}
#navi li span {display:none;}
#navi .office {width:78px;}
#navi .office a {background:url(../images/commun/navi_office.gif);}
#navi .news {width:159px;}
#navi .news a {background:url(../images/commun/navi_news.gif);}
#navi .association {width:173px;}
#navi .association a {background:url(../images/commun/navi_association.gif);}
#navi .conference {width:173px;}
#navi .conference a {background:url(../images/commun/navi_conference.gif);}
#navi .community {width:94px;}
#navi .community a {background:url(../images/commun/navi_community.gif);}
#navi .members {width:109px;}
#navi .members a {background:url(../images/commun/navi_members.gif);}
	
/* *************	04 : Footer   ***************************** */
#footer {
	width: 980px;
	background: url(../images/commun/footer.gif) no-repeat;
	height: 90px;
	margin: 20px 0 0 0 ;
	padding: 20px 0 0 0;
	clear: both;
}

#copyright {
text-align: center;
	}
	
#add {
text-align: center;
font-size: 10px;
line-height: 12px;

}
	
	/* *************	05 : contents      ***************************** */
#contents, .contents {
	background:url(../images/commun/bg_body.gif) repeat-y ;
	margin: 20px auto;
	position: relative;
	width: 980px;
}

#contents .top, .contents .top {
	background: url(../images/commun/bg_top.gif) no-repeat ;
	width: 980px;
}

#contents .bottom, .contents .bottom {
 background: url(../images/commun/bg_bottom.gif) no-repeat 0 100%;
	overflow: hidden;
 width: 980px;
}



/****** h2 h3 or h2 h3 lang icon  **********/
.column {
 width: 880px;
	padding: 50px;
}

.column h2{
	padding: 0px 0px 8px 0 ;
	margin: 0px 0 15px 0;
	border-bottom: 1px solid #b9b9b7;
	}
	
.lang{
 width: 880px;
	height:20px;
	padding: 0px 0px 8px 0 ;
	margin: 0px 0 15px 0;
	border-bottom: 1px solid #b9b9b7;
	clear: both;
}

.column .lang h2{
	padding: 0 ;
	margin: 0;
 border-bottom: none;
	float: left;
}

.column h3{
	font-size: 12px;
	color: #000;
	padding: 12px 0px 8px 0;
	margin: 0px 0 10px 0;
	border-bottom: 1px solid #d5d4d4;
	clear: both;
}

.column h4{
 font-size:12px;
	color: #000;
	padding: 12px 0px 8px 0;
	margin: 0px 0 10px 0;
 clear: both;
}

.lang2{
	width: 880px;
	height:20px;
	padding: 12px 0px 8px 0;
	margin: 0px 0 10px 0;
	border-bottom: 1px solid #b9b9b7;
	clear: both;
}

.column .lang2 h3{
	padding: 0 ;
	margin: 0;
 border-bottom: none;
	float: left;
}

.lang ul, .lang2 ul{
 margin: 0;
	padding: 0px 10px 0 0 ;
	float: right;
}

.lang ul li, .lang2 ul li{
 margin: 0 0px 0 20px;
 float: left;
}

.lang img,.lang2 img,.column h2 img, .column h3 img { vertical-align:bottom; }

/*** additional styles March 2018 and later **/
.column .h3 {
	font-weight: bold;
	font-size: 1.2rem;
}

.row {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-right: -15px;
	margin-left: -15px;
	box-sizing: border-box;
}

.col-8, .col-4 {
	position: relative;
	min-height: 1px;
	padding-right: 15px;
	padding-left: 15px;
	box-sizing: border-box;
}

.col-8 {
	-webkit-box-flex: 0;
	-ms-flex: 0 0 66.666667%;
	flex: 0 0 66.666667%;
	max-width: 66.666667%;
}

.col-4 {
	-webkit-box-flex: 0;
	-ms-flex: 0 0 33.333333%;
	flex: 0 0 33.333333%;
	max-width: 33.333333%;
}

.d-flex {
	display: flex;
}

.col-auto {
	display: block;
	width: auto;
}

.a-style h1 {
	font-size: 1.2rem;
	font-weight: bold;
	background-color: #4c805e;
	color: transparent;
	text-shadow: 2px 2px 1px rgba(255,255,255,.3);
	-webkit-background-clip: text;
     -moz-background-clip: text;
          background-clip: text;
	padding-bottom: 1.5rem;
	margin-bottom: 1.5rem;
	border-bottom: 1px solid #b9b9b7;
}

#lecture-menu {
	width: 240px;
	padding-left: 40px;
	min-height: 315px;
	border-left: 1px dotted #747474;
}

#lecture-menu .h2 {
	text-transform: uppercase;
	font-size: 16px;
	color: #666;
	line-height: 20px;
	margin: 15px 0 15px 0;
	border: none;
}

.img-fluid {
	max-width: 100%;
}

.flag-menu li {
	list-style: none;
	font-size: 1rem;
}

.flag-menu li a {
	display: flex;
	-webkit-box-align: center !important;
	-ms-flex-align: center !important;
	align-items: center !important;
	padding: 0.25rem !important;
	background: none !important;
}

.flag {
	display: inline-block;
	width: 30px;
	height: 24px;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	margin-right: 5px;
}

.flag-at {
	background-image: url(../images/flags/AT.png);
}

.flag-be {
	background-image: url(../images/flags/BE.png);
}

.flag-ch {
	background-image: url(../images/flags/CH.png);
}

.flag-de {
	background-image: url(../images/flags/DE.png);
}

.flag-es {
	background-image: url(../images/flags/ES.png);
}

.flag-fr {
	background-image: url(../images/flags/FR.png);
}

.flag-it {
	background-image: url(../images/flags/IT.png);
}

.flag-nl {
	background-image: url(../images/flags/NL.png);
}

.flag-no {
	background-image: url(../images/flags/NO.png);
}

.flag-pl {
	background-image: url(../images/flags/PL.png);
}

.flag-pt {
	background-image: url(../images/flags/PT.png);
}

.flag-se {
	background-image: url(../images/flags/SE.png);
}

.mb-0 {
	margin-bottom: 0 !important;
}

.mb-2 {
	margin-bottom: .5rem;
}

.mb-3 {
	margin-bottom: 1rem;
}

.mb-4 {
	margin-bottom: 1.5rem;
}

.mb-5 {
	margin-bottom: 3rem;
}

.mt-0 {
	margin-top: 0;
}

.mt-5 {
	margin-top: 3rem !important;
}

.p-3 {
	padding: 1rem;
}

.p-20 {
	padding: 20px;
}

.float-right {
	float: right;
}

.v-align-top {
	vertical-align: top;
}

.text-normal {
	font-weight: normal !important;
}

.bg-light {
	background-color: #f0f0f0;
}

.bg-logo {
	background-image: url(../images/logo.svg);
	background-position: right top;
	background-size: 50%;
	background-repeat: no-repeat;
}

.lh-2 {
	line-height: 2;
}

h2.title {
	font-size: 18px;
	font-weight: bold;
	line-height: 1.5;
}

.hr {
	border: .5px solid #aaa;
}