/* CSS Document */

#main .col img.link_icon{
	margin-top: 0;
}

/*component*/
.c-dash{
	letter-spacing: -0.15em;
}
.c-tight_spacing{
	letter-spacing: -0.03em;
}
.c-paren{
	margin-left: -0.5em;
	margin-right: -0.5em;
}

.c-line_section{
	padding-top: 1.5rem;
	border-top: #ccc 1px solid;
}
.c-border_img{
	border: #ccc 1px solid;
}

/*c-block_hover*/
.c-block_hover{
	position: relative;
}
.c-block_hover a:before{
	content: '';
	display: block;
	box-sizing: border-box;
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0px; top: 0px;
	transition: all 0.3s;
	border: #a6c4eb 1px solid;
	border-radius: 2px;
	background-color: rgba(166,196,235,0.3);
	opacity: 0;
}
.c-block_hover:hover a:before{
	border-width: 2px;
	opacity: 1;
}

/*  Heading reset -- default style
----------------- */
.p-rhythm_logo{
	margin: 1.75rem 0 0;
	text-align: center;
}
#main .p-rhythm_logo h1{
	margin: 0 auto;
	width: 700px;
	max-width: 100%;
	height: auto;
	position: relative;
	padding-top: 30%;
}
.p-rhythm_logo h1 span{
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top:0px;
	opacity: 0;
}
.sp #main .p-rhythm_logo h1{
	overflow: hidden;
	width: 100%;
	margin-bottom: 1.5rem;
}

.p-rhythm_logo__f1{
	left: -30px;
	transition: all 0.8s ease-out 0.2s;
}
.p-rhythm_logo__f2{
	left: 32px;
	transition: all 0.6s ease-out 1s;
}
.p-rhythm_logo__f3{
	left: -24px;
	transition: all 0.6s ease-out 1s;
}
.p-rhythm_logo__f4{
	left: -12px;
	transition: all 0.4s ease 1.4s;
}

.is-appear .p-rhythm_logo__f1,
.is-appear .p-rhythm_logo__f2,
.is-appear .p-rhythm_logo__f3,
.is-appear .p-rhythm_logo__f4{
	left: 0;
	opacity: 1;
}

#main h2.p-rhythm_title{
	margin: 0 0 0.25rem;
	text-align: left;
}

#main h3.p-rhythm_heading{
	font-size: 1.375rem; /*18px*/
	margin: 1.5rem 0 2rem;
	text-align: center;
	position: relative;
}

/*p-photo_unit*/

.p-photo_unit{
	background-color: #1A1A1A;
}
#main .col.p-photo_unit img,
#main .col .p-photo_unit img{
	margin-top: 0;
}
.p-photo_unit__caption{
	padding: 0.8125rem 1.25rem 0.9375rem;
	color: #fff;
	font-size: 0.875rem;
	line-height: 1.8;
}

.p-rhythm_map{
	margin: 0.875rem auto;
	width: auto;
	text-align: center;
}
.p-rhythm_map img{
	max-width: 100%;
}
/*.sp .p-rhythm_map{
	width: 100%;
}*/
/**/
.p-rhythm_txt{
	padding: 0 40px;
}
.p-rhythm_txt .p-indent{
	padding-left: 30px;
}
.p-rhythm_separate_mark{
	font-size: 1.25rem;
	line-height: 1;
}

.p-lede{
	text-align: center;
}
.sp .p-lede{
	text-align: left;
}
.p-photoby{
	font-size: 0.8125rem;
}

.p-author{
	padding-top: 1rem;
	border-top: #ccc 1px solid;
	margin-bottom: 2rem;
	font-size: 0.875rem;
	line-height: 1.7;
}
#main .p-author h4{
	font-size: 1rem;
	margin: 0 0 0.25rem;
}

