@charset "utf-8";


.woDT,
.onTB,
.onSP { display: none !important; }
.onDT,
.woTB,
.woSP { display: inline !important; }

html {
	font-size: 62.5%;
}

body {
/*
	CSSでtransitionかけて背景を変えると、safariだけ文字が一瞬細くなる現象を解消
	-webkit-font-smoothing: antialiased;
*/
	font-family: 'Noto Sans Japanese', sans-serif;
	font-size: 1.5rem;
	line-height: 1.70;
	color: #2a2a2a;

}

.roman {
/*
	ローマ数字をアルファベットで表記するときに指定する &#8544;=I, &#8561;=i, ...
	ex: <span class="roman">&#8544;</span>
*/
/*
	font-family: roman;
	font-size: 132%;
	vertical-align: -3.4%;
*/
	font-family: serif;
	font-size: 107%;
	font-weight: 900;
	padding: 0 3px;
	display: inline-block;
	transform: translateY(2px);
}

.roman2 {
	font-family: serif;
/*
	display: inline-block;
	transform: translateY(2px);
*/
}

a {
	text-decoration: none;
	color: #0096e9;
	transition: all 0.2s linear;
}

a:visited {
	color: #05b;
}

body:not(.HOME23) a:hover, 
body:not(.HOME23) a:visited:hover {
/*	color: #00a6f9 !important;*/
	color: #00b6f9 !important;
	text-decoration: underline;
}

body:not(.HOME23) a.action:hover,
body:not(.HOME23) a.download:hover {
	color: #fff !important;
}

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;
}


.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;
}

header .list-shortcuts {
	display: flex;
	height: 68px;
	margin: 0;
	padding: 12px 0 0;
	list-style: none;
	font-size: 1.2rem;
	line-height: 1.75;
}

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;
}

body:not(.page23) .list-shortcuts > li#g_search.active,
body:not(.page23) .list-shortcuts #searchForm > form {
	z-index: 9999;
}

.list-shortcuts > li#g_search.active a,
.list-shortcuts > li#g_search.active a:hover {
	color: #fff !important;
}

body:not(.page23) #searchForm {
	display: none;
	position: absolute;
	top: 25px;
	right: 0;
}

body:not(.page23) #searchForm > form {
	display: inline-block;
	margin: 0;
	padding: 4px;
	background: #00a6f9;
	white-space: nowrap;
	border-radius: 3px 0 3px 3px;
}

body:not(.page23) #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;
}

body:not(.page23) #searchForm input:placeholder-shown {
	color: #00a6f9;
	opacity: 1.0;
}

body:not(.page23) #searchForm input::-webkit-input-placeholder {
	color: #00a6f9;
	opacity: 1.0;
}

body:not(.page23) #searchForm input::-moz-placeholder {
	color: #00a6f9;
	opacity: 1.0;
}

body:not(.page23) #searchForm input:-moz-placeholder {
	color: #00a6f9;
	opacity: 1.0;
}

body:not(.page23) #searchForm input:-ms-input-placeholder {
	color: #00a6f9;
	opacity: 1.0;
}


body:not(.page23) #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;
}

body:not(.page23) #searchForm button .fa {
	font-size: 1.6rem;
	line-height: 22px;
}

body:not(.page23) #searchForm button:hover,
body:not(.page23) #searchForm button:focus,
body:not(.page23) #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;
*/
}

body:not(.page23) #mainNav {
	position: relative;
	display: flex;
	align-content: space-around;
	width: 961px;
	margin: 0;
	padding: 0;
	list-style: none;
	font-weight: bold;
	z-index: 1000;
}

body:not(.page23)  #mainNav > li {
	flex-grow: 1;
	z-index: 2000;
	text-align: center;
	font-size: 1.6rem;
	line-height: 1.75;
	border-width: 0 1px 0 0;
	border-style: dotted;
	border-color: #c8c8c8;
}

body:not(.page23)  #mainNav > li:first-child {
	border-left-width: 1px;
}

body:not(.page23)  #mainNav > li > a,
body:not(.page23)  #mainNav > li > .lv1 {
	display: block;
	padding: 5px;
	color: #4c4c4c;
	cursor: pointer;
	transition: all linear 0.2s;
}

