@charset "utf-8";


html {
	font-size: 62.5%;
	line-height: 1.75;
}

body {
/*
	-webkit-font-smoothing: antialiased;
	font-optical-sizing: auto;
	font-variation-settings: "wdth" 100;
*/
	font-size: 1.6rem;

	font-family: "Open Sans", Roboto, sans-serif;
	font-weight: 400;
	font-style: normal;

}

.roman {
/*
	ローマ数字をアルファベットで表記するときに指定する &#8544;=I, &#8561;=i, ...
	ex: <span class="roman">&#8544;</span>
*/
/*
	font-family: roman;
	font-size: 132%;
	vertical-align: -3.4%;
*/
	padding: 0 3px;
	font-family: serif;
	font-size: 107%;
	display: inline-block;
	transform: translateY(1px);
}



a {
	text-decoration: none;
	color: #0096e9;
	transition: all 0.2s linear;
}

a:visited {
	color: #05b;
}

a:hover {
	color: #0096e9 !important;
	text-decoration: underline;
}

a:active {
	color: #f00;
}

a.banner {
	transition: opacity 0.1s linear;
}

a.ic-arrow-right:after {
	content: "\f105";
	font-family: "FontAwesome";
	font-size: 1.6rem;
	line-height: 1.0;
	margin-left: 10px;
	color: #a2a2a2;
}

a.ic-arrow-right:hover, 
a.ic-arrow-right:hover:after {
	color: #00a6f9;
}

a.banner:hover {
	opacity: 0.85;
}


.is-hidden {
	display: none;
}

.bold {
	font-weight: bold;
}

img {
	vertical-align: bottom;
	border: 0;
	outline: 0;
}


.wrapper960 {
	width: 960px;
	margin: 0 auto;
}

h1#siteTitle,
#siteTitle {
	margin: 0;
	padding: 0;
	line-height: 1.0;
}

header {
	display: flex;
}

header #siteTitle {
	margin-right: auto;
}

a#siteTitle:lang(en) {
	position: relative;
}

a#siteTitle:lang(en) > img {
	position: absolute;
	left: 0;
	top: 0;
	z-index: 1000;
}


header .list-shortcuts {
	display: flex;
	height: 68px;
	margin: 0;
	padding: 12px 0 0;
	list-style: none;
	font-family: 'Roboto', sans-serif;
	font-size: 1.2rem;
}

header .list-shortcuts > li {
	margin-right: 14px;
}

header .list-shortcuts > li > a {
	display: inline-block;
	padding: 2px;
	color: #5a5a5a;
}

header .list-shortcuts a:hover {
	color: #00a6f9;
}


header .list-shortcuts > li > a .fa {
	display: inline-block;
	margin-right: 3px;
	font-size: 1.8rem;
	vertical-align: -10%;
	color: #00a6f9;
}

header .list-shortcuts > li:last-of-type > a .fa {
	margin-right: 0;
	margin-left: 3px;
}

.list-shortcuts > li#g_search {
	position: relative;
	z-index: 0;
}

.list-shortcuts > li#g_search.active a {
	padding: 2px 8px;
	background: #00a6f9;
	border-radius: 3px 3px 0 0;
}

.list-shortcuts > li#g_search.active a, 
.list-shortcuts > li#g_search.active a .fa {
	color: #fff;
}

.list-shortcuts > li#g_search.active,
.list-shortcuts #searchForm > form {
	z-index: 9999;
}

#searchForm {
	display: none;
	position: absolute;
	top: 25px;
	right: 0;
}

#searchForm > form {
	display: inline-block;
	margin: 0;
	padding: 4px;
	background: #00a6f9;
	white-space: nowrap;
	border-radius: 3px 0 3px 3px;
}

#searchForm input {
	display: inline-block;
	width: 82px;
	margin: 0 1px;
	padding: 2px 4px;
	line-height: 20px;
	outline: none;
	border: none;
	background: rgba(255,255,255,0.85);
	color: #333;
	vertical-align: middle;
}

#searchForm input:placeholder-shown {
	color: #00a6f9;
	opacity: 1.0;
}

#searchForm input::-webkit-input-placeholder {
	color: #00a6f9;
	opacity: 1.0;
}

#searchForm input::-moz-placeholder {
	color: #00a6f9;
	opacity: 1.0;
}

#searchForm input:-moz-placeholder {
	color: #00a6f9;
	opacity: 1.0;
}

#searchForm input:-ms-input-placeholder {
	color: #00a6f9;
	opacity: 1.0;
}


#searchForm button {
	display: inline-block;
	width: 24px;
	height: 24px;
	overflow: hidden;
	text-align: center;
	border: none;
	color: rgba(255,255,255,0.85);
	background: none;
	vertical-align: middle;
	cursor: pointer;
	transition: all 0.2s;
}

#searchForm button .fa {
	font-size: 1.6rem;
	line-height: 22px;
}

#searchForm button:hover, 
#searchForm button:focus, 
#searchForm button:active {
	color: #00a6f9;
	background: rgba(255,255,255,0.85);
}

#closeArea {
	display: none;
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
/*
	background:#f00;
*/
}


