@charset "UTF-8";
/* --------------------------------
	記事
-------------------------------- */
.wrapper {
	min-width: 1020px;
}

.content_wrapper {
	position: relative;
	z-index: 1;
}
.content_wrapper:before,
.content_wrapper:after {
	content: ""; 
	display: block;
	position: absolute;
	z-index: -1;
}
.content_wrapper:before {
	content: "";
	display: block;
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	width: 93px;
	height: 154px;
	background: url(/assets/sp/ilm/img/common/bg_main_top.png) repeat 0 0;
}
.content_wrapper:after {
	right: 0;
	bottom: 0;
	width: 95px;
	height: 329px;
	background: url(/assets/sp/ilm/img/common/bg_main_bottom.png) repeat 100% 0;
}

/***  link ***/
.entry_body a {
	color: #316ba5 !important;
}

/*** ヘッダー ***/
.entry .entry_hdr .category {
	position: relative;
	float: left;
	background: #316ba5;
	color: #fff;
	font-size: 12px;
	font-weight: bold;
}
.entry .entry_hdr .category:not(:first-of-type) {
	margin-left: 10px;
}
.entry .entry_hdr .category > span {
	display: inline-block;
	padding: 2px 6px;
}

.entry .entry_hdr .date {
	float: left;
	padding: 5px 0 0 14px;
	font-size: 16px;
	line-height: 1;
}

.entry .entry_hdr .entry_ttl {
	margin-top: 15px;
	padding-bottom: 10px;
	border-bottom: 2px solid #316ba5;
	font-size: 30px;
	line-height: 1.45;
}

/*** ボディ ***/
.entry .entry_body {
	padding-top: 30px;
}
.entry .entry_body .catch {
	margin: 0 auto 25px;
	width: 540px;
	text-align: center;
}
.entry .entry_body .catch .slider li {
	position: relative;
	float: left;
	height: 540px;
}

/** 画像・スライダー **/
.bx-wrapper {
	border: none; 
	background-color: transparent;
	-webkit-box-shadow: none;
	        box-shadow: none;
}

.bx-wrapper img {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}

.entry .entry_body .catch .bx-wrapper .bx-controls-direction a {
	z-index: 10; 
	margin-top: -18px;
	width: 36px;
	height: 36px;
	background-repeat: no-repeat;
	background-position: 0 0;
}
.entry .entry_body .catch .bx-wrapper .bx-controls-direction a:hover {
	background-position: 0 -36px;
}
.entry .entry_body .catch .bx-wrapper .bx-controls-direction a.bx-prev {
	left: -138px;
	background-image: url(/assets/sp/ilm/img/detail/slide_nav_prev.png);
}
.entry .entry_body .catch .bx-wrapper .bx-controls-direction a.bx-next {
	right: -138px;
	background-image: url(/assets/sp/ilm/img/detail/slide_nav_next.png);
}

/** エディタスタイル **/
.entry_body {
	color: #333;
	font-size: 18px;
	line-height: 1.66;
}

.mode_sp:not(.ilm_index) .entry_body {
	font-size: 36px;
}

.entry_body a {
	text-decoration: none; 
	color: #000;
}
.entry_body a:hover {
	text-decoration: underline; 
	color: #000;
}
.entry_body a[target="_blank"] {
	padding-right: 17px;
	background: url(/assets/sp/ilm/img/detail/ico_outer.png) right center no-repeat;
	background: url(/assets/sp/ilm/img/detail/ico_outer.png) right center no-repeat;
}

/* widget.css上書き */
h2.h2_A {
	font-size: 24px;
}

h3.h3_C {
	font-size: 18px;
}

.mode_sp:not(.ilm_index) h2.h2_A {
	font-size: 40px;
}

.mode_sp:not(.ilm_index) h3.h3_C {
	font-size: 36px;
}

div.content_2cl_A .txtarea,
div.content_2cl_B .txtarea {
	line-height: 1.66;
}

div.btn_link_arw_right p,
div.btn_link_arw_bottom p {
	font-size: 18px;
	font-weight: bold;
}