body:not(.page23)  #mainNav > li > a:after,
body:not(.page23)  #mainNav > li > .lv1:after {
	content: "\f0d7";
	display: block;
	font-family: "FontAwesome";
	font-weight: normal;
	line-height: 5px;
	color: #00a6f9;
}

body:not(.page23)  #mainNav > li:first-of-type > a:after {
	content: "";
}

body:not(.page23)  #mainNav > li > a:hover,
body:not(.page23)  #mainNav > li > .lv1:hover {
	color: #00a6f9;
}

body:not(.page23)  #mainNav > li > a.active,
body:not(.page23)  #mainNav > li > .lv1.active {
	color: #fff !important;
	background: #00a6f9;
}

body:not(.page23)  #mainNav > li > a.active .fa {
}

body:not(.page23)  #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);
}

body:not(.page23)  #mainNav .naviPanel > ul {
	display: flex;
	flex-flow: row wrap;
	width: 580px;
	margin: 0;
	padding: 0;
	list-style: none;
}

body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel > ul,
body:not(.page23)  #mainNav > li:nth-child(3) .naviPanel > ul,
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel > ul,
body:not(.page23)  #mainNav > li:nth-child(5) .naviPanel > ul,
body:not(.page23)  #mainNav > li:nth-child(6) .naviPanel > ul,
body:not(.page23)  #mainNav > li:nth-child(7) .naviPanel > ul,
body:not(.page23)  #mainNav > li:nth-child(8) .naviPanel > ul {
	width: auto;
}

body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(9) {
/*	border-bottom: none;*/
}

body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(1),
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(5),
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(10),
body:not(.page23)  #mainNav > li:nth-child(3) .naviPanel li:nth-child(1),
body:not(.page23)  #mainNav > li:nth-child(3) .naviPanel li:nth-child(2),
body:not(.page23)  #mainNav > li:nth-child(3) .naviPanel li:nth-child(3),
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(1),
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(6),
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(10),
body:not(.page23)  #mainNav > li:nth-child(5) .naviPanel li:nth-child(1),
body:not(.page23)  #mainNav > li:nth-child(5) .naviPanel li:nth-child(2),
body:not(.page23)  #mainNav > li:nth-child(5) .naviPanel li:nth-child(3),
body:not(.page23)  #mainNav > li:nth-child(6) .naviPanel li:nth-child(1),
body:not(.page23)  #mainNav > li:nth-child(6) .naviPanel li:nth-child(2),
body:not(.page23)  #mainNav > li:nth-child(6) .naviPanel li:nth-child(3),
body:not(.page23)  #mainNav > li:nth-child(7) .naviPanel li:nth-child(1),
body:not(.page23)  #mainNav > li:nth-child(7) .naviPanel li:nth-child(2),
body:not(.page23)  #mainNav > li:nth-child(7) .naviPanel li:nth-child(3),
body:not(.page23)  #mainNav > li:nth-child(8) .naviPanel li:nth-child(1),
body:not(.page23)  #mainNav > li:nth-child(8) .naviPanel li:nth-child(2),
body:not(.page23)  #mainNav > li:nth-child(8) .naviPanel li:nth-child(3) {
	border-top: 1px solid rgba(255,255,255,0.4);
}

body:not(.page23)  #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);
}

body:not(.page23)  #mainNav ul a {
	display: block;
	color: #fff;
	padding: 8px 3px;
	transition: color,opacity 0.2s linear;
}

body:not(.page23)  #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;
}

body:not(.page23)  #mainNav ul a:hover {
	color: #fff !important;
}

body:not(.page23)  #mainNav ul a:hover:after {
	opacity: 1.0;
}

body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(1)	{ order: 0; }
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(5)	{ order: 1; }
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(10)	{ order: 2; }
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(2)	{ order: 3; }
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(6)	{ order: 4; }
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(8)	{ order: 5; }
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(3)	{ order: 6; }
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(7)	{ order: 7; }
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(9)	{ order: 8; }
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(4)	{ order: 9; }
body:not(.page23)  #mainNav > li:nth-child(2) .naviPanel li:nth-child(11)	{ order: 10; }