#mainNav {
	position: relative;
	display: flex;
	align-content: space-around;
	align-items: center;
	width: 961px;
	margin: 0;
	padding: 0;
	list-style: none;
	font-weight: bold;
	font-family: 'Roboto', sans-serif;
	z-index: 1000;
}

#mainNav > li {
	flex-grow: 1;
	z-index: 2000;
	text-align: center;
	font-size: 1.6rem;
	align-items: center;
	border-width: 0 1px 0 0;
	border-style: dotted;
	border-color: #c8c8c8;
}

#mainNav > li:first-child {
	border-left-width: 1px;
}

#mainNav > li > a, 
#mainNav > li > .lv1 {
	display: block;
	padding: 5px;
	color: #4c4c4c;
	cursor: pointer;
	transition: all linear 0.2s;
}

#mainNav > li > a:after, 
#mainNav > li > .lv1:after {
	content: "\f0d7";
	display: block;
	font-family: "FontAwesome";
	font-weight: normal;
	line-height: 5px;
	color: #00a6f9;
}

#mainNav > li:first-of-type > a:after {
	content: "";
}

#mainNav > li > a:hover, 
#mainNav > li > .lv1:hover {
	color: #00a6f9;
}
#mainNav > li > a.active, 
#mainNav > li > .lv1.active {
	color: #fff !important;
	background: #00a6f9;
}

#mainNav > li > a.active .fa {
}

#mainNav > li > .naviPanel {
	display: none;
	position: absolute;
	top: 43px;
	left: 0px;
	z-index: -1;
	width: 880px;
	margin: 0;
	padding: 24px 40px;
	list-style: none;
	text-align: left;
	background: #00a6f9;
	box-shadow: 0 5px 12px rgba(0,0,0,0.6);
}

#mainNav .naviPanel > ul {
	display: flex;
	flex-flow: row wrap;
	margin: 0;
	padding: 0;
	list-style: none;
}

#mainNav > li .naviPanel li:nth-child(1), 
#mainNav > li .naviPanel li:nth-child(2), 
#mainNav > li .naviPanel li:nth-child(3) {
	border-top: 1px solid rgba(255,255,255,0.4);
}

#mainNav .naviPanel > ul > li {
	display: block;
	width: 270px;
	margin: 0 10px;
	padding: 0;
	font-size: 1.4rem;
	line-height: 1.3;
	border-bottom: 1px solid rgba(255,255,255,0.4);
}

#mainNav ul a {
	display: inline-block;
	color: #fff;
	padding: 8px 3px;
	transition: color,opacity 0.2s linear;
}

#mainNav > li:nth-of-type(5) ul li, 
#mainNav > li:nth-of-type(6) ul li, 
#mainNav > li:nth-of-type(7) ul li {
	min-height: 39px;
}

#mainNav ul a:after {
	content: "\f0a9";
	display: inline-block;
	margin-left: 3px;
	opacity: 0.6;
	font-family: "FontAwesome";
	font-weight: normal;
	font-size: 1.6rem;
}

#mainNav ul a:hover {
	color: #fff !important;
}

#mainNav ul a:hover:after {
	opacity: 1.0;
}

#mainNav > li#language {
	display: none;
}

#maintenance {
	width: calc(100% - (1.8em * 2));
	max-width: calc(960px - (1.8em * 2));
	margin: 8px auto 12px;
	padding: 0.8em 1.8em;
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	background: #dadada;

	letter-spacing: -0.01em;
}

.preload #slideHOME {
	overflow: hidden;
}

#slideHOME {
	position: relative;
	width: 960px;
	height: 366px;
	margin-top: 7px;
	margin-bottom: 60px;
}

#slideHOME.forCheck {
	height: auto;
	margin: 0 auto;
}

#slideHOME > div {
	width: 960px;
	height: 366px;
	overflow: hidden;
}

#slideHOME.forCheck > div + div {
	margin-top: 30px;
}

#slideHOME img {
	max-width: 960px;
}

a.slick-prev,
a.slick-next {
	position: absolute;
	top: 50%;
	margin-top: -16px;
	outline: 0;
	width: 32px;
	height: 32px;
	z-index: 9999;
	font-size: 4.2rem;
	line-height: 32px;
	text-align: center;
	color: #a2a2a2;
	z-index: 7999;
}

a.slick-prev { left: -32px; }
a.slick-next { right: -32px; }

.slick-dots {
	display: flex;
	justify-content: center;
	width: 100%;
	margin: 0 auto;
	padding: 8px 0 0;
	list-style: none;
}

.slick-dots button {
	display: inline-block;
	width: 16px;
	height: 16px;
	overflow: hidden;
	text-indent: 100%;
	margin: 8px 4px;
	padding: 0;
	outline: 0;
	border-radius: 50%;
	border: 4px solid #fff;
	background: #a2a2a2;
	cursor: pointer;
}

.slick-dots .slick-active button {
	background: #000;
}

.slick-slide {
	background: #dddbe4;
	text-align: center;
}

#IOPmovDiv {
	text-align: center;
	background: #dddbe4;
}

#IOPmov {
	display: block;
	text-align: center;
	background: #dddbe4;
}

