@charset "UTF-8";

#single{
	padding-top: 117px;
	padding-bottom: 120px;
}

#single .container{
	max-width: 950px;
	display: flex;
	justify-content: space-between;
/*	flex-direction: row-reverse;*/
}

#single aside.top{
	width: 225px;
}

#single article{
	width: 650px;
}

#toNews{
	position: relative;
	cursor: pointer;
	width: 100%;
	height: 17px;
	margin-bottom: 32px;
}

#toNews a{
	display: block;
	position: relative;
	height: 17px;
}

#toNews .normal-image{
    position: absolute;
    top: 0px;
    left: 0px;
    transition: opacity 0.5s ease; /* フェード効果の設定 */
}

#toNews .hover-image {
    position: absolute;
    top: 0px;
    left: 0px;
    transition: opacity 0.5s ease; /* フェード効果の設定 */
    opacity: 0;
}

#toNews:hover .normal-image {
    opacity: 0;
}

#toNews:hover .hover-image {
    opacity: 1;
}

#share p{
	color: #5E5E5E;
	font-feature-settings: 'clig' off, 'liga' off;
	font-size: 16px;
	font-style: normal;
	font-weight: 400;
	line-height: 120%; /* 19.2px */
	letter-spacing: 0.8px;
	margin-bottom: 8px;
}

#share ul{
	display: flex;
}

#share li{
	margin-right: 12px;
}

#share li a{
	width: 35px;
	height: 35px;
	display: block;
	position: relative;
}

#share li a .normal-image {
    position: relative;
    transition: opacity 0.5s ease; /* フェード効果の設定 */
}

#share li a .hover-image {
    position: absolute;
    top: 0px;
    left: 0px;
    transition: opacity 0.5s ease; /* フェード効果の設定 */
    opacity: 0;
}

#share li a:hover .normal-image {
    opacity: 0;
}

#share li a:hover .hover-image {
    opacity: 1;
}

.postHead .description ul{
	display: flex;
	margin-bottom: 16px;
}

.postHead .description ul li{
	color: #0B397D;
	font-family: Sofia Sans;
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 150%;
	margin-right: 16px;
}

.postHead .description ul li a{
	color: #0B397D;
	font-family: Sofia Sans;
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 150%;
}

.singleTtl{
	color: #302C28;
	font-family: ryo-gothic-plusn;
	font-size: 39px;
	font-weight: 400;
	line-height: 120%; /* 46.8px */
	letter-spacing: -0.78px;
	margin-bottom: 56px;
}

.sticky{
	position: sticky;
	top: 117px;
}

.postIn{
	color: #302C28;
	font-size: 16px;
	font-weight: 500;
	line-height: 180%;
}

@media screen and (max-width: 1024px) {
	.sticky{
		position: relative;
		top: 0;
		display: flex;
		justify-content: space-between;
		-webkit-align-items: flex-end;
		        align-items: flex-end;
		margin-bottom: 32px;

	}

	#single .container{
		display: block;
		width: 90%;
		max-width: 650px;
	}

	#single aside.top{
		width: 100%;
		margin-bottom: 80px;
	}

	#single article{
		width: 100%;
		max-width: 650px;
	}

	#share{
		display: flex;
		align-items: flex-end;
	}

	#share p{
		margin-right: 4px;
		margin-bottom: 0;
	}

	#share li{
		margin-right: 0;
		margin-left: 8px;

	}

	.singleTtl{
		font-size: 35px;
	}

	#toNews{
		margin-bottom: 0;
	}
}


@media screen and (max-width: 767px) {
	#share ul{
		display: block;
	}

	#share li{
		margin-top: 0;
	}

	#share ul li{
		margin-bottom: 8px;
	}

	#single aside{
		margin-bottom: 16px;
	}

	.postHead .description ul li,
	.postHead .description ul li a{
		font-size: 14px;
		line-height: 1em;
	}

	.postHead .description ul{
		margin-bottom: 8px;
	}

	.singleTtl{
		font-size: 25px;
	}

	.postIn{
		font-size: 15px;
	}

	#share ul li:last-of-type{
		margin-bottom: 0;
	}
}

#single.interview #toNews{
	height: 0;
	margin: 0;
}

#single.interview #toNews a{
	display: none;
	height: 0;
}

#single.interview .description{
	display: none;
}


aside.bottom{
	display: none;
}

@media screen and (max-width: 1024px) {

#single{
	padding-bottom: 0;
}
article{
	margin-bottom: 80px;
}
aside.bottom{
	padding-bottom: 0;
	margin: 0;
	display: block;
	width: 100%;
}

}


/* article */

article .postIn strong,
article .postIn b{
	font-weight: bold;
}

article .postIn a{
	color: #0000EE !important;
	text-decoration: underline !important;
}

article .postIn em{
    font-style: italic !important;
}

article .postIn blockquote {
    display: block !important;
    margin-block-start: 1em !important;
    margin-block-end: 1em !important;
    margin-inline-start: 40px !important;
    margin-inline-end: 40px !important;
}

article .postIn ul {
    display: block;
    list-style-type: disc !important;
    margin-block-start: 1em !important;
    margin-block-end: 1em !important;
    margin-inline-start: 0px !important;
    margin-inline-end: 0px !important;
    padding-inline-start: 40px !important;
}

article .postIn ol {
    display: block;
    list-style-type: decimal !important;
    margin-block-start: 1em !important;
    margin-block-end: 1em !important;
    margin-inline-start: 0px !important;
    margin-inline-end: 0px !important;
    padding-inline-start: 40px !important;
}

article .postIn h1 {
    display: block;
    font-size: 2em !important;
    margin-block-start: 0.67em !important;
    margin-block-end: 0.67em !important;
    margin-inline-start: 0px !important;
    margin-inline-end: 0px !important;
    font-weight: bold !important;
}

article .postIn h2 {
    display: block;
    font-size: 1.5em !important;
    margin-block-start: 0.83em !important;
    margin-block-end: 0.83em !important;
    margin-inline-start: 0px !important;
    margin-inline-end: 0px !important;
    font-weight: bold !important;
}
article .postIn h3 {
	    display: block;
    font-size: 1.17em !important;
    margin-block-start: 1em !important;
    margin-block-end: 1em !important;
    margin-inline-start: 0px !important;
    margin-inline-end: 0px !important;
    font-weight: bold !important;
}
article .postIn h4 {
	    display: block;
    margin-block-start: 1.33em !important;
    margin-block-end: 1.33em !important;
    margin-inline-start: 0px !important;
    margin-inline-end: 0px !important;
    font-weight: bold !important;
}
article .postIn h5 {
	    display: block;
    font-size: 0.83em !important;
    margin-block-start: 1.67em !important;
    margin-block-end: 1.67em !important;
    margin-inline-start: 0px !important;
    margin-inline-end: 0px !important;
    font-weight: bold !important;
}
article .postIn h6 {
	display: block;
    font-size: 0.67em;
    margin-block-start: 2.33em;
    margin-block-end: 2.33em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
    font-weight: bold;
}
