#mainvisual {
	position: relative;
	width: 100%;
	height: calc(100vh - 85px);
	margin-top: 80px;
	overflow: hidden;
}
.spc #mainvisual {
	height: auto;
	margin-top: 60px;
}
#mainvisual #catch {
	position: absolute;
	top: calc(50% - 40px);
	left: 90px;
	font-size: 80px;
	font-size: 5rem;
	line-height: 88px;
	line-height: 5.5rem;
	font-weight: 600;
	text-shadow: 0 0 3px white, 0 0 3px white, 0 0 3px white;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	z-index: 50;
}
.sp #mainvisual #catch {
	top: 50%;
	left: auto;
	right: 10px;
	font-size: 40px;
	font-size: 2.5rem;
	line-height: 44px;
	line-height: 2.75rem;
}
#mainvisual ul {
	position: absolute;
	right: 480px;
	top: calc((100vh - 80px) * 0.88 + 20px);
	counter-reset: number;
	font-size: 0px;
	z-index: 50;
}
.spc #mainvisual ul {
	display: none;
}
#mainvisual ul li {
	position: relative;
	display: inline-block;
	width: 100px;
	height: 6px;
	background: #B5B5B5;
}
#mainvisual ul li:after {
	position: absolute;
	counter-increment: number;
	content: "0" counter(number);
	top: 11px;
	font-size: 16px;
	font-size: 1rem;
	line-height: 17.6px;
	line-height: 1.1rem;
}
#mainvisual ul li span {
	position: absolute;
	display: block;
	width: 0%;
	height: 100%;
	background: #004295;
	-webkit-transition: 1s linear;
	transition: 1s linear;
}
#mainvisual ul li.current {
	color: #004295;
	font-weight: 600;
}
#mainvisual .controller {
	position: absolute;
	right: 230px;
	top: calc((100vh - 80px) * 0.88 + 8px);
	width: 230px;
	height: calc((100vh - 80px) * 0.09);
	z-index: 50;
	color: #000;
}
.spc #mainvisual .controller {
	display: none;
}
#mainvisual .controller > p {
	display: table;
	width: 100%;
	height: 50%;
}
#mainvisual .controller > p a {
	display: table-cell;
	vertical-align: middle;
	-webkit-transition: opacity 0.2s, background 0.2s;
	transition: opacity 0.2s, background 0.2s;
	cursor: pointer;
}
#mainvisual .controller > p a:hover {
	opacity: 0.7;
}
#mainvisual .controller > p a span {
	position: relative;
}
#mainvisual .controller > p.next span:after {
	content: "";
	position: absolute;
	width: 20px;
	height: 20px;
	background: url(../images/next.svg) no-repeat center center;
	top: 50%;
	right: -30px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
#mainvisual .controller > p.youtubelink span:after {
	content: "";
	position: absolute;
	width: 20px;
	height: 20px;
	background: url(../images/blank.svg) no-repeat center center;
	top: 50%;
	right: -30px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.spc #mainvisual #videos {
	display: none;
}
#mainvisual #videos.h .player.play .video {
	width: 100%;
	height: 0;
	padding-top: 56.25%;
}
#mainvisual #videos .player {
	position: absolute;
	width: 210px;
	height: calc((100vh - 80px) * 0.12);
	right: 0px;
	bottom: 0px;
	overflow: hidden;
	background: #ffffff;
	-webkit-transform: translateY(100%);
	transform: translateY(100%);
}
#mainvisual #videos .player .video {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	opacity: 0;
	-webkit-transition: opacity 500ms;
	transition: opacity 500ms;
}
#mainvisual #videos .player .video.play {
	opacity: 1;
}
#mainvisual #videos .player .video > * {
	position: absolute;
	width: 100%;
	height: calc(100% + 120px);
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
#mainvisual #videos .player .thumbnail {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 50%;
	left: 50%;
	background: none no-repeat center center;
	background-size: cover;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	overflow: hidden;
	cursor: pointer;
}
#mainvisual #videos .player .thumbnail .next {
	position: absolute;
	width: 210px;
	height: 50%;
	bottom: 0px;
	left: -210px;
	font-size: 20px;
	font-size: 1.25rem;
	line-height: 22px;
	line-height: 1.375rem;
	background: rgba(255, 255, 255, 0.7);
}
#mainvisual #videos .player .thumbnail .next:before {
	content: "Next Video";
	position: absolute;
	top: 10%;
	left: 20px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