#IOPmovRect {
	display: inline-block;
	position: relative;
}

#IOPmovRect:after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;

	display: block;
	width: 100%;
	height: 100%;

	outline: 3px solid #dddbe4;
	outline-offset: -3px;

}

#IOPmov video {
	height: 100%;
	max-height: calc(100vw * 0.38125);
	margin: 0 auto;
}

.flex-container {
	display: flex;
}

.flex-content {
	
}



.column_single h2, 
.column_L h2 {
	clear: both;
	margin: 60px 0 0;
	padding: 64px 0 0;
	font-size: 2.6rem;
	color: #002360;
	border-top: 3px solid #002360;
}

.column_single h2, .column_L h2 {	}
.column_single h3, .column_L h3 {	}
.column_single h4, .column_L h4 {	}
.column_single h5, .column_L h5 {	}
.column_single h6, .column_L h6 {	}

.column_single h3, .column_L h3 {
	font-size: 2.0rem;
	color: #002360;
}

.column_single h4, .column_L h4, 
.column_single h5, .column_L h5, 
.column_single h6, .column_L h6 {
	margin: 18px 0;
	font-size: 1.6rem;
	color: #002360;
}

#news {
	width: 660px;
	margin-right: auto;
	border-top: 5px solid #00a6f9;
}

#news h2 {
	margin: 0;
	margin-right: auto;
	padding: 15px 0;
	font-family: Roboto;
	font-size: 2.0rem;
	line-height: 1.0rem;
}

#news h2 .fa {
	margin-right: 8px;
	vertical-align: middle;
	font-size: 3.0rem;
}

#news_header a {
	display: inline-block;
	padding: 2px 20px;
	font-size: 1.3rem;
	align-self: center;
	border-left: 1px dotted #999;
	color: #333;
}

#news_header a:hover, 
#news_header a:hover:after {
	color: #00a6f9;
}

#news_header a.ic-arrow-right {
	padding-right: 0;
}

#news_header a:first-of-type .fa {
	margin-right: 5px;
	vertical-align: middle;
	font-size: 1.8rem;
	line-height: 1.0;
	color: #ff8c00;
}


.list-links-date {
	margin: 0;
	padding: 0;
	list-style: none;
}

.main .list-links-date {
	border: solid #a2a2a2;
	border-width: 1px 0;
}

.main .list-links-date > li a {
	padding: 11px 16px 12px 108px;
}

.list-links-date > li {
	margin: 0;
	padding: 0;
	font-size: 1.5rem;
	line-height: 1.3;
	border-top: 1px solid #dadada;
}

.list-links-date > li:first-child {
	border-top: none;
}

.list-links-date > li a {
	position: relative;
	display: block;
	padding: 10px 16px 10px 108px;
	color: #333;
}

.list-links-date > li a:after {
	content: "\f105";
	font-family: "FontAwesome";
	font-size: 1.6rem;
	line-height: 1.0;
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	color: #a2a2a2;
	width: 8px;
	height: 15px;
	text-align: right;
}

.list-links-date > li a:hover, 
.list-links-date > li a:hover:after {
	color: #00a6f9;
}

.list-links-date .time {
	display: none;
}

.list-links-date .date {
	float: left;
	display: block;
	width: 102px;
	margin: 3px 0 0 -108px;
	font-size: 1.3rem;
/*
	font-family: Consolas, 'Courier New', Courier, Monaco, monospace;
*/
	font-weight: bold;
	color: #00a6f9;
	position: relative;
}

#news .scrollbox {
	width: 660px;
	height: 176px;
	border: solid #a2a2a2;
	border-width: 1px 0;
}

.scrollbox {
/*
	position: relative;
	overflow: hidden;
*/
}

.list-links-date li.juyo a:before {
	content: "重要";
	display: inline-block;
	margin-right: 8px;
	padding: 0 6px 1px;
	font-size: 1.4rem;
	color: #fff;
	background: #f80000;
	border-radius: 3px;
}

.list-links-date li.new .date:after {
	content: "";
	position: absolute;
	right: 0px;
	display: inline-block;
	width: 10px;
	height: 10px;
	margin: 2px 0 0 5px;
	background: #f80000;
	border-radius: 5px;
}

.list-links-date li.new.caution .date:after, 
.list-links-date li.caution .date:after {
	content: "\f12a";
	display: inline-block;
	position: absolute;
	width: 21px;
	height: 17px;
	margin: -4px 0 0 5px;
	padding-top: 4px;
	font-family: "FontAwesome";
	font-size: 1.7rem;
	line-height: 1.0;
	text-align: center;
	color: #000;
	background: #fc0;
	border-radius: 10.5px;
}


#news .scrollbox {
	width: 660px;
	height: 176px;
	border: solid #a2a2a2;
	border-width: 1px 0;
}

#home_block2.flex-container {
	flex-direction: row-reverse;
	margin-top: 60px;
}



#home_block2 .list-shortcuts {
	width: 240px;
	margin: 0;
	padding: 0;
	list-style: none;
	border-top: 1px solid #c6c6c6;
}