/* --------------------------------
   ボタンレイアウト
-------------------------------- */
.btn_layout {
	display: inline-block;
	min-width: 180px;
	-webkit-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.btn_layout > a {
	display: block;
	position: relative; 
	padding: 15px 20px;
	width: 100%;
	height: 100%;
	text-align: center;
	text-decoration: none;
	color: #fff !important;
	font-size: 19px;
}
.btn_layout > a:before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 20px;
	margin: auto;
	width: 11.5px;
	height: 18.5px;
	-webkit-transform: scale(-1, 1);
	    -ms-transform: scale(-1, 1);
	        transform: scale(-1, 1); 
	background: url(/assets/sp/ilm/img/common/icon_arrow.png) no-repeat left top/100% auto;
}
@media screen and (min-width: 1000px) {
	.btn_layout > a:before {
		-webkit-transition: all 0.3s ease-in-out;
		transition: all 0.3s ease-in-out;
	}
}
.btn_layout > a:hover {
	text-decoration: none;
}
.btn_layout > a:hover:before {
	background-image: url(/assets/sp/ilm/img/common/icon_arrow_on.png);
}

.btn_layout-left {
	display: inline-block;
	overflow: hidden;
}
.btn_layout-left > a {
	display: block;
	padding: 14px 50px;
}
@media screen and (min-width: 736px) {
	.btn_layout-left > a {
		padding: 16px 70px 16px 80px;
	}
}
.btn_layout-left > a span {
	display: inline-block;
	position: relative;
	font-weight: bold;
}
@media screen and (min-width: 736px) {
	.btn_layout-left > a:hover:before {
		-webkit-transform: scale(-1, 1) translateX(-3px);
		    -ms-transform: scale(-1, 1) translateX(-3px);
		        transform: scale(-1, 1) translateX(-3px);
	}
}

.btn_layout-bottom > a {
	position: relative;
	padding: 15px 50px;
}
.btn_layout-bottom > a:before {
	display: inline-block; 
	position: absolute;
	top: 8px;
	bottom: 0;
	left: 20px;
	margin: auto;
}
@media screen and (min-width: 1000px) {
	.btn_layout-bottom > a:before {
		-webkit-transition: all 0.3s ease-in-out;
		transition: all 0.3s ease-in-out; 
		-webkit-transform: translateY(-2px) rotate(-90deg); 
		    -ms-transform: translateY(-2px) rotate(-90deg); 
		        transform: translateY(-2px) rotate(-90deg);
	}
}

@media screen and (min-width: 1000px) {
	.btn_layout-bottom:hover > a:before {
		-webkit-transform: translateY(2px) rotate(-90deg);
		    -ms-transform: translateY(2px) rotate(-90deg);
		        transform: translateY(2px) rotate(-90deg);
	}
}

.layout_btn_back {
	display: block; 
	margin: 45px auto 61px;
	width: 250px;
}
.layout_btn_back > a {
	display: block;
	padding: 15px 80px;
}
.layout_btn_back > a:before {
	top: 0;
	bottom: 0;
	left: 20px;
	margin: auto;
	-webkit-transform: scale(1, 1);
	    -ms-transform: scale(1, 1);
	        transform: scale(1, 1);
}
@media screen and (min-width: 1000px) {
	.layout_btn_back > a:hover:before {
		-webkit-transform: scale(1, 1) translateX(-3px);
		    -ms-transform: scale(1, 1) translateX(-3px);
		        transform: scale(1, 1) translateX(-3px);
	}
}

/* --------------------------------
	#side（関連記事・おすすめ記事）
-------------------------------- */
#side {
	position: relative;
	margin: 0 auto 208px;
	padding: 43px 0;
	width: 780px;
	background: #f1f1f0;
}
#side:before {
	content: "";
	display: inline-block;
	position: absolute;
	z-index: -1;
	bottom: -60px;
	left: -70px;
	width: 469px;
	height: 310px;
	background: url(/assets/sp/ilm/img/detail/bg_side.png) no-repeat left top;
}
#side .side_article {
	float: left;
	margin: 0 0 0 60px;
	width: 300px;
}
#side .side_article h3 {
	overflow: hidden;
	margin-bottom: 20px;
	width: 300px;
	height: 40px;
	white-space: nowrap; 
	text-indent: 100%;
}

#side .side_article_relate h3 {
	background: url(/assets/sp/ilm/img/detail/relate_ttl.png) no-repeat 0 0;
}

#side .side_article_recommend h3 {
	background: url(/assets/sp/ilm/img/detail/recommend_ttl.png) no-repeat 0 0;
}