#mainvisual #videos .player .thumbnail .next:after {
	content: "";
	position: absolute;
	width: 20px;
	height: 20px;
	background: url(../images/next.svg) no-repeat center center;
	top: 30%;
	left: calc(20px + 5.8em + 10px);
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
#mainvisual #videos .player .thumbnail .next span {
	display: block;
	position: absolute;
	width: 100%;
	height: 152%;
	top: -100%;
	left: 0px;
	background: transparent;
	z-index: 1;
	-webkit-transition: background 0.2s;
	transition: background 0.2s;
}
#mainvisual #videos .player .thumbnail .next span:hover {
	background: rgba(255, 255, 255, 0.3);
}
#mainvisual #videos .player .thumbnail .youtubelink {
	display: none;
	position: absolute;
	width: 100%;
	height: 24%;
	bottom: 0;
	border-top: 1px solid #666;
	font-size: 20px;
	font-size: 1.25rem;
	line-height: 22px;
	line-height: 1.375rem;
	color: #000000;
	z-index: 30;
	background: transparent;
	-webkit-transition: background 0.2s;
	transition: background 0.2s;
}
#mainvisual #videos .player .thumbnail .youtubelink:hover {
	background: rgba(255, 255, 255, 0.3);
}
#mainvisual #videos .player .thumbnail .youtubelink:before {
	content: "Tadano's Youtube Page";
	position: absolute;
	top: 50%;
	left: 20px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
#mainvisual #videos .player .thumbnail .youtubelink:after {
	content: "";
	position: absolute;
	width: 20px;
	height: 20px;
	background: url(../images/blank.svg) no-repeat center center;
	top: 50%;
	left: calc(20px + 13.6em + 10px);
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
#mainvisual #videos .player.next .youtubelink {
	display: block;
}
#mainvisual #videos .player.play {
	width: 100%;
	height: calc((100vh - 80px) * 0.88);
	bottom: calc((100vh - 80px) * 0.12);
	z-index: 0;
	transform: translateY(0%);
	background: #000;
}
#mainvisual #videos .player.play .video {
	width: calc((100vh - 80px) * 0.88 / 9 * 16);
	height: 100%;
	padding-top: 0;
}
#mainvisual #videos .player.play .thumbnail {
	opacity: 0;
	cursor: default;
}
#mainvisual #videos .player.next {
	z-index: 20;
	-webkit-transform: translateY(0%);
	transform: translateY(0%);
	-webkit-transition: transform 500ms 1000ms;
	transition: transform 500ms 1000ms;
}
#mainvisual #videos .player.next.play {
	width: 100%;
	height: calc((100vh - 80px) * 0.88);
	bottom: calc((100vh - 80px) * 0.12);
	-webkit-transition: bottom 500ms 0ms, width 500ms 500ms, height 500ms 500ms;
	transition: bottom 500ms 0ms, width 500ms 500ms, height 500ms 500ms;
	z-index: 10;
}
#mainvisual #spimage {
	display: none;
}
.spc #mainvisual #spimage {
	display: block;
}
.spc #mainvisual #spimage img {
	display: block;
	width: 100%;
	height: auto;
}