#home_block2 .list-shortcuts > li {
	border-bottom: 1px solid #bfbfbf;
	font-size: 1.4rem;
}

#home_block2 .list-shortcuts > li > a {
	display: block;
/*	padding: 10px 0 8px;*/
	padding: 13px 0 13px 40px;
	color: #333;
}

#home_block2 .list-shortcuts > li > a:after {
	content: "\f105";
	font-family: "FontAwesome";
	font-size: 1.6rem;
	line-height: 1.0;
	float: right;
	margin: 4px 10px 0 0;
	color: #a2a2a2;
}

#home_block2 .list-shortcuts > li > a:hover, 
#home_block2 .list-shortcuts > li > a:hover:after {
	color: #00a6f9;
}

#home_block2 .list-shortcuts .fa {
	margin: -3px 8px 0 -32px;
	font-size: 2.4rem;
	line-height: 1.0;
	vertical-align: middle;
	color: #00a6f9;
}

.icomoon {
	display: inline-block;
}

.list-sns {
	justify-content: center;
	margin: -1px 0 0;
	padding: 0;
	list-style: none;
}

.list-sns > li {
	margin: 0 10px;
}

#home_block2 .list-sns a {
	font-size: 3.4rem;
}

#home_block2 .list-sns li:nth-child(1) a .fa {
	position: relative;
	top: 1px;
}

.list-sns a {
	transition: opacity 0.1s linear;
}

.list-sns a:hover {
	opacity: 0.85;
}

.fa-facebook-official	{ color: #3b5998; font-size: 3.23rem; vertical-align: 2px; }
.fa-twitter				{ color: #1da1f2; }
.icomoon-line			{ color: #00c300; font-size: 3.06rem; }
.icon-lineat-1			{ color: #00b900; font-size: 2.89rem; vertical-align: 2px; }
.icon-lineat-2			{ color: #00b900; font-size: 2.89rem; vertical-align: 2px; }
.fa-instagram			{ color: #1a1a1a; }
.fa-youtube,
.fa-youtube-play		{ color: #ff0000; font-size: 3.00rem; vertical-align: 2px; }


#publish {
	margin-top: 24px;
	padding: 0 0 40px 0;
	background: #f2f2f2;
}

#publish h2 {
	height: 40px;
	margin: 0;
	padding: 0;
	overflow: hidden;
	text-indent: 101%;
	white-space: nowrap;
	font-family: 'Roboto', sans-serif;
}

#publish .wrapper960 > .flex-container {
	border-left: 1px solid #000;
	justify-content: space-around;
}

#publish .pub {
	position: relative;
	width: 284px;
	padding: 0 18px;
	flex: 1 1 284px;
	line-height: 1.3;
	border-right: 1px solid #000;
}

#publish .pub_header > img {
	width: 100px;
	height: 142px;
	margin: 0 12px 12px 0;
	box-shadow:0px 5px 14px 2px rgba(0,0,0,0.3);
}

#publish .pub_header h3 {
	margin: 0;
	padding: 48px 0 0 0;
}

#publish #AP .pub_header h3 {
}

.pub-type {
	margin: 5px 0 13px;
	font-size: 1.1rem;
}

.pub-uptodate, 
.pub-uptodate-pubdate {
	font-size: 1.8rem;
	line-height: 1.15;
	font-weight: bold;
	letter-spacing: -0.03em;
}

.pub-uptodate-pubdate {
}

#AP .pub-uptodate-pubdate {
/*
	margin-top: 2px;
	font-size: 1.4rem;
*/
	color: #e90870;
}

#AP.jsap-rev .pub-uptodate {
	margin-top: 30px;
	font-size: 1.8rem;
	color: #125656;
}

#AP.jsap-rev.Blue .pub-uptodate {
	color: #0086b2;
}



#JJAP .pub-uptodate, 
#JJAP .pub-uptodate-pubdate {
	color: #86bb37;
	color: #54af17;
}

#APEX .pub-uptodate, 
#APEX .pub-uptodate-pubdate {
	color: #ee7506;
	color: #ef5700;
}

.pub a.toSite {
	position: absolute;
	top: 0;
	left: 18px;
	display: inline-block;
	width: 280px;
	height: 143px;
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
}

.pub a.toSite:after {
	content: "\f0a9";
	font-family: "FontAwesome";
	display: inline-block;
	position: absolute;
	top: 75px;
	right: 0;
	font-size: 2.4rem;
	line-height: 1.0;
	color: transparent;
	transition: color 0.2s linear;
}

.pub#JJAP a.toSite:after { top: 49px; right: 72px; }
.pub#APEX a.toSite:after { top: 49px; right: 60px; }

.pub a.toSite:hover:after {
	color: #00a6f9;
}

.pub-theme {
	font-family: 'Roboto', sans-serif;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: -0.02em;
}

.pub-theme-sub {
	font-size: 1.2rem;
}

.pub .scrollbox {
	width: 290px;
	height: 237px;
	margin-top: 3px;
	border: solid #a2a2a2;
	border-width: 1px 0;
}

.pub#AP .scrollbox {
	height: 230px;
	margin-top: 10px;
	margin-top: 3px;
}