body:not(.page23)  #mainNav > li:nth-child(3) .naviPanel li:nth-child(12)	{ margin-right: 300px; }
body:not(.page23)  #mainNav > li:nth-child(3) .naviPanel li:nth-child(13)	{ margin-right: 600px; }

body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(1)	{ order: 0; }
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(6)	{ order: 1; }
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(10)	{ order: 2; }
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(2)	{ order: 3; }
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(7)	{ order: 4; }
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(11)	{ order: 5; }
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(3)	{ order: 6; }
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(8)	{ order: 7; }
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(12)	{ order: 8; }
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(4)	{ order: 9; }
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(9)	{ order: 10; }
body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(5)	{ order: 11; }

body:not(.page23)  #mainNav > li:nth-child(4) .naviPanel li:nth-child(9)	{ margin-right: 300px; }

/*
body:not(.page23)  #mainNav > li:nth-child(6) .naviPanel li:nth-child(3)	{ order: 4; }
body:not(.page23)  #mainNav > li:nth-child(6) .naviPanel li:nth-child(4)	{ order: 5; }
body:not(.page23)  #mainNav > li:nth-child(6) .naviPanel li:nth-child(5)	{ order: 6; }
body:not(.page23)  #mainNav > li:nth-child(6) .naviPanel li:nth-child(6)	{ order: 3; }

body:not(.page23)  #mainNav > li:nth-child(6) .naviPanel li:nth-child(3)	{ margin-right: 600px; }
*/


.o1 { order: 0; }
.o2 { order: 1; }
.o3 { order: 2; }
.o4 { order: 3; }
.o5 { order: 4; }
.o6 { order: 5; }
.o7 { order: 6; }
.o8 { order: 7; }
.o9 { order: 8; }
.o10 { order: 9; }

body:not(.page23) #mainNav .naviPanel .spot {
	position: absolute;
	right: 0;
	top: 0;
	display: inline-block;
	margin: 0;
	padding: 0;
	background: none;
}

body:not(.page23)  #mainNav .naviPanel .spot > a {
	padding: 0;
}

body:not(.page23)  #mainNav .naviPanel .spot > a:after {
	content: "";
}


/*
body:not(.page23)  #mainNav > li:nth-child(2) > .naviPanel .spot {
	top: 69px;
	right: 56px;
	padding-right: 14px;
}
*/

body:not(.page23)  #mainNav > li:nth-child(3) > .naviPanel .spot {
	top: 15px;
	top: 62px;
	right: 45px;
	width: 285px;
	height: 91px;
	overflow: hidden;
}

body:not(.page23)  #mainNav > li:nth-child(3) > .naviPanel .spot img {
	width: 285px;
	margin-top: -15px;
}

body:not(.page23)  #mainNav > li:nth-child(5) > .naviPanel {
	padding-bottom: 32px;
}
body:not(.page23)  #mainNav > li:nth-child(5) > .naviPanel .spot {
	display: block;
	width: 268px;
	height: 48px;
	overflow: hidden;
	background: #008bea;
	top: 61px;
	right: 60px;
	text-align: center;
	border: 1px solid rgba(255, 255, 255, 0.4);
}
body:not(.page23)  #mainNav > li:nth-child(5) > .naviPanel .spot a {
	display: inline-block;
	width: 268px;
	height: 48px;
}
body:not(.page23)  #mainNav > li:nth-child(5) > .naviPanel .spot img {
	display: inline-block;
	margin-top: -7px;
}

body:not(.page23)  #mainNav > li:nth-child(7) > .naviPanel .spot {
	display: block;
	width: 270px;
	height: 35px;
	overflow: hidden;
	padding: 1px 0 0 0;

/*
	position: static;
	margin-left: auto;
	margin-right: 20px;
*/
	top: 188px;
	right: 60px;
	border-top: 1px solid rgba(255, 255, 255, 0.4);
}

body:not(.page23)  #mainNav > li:nth-child(7) > .naviPanel .spot a {
	padding: 0;
}

body:not(.page23)  #mainNav > li:nth-child(7) > .naviPanel .spot img {
	display: block;
}

body:not(.page23)  #mainNav > li:nth-child(7) > .naviPanel {
	padding-bottom: 32px;
}

body:not(.page23)  #mainNav .naviPanel > ul > li.spot_li {
	border: none;
}