#side .side_article ul li {
	margin-top: 25px;
}
#side .side_article ul li:first-child {
	margin-top: 0;
}
#side .side_article ul li a {
	display: block;
	text-decoration: none; 
	color: #000;
	font-size: 14px;
	line-height: 1.42;
}
#side .side_article ul li a:hover {
	text-decoration: underline;
}
#side .side_article ul li .thumb {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	margin: 0 auto;
	width: 300px;
	height: 300px;
	text-align: center;

	-webkit-box-align: center;

	    -ms-flex-align: center;

	        align-items: center;
}
#side .side_article ul li .ttl {
	margin-top: 20px;
}

/* --------------------------------
 メニュー SPの際に表示を拡大する指定
-------------------------------- */
.mode_sp:not(.ilm_index) .gnav_overlay {
	overflow-y: scroll;
	width: 100%; 

	-webkit-overflow-scrolling: touch;
}

.mode_sp:not(.ilm_index) .btn-close {
	top: 34px;
	right: 34px;
	width: 100px;
	height: 100px;
}
.mode_sp:not(.ilm_index) .btn-close:after {
	top: 67px;
	right: 6px;
	font-size: 27px;
}
.mode_sp:not(.ilm_index) .btn-close .line {
	top: 32px;
	right: 9px;
	width: 78px;
	height: 6px;
}

.mode_sp:not(.ilm_index) .gnav_content {
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
	padding: 160px 0;
}
.mode_sp:not(.ilm_index) .gnav_content li a,
.mode_sp:not(.ilm_index) .gnav_content li .not-link {
	padding: 40px 0;
	text-align: center;
	font-size: 50px;
}
.mode_sp:not(.ilm_index) .gnav_content .title {
	padding: 70px 0;
	width: auto;
	height: auto;
}
.mode_sp:not(.ilm_index) .gnav_content .title img {
	width: auto;
	height: auto;
}
.mode_sp:not(.ilm_index) .gnav_content .menu li:before {
	height: 2px;
}

.mode_sp:not(.ilm_index) .sns {
	width: 640px;
}
.mode_sp:not(.ilm_index) .sns > li {
	width: 130px;
	height: 130px;
	background-size: 520px 130px;
}
.mode_sp:not(.ilm_index) .sns .sns_f {
	background-position: -130px 0;
}
.mode_sp:not(.ilm_index) .sns .sns_y {
	background-position: -259px 0;
}
.mode_sp:not(.ilm_index) .sns .sns_i {
	background-position: -389px 0;
}

.mode_sp:not(.ilm_index) .entry .entry_hdr .category > span {
	font-size: 24px;
}

.mode_sp:not(.ilm_index) .entry .entry_hdr .date {
	font-size: 34px;
}

.mode_sp:not(.ilm_index) .entry_body {
	font-size: 36px;
}

.mode_sp:not(.ilm_index) .entry .entry_hdr .entry_ttl {
	font-size: 48px;
}

.mode_sp:not(.ilm_index) h2.h2_A {
	font-size: 40px;
}

.mode_sp:not(.ilm_index) h3.h3_C {
	font-size: 36px;
}

.mode_sp:not(.ilm_index) .btn_layout > a {
	font-size: 36px;
}

.mode_sp:not(.ilm_index) #side .side_article h3 {
	height: 45px;
}

.mode_sp:not(.ilm_index) #side .side_article ul li .ttl {
	font-size: 28px;
}

.mode_sp:not(.ilm_index) .ftr_body .inner {
	width: 930px;
}

.mode_sp:not(.ilm_index) .ftr_body .menu > li {
	width: 432px;
}

.mode_sp:not(.ilm_index) .ftr_body.cover .ftr_note {
	font-size: 20px;
}

.mode_sp:not(.ilm_index) .ftr_body .inner .menu > li > a,
.mode_sp:not(.ilm_index) .ftr_body .inner .menu > li > .not-link {
	font-size: 28px;
}

.mode_sp:not(.ilm_index) .ftr_body.uftr > div.inner {
	width: 880px;
}

.mode_sp:not(.ilm_index) .ftr_body.uftr > div.inner > ul > li {
	width: 410px;
}

.mode_sp:not(.ilm_index) .l-ftr .copyright > p {
	font-size: 24px;
	font-weight: bold;
}