.pub#AP .scrollbox {
/*タイトルの行数により変える*/
	height: 212px;	/*1行のとき*/
	height: 194px;	/*2行のとき*/
	height: 176px;	/*3行のとき*/
	height: 158px;	/*4行のとき*/
	height: 145px;	/*5行のとき*/
	height: 237px;	/*0行のとき*/
}

.pub-articles {
	width: 280px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.pub-articles > li {
	clear: both;
	border-bottom: 1px solid #c6c6c6;
}

.pub-articles > li:last-child {
	border-bottom: none;
}

.pub-articles > li:after {
	content: " ";
	display: block;
	clear: both;
}

.pub-articles > li > a {
	position: relative;
	display: block;
	padding: 5px 0 8px;
	line-height: 1.16;
	color: #333;
}

#JJAP .pub-articles > li > a, 
#APEX .pub-articles > li > a {
	min-height: 90px;
}

.pub-articles > li > a:after {
	content: "\f105";
	font-family: "FontAwesome";
	font-size: 1.6rem;
	line-height: 1.0;
	position: absolute;
	right: -8px;
	top: 0;
	bottom: 0;
	margin: auto;
	color: #a2a2a2;
	width: 8px;
	height: 16px;
	text-align: right;
}

#JJAP .pub-articles > li > a, 
#APEX .pub-articles > li > a {
	padding: 6px 0 7px 130px;
}

#JJAP .pub-articles > li.noImg > a, 
#APEX .pub-articles > li.noImg > a {
	padding: 6px 0 7px 0;
}

.pub-articles > li > a:hover, 
.pub-articles > li > a:hover:after {
	color: #00a6f9;
}

.pub-articles > li .article-image {
	display: inline-block;
	float: left;
	margin-left: -130px;
	padding-bottom: 8px;
}

.pub-articles > li .article-image img {
	width: 120px;
}

#AP.jsap-rev .article-type,
#AP.jsap-rev .article-date {
	display: none;
}

.article-title {
	display: block;
/*	margin-bottom: 6px;*/
	margin-bottom: 2px;
	font-size: 1.3rem;
	line-height: 1.16;
}

#AP .article-title {
	display: inline-block !important;
}

#AP .article-title:after {
	content: "";
	margin-right: 1.0rem;
}

.article-author {
	display: inline-block;
	font-size: 1.2rem;
}

#home_block3 {
	padding: 40px 0;
}

#events {
	width: 660px;
	margin-right: auto;
	border-top: 5px solid #00a6f9;
}

#events h2 {
	margin: 0;
	margin-right: auto;
	padding: 16px 0;
	font-family: 'Roboto', sans-serif;
	font-size: 2.0rem;
	line-height: 1.0rem;
}

#events h2 .fa {
	margin-right: 8px;
	vertical-align: middle;
	font-size: 3.0rem;
}

#events_header a {
	display: inline-block;
	padding: 2px 0 2px 20px;
	font-size: 1.3rem;
	align-self: center;
	border-left: 1px dotted #999;
}

#events_header a:first-of-type {
	display: inline-block;
/*
	margin-right: 16px;
*/
	border-left: none;
}

#events .scrollbox {
	height: 288px;	/* バナー4点 */
	height: 348px;
	height: 372px;
	height: 392px;
	height: 328px;
	height: 236px;
	border: solid #a2a2a2;
	border-width: 1px 0;
}

.list-events {
	margin: 0;
	padding: 0;
	list-style: none;
}


.list-events > li {
	border-bottom: 1px solid #c6c6c6;
}

.list-events li:last-child {
	border-bottom: none;
}

.list-events > li > a, 
.list-events > li > .nolink {
	display: flex;
	align-items: center;
	min-height: 44px;
	padding: 8px 16px 9px 57px;
	line-height: 1.16;
	position: relative;
}

.list-events > li > a:after {
	content: "\f105";
	font-family: "FontAwesome";
	font-size: 1.6rem;
	line-height: 1.0;
	position: absolute;
	right: 0;
/*
	top: 0;
	bottom: 0;
	margin: auto;
*/
	color: #a2a2a2;
	width: 8px;
	height: 16px;
	text-align: right;
}

.list-events > li > a:hover, 
.list-events > li > a:hover:after {
	color: #00a6f9;
}

.list-events .date {
	position: absolute;
	left: 0;

	display: block;
	width: 44px;
	height: 44px;
	overflow: hidden;
	font-family: 'Roboto', sans-serif;
	text-align: center;
	color: #fff;
	background: #004d99;
	border-radius: 3px;
}

.list-events .date.soon {
	background: #ff7000;
}

.list-events .date .dM {
	display: block;
	margin-top: 3px;
	font-size: 1.3rem;
}

.list-events .date .dD {
	font-size: 2.1rem;
	font-weight: bold;
}

.list-events .dateS, 
.list-events .dateE {
	display: none;
}

.list-events .shortname {
	display: block;
	margin-bottom:2px;
	font-size: 1.6rem;
	font-weight: bold;
}

.list-events .title {
	font-size: 1.3rem;
	line-height: 1.1;
}

.list-events .shortname:empty + .title {
	display: block;
	margin-bottom:2px;
	font-size: 1.6rem;
	font-weight: bold;
}