.p-rhythm_txt .col2 .col{
	width: calc((100% - 40px)/2);
}
.p-rhythm_txt .col3 .col{
	width: calc((100% - 80px)/3);
}
.p-rhythm_txt .col3 .col.span-2{
	width: calc((100% - 80px)/3*2 + 40px);
}
.p-rhythm_txt .col5 .col{
	width: calc((100% - 160px)/5);
}
.p-rhythm_txt .col5 .col.span-2{
	width: calc((100% - 160px)/5*2 + 40px);
}
.p-rhythm_txt .col5 .col.span-3{
	width: calc((100% - 160px)/5*3 + 80px);
}

/*listening*/
.c-box_article.c-padding.p-listening{
	margin-top: 2.5rem;
	margin-bottom: 3.5rem;
	padding-bottom: 1.5rem;
	font-size: 0.875rem;
	background-color: #EDEEF0;
}

#main .c-box_article h3.p-title_listening{
	font-size: 1.375rem;
	letter-spacing: 0.01em;
	font-weight: 300;
	font-family: Arial, Helvetica, "sans-serif";
}
#main .c-box_article h3.p-title_listening strong{
	font-weight: 600;
}
.p-listening_caution{
	color: #A10B0D;
	margin: 0.25rem 0 0.5rem;
}

.p-listening_block{
	display: flex;
	justify-content: space-between;
}
.p-listening_block__cover{
	flex: 0 0 auto;
	width: 120px;
	margin-right: 1.5rem;
}
.p-listening_block__txt{
	flex: 1 0 auto;
	width: 50%;
}

/*youtube_link*/
.p-youtube_link{
	display: flex;
	justify-content: space-between;
	padding: 0.625rem 0.875rem 0.8125rem 0.625rem;
	background: #333;
	color: #fff;
	box-shadow: 2px 3px 8px -1px rgba(0,0,0,0.4);
}
.p-youtube_link::before{
	content: "";
	display: block;
	position: absolute;
	top:10px; right: 10px;
	width: 15px;
	height: 15px;
	background: url("/common/image/icon_blank.png") no-repeat 50% 50%;
}
.p-youtube_link__thumb{
	flex: 0 0 auto;
	width: 240px;
	margin-right: 1rem;
}
.p-youtube_link__txt{
	flex: 1 0 auto;
	width: 50%;
	line-height: 1.5;
}
.p-youtube_link__txt a{
	color: #fff;
	text-decoration: none;
}
#main .p-youtube_link__txt h4{
	font-size: 1rem;
}
.p-youtube_link__shoulder{
	font-size: 0.875rem;
	color: #999;
	padding-bottom: 0.375rem;
	margin-bottom: 0.375rem;
	border-bottom: #777 1px solid;
}


/*sp*/

.sp .p-listening_block{
	display:block;
}
.sp .p-listening_block__cover{
	flex: 0 0 auto;
	width: 120px;
	margin:0.875rem auto;
}
.sp .p-listening_block__txt{
	width: 100%;
}

.sp .p-youtube_link{
	display: block;
	padding: 0.875rem 0.875rem 1rem;
}
.sp .p-youtube_link__txt{
	width: 100%;
}
.sp .p-youtube_link__thumb{
	width: 240px;
	margin-right: 0;
	margin: 0.875rem auto 1rem;
}

/*202211*/
.p-photo_unit.color_1{
	background-color: #232E00;
}
.p-photo_unit.color_2{
	background-color: #A1666A;
}
.p-photo_unit.color_3{
	background-color: #D37C30;
}
.p-photo_unit.color_4{
	background-color: #B25435;
}
.p-photo_unit.color_5{
	background-color: #6A8671;
}
.p-photo_unit.color_6{
	background-color: #C78430;
}
.p-photo_unit.color_7{
	background-color: #3F5369;
}
.p-photo_unit.color_8{
	background-color: #BC9333;
}


/* sp ****************************/


.sp .p-rhythm_txt{
	padding: 0 0.5rem;
}

.sp #main h2.p-rhythm_title img{
	min-width: auto !important;
}

.sp #main h3.p-rhythm_heading{
	font-size: 1.125rem;
}