body:not(.page23)  #mainNav ul li.spot_li a {
	padding: 0;
	border: none;
}

body:not(.page23)  #mainNav ul li.spot_li > a:after {
	content: "";
	display: none;
}

body:not(.page23)  #mainNav > li#language {
	display: none;
}


.preload #slideHOME {
	overflow: hidden;
}

#slideHOME {
	position: relative;
	width: 960px;
	height: 366px;
	margin-top: 7px;
	margin-bottom: 60px;
}

#slideHOME > div {
	width: 960px;
	height: 366px;
	overflow: hidden;
}

#slideHOME img {
	max-width: 960px;
}

a.slick-prev,
a.slick-next {
	position: absolute;
	top: 50%;
	margin-top: -16px;
	outline: 0;
	width: 32px;
	height: 32px;
	/* text-indent: -9999px; */
	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: none;
	border-radius: 50%;
	border: 4px solid #fff;
	background: #a2a2a2;
	cursor: pointer;
}

.slick-dots button:-moz-focusring {
	outline: 0;
}

.slick-dots .slick-active button {
	background: #000;
}

.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.4rem;
	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: 1.8rem;
	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;
}

.column_single h2.like-h3,
.column_L h2.like-h3 {
	font-size: 1.8rem !important;
}

#news h2 {
	margin: 0;
	margin-right: auto;
	padding: 15px 0;
	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,
.main .list-links-date > li > .nolink {
	padding: 14px 16px 12px 110px;
}

.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,
.list-links-date > li > .nolink {
	position: relative;
	display: block;
	padding: 11px 16px 9px 110px;
	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,
.list-links-date .h {
	float: left;
	display: block;
	width: 104px;
	margin: 2px 0 0 -110px;
	font-size: 1.3rem;
	font-family: "Roboto Mono", monospace;
/*
	font-weight: bold;
	color: #00a6f9;
*/
	position: relative;
}

.list-links-date .nolink .date,
.list-links-date .nolink .h {
color: #333;
font-weight: normal;
}

#news .scrollbox {
	width: 660px;
	height: 200px;	/* 5行 */
	height: 239px;	/* 6行 */
	height: 279px;	/* 7行 */
	height: 176px;	/* 標準（4.25行） */
	border: solid #a2a2a2;
	border-width: 1px 0;
}

.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 15px;
	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;
}


#home_block2.flex-container {
	flex-direction: row-reverse;
}

#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;
	line-height: 1.2;
}

#home_block2 .list-shortcuts > li > a {
	display: block;
	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: 1px 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 {
	float: left;
	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 9px;
}

#home_block2 .list-sns a {
	font-size: 3.4rem;
}

#home_block2 .list-sns li:nth-child(1) a .fa {
	position: relative;
	top: 1px;
}

#mid-banners a,
.list-sns a {
	transition: opacity .2s linear 0s;
}

#mid-banners a:hover,
.list-sns a:hover {
	opacity: 0.75;
}

.list-sns a:after {
	content: "" !important;
}

.fa-facebook-official	{ color: #3b5998; font-size: 3.23rem; vertical-align: 2px; }
.fa-twitter				{ color: #1da1f2; }
.icomoon-line			{ color: #00b900; 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; }

#mid-banners {
	margin-top: 8px;
}

#mid-banners > p {
	margin: 0;
	padding: 0;
}

#mid-banners > p + p {
	margin-top: 8px;
}

#publish {
	margin-top: 40px;
	padding: 0 0 40px 0;
	background: #f2f2f2;
}

#publish h2 {
	height: 40px;
	margin: 0;
	padding: 0;
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
}

#publish .wrapper960 > .flex-container {
	border-left: 1px solid #000;
	justify-content: space-around;
}

#publish .pub {
	position: relative;
	width: 290px;
	padding: 0 14px 0 15px;
	flex: 0 1 319px;
	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 {
	padding-top: 35px;
}

.pub-type {
	margin: 5px 0 10px;
	font-size: 1.1rem;
}

.pub-uptodate,
.pub-uptodate-pubdate {
	font-size: 1.8rem;
	line-height: 1.15;
	font-weight: bold;
}