/*
.list-events > li > a, 
.list-events > li > .nolink {
	display: block;
	min-height: 44px;
	padding: 8px 16px 9px 57px;
	line-height: 1.16;
	color: #333;
	position: relative;
}

.list-events > li > a:after {
	content: "\f105";
	font-family: "FontAwesome";
	font-size: 1.6rem;
	line-height: 1.0;
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	color: #a2a2a2;
	width: 8px;
	height: 16px;
	text-align: right;
}

.list-events .date {
	position: relative;
	float: left;
	display: block;
	width: 44px;
	height: 44px;
	overflow: hidden;
	margin-left: -57px;
}

.list-events .dateD {
	position: absolute;
	top: 0;
	left: 0;
	display: inline-block;
	width: 44px;
	height: 44px;
	font-family: 'Roboto', sans-serif;
	text-align: center;
	color: #fff;
	background: #004d99;
	border-radius: 3px;
}

.list-events .dateD.soon {
	background: #ff7000;
}

.list-events .dateD .dY {}
.list-events .dateD .dM { display:block; margin-top: 3px; font-size: 1.3rem; }
.list-events .dateD .dM:after {
	content: "";
	display: inline-block;
	font-size: 1.1rem;
	line-height: 1.0;
	margin-left: 1px;
	position: relative;
	top: -1px;
}

.list-events .dateD .dD { font-size: 2.1rem; font-weight: bold; }

.list-events .dateS, 
.list-events .dateE {
	display: none;
}

.list-events .shortname {
	display: block;
	margin-bottom:2px;
	font-size: 1.8rem;
	font-weight: bold;
}

.list-events .title {
	font-size: 1.3rem;
	line-height: 1.1;
}

.list-events .shortname:empty + .title {
	display: block;
	margin-bottom:2px;
	font-size: 1.5rem;
	font-weight: bold;
}
*/

/*
.list-events li {
	display: table;
	width: 100%;
}

.list-events li > a {
	display: table-row;
}

.list-events .date {
	display: table-cell;
}
.list-events li .title {
	display: table-cell;
	vertical-align: middle;
}
*/

.list-events + .continue {
	border-top: 1px solid #c6c6c6;
	background: #f8f8f8;
}

.list-events + .continue > a {
	display: block;
	padding: 8px 0;
	text-align: center;
	font-size: 1.3rem;
	color: #5a5a5a;
	transition: color 0.2s linear 0;
}

.list-events + .continue > a:after {
	content: "\f105";
	font-family: "FontAwesome";
	font-size: 1.6rem;
	line-height: 1.0;
	margin-left: 10px;
	color: #a2a2a2;
}


#banners {
	position: relative;
}

#banners a {
	display: block;
	margin-bottom: 9px;
	transition: 0.1s opacity linear;
}

#banners a:hover {
	opacity: 0.85;
}

#JSAPcharacters {
	position: absolute;
	bottom: -40px;
}

footer {
	padding: 30px 0 0;
	background: #002360;
}

footer, 
footer .fa, 
footer .icomoon, 
footer .icon		{ color: #fff; }
footer a,
footer a:visited	{ color: rgba(255,255,255,0.85); }
footer a:hover, 
footer a:focus, 
footer a:hover .fa, 
footer a:focus .fa, 
footer a:hover .icomoon, 
footer a:focus .icomoon, 
footer a:hover .icon, 
footer a:focus .icon	{ color: #00b0fa; }

footer .flex-container {
	align-items: flex-end;
}

footer address {
	margin-right: auto;
	padding-left: 45px;
	font-family: 'Roboto', sans-serif;
	font-size: 1.5rem;
	font-style: normal;
	line-height: 1.4;
}

footer address:before {
	content: url("../img/JSAPlogo-white.png");
	display: inline-block;
	float: left;
	margin: 3px 0 0 -45px;
}

footer address .add, 
footer address .tel {
	display: inline;
	margin-right: 2.0rem;
	font-size: 1.3rem;
}

footer .list-shortcuts {
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 1.2rem;
	line-height: 1.4;
}

footer .list-shortcuts li {
	display: inline-block;
	margin-right: 24px;
}

footer .list-shortcuts .fa {
	margin-right: 3px;
	font-size: 2.4rem;
}

footer .list-sns {
	margin: 0 0 3px;
	padding: 0;
	list-style: none;
	line-height: 1.4;
}

footer .list-sns > li {
	display: inline-block;
	margin: 0 3px 0;
}

footer .list-sns > li:nth-child(3) {
	margin-left: 1px;
}

footer .list-sns li a {
	display: inline-block;
	position: relative;
	width: 20px;
	height: 20px;
	overflow: hidden;
/*
	background: #fff;
*/
	text-indent: 100%;
	white-space: nowrap;
	border-radius: 2px;
	transition: color 0.1s linear, background-color 0.1s linear;
}


footer .list-sns li a:before {
	position: absolute;
	left: 0;
	top: 0;

	display: inline-block;
	width: 20px;
	height: 20px;
	overflow: hidden;
	font-family: "FontAwesome";
	color: #002360;
	line-height: 20px;
	text-align: center;
	text-indent: 0;
}

footer .list-sns li:nth-child(1) a:before {
	content: "\f230";
	font-size: 2.2rem;
	top: 0px;
	left: 0px;
	color: #fff;
}

footer .list-sns li:nth-child(2) a:before {
	content: "\f099";
	font-size: 2.2rem;
	top: 0px;
	left: 0px;
	color: #fff;
}

footer .list-sns li:nth-child(3) a {
	background: none;
	width: 22px;
}
footer .list-sns li:nth-child(3) a:before {
	content: "\e800";
	top: 0px;
	left: 1px;
	width: 21px;
	height: 20px;
	font-family: "fontello";
	font-size: 1.8rem;
	line-height: 2.0rem;
	color: #fff;
}

@media all and (-ms-high-contrast:none){
	*::-ms-backdrop, footer .list-sns li:nth-child(3) a:before {
		line-height: 1.1;
	} /* IE11 */
}


footer .list-sns li:nth-child(4) a:before {
	content: "\f16d";
	font-size: 2.2rem;
	color: #fff;
}

#home_block3 .list-sns li:nth-child(5) a,
footer .list-sns li:nth-child(5) a {
	width: 23px;
}

#home_block3 .list-sns li:nth-child(5) a:before,
footer .list-sns li:nth-child(5) a:before {
	content: "\f167";
	content: "\f16a";
	width: 23px;
	font-size: 2.2rem;
	color: #fff;
}


footer .list-sns a:hover {
/*	color: #00b0fa;	*/
/*	background: #00b0fa;*/
}

footer .list-sns li a:hover:before {
	color: #00b0fa;
	background: none;
}

#footNav {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 18px auto 0;
	padding: 0 0 28px;
	list-style: none;
	font-family: 'Roboto', sans-serif;
	border: solid rgba(255,255,255,0.65);
	border-width: 1px 0;
}

#footNav > li {
/*	white-space: nowrap;*/
}