#topfeaturedcontent > div {
	position: relative;
	width: 100%;
	max-width: 1220px;
	margin: auto;
	padding: 40px 20px 80px;
}
.sp #topfeaturedcontent > div {
	padding: 20px 10px 40px;
}
.sp #topfeaturedcontent > div {
	padding-top: 40px;
}
#topfeaturedcontent h2 {
	margin: 0px 0px 40px;
	padding: 32px 0px 0px;
	font-size: 32px;
	font-size: 2rem;
	line-height: 41.6px;
	line-height: 2.6rem;
	font-weight: 600;
	text-align: center;
	border-top: 4px solid #004295;
}
.sp #topfeaturedcontent h2 {
	padding-top: 16px;
	font-size: 26px;
	font-size: 1.625rem;
	line-height: 33.8px;
	line-height: 2.1125rem;
}
#topfeaturedcontent .menu {
	margin: 0px -5px 0px -20px;
	overflow: hidden;
}
.sp #topfeaturedcontent .menu {
	margin: 0px;
	padding-bottom: 20px;
	border-bottom: 4px solid #004295;
}
#topfeaturedcontent .menu a {
	position: relative;
	float: left;
	display: block;
	margin-left: 20px;
	width: calc((100% - 85px) / 4);
	border-bottom: 4px solid #004295;
}
.sp #topfeaturedcontent .menu a {
	float: none;
	width: 100%;
	min-height: 76px;
	margin-left: 0px;
	border-bottom: 0;
}
.sp #topfeaturedcontent .menu a + a {
	margin-top: 40px;
}
.sp #topfeaturedcontent .menu a + a:before {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	top: -20px;
	left: 0px;
	background: #707070;
}
#topfeaturedcontent .menu a.popin .image span {
	top: 100%;
}
.sp #topfeaturedcontent .menu a.popin .image span {
	top: 0px;
}
#topfeaturedcontent .menu a:hover .image span {
	transform: scale(1.1) rotate(0.0001deg);
}
#topfeaturedcontent .menu a:hover .info {
	top: -15px;
}
.sp #topfeaturedcontent .menu a:hover .info {
	top: 0px;
}
#topfeaturedcontent .menu a .image {
	position: relative;
	display: block;
	padding-top: 100%;
	background: #004295;
	overflow: hidden;
}
.sp #topfeaturedcontent .menu a .image {
	position: absolute;
	width: 76px;
	padding-top: 76px;
	left: 0px;
	top: 0px;
}
#topfeaturedcontent .menu a .image span {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background: none no-repeat center center;
	background-size: cover;
	-webkit-transition: -webkit-transform 0.4s, top 0.6s;
	transition: transform 0.4s, top 0.6s;
	backface-visibility: hidden;
}
#topfeaturedcontent .menu a .info {
	display: block;
	position: relative;
	top: 0px;
	width: calc(100% - 40px);
	margin: -5em auto 30px;
	padding: 15px 10px 0px;
	color: #000000;
	background: #ffffff;
	-webkit-transition: top 0.5s 0.15s;
	transition: top 0.5s 0.15s;
}
.sp #topfeaturedcontent .menu a .info {
	width: calc(100% - 86px);
	margin: 0px 0px 0px 86px;
	padding: 0px;
}
#topfeaturedcontent .menu a .info .title {
	display: block;
	padding: 0px 5px 20px;
	font-size: 18px;
	font-size: 1.125rem;
	line-height: 23.4px;
	line-height: 1.4625rem;
	font-weight: bold;
	text-align: center;
}
.sp #topfeaturedcontent .menu a .info .title {
	padding: 0 0 5px 0;
	text-align: left;
}
#topfeaturedcontent .menu a .info .text {
	display: block;
	font-size: 16px;
	font-size: 1rem;
	line-height: 22.4px;
	line-height: 1.4rem;
}
.sp #topfeaturedcontent .menu a .info .text {
	display: none;
}