#AP .pub-uptodate-pubdate {
	margin-top: 2px;
	font-size: 1.4rem;
	color: #e90870;
}

#JJAP .pub-uptodate,
#JJAP .pub-uptodate-pubdate {
	color: #54af17;
}

#APEX .pub-uptodate,
#APEX .pub-uptodate-pubdate {
	color: #ef5700;
}

.pub a.toSite {
	position: absolute;
	top: 0;
	left: 0;
	display: inline-block;
	width: 290px;
	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: 45px;
	left: -50px;
	padding-right: 2px;
	font-size: 2.4rem;
	line-height: 1.0;
	color: transparent;
	transition: color 0.2s linear;
}

.pub#JJAP a.toSite:after { top: 46px; left: -90px; }
.pub#APEX a.toSite:after { top: 46px; left: -80px; }

.pub a.toSite:hover:after {
	color: #00a6f9;
}

.pub-theme {
	font-size: 1.5rem;
	font-weight: bold;
	line-height: 1.25;
}

.pub-theme-sub {
	font-size: 1.2rem;
}

.pub .scrollbox {
	width: 290px;
	height: 237px;
	margin-top: 3px;
	margin-top: 0;
	border: solid #a2a2a2;
	border-width: 1px 0;
}

.pub#AP .scrollbox {
	height: 212px;	/*1行*/
	height: 194px;	/*2行*/
	height: 176px;	/*3行*/
	height: 158px;	/*4行*/
	height: 140px;	/*5行*/
	height: 237px;	/*0行*/
}




.pub-articles {
	width: 290px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.pub-articles > li {
	clear: both;
	border-bottom: 1px solid #d8d8d8;
}

.pub-articles > li:after {
	content: " ";
	display: block;
	clear: both;
}

.pub-articles > li:last-child {
	border-bottom: none;
}

.pub-articles > li > a {
	position: relative;
	display: block;
	padding: 5px 8px 8px 0;
	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: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	color: #a2a2a2;
	width: 8px;
	height: 16px;
	overflow: hidden;
	text-align: right;
}
/*
*/

#JJAP .pub-articles > li > a,
#APEX .pub-articles > li > a {
	padding: 6px 8px 7px 130px;
}

#JJAP .pub-articles > li.noImg > a,
#APEX .pub-articles > li.noImg > a {
	padding: 6px 8px 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;
	height: auto;
}

.pub-articles .article-title {
	display: block;
	margin-bottom: 6px;
	font-size: 1.3rem;
	line-height: 1.16;
}

#AP .article-title {
	display: inline;
	margin-bottom: 0;
	margin-right: 1.0rem;
}

.article-author {
	display: inline-block;
	font-size: 1.2rem;
	opacity: 0.75;
}

#AP .pub-articles .open {
	display: inline-block;
	padding: 1px 8px;
	white-space: nowrap;
	font-size: 1.0rem;
	text-shadow: 0 0 1px rgba(0,0,0,0.4);
	color: #fff;
	background: rgb(221, 22, 115);
	border-radius: 2px;

	transform: translateY(-1px);
	margin-top: -8px;
	margin-bottom: -8px;
}

#AP .pub-articles .open + br {
	height: 0;
	line-height: 0;
}

#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-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 20px;
	font-size: 1.3rem;
	align-self: center;
	border-left: 1px dotted #999;
	color: #333;
}

/*
#events_header a:first-of-type {
	display: inline-block;

	margin-right: 16px;
	border-left: none;
}
*/

#events_header a.ic-arrow-right {
	padding-right: 0;
}

#events_header a:first-of-type .fa {
	margin-right: 5px;
	vertical-align: middle;
	font-size: 1.8rem;
	line-height: 1.0;
	color: #ff8c00;
}


#events .scrollbox {
	height: 286px;	/* バナー4点 */
	height: 355px;	/* バナー5点 */
	height: 424px;	/* バナー6点 */
	height: 440px;	/* バナー7点 */
	height: 319px;	/* 調整 */
	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: block;
	min-height: 44px;
	padding: 4px 16px 7px 57px;
	line-height: 1.16;
	color: #333;
	vertical-align: middle;
	position: relative;
}

.list-events > li:first-child > a {
	padding-top: 7px;
}

