@charset "UTF-8";
/* @import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css); */
@import url(../../fonts/DINPro/load.css);

/* noto-sans-jpをセルフホスティング
   https://asobi-lab.co.jp/lecture/web/noto-sans/ */
@font-face {
    /*font-family: 'noto-sans-jp';*/
    font-family: 'Noto Sans JP';
    src: url(../../fonts/Noto_Sans_JP/NotoSansJP.woff)format("woff");
    font-weight: normal;
    font-display: swap;
}
@font-face {
    /*font-family: 'noto-sans-jp';*/
    font-family: 'Noto Sans JP';
    src: url(../../fonts/Noto_Sans_JP/NotoSansJP.woff)format("woff");
    font-weight: bold;
    font-display: swap;
}

html {
	font-size: 16px;
}

body {
	min-width: 1200px;
	color: #222;
	font-size: 16px;
	line-height: 1.7;
	/*font-family: "Noto Sans JP", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;*/
	font-family: "メイリオ", Meiryo, "Noto Sans JP", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

/* ==================================================
ダミー部分用
================================================== */
.please-contents {
	height: 700px;
	font-size: 24px;
	background: #d5d5d5;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

/* ==================================================
タグ
================================================== */
a {
	text-decoration: none;
	-webkit-transition: All 0.4s ease;
	transition: All 0.4s ease;
}

a:hover {
/*	text-decoration: underline;
	opacity: .8;*/
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: top;
}

/* ==================================================
汎用クラス
================================================== */
@media screen and (min-width: 768px) {
	.sp-only {
		display: none !important;
	}
}

@media screen and (max-width: 768px) {
	.pc-only {
		display: none !important;
	}
}

/* 改行
-------------------------------------------------- */
.br {
	line-height: 0;
	font-size: 0;
	letter-spacing: 0;
	display: block;
}

.header-slip-anchor {
	-webkit-transform: translateY(-130px);
	        transform: translateY(-130px);
	display: block;
}

@media screen and (max-width: 768px) {
	.header-slip-anchor {
		-webkit-transform: none;
		        transform: none;
	}
}


/* 端末別表示非表示設定
-------------------------------------------------- */
@media screen and (max-width: 768px) {
	.pc-only { /* PCでの閲覧時にのみ表示したいコンテンツにつける */
		display: none !important;
	}
}

@media screen and (min-width: 768px) {
	.sp-only { /* スマホでの閲覧時にのみ表示したいコンテンツにつける */
		display: none !important;
	}
}

/* 改行
-------------------------------------------------- */
.app-br {
	display: block;
}

/* clearfix
-------------------------------------------------- */
.clearfix:after {
	content: ".";
	height: 0;
	clear: both;
	display: block;
	visibility: hidden;
}

.clearfix {
	display: inline-block;
	overflow: hidden;
}

/* ==================================================
詳細ページ用　前後の記事
================================================== */
/* 記事情報
------------------------- */
.post-info-wrap {
	margin: 0 0 16px;
	overflow: hidden;
}

.post-info-wrap .post-info-item {
	margin: 0 15px 0 0;
	padding: 0 0 0 20px;
	background: left top 4px no-repeat;
	float: left;
}


/* タグリスト */
.post-tag-list {
	overflow: hidden;
}

.post-tag-list li {
	margin: 0 5px 0 0;
	float: left;
}

.post-tag-list li:not(:last-child):after {
	content: ',';
}

.prev-next-post {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
}

.prev-next-post div {
	width: calc(50% - 4px);
}

.prev-next-post a {
	padding: 0 20px;
	color: inherit;
	line-height: 96px;
	border: 1px solid #e6e6e6;
	text-overflow: ellipsis;
	white-space: nowrap;
	display: block;
	overflow: hidden;
}

.prev-next-post .prev-post a {
	padding-left: 47px;
	background: url(../images/common/icon_arrow08.png) left 20px center no-repeat;
}

.prev-next-post .next-post a {
	padding-right: 47px;
	background: url(../images/common/icon_arrow09.png) right 20px center no-repeat;
}

.prev-next-post a:hover {
	text-decoration: none;
	background-color: #fafafa;
}

/* 投稿日 */
.post-date {
	margin: 0 0 15px;
	padding: 1px 0 0 12px;
	font-size: 13px;
	background: url(../images/common/icon_arrow07.png) left center no-repeat;
	display: block;
}


/* ==================================================
ページネーション
================================================== */
.pagenation {
	margin: 20px 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}

.pagenation li {
	width: 30px;
	margin: 0 4px;
	line-height: 35px;
	text-align: center;
	background: #aaa;
}

.pagenation li > * {
	color: #fff;
	font-size: 13px;
	text-decoration: none;
	display: block;
}

.pagenation li:hover,
.pagenation li.current {
	background: #0046ae;
}


/* ==================================================
アニメーション
================================================== */
/* 白ボーダー
-------------------------------------------------- */
.hover-frame > a:hover {
	opacity: 1;
}

.hover-frame > a > span,
.hover-frame > a {
	position: relative;
	display: block;
}

.hover-frame > a > span:before,
.hover-frame > a > span:after,
.hover-frame > a:before,
.hover-frame > a:after {
	content: '';
	width: 0;
	height: 0;
	background: #fff;
	display: block;
	position: absolute;
	z-index: 200;
	-webkit-transition: all 0.5s ease;
	transition: all 0.5s ease;
}

.hover-frame > a > span:before,
.hover-frame > a:before {
	height: 3px;
}

.hover-frame > a > span:after,
.hover-frame > a:after {
	width: 3px;
}

.hover-frame > a > span:before,
.hover-frame > a > span:after {
	top: 0;
	right: 0;
}

.hover-frame > a:before,
.hover-frame > a:after {
	bottom: 0;
	left: 0;
}

.hover-frame > a > span:hover:before,
.hover-frame > a:hover:before {
	width: 100%;
}

.hover-frame > a > span:hover:after,
.hover-frame > a:hover:after {
	height: 100%;
}

/* 青ボーダー
-------------------------------------------------- */
.hover-frame-blue > a > span:before,
.hover-frame-blue > a > span:after {
	background: #174aaa;
}

.hover-frame-blue > a:before,
.hover-frame-blue > a:after {
	background: #0d3179;
}

/* オレンジボーダー
-------------------------------------------------- */
.hover-frame-orange > a > span:before,
.hover-frame-orange > a > span:after {
	background: #f8883d;
}

.hover-frame-orange > a:before,
.hover-frame-orange > a:after {
	background: #dd621e;
}

/* 太いボーダー
-------------------------------------------------- */
.hover-frame-bold > a > span:before,
.hover-frame-bold > a:before {
	height: 10px;
}

.hover-frame-bold > a > span:after,
.hover-frame-bold > a:after {
	width: 10px;
}

/* 中ボーダー
-------------------------------------------------- */
.hover-frame-middle > a > span:before,
.hover-frame-middle > a:before {
	height: 5px;
}

.hover-frame-middle > a > span:after,
.hover-frame-middle > a:after {
	width: 5px;
}

/* メインビジュアル
-------------------------------------------------- */




.main-visual-wrap:after {
	/* content: ''; */
	width: 100%;
	border-top: 2px solid #fff;
	position: absolute;
	top: 50%;
	left: -100%;
	-webkit-transform: translateY(-50%);
	        transform: translateY(-50%);
	-webkit-transition: all .8s linear;
	transition: all .8s linear;
	-webkit-transition-delay: 0s;
	        transition-delay: 0s;
}

.main-visual-wrap .visual-catch {
	line-height: 1;
	color: #fff;
	font-size: 37px;
}

.main-visual-wrap .visual-catch .en {
	margin: 0 0 1.72em;
	/*font-family: "Noto Sans JP", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;*/
	font-family: "メイリオ", Meiryo, "Noto Sans JP", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	letter-spacing: .1em;
	opacity: 0;
	-webkit-transition: opacity 1.5s ease;
	transition: opacity 1.5s ease;
	-webkit-transition-delay: 1.3s;
	        transition-delay: 1.3s;
}

.main-visual-wrap .visual-catch .ja {
	font-size: 1.48em;
	font-style: italic;
	letter-spacing: .3em;
	opacity: 0;
	-webkit-transition: opacity 1.5s ease;
	transition: opacity 1.5s ease;
	-webkit-transition-delay: 2.2s;
	        transition-delay: 2.2s;
}

/* アニメーション時
------------------------- */
.main-visual-wrap.is-view:after {
	left: 0;
}

.main-visual-wrap.is-view .visual-catch .en,
.main-visual-wrap.is-view .visual-catch .ja {
	opacity: 1;
}

/* サブビジュアル
-------------------------------------------------- */
.sub-visual-wrap {
	height: 360px;
	
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.sub-visual-wrap .visual-catch {
	line-height: 1;
	text-align: center;
	font-size: 45px;
	font-weight: bold;
}

.sub-visual-wrap .visual-catch .en {
	margin: 0 0 2.56em;
	color: #666;
	font-size: .66em;
	/*font-family: "Noto Sans JP", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;*/
	font-family: "メイリオ", Meiryo, "Noto Sans JP", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	position: relative;
}

.sub-visual-wrap .visual-catch .en:after {
	content: '';
	width: 48px;
	border-top: 1px solid #666;
	border-bottom: 1px solid transparent;
	display: block;
	position: absolute;
	bottom: -1.5em;
	left: 50%;
	-webkit-transform: translateX(-50%);
	        transform: translateX(-50%);
}

.sub-visual-wrap .visual-catch .ja {
	line-height: 1.3;
}

/* カラーバリエーション
------------------------- */
/* 青 */
.sub-visual-wrap .visual-catch-blue .en {
	color: #0046ae;
}

.sub-visual-wrap .visual-catch-blue .en:after {
	border-top-color: #0046ae;
}

/* オレンジ */
.sub-visual-wrap .visual-catch-orange .en {
	color: #ee7911;
}

.sub-visual-wrap .visual-catch-orange .en:after {
	border-top-color: #ee7911;
}



/* カテゴリー固有ナビ
-------------------------------------------------- */
.header-category-nav {
	border-top: 1px solid #fff;
}

.header-category-nav ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}

.header-category-nav a {
	padding: 0 22px;
	line-height: 49px;
	color: #fff;
	font-size: 14px;
	font-weight: bold;
	letter-spacing: .1em;
	display: block;
}

/* カラーバリエーション
------------------------- */
/* 青 */
.header-category-nav-blue {
	background: #0046ae;
}

/* オレンジ */
.header-category-nav-orange {
	background: #ee7911;
}


/* ==================================================
content layout
================================================== */
.l-content-wrap {
	padding: 80px 0;
}

.l-content-wrap .l-content-inner {
	max-width: 1200px;
	margin: 0 auto;
}

/* ==================================================
NEWS
================================================== */
.header-news-section {
	border-bottom: 1px solid #e0e0e0;
}

.header-news-section .inner {
	max-width: 1200px;
	height: 70px;
	margin: 0 auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	position: relative;
}

/* 見出し */
.header-news-section .news-title {
	width: 95px;
	margin: 0 24px 0 5px;
	color: #0046ae;
	font-size: 20px;
	/*font-family: "Noto Sans JP", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;*/
	font-family: "メイリオ", Meiryo, "Noto Sans JP", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-weight: bold;
	letter-spacing: .1em;
	background: url(../images/common/icon_arrow01.png) right center no-repeat;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}

/* リスト */
.header-news-section .news-list-wrap {
	width: 936px;
}

/* 一覧へ */
.header-news-section .news-more {
	width: 120px;
	margin-left: auto;
}

.header-news-section .news-more a {
	text-align: center;
	line-height: 31px;
	color: #074095;
	font-size: 13px;
	border: 2px solid #074095;
	display: block;
}

.header-news-section .news-more a:hover {
	color: #fff;
	text-decoration: none;
	background: #074095;
}

/* リスト
------------------------- */
.header-news-section .item {
	font-size: 14px;
}

.header-news-section .item-inner {
	width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.header-news-section .item a {
	color: inherit;
}

/* 日付 */
.header-news-section .item-date {
	width: 95px;
	letter-spacing: .1em;
}

/* カテゴリー */
.header-news-section .item-category {
	width: 80px;
	margin: 0 21px 0 0;
	line-height: 24px;
	text-align: center;
	color: #fff;
	font-size: 11px;
	letter-spacing: .2em;
	font-weight: 300;
	background: #666;
}

.header-news-section .item-category-new {
	background: #0046ae;
}

.header-news-section .item-category-mid {
	background: #ee7911;
}

img.sm {
    border: 1px #c8c8c8 solid;
    box-shadow: 0 0 6px gray;
}
img.sm_novideo{
    border: 1px #c8c8c8 solid;
    box-shadow: 0 0 6px gray;
    width: 100%;
    opacity: 0.5;
}

.dialog_nursery {
    display: block;
    height: 100%;
}