#topproducts {
	position: relative;
}
#topproducts h2 {
	margin: 0px 0px 20px;
	padding: 0px;
	font-size: 32px;
	font-size: 2rem;
	line-height: 41.6px;
	line-height: 2.6rem;
	font-weight: 600;
	text-align: center;
}
.sp #topproducts h2 {
	font-size: 26px;
	font-size: 1.625rem;
	line-height: 33.8px;
	line-height: 2.1125rem;
}
#topproducts .more {
	position: absolute;
	right: 40px;
	margin-top: -40px;
}
.sp #topproducts .more {
	position: static;
	margin-top: 0px;
	margin-bottom: 20px;
	text-align: center;
}
#topproducts .more a {
	position: relative;
	margin-right: 30px;
	font-size: 16px;
	font-size: 1rem;
	line-height: 20.8px;
	line-height: 1.3rem;
	color: #000000;
	position: relative;
	display: inline-block;
}
#topproducts .more a:before {
	content: "";
	display: block;
	position: absolute;
	bottom: calc(0.15em - 5px);
	left: 0px;
	width: 100%;
	height: 1px;
	background: #000000;
	-webkit-transition: 0.2s;
	transition: 0.2s;
	-webkit-transform: scale(0);
	transform: scale(0);
}
#topproducts .more a:hover:before {
	-webkit-transform: scale(1);
	transform: scale(1);
}
#topproducts .more a:after {
	content: "";
	position: absolute;
	display: block;
	width: 20px;
	height: 20px;
	right: -30px;
	top: 50%;
	margin-top: -10px;
	background: url(../images/next.svg) no-repeat center center;
}
#topproducts .products {
	margin: 0px -5px 0px 0px;
	overflow: hidden;
}
.sp #topproducts .products {
	margin-left: -1px;
}
#topproducts .products a {
	position: relative;
	float: left;
	display: block;
	width: calc((100% - 5px) / 4);
	height: 19.27083333333333vw;
}
.sp #topproducts .products a {
	width: calc((100% - 7px) / 2);
	height: 37.33333333333333vw;
	margin-left: 1px;
	margin-bottom: 1px;
}
#topproducts .products a.popin .image span {
	top: 100%;
}
.sp #topproducts .products a.popin .image span {
	top: 0px;
}
#topproducts .products a:hover .image span {
	transform: scale(1.1) rotate(0.0001deg);
}
#topproducts .products a:hover .title span {
	top: 50%;
}
#topproducts .products a .image {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	background: #004295;
	overflow: hidden;
}
#topproducts .products a .image span {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background: none no-repeat center center;
	background-size: cover;
	-webkit-transition: -webkit-transform 0.4s, top 0.6s;
	transition: transform 0.4s, top 0.6s;
	backface-visibility: hidden;
}
#topproducts .products a .title {
	position: absolute;
	display: block;
	width: 100%;
	height: 37.83783783783784%;
	bottom: 0px;
	left: 0px;
	background: -moz-linear-gradient(top, transparent 0%, black 100%);
	background: -webkit-linear-gradient(top, transparent 0%, black 100%);
	background: linear-gradient(to bottom, transparent 0%, black 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#000000',GradientType=0 );
}
.sp #topproducts .products a .title {
	height: 50%;
}
#topproducts .products a .title span {
	position: absolute;
	display: block;
	width: 100%;
	top: 60%;
	padding: 0px 10px;
	font-size: 24px;
	font-size: 1.5rem;
	line-height: 31.2px;
	line-height: 1.95rem;
	color: #ffffff;
	font-weight: 600;
	text-align: center;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	-webkit-transition: top 0.5s 0.15s;
	transition: top 0.5s 0.15s;
}
.sp #topproducts .products a .title span {
	font-size: 13px;
	font-size: 0.8125rem;
	line-height: 16.9px;
	line-height: 1.05625rem;
}
#topproducts .others {
	margin: 20px -5px 0px 0px;
	padding-top: 40px;
	overflow: hidden;
}
.sp #topproducts .others {
	margin: 10px 0 0 0;
	padding-top: 0;
	border-top: 1px solid #707070;
}
#topproducts .others a {
	position: relative;
	float: left;
	display: block;
	width: calc((100% - 5px) / 4);
	padding-top: 3em;
}
.sp #topproducts .others a {
	float: none;
	width: 100%;
	padding-top: 0px;
	border-bottom: 1px solid #707070;
}
#topproducts .others a.popin .image span {
	top: 100%;
}
.sp #topproducts .others a.popin .image span {
	top: 0px;
}
#topproducts .others a:hover .image span {
	transform: scale(1.1) rotate(0.0001deg);
}
#topproducts .others a .image {
	position: relative;
	display: block;
	width: 100%;
	padding-top: 9.89583333333333vw;
	background: #004295;
	overflow: hidden;
}
.sp #topproducts .others a .image {
	position: absolute;
	width: 60px;
	height: 100%;
	left: 0px;
	top: 0px;
}
#topproducts .others a .image span {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background: none no-repeat center center;
	background-size: cover;
	-webkit-transition: -webkit-transform 0.4s, top 0.6s;
	transition: transform 0.4s, top 0.6s;
	backface-visibility: hidden;
}
#topproducts .others a .title {
	position: absolute;
	display: block;
	width: 100%;
	bottom: calc(9.89583333333333vw + 15px);
	left: 0px;
}
.sp #topproducts .others a .title {
	position: static;
	display: table;
	height: 60px;
}
#topproducts .others a .title span {
	display: block;
	padding: 0px 10px;
	font-size: 28px;
	font-size: 1.75rem;
	line-height: 36.4px;
	line-height: 2.275rem;
	color: #000000;
	font-weight: 600;
	text-align: center;
}
.sp #topproducts .others a .title span {
	display: table-cell;
	padding: 5px 40px 5px 70px;
	vertical-align: middle;
	font-size: 18px;
	font-size: 1.125rem;
	line-height: 23.4px;
	line-height: 1.4625rem;
	text-align: left;
	background: url(../images/next.svg) no-repeat right 10px center;
}