.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: relative;
	float: left;
	display: block;
	width: 44px;
	height: 44px;
	overflow: hidden;
	margin-left: -57px;
	vertical-align: middle;
}

.list-events .dateD {
	position: absolute;
	top: 0;
	left: 0;
	display: inline-block;
	width: 44px;
	height: 44px;
	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 .date {
/*	margin: -4px 0 -4px -57px;*/
}

.list-events li .title {
	display: table-cell;
	height: 44px;
/*	min-height: 44px;*/
	vertical-align: middle;
}

/*

.list-events > li > a,
.list-events > li > .nolink {
	display: block;
	min-height: 44px;
	padding: 8px 16px 9px 87px;
	line-height: 1.16;
	color: #333;
	vertical-align: middle;
	position: relative;
}

.list-events .date {
	position: relative;
	float: left;
	display: inline-block;
	width: 49px;
	height: 26px;
	overflow: hidden;
	margin: -4px 0 -4px -87px;
	vertical-align: middle;
}

.list-events .dateD {
	position: absolute;
	top: 0;
	left: 0;
	display: inline-block;
	width: 39px;
	height: 22px;
	padding: 2px 5px;
	text-align: center;
	color: #fff;
	background: #004d99;
	border-radius: 3px;
}

.list-events .dateD .dM {
	display: inline-block;
	width: 18px;
	margin-top: 3px;
	font-size: 1.2rem;
	text-align: right;
}

.list-events .dateD .dM:after {
	content: "/";
	display: inline-block;
	font-size: 0.9rem;
	line-height: 1.0;
	margin-left: 1px;
	position: relative;
	top: -1px;
}

.list-events .dateD .dD {
	margin-left: 2px;
	font-size: 1.6rem;
}

*/




/*
.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: -20px;
}

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;
	align-self: flex-end;
}

footer address {
	margin-right: auto;
	padding-left: 54px;
	font-size: 1.5rem;
	font-style: normal;
	line-height: 1.4;
}

footer address:before {
	content: "";
	display: inline-block;
	float: left;
	width: 54px;
	height: 34px;
	margin: 3px 0 0 -54px;
	background: url("../img/JSAPlogo-white-H35.png") left bottom no-repeat;
	background-size: auto 35px;

}

footer address .add,
footer address .tel {
	display: inline;
	margin-right: 2.0rem;
	font-size: 1.2rem;
}

footer .list-shortcuts {
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 1.2rem;
}

footer .list-shortcuts li {
	display: inline-block;
	margin-right: 24px;
	margin-bottom: 0;
}

footer .list-shortcuts .fa {
	margin-right: 3px;
	font-size: 2.4rem;
}

#home_block3 .list-sns,
footer .list-sns {
	margin: 0 0 -2px;
	padding: 0;
	list-style: none;
}

#home_block3 .list-sns > li,
footer .list-sns > li {
	display: inline-block;
	margin: 0 3px 0;
}

/*
footer .list-sns > li:nth-child(3) {
	margin-left: 1px;
}
*/
#home_block3 .list-sns li a,
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.15s linear, background-color 0.15s linear;
}


#home_block3 .list-sns li a:before,
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;
	transition: color 0.15s linear, background-color 0.15s linear;
}

#home_block3 .list-sns li:nth-child(1) a:before,
footer .list-sns li:nth-child(1) a:before {
	content: "\f230";
	font-size: 2.2rem;
	top: 0px;
	left: 0px;
	color: #fff;
}

#home_block3 .list-sns li:nth-child(2) a:before,
footer .list-sns li:nth-child(2) a:before {
	content: "\f099";
	font-size: 2.2rem;
	top: 2px;
	left: 0px;
	color: #fff;
}

#home_block3 .list-sns li:nth-child(3) a,
footer .list-sns li:nth-child(3) a {
	background: none;
	width: 22px;
}

#home_block3 .list-sns li:nth-child(3) a:before,
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 */
	*::-ms-backdrop, #home_block3 .list-sns li:nth-child(3) a:before {
		line-height: 1.1;
	} /* IE11 */
}


#home_block3 .list-sns li:nth-child(4) a:before,
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;
}

#home_block2 .list-sns > li { margin: 0 11px; }
#home_block2 .list-sns > li:first-child	{ margin-left: 0; }
#home_block2 .list-sns > li:last-child	{ margin-right: 0; }



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;
	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-size: 1.5rem;
	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.2rem;
	line-height: 1.3;
}

#footNav ul a {
	display: block;
	padding: 2px 0;
}
*/
footer ul.list-links {
	margin: 0 auto;
	padding: 17px 0;
	list-style: none;
	font-size: 1.24rem;
	border-top: none;
}

footer ul.list-links > li {
	padding: 2px 0;
	border-bottom: none;
}

footer ul.list-links > li > a {
	display: inline-block;
	padding: 3px 0;
}

.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: rgba(0, 150, 233, 0.5);
	border-radius: 2px;
	cursor: pointer;
}

.totop:before {
	content: "\f062";
	display: inline-block;
	width: 100%;
	height: 100%;
	padding-top: 5px;
	font-family: "FontAwesome";
	font-size: 1.8rem;
	line-height: 1.2;
	color: #eaeaea;
	transition: all linear 0.2s;
}

.totop:hover:before {
	transform: translateY(-5px);
}


.column_single,
.columns {
	position: relative;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
	padding-bottom: 80px;
}

.column_single > .columns {
	padding-bottom: 0;
}

.columns {
	display: flex;
	justify-content: space-between;
}

.column_L {
	position: relative;
	flex-basis: 700px;
	padding: 0;
}

.column_R {
	position: relative;
	flex-basis: 200px;
	padding: 0;
}

.main {
	padding: 7px 0 0;
	min-height: 600px;
}

#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: 2.8rem;
	line-height: 1.125;
	line-height: 1.25;
	font-weight: normal;
	color: #fff;
}

h1 .entry-title-primary {
	display: block;
	margin-top: -13px;
	margin-bottom: 3px;
}

h1 .entry-subtitle {
	display: block;
	margin-top: 8px;
	margin-bottom: -11px;
	font-size: 1.5rem;
}

/*
.column_L :first-child,
.column_R :first-child {
	margin-top: 0;
}
*/

.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 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;
}


#refresh201809,
#refreshNEXT {
	margin-top: -16%;
	margin-left: 90px;
}

#refresh201809 > .figure,
#refreshNEXT > .figure {
	padding: 0 0 5px;
	white-space: nowrap;
}

#refresh201809 > .figure img,
#refreshNEXT > .figure img {
	width: 200px;
}


#chapter-code tbody th:nth-child(1),
#chapter-code td:nth-child(2) {
	text-align: center;
}

.column_single p {
	text-align: justify;
	text-justify: inter-ideograph;
}

#youtube_banner {
	width: 240px;
	margin-top: 40px;
	text-align: center;
}


.safari #youtube_banner		{ margin-top: 44px; }

/*
	講演会予稿集バックナンバーについて
	2023-06-09
*/

.list-yokoshu.col2 {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;


	margin: 30px 0 0;
	padding: 0;
	list-style: none;
}

.list-yokoshu.col2 > li {
	display: flex;
	justify-content: space-between;
	flex-wrap: nowrap;
	padding: 8px 0;
	border-bottom: 1px solid #dadada;
}

.list-yokoshu.col2 > li					{ width: calc(50% - 40px); }
dd .list-yokoshu.col2 > li				{ width: calc(50% - 20px); }

.list-yokoshu.col2 > li > .val {
	display: inline-block;
	margin-left: auto;
	min-width: 60px;
	text-align: right;
}

.list-yokoshu.col2 > li.lbl {
	margin: 0;
	font-size: 1.2rem;
	font-weight: bold;
}

.list-yokoshu.col2 > li.lbl .val {
	text-align: center;
}

.list-yokoshu.col2.spring {
	flex-direction: row-reverse;
}
.list-yokoshu.col2.spring > li:nth-child(even)	{ margin-right: 40px; }
.list-yokoshu.col2.spring > li:nth-child(odd)	{ margin-left: 40px; }

.list-yokoshu.col2.autum {
	flex-direction: reverse;
}
.list-yokoshu.col2.autum > li:nth-child(even)	{ margin-left: 40px; }
.list-yokoshu.col2.autum > li:nth-child(odd)	{ margin-right: 40px; }