#footNav > li:nth-child(1) { margin-left: 0; }
#footNav > li:nth-child(4) { margin-right: 0; }

#footNav .nav_label {
	margin: 32px 0 3px;
	font-weight: bold;
}

#footNav .nav_label:before {
	content: " ";
	display: block;
	width: 18px;
	height: 3px;
	margin-bottom: 8px;
	background: #00b0fa;
}

#footNav ul {
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 1.3rem;
	line-height: 1.3;
}

#footNav ul a {
	display: block;
	padding: 3px 0;
}

footer ul.list-links {
	margin: 0 auto;
	padding: 17px 0;
	list-style: none;
	font-size: 1.3rem;
	border-top: none;
}

footer ul.list-links > li {
	margin-bottom: 0;
	padding: 2px 0;
	border-bottom: none;
}

footer ul.list-links > li > a {
	display: inline-block;
	padding: 3px 0;
	color: rgba(255, 255, 255, 0.85);
}

.list-seperate > li {
}

.list-seperate > li:after {
	content: "|";
	padding: 0 1.2rem;
	color: rgba(255, 255, 255, 0.6);
}

.list-seperate > li:last-child:after {
	content: "";
	padding: 0;
}

#copyright {
	margin: 0 auto;
	padding: 20px 0;
}

#copyright small {
	font-size: 1.2rem;
}

.totop {
	position: fixed;
	bottom: 10px;
	right: 10px;
	display: none;
	width: 40px;
	height: 50px;
	text-align: center;
	background: #9ab;
	border-radius: 2px;
	opacity: 0.72;
	cursor: pointer;
}

.totop:before {
	content: "\f062";
	display: block;
	padding-top: 5px;
	font-family: "FontAwesome";
	font-size: 1.8rem;
	line-height: 1.2;
	color: #eaeaea;
	transition: all linear 0.2s;
}

.totop:hover:before {
	padding-top: 1px;
}


.column_single,
.columns {
	position: relative;
	width: 960px;
	margin: 0 auto;
	padding-bottom: 80px;
}

.columns {
	display: flex;
	justify-content: space-between;
}

.column_L {
	flex-basis: 700px;
	padding: 0;
}

.column_R {
	flex-basis: 200px;
	padding: 0;
}

.main {
	padding: 7px 0 0;
	min-height: 500px;
}

#headerBar {
	margin: 0 0 80px;
	padding: 36px 0;
	background: #002360;
}

#headerBar .wrapper960 {
	display: flex;
	justify-content: space-between;
}

h1#pageTitle {
	float: left;
	margin: 0;
	padding: 0;
	font-size: 3.0rem;
	line-height: 1.125;
/*	font-weight: normal;*/
	color: #fff;
}

.entry-title-primary {
	display: block;
	margin-top: -13px;
	margin-bottom: 3px;
}

.entry-subtitle {
	display: block;
	margin-top: 8px;
	margin-bottom: -11px;
	font-size: 1.5rem;
}

#crumbs {
	float: right;
	margin: 6px 0 0;
	font-size: 1.2rem;
	color: #9a9a9a;
}

/*
.column_L :first-child, 
.column_R :first-child {
	margin-top: 0;
}
*/