#toppanelmenu {
	position: relative;
	margin-top: 80px;
	overflow: hidden;
}
.sp #toppanelmenu {
	margin-top: 40px;
}
#toppanelmenu .bg {
	position: absolute;
	width: 100%;
	height: 120vh;
	background: url(../images/panelbg.jpg) no-repeat center center;
	background-size: cover;
}
#toppanelmenu .bg:after {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background: rgba(0, 66, 149, 0.5);
}
#toppanelmenu .main {
	position: relative;
	width: 100%;
	max-width: 1220px;
	margin: auto;
	padding: 0px 20px;
}
.sp #toppanelmenu .main {
	padding: 0px 10px;
}
.sp #toppanelmenu .main {
	padding: 0px;
}
#toppanelmenu .main div {
	position: relative;
	margin-right: -5px;
	overflow: hidden;
}
.sp #toppanelmenu .main div {
	margin-left: -1px;
}
#toppanelmenu .main div:before {
	content: "";
	display: block;
	position: absolute;
	right: 0px;
	top: 0px;
	width: 1px;
	height: 100%;
	background: #ffffff;
}
.sp #toppanelmenu .main div:before {
	display: none;
}
#toppanelmenu .main div a {
	position: relative;
	float: left;
	width: calc((100% - 5px) / 4);
	height: 33.89830508474576vw;
	max-height: 400px;
	font-size: 24px;
	font-size: 1.5rem;
	line-height: 31.2px;
	line-height: 1.95rem;
	font-weight: 600;
	color: #ffffff;
	-webkit-transition: background 0.2s;
	transition: background 0.2s;
}
.sp #toppanelmenu .main div a {
	width: calc((100% - 7px) / 2);
	height: 37.33333333333333vw;
	font-size: 18px;
	font-size: 1.125rem;
	line-height: 23.4px;
	line-height: 1.4625rem;
	border-left: 1px solid #ffffff;
	border-bottom: 1px solid #ffffff;
}
#toppanelmenu .main div a:hover {
	background: rgba(0, 66, 149, 0.2);
}
#toppanelmenu .main div a:before {
	content: "";
	display: block;
	position: absolute;
	left: 0px;
	top: 0px;
	width: 1px;
	height: 100%;
	background: #ffffff;
}
.sp #toppanelmenu .main div a:before {
	display: none;
}
#toppanelmenu .main div a:after {
	content: "";
	display: block;
	position: absolute;
	left: 0px;
	top: 20%;
	width: 100%;
	height: 40%;
	background: none no-repeat center center;
}
#toppanelmenu .main div a.panelmenu01:after {
	background-image: url(../images/panelmenu01.svg);
}
#toppanelmenu .main div a.panelmenu02:after {
	background-image: url(../images/panelmenu02.svg);
}
#toppanelmenu .main div a.panelmenu03:after {
	background-image: url(../images/panelmenu03.svg);
}
#toppanelmenu .main div a.panelmenu04:after {
	background-image: url(../images/panelmenu04.svg);
}
#toppanelmenu .main div a .title {
	position: absolute;
	display: block;
	width: 100%;
	top: 60%;
	left: 0px;
	padding: 0px 10px;
	text-align: center;
}

#banner_area {
	position: relative;
	margin-top: 80px;
	overflow: hidden;
}
.sp #banner_area {
	margin-top: 40px;
}
#banner_area > div {
	position: relative;
	width: 100%;
	max-width: 1220px;
	margin: auto;
	padding: 0px 20px;
}
.sp #banner_area > div {
	padding: 0px 10px;
}
.sp #banner_area > div {
	padding: 0px;
}
#banner_area > div .banner {
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.pc #banner_area > div .banner {
	display: block;
}
#banner_area > div .banner a {
	position: relative;
	display: block;
	width: 560px;
	height: 280px;
}
#banner_area > div .banner a + a {
	margin-left: 20px;
}
.pc #banner_area > div .banner a + a {
	margin-left: auto;
	margin-top: 20px;
}
.pc #banner_area > div .banner a {
	margin-left: auto;
	margin-right: auto;
	width: auto;
	max-width: 560px;
}
.sp #banner_area > div .banner a {
	height: 200px;
}
#banner_area > div .banner a.popin .image span {
	top: 100%;
}
.sp #banner_area > div .banner a.popin .image span {
	top: 0px;
}
#banner_area > div .banner a:hover .image span {
	transform: scale(1.1) rotate(0.0001deg);
}
#banner_area > div .banner a .image {
	position: absolute;
	display: block;
	width: 560px;
	height: 250px;
	background: #004295;
	overflow: hidden;
}
.sp #banner_area > div .banner a .image {
	width: 100%;
	height: 170px;
}
#banner_area > div .banner a .image span {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background: no-repeat center center;
	background-size: cover;
	transition: transform 0.4s, top 0.6s;
	backface-visibility: hidden;
}
.sp #banner_area > div .banner a .image span {
	background: no-repeat center center;
	background-size: cover;
}
#banner_area > div .banner a .title {
	width: 100%;
	position: absolute;
	top: 255px;
	display: block;
	margin-top: 5px;
}
.sp #banner_area > div .banner a .title {
	top: 175px;
}
#banner_area > div .banner a .title span {
	display: block;
	width: 100%;
	color: #000000;
	text-align: center;
	font-size: 18px;
	font-size: 1.125rem;
	line-height: 23.4px;
	line-height: 1.4625rem;
}
.sp #banner_area > div .banner a .title span {
	font-size: 16px;
	font-size: 1rem;
	line-height: 20.8px;
	line-height: 1.3rem;
}

#topnews > div, #topir > div {
	position: relative;
	width: 100%;
	max-width: 1220px;
	margin: auto;
	padding: 80px 20px;
	padding-bottom: 0;
}
.sp #topnews > div, .sp #topir > div {
	padding: 40px 10px;
}
.sp #topnews > div, .sp #topir > div {
	padding-bottom: 20px;
}
#topnews h2, #topir h2 {
	margin: 0px 0px 40px;
	padding: 0px;
	font-size: 32px;
	font-size: 2rem;
	line-height: 41.6px;
	line-height: 2.6rem;
	font-weight: 600;
	text-align: center;
}
.sp #topnews h2, .sp #topir h2 {
	margin-bottom: 20px;
	font-size: 26px;
	font-size: 1.625rem;
	line-height: 33.8px;
	line-height: 2.1125rem;
}
#topnews .more, #topir .more {
	text-align: right;
	margin-top: 20px;
}
#topnews .more .rss, #topir .more .rss {
	display: inline-block;
	vertical-align: bottom;
}
#topnews .more .rss a, #topir .more .rss a {
	-webkit-transition: opacity 0.2s, background 0.2s;
	transition: opacity 0.2s, background 0.2s;
	cursor: pointer;
	display: block;
	width: 30px;
	height: 30px;
	background: #f00;
	background: url(../images/ico_rss.svg) center center no-repeat #004295;
	background-size: 24px 24px;
	margin-right: 15px;
  /*
  &.default{
  	display: block;
  	
  	.region1 &, .region2 &, .region3 &, .region4 &, .region5 &, .region6 &, .region7 &, .region8 &, .region9 &{
  		display: none;
  	}
  }
  
  .region1 &.Europe{
  	display: block;
  }
  .region2 &.NorthAmerica{
  	display: block;
  }
  .region3 &.CentralSouthAmerica{
  	display: block;
  }
  .region4 &.Asia{
  	display: block;
  }
  .region5 &.MiddleEast{
  	display: block;
  }
  .region6 &.Africa{
  	display: block;
  }
  .region7 &.SouthAfrica{
  	display: block;
  }
  .region8 &.CIS{
  	display: block;
  }
  .region9 &.Oceania{
  	display: block;
  }
  */
}
#topnews .more .rss a:hover, #topir .more .rss a:hover {
	opacity: 0.7;
}
.sp #topnews .more, .sp #topir .more {
	display: none;
}
#topnews .more.sp, #topir .more.sp {
	display: none;
}
.sp #topnews .more.sp, .sp #topir .more.sp {
	display: block;
	margin-bottom: 20px;
	text-align: center;
}
#topnews .more > a, #topir .more > a {
	position: relative;
	margin-right: 30px;
	font-size: 16px;
	font-size: 1rem;
	line-height: 20.8px;
	line-height: 1.3rem;
	color: #000000;
	position: relative;
	display: inline-block;
}
#topnews .more > a:before, #topir .more > a:before {
	content: "";
	display: block;
	position: absolute;
	bottom: calc(0.15em - 5px);
	left: 0px;
	width: 100%;
	height: 1px;
	background: #000000;
	-webkit-transition: 0.2s;
	transition: 0.2s;
	-webkit-transform: scale(0);
	transform: scale(0);
}
#topnews .more > a:hover:before, #topir .more > a:hover:before {
	-webkit-transform: scale(1);
	transform: scale(1);
}
#topnews .more > a:after, #topir .more > a:after {
	content: "";
	position: absolute;
	display: block;
	width: 20px;
	height: 20px;
	right: -30px;
	top: 50%;
	margin-top: -10px;
	background: url(../images/next.svg) no-repeat center center;
}
#topnews .slide li, #topnews .slidenon li, #topir .slide li, #topir .slidenon li {
	display: block;
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px dotted #535353;
}
#topnews .slide li div, #topnews .slidenon li div, #topir .slide li div, #topir .slidenon li div {
	position: relative;
	display: table;
	width: 100%;
}
.sp #topnews .slide li div, .sp #topnews .slidenon li div, .sp #topir .slide li div, .sp #topir .slidenon li div {
	display: block;
}
#topnews .slide li div .date, #topnews .slidenon li div .date, #topir .slide li div .date, #topir .slidenon li div .date {
	display: table-cell;
	width: 8.75rem;
	padding-top: 0.85rem;
	font-size: 18px;
	font-size: 1.125rem;
	line-height: 19.8px;
	line-height: 1.2375rem;
	font-weight: bold;
	vertical-align: top;
	-webkit-transform: translateY(-0.5em);
	transform: translateY(-0.5em);
}
.sp #topnews .slide li div .date, .sp #topnews .slidenon li div .date, .sp #topir .slide li div .date, .sp #topir .slidenon li div .date {
	display: inline-block;
	margin-bottom: 10px;
	font-size: 16px;
	font-size: 1rem;
	line-height: 17.6px;
	line-height: 1.1rem;
}
#topnews .slide li div .category, #topnews .slidenon li div .category, #topir .slide li div .category, #topir .slidenon li div .category {
	position: relative;
	display: table-cell;
	width: 10rem;
	top: 0.85rem;
	vertical-align: top;
	-webkit-transform: translateY(-10px);
	transform: translateY(-10px);
}
.sp #topnews .slide li div .category, .sp #topnews .slidenon li div .category, .sp #topir .slide li div .category, .sp #topir .slidenon li div .category {
	display: inline-block;
	padding-bottom: 5px;
	width: calc(100% - 8.75rem - 10px);
	font-size: 10px;
	font-size: 0.625rem;
	line-height: 20px;
	text-align: right;
}
#topnews .slide li div .category span, #topnews .slidenon li div .category span, #topir .slide li div .category span, #topir .slidenon li div .category span {
	display: inline-block;
	width: 7.5rem;
	height: 20px;
	margin-bottom: 5px;
	font-size: 12px;
	font-size: 0.75rem;
	line-height: 20px;
	color: #ffffff;
	text-align: center;
	background: #535353;
}
.sp #topnews .slide li div .category span, .sp #topnews .slidenon li div .category span, .sp #topir .slide li div .category span, .sp #topir .slidenon li div .category span {
	margin-right: 5px;
}
#topnews .slide li div .link, #topnews .slidenon li div .link, #topir .slide li div .link, #topir .slidenon li div .link {
	display: table-cell;
	vertical-align: top;
	font-size: 16px;
	font-size: 1rem;
	line-height: 27.2px;
	line-height: 1.7rem;
}
.sp #topnews .slide li div .link, .sp #topnews .slidenon li div .link, .sp #topir .slide li div .link, .sp #topir .slidenon li div .link {
	display: block;
	font-size: 14px;
	font-size: 0.875rem;
	line-height: 23.8px;
	line-height: 1.4875rem;
}
#topnews .slide li div .link a, #topnews .slidenon li div .link a, #topir .slide li div .link a, #topir .slidenon li div .link a {
	position: relative;
	display: table;
	width: 100%;
	color: #000000;
}
#topnews .slide li div .link a > div, #topnews .slidenon li div .link a > div, #topir .slide li div .link a > div, #topir .slidenon li div .link a > div {
	width: auto;
}
#topnews .slide li div .link a .size, #topnews .slidenon li div .link a .size, #topir .slide li div .link a .size, #topir .slidenon li div .link a .size {
	display: block;
}
.sp #topnews .slide li div .link a .size:before, .sp #topnews .slidenon li div .link a .size:before, .sp #topir .slide li div .link a .size:before, .sp #topir .slidenon li div .link a .size:before {
	content: "";
	position: relative;
	display: inline-block;
	width: 18px;
	height: 20px;
	top: -1px;
	margin: 0px 5px;
	padding: 0px !important;
	background: url(../images/pdficon.svg) no-repeat;
	background-size: 18px 20px;
	vertical-align: middle;
	overflow: hidden;
}
#topnews .slide li div .link a *, #topnews .slidenon li div .link a *, #topir .slide li div .link a *, #topir .slidenon li div .link a * {
	-webkit-transition: opacity 0.2s;
	transition: opacity 0.2s;
}
#topnews .slide li div .link a:hover *, #topnews .slidenon li div .link a:hover *, #topir .slide li div .link a:hover *, #topir .slidenon li div .link a:hover * {
	opacity: 0.7;
}
#topnews .slide li div .link a > *, #topnews .slidenon li div .link a > *, #topir .slide li div .link a > *, #topir .slidenon li div .link a > * {
	display: table-cell;
}
#topnews .slide li div .link a .icon, #topnews .slidenon li div .link a .icon, #topir .slide li div .link a .icon, #topir .slidenon li div .link a .icon {
	position: relative;
	width: 120px;
	background: none no-repeat center center;
}
.sp #topnews .slide li div .link a .icon, .sp #topnews .slidenon li div .link a .icon, .sp #topir .slide li div .link a .icon, .sp #topir .slidenon li div .link a .icon {
	display: none;
}
#topnews .slide li div .link a .icon:before, #topnews .slidenon li div .link a .icon:before, #topir .slide li div .link a .icon:before, #topir .slidenon li div .link a .icon:before {
	content: "";
	display: block;
	position: absolute;
	width: 1px;
	height: 80%;
	top: 10%;
	left: 40px;
	background: #535353;
}
.sp #topnews .slide li div .link a .icon:before, .sp #topnews .slidenon li div .link a .icon:before, .sp #topir .slide li div .link a .icon:before, .sp #topir .slidenon li div .link a .icon:before {
	left: 10px;
}
#topnews .slide li div .link a .icon.pdf, #topnews .slidenon li div .link a .icon.pdf, #topir .slide li div .link a .icon.pdf, #topir .slidenon li div .link a .icon.pdf {
	background-position: 71.25px center;
	background-image: url(../images/pdficon.svg);
}
.sp #topnews .slide li div .link a .icon.pdf, .sp #topnews .slidenon li div .link a .icon.pdf, .sp #topir .slide li div .link a .icon.pdf, .sp #topir .slidenon li div .link a .icon.pdf {
	background-position: 25px center;
}
#topnews .slide li div .link a .icon.blank, #topnews .slidenon li div .link a .icon.blank, #topir .slide li div .link a .icon.blank, #topir .slidenon li div .link a .icon.blank {
	background-position: 71.25px center;
	background-image: url(../images/blank.svg);
}
#topnews .slide li div .link a .icon.blank:after, #topnews .slidenon li div .link a .icon.blank:after, #topir .slide li div .link a .icon.blank:after, #topir .slidenon li div .link a .icon.blank:after {
	display: none;
}
.sp #topnews .slide li div .link a .icon.blank, .sp #topnews .slidenon li div .link a .icon.blank, .sp #topir .slide li div .link a .icon.blank, .sp #topir .slidenon li div .link a .icon.blank {
	background-position: 25px center;
}

#topbanner > div {
	position: relative;
	width: 100%;
	max-width: 1220px;
	margin: auto;
	padding: 80px 20px;
}
.sp #topbanner > div {
	padding: 40px 10px;
}
#topbanner ul {
	margin: -20px -5px 0px -20px;
	overflow: hidden;
}
.sp #topbanner ul {
	margin-top: -10px;
}
#topbanner ul li {
	float: left;
	width: calc((100% - 85px) / 4);
	margin-left: 20px;
	margin-top: 20px;
}
.sp #topbanner ul li {
	width: calc(100% - 25px);
	margin-top: 10px;
}
#topbanner a {
	display: block;
	-webkit-transition: opacity 0.2s, background 0.2s;
	transition: opacity 0.2s, background 0.2s;
	cursor: pointer;
}
#topbanner a:hover {
	opacity: 0.7;
}
#topbanner a img {
	display: block;
	max-width: 100%;
	height: auto;
	margin: auto;
}

.top_alert {
	position: absolute;
	width: 100%;
	top: 80px;
	padding: 16px 20px;
	background: rgba(219, 219, 219, 0.7);
	opacity: 1;
	transition: 0.2s;
	z-index: 2;
}
.sp .top_alert {
	top: 60px;
	padding: 16px 10px;
}
.headermove .top_alert, .menuopen .top_alert, .searchopen .top_alert {
	opacity: 0;
	visibility: hidden;
}
.top_alert > div {
	position: relative;
	width: 100%;
	max-width: 1180px;
	margin: auto;
}
.top_alert > div p {
	position: relative;
	display: inline-block;
	padding-left: 3.2rem;
	font-size: 16px;
	font-size: 1rem;
	line-height: 22.4px;
	line-height: 1.4rem;
	color: #c90000;
}
.top_alert > div p:before {
	content: "";
	position: absolute;
	display: block;
	margin-left: -3.2rem;
	width: 2rem;
	height: 1.75rem;
	top: -0.2rem;
	background: url(../images/ico_aleat.svg) no-repeat;
	background-size: cover;
}
.top_alert > div p a {
	color: #c90000;
}
.top_alert > div p a.pdf {
	position: relative;
	padding-right: 25px;
}
.top_alert > div p a.pdf:after {
	content: "";
	position: absolute;
	width: 20px;
	height: 20px;
	right: 0;
	background: url(../images/pdficon.svg) no-repeat;
	background-size: 20px 20px;
}
.top_alert > div p a.blank {
	position: relative;
	padding-right: 25px;
}
.top_alert > div p a.blank:after {
	content: "";
	position: absolute;
	width: 20px;
	height: 20px;
	right: 0;
	top: 0;
	margin: 0;
	background: url(../images/blank.svg) no-repeat;
	background-size: 20px 20px;
}
.top_alert > div p + p {
	margin-top: 20px;
}