.column_single h2, 
.column_L h2 {
	clear: both;
	margin: 60px 0 0;
	padding: 64px 0 0;
	border-top: 3px solid #002360;
}

.column_single h2:first-child, 
.column_L h2:first-child {
	margin: 0;
	padding: 0;
	border-top: none;
}

.category_pageList {
	font-size: 1.3rem;
	line-height: 1.25;
}

.category_pageList > header {
	padding: 14px 0 12px;
	font-size: 1.4rem;
	font-weight: bold;
	border-top: 3px solid #00a6f9;
	border-bottom: 1px solid #00a6f9;
}

.category_pageList > ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.category_pageList > ul > li {
	border-bottom: 1px dotted #a2a2a2;
}

.category_pageList > ul > li:last-child {
	border-bottom: 1px solid #00a6f9;
}

.category_pageList > ul > li > a {
	position: relative;
	display: block;
	padding: 10px 1.4em 10px 2px;
	transition: all linear 0.2s;
}

.category_pageList > ul > li > a:after {
	content: "\f105";
	position: absolute;
	top: calc(50% - 0.8rem);
	right: 2px;
	font-family: "FontAwesome";
	font-size: 1.5rem;
	color: #a2a2a2;
}

.category_pageList a {
	color: #4a4a4a;
}

.category_pageList > ul > li > a:hover {
/*
	background: rgba(0, 166, 249, 0.1);
*/
}

.category_pageList a:hover, 
.category_pageList > ul > li > a:hover:after {
	color: #00a6f9;
}

.category_pageList .entry-subtitle {
	display: inline;
	font-size: 1.2rem;
}


iframe {
	border: none;
	overflow-y: hidden;
}

#notfound {
	margin-top: 3.0em;
	padding: 2.0em 3.0em 3.8em;
	color: #4a4a4a;
	text-align: center;
}


#breadcrumb {
	position: absolute;
	top: -72px;
	font-size: 1.22rem;
	line-height: 1.2;
	color: #a2a2a2;
}

#breadcrumb > div {
	display:table-cell;
	padding-left: 6px;
	white-space: nowrap;
}
#breadcrumb > div:first-child {
	padding-left: 0;
}

#breadcrumb > div:last-child, 
#breadcrumb a {
	margin-right: 6px;
	color: #666;
}

#breadcrumb a:hover {
	color: #00a6f9;
	text-decoration: underline;
}

#breadcrumb + .list-links {
	margin-top: 0;
}

.en ul#todan-flow {
	justify-content: center;
}

.en ul#todan-flow > li {
	width: 200px;
	margin-right: 72px;
}

.en ul#todan-flow > li > a {
	width: 200px;
}

.en ul#todan-flow > li:last-child {
	margin-right: 0;
}

.en #nextmeeting {
	margin-top: 80px;
}

.en #nextmeeting a:first-child img {
	width: 100% !important;
	height: auto;
}

.en .column_single #nextmeeting h2 {
	margin-top: 10px;
}

.en #nextmeeting dl {
	display: inline-block;
	margin: 12px 0 0 2.0em;
}

.en #nextmeeting dl > dt {
	margin-top: 6px;
	padding: 2px 0;
	text-align: center;
	line-height: 1.1;
	color: #fff;
	background: #bf132b;
}

.en #nextmeeting dl > dd {
	text-align: left;
	font-size: 120%;
}


.award-announce {
	display: block;
	margin: 2.5em 0;
	padding: 1.8em;
	text-align: center !important;
	font-weight: bold;
	font-size: 1.8rem;
	background: #eaeaea;
}





#publish {
	margin-top: 40px;
}


.list-publish-home {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0;
	width: 100%;
	max-width: 880px;
	margin: 0 auto;
	padding: 0 40px;
	list-style: none;
}

.list-publish-home > li {
	position: relative;
	text-align: center;
	flex: 1;
	width: 100%;
	max-width: 150px;
}

.list-publish-home .img {
	position: relative;
	display: block;
	background: #fff;
}

.list-publish-home img {
	width: 100%;
	max-width: 150px;
	height: auto;
}

.list-publish-home .img:after {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	display: block;
	width: calc(100% - 2px);
	height: calc(100% - 2px);
	border: 1px solid rgba(0,0,0,0.15);
}

.list-publish-home .txt {
	display: block;
	margin: 6px -12px 0;
	font-weight: bold;
	font-size: 1.6rem;
	line-height: 1.4;
}

.list-publish-home a, 
.list-publish-home .img, 
.list-publish-home .txt, 
.list-publish-home .txt-s {
	transition: all .16s linear 0s;
	text-decoration: none;
}

.list-publish-home a .ic-ext {
	position: relative;
}

.list-publish-home a .ic-ext:after {
	content: "\f08e";
	font-family: "FontAwesome";
	font-weight: 400;
	font-size: 85%;
	opacity: 0.6;
	position: absolute;
	right: -17px;
	top: 3px;
}

.list-publish-home a:hover .img {
	filter: drop-shadow(0 3px 8px rgba(0,0,0,0.28));
}

.safari .list-publish-home .img {
	transform: translateZ(0);
}