@charset "utf-8";

/*
	/tv/kuramotoso/css/style.css
	-----------------------------------
	v1.0
	Last Updated: 2020-03-09
	Copyright: CBC TELEVISION CO.,LTD. All rights Reserved.
	-----------------------------------
	[Updated]
	v1.0		2020-03-09
	-----------------------------------

基本設定
ソーシャルボタン
ヘッダー
フッター
コンテンツ


*/

/* ***********************************************************

		基本設定

*********************************************************** */
html {
	/*font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, 'メイリオ', 'ＭＳ Ｐゴシック', 'MS PGothic', Verdana, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	/*-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;*/
}
body {
	/*font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, 'メイリオ', 'ＭＳ Ｐゴシック', 'MS PGothic', Verdana, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	/*-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;*/
	/*background: #000;*/
	color: #fff;
}
@media only screen and (max-width: 640px) {
	html, body {
		/*background: #000 url(../images/bg.png) repeat 182px 0;
		background-size: 1000px auto;*/
		overflow-x:initial !important;
	}
}
@media print, screen and (min-width: 641px) {
	body {
		/*background: #000 url(../images/bg.png) repeat center 0;*/
		min-width: 980px;
	}
}

/*フォントの滲みの修正＠EdgeとFirefox*/
/*
.kuramotoso p,
.kuramotoso h3 {
	transform: rotate(0.001deg);
}
*/


/*デフォルトリンクカラー*/
a, a:link {
	color: #0000DE;
}
a:visited {
	color: #941D55;
}
a:active,
a:hover {
	color: #CC0000;
}
a:focus {
	color: #CC0000;
}

.clearfix:after {
	content: "";
	display: block;
	clear: both;
}

/* FireFox リンク選択時の点線を消す */
a:link,
a:visited,
a:active,
a:hover {
	overflow: hidden;
	outline: none;
}


/*画像の横幅*/
img {
	width: 100%;
	height: auto;
	vertical-align: middle;
}
.img-max {
	width: 100%;
	height: auto;
	vertical-align: middle;
}
@media only screen and (max-width: 640px) {
	.img-max-sp {
		width: 100%;
		height: auto;
		vertical-align: middle;
	}
}

@media print, screen and (min-width: 641px) {
	.img-max-pc {
		width: 100%;
		height: auto;
		vertical-align: middle;
	}
}

figure {
	padding: 0;
	margin: 0;
}

/* -----------------------------------------------------

	非表示設定

----------------------------------------------------- */
@media only screen and (max-width: 640px) {
	.hide-sp {
		display: none !important;
	}
	#global-nav:nth-of-type(1) {
		display: none;
	}
}

@media print, screen and (min-width: 641px) {
	.hide-pc {
		display: none !important;
	}
}
.hide-text {
	font-size: 0;
	line-height: 0;
	text-indent: -9999px;
	list-style-type: none;
	height: 0;
	overflow: hidden;
}

/* ***********************************************************

		ソーシャルボタン

*********************************************************** */
/*CBC用GナビとSNSボタンの上部固定*/
#global-nav {
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 9999;
}
#sns-block {
	position: absolute;
	top: 52px;
	left: 0;
	z-index: 9999;
}
@media only screen and (max-width: 640px) {
	#sns-block {
		top: 15.625vw;
	}
}

@media print, screen and (min-width: 641px) {
	#global-nav,
	#sns-block {
		min-width: 980px;
	}
}

/**/



#sns-block {
	width: 100%;
	background: #fff;
	padding-bottom: .75em;
}
.sns {
	width: 96%;
	padding-top: .75em;
	margin: 0 auto;
	text-align: center;
}
.ttl-sns {
	display: inline-block;
	vertical-align: top;
	margin-right: 1em;
	color: #000;
	font-size: .9em;
}
.ttl-sns i {
	padding-right: .1em;
}
.sns-list {
	display: inline-block;
}
.sns-list li {
	display: inline-block;
	position: relative;
}
.sns-list li img {
	width: 42px;
	height: auto;
	vertical-align: middle;
}
@media screen and (min-width: 40em) {
	.sns {
		width: 980px;
	}
	.sns-list li img {
		width: 26px;
		height: auto;
		vertical-align: middle;
	}
}
@media screen and (min-width: 64em) {
}


/* ***********************************************************

	block

*********************************************************** */
.kuramotoso .block {
  width: 100%;
  min-height: 100vh;
  /*display: flex;
  align-items: center;
  justify-content: center;*/
  position: -webkit-sticky;
  position: sticky;
  top: 0;
}
@media only screen and (max-width: 640px) {
	.kuramotoso .block {
		display: flex;
		align-items: center;
		justify-content: center;
	}
}
@media print, screen and (min-width: 641px) {
	.kuramotoso .block {
		min-width: 980px;
	}
}

/*alpha-block*/
.kuramotoso .alpha-block {
	/*background-color: #F00;
	opacity: 0.5;*/
}
@media only screen and (max-width: 640px) {
	.kuramotoso .alpha-block {
		/*width: 100%;*/
		width: 1px;
		min-height: 50vh;
		display: flex;
		align-items: center;
		justify-content: center;
	}
}
@media print, screen and (min-width: 641px) {
	.kuramotoso .alpha-block {
		/*width: 100%;*/
		width: 1px;
		min-height: 100vh;
		position: -webkit-sticky;
		position: sticky;
		top: 0;
		/*min-width: 980px;*/
	}
}




/* ***********************************************************

	ヘッダー

*********************************************************** */
@media only screen and (max-width: 640px) {
	.kuramotoso .header {
		background: url(../images/sp/header.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .header figure.logo {
	}
	.kuramotoso .header p {
		font-size: 23px;
		font-weight: 600;
		line-height: 36px;
		width: 100vw;
		margin: 0;
		padding: 0 0 10vw 6.25vw;
	}
}
@media print, screen and (min-width: 641px) {
	.kuramotoso .header {
		background: url(../images/pc/header.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .header figure.logo {
		display: none;
	}
	.kuramotoso .header-inner {
		width: 980px;
		min-height: 100vh;
		margin: auto;
		padding: 0 20px;
		position: relative;
	}
	.kuramotoso .header p {
		font-size: 44px;
		font-weight: 600;
		line-height: 70px;
		padding-top: 60vh;
	}
}
.kuramotoso .header h1 {
	font-size: 0;
	line-height: 0;
	text-indent: -9999px;
	list-style-type: none;
	height: 0;
	overflow: hidden;
}



/*scrollbtn＠全て共通*/
@media only screen and (max-width: 640px) {
	.kuramotoso figure.btn {
		width: 30px;
		/*margin: 8vw 0 0 calc(6.25vw + 56px);*/
		position: absolute;
		bottom: 4.61095100864553vh;
		left: calc(50% - 15px);
	}
	.kuramotoso header figure.btn {
		position: relative;
		bottom: auto;
		left: calc(6.25vw + 70px);
		padding: 0 0 13vw 0;
	}
}
@media print, screen and (min-width: 641px) {
	.kuramotoso figure.btn {
		width: 36px;
		position: absolute;
		bottom: 3vh;
		left: calc(50% - 18px);
	}
}





/* ***********************************************************

	フッター

*********************************************************** */
/*フッター枠*/
@media only screen and (max-width: 640px) {
	.kuramotoso .footer {
		padding:50px 15px 50px;
	}
	.kuramotoso .footer p {
		line-height:1.5;
	}
}
@media print, screen and (min-width: 641px) {
	.kuramotoso .footer {
		width: 980px;
		margin:auto;
		padding: 50px 0;
	}
	.kuramotoso .footer p {
		text-align: center;
	}
}
.kuramotoso .footer p {
	font-size: 12px;
	text-align: center;
}
.kuramotoso .footer p a,
.kuramotoso .footer p a:link,
.kuramotoso .footer p a:visited {
	color: #fff;
	text-decoration: none;
}
.kuramotoso .footer p a:active,
.kuramotoso .footer p a:hover {
	color: #fff;
	text-decoration: underline;
}
.kuramotoso .footer p a:focus {
	color: #fff;
}

/*ページアップ*/
.kuramotoso .pageup a {
	display: block;
	background: url('../images/pageup.png') no-repeat 0 0 ;
	-moz-background-size:100% auto;
	background-size:100% auto;
	font-size: 0px;
	line-height: 0px;
	text-indent: -9999px;
	text-decoration: none;
	position: fixed;
}
@media only screen and (max-width: 640px) {
	.kuramotoso .pageup a {
		width: 64px;
		height:64px;
		right: 12px;
		bottom: 10px;
	}
}
@media print, screen and (min-width: 641px) {
	.kuramotoso .pageup a {
		width: 76px;
		height: 76px;
		right: 20px;
		bottom: 30px;
		transition: 0.3s ease-in-out;
	}
	.kuramotoso .pageup a:hover {
		opacity: 0.7;
	}
}





/* ***********************************************************

	コンテンツ

*********************************************************** */

/*box01*/
.kuramotoso .box01-slide {
	background: #000;
	height: 100vh;
	overflow: hidden;
}
@media only screen and (max-width: 640px) {
	.kuramotoso .box01-slide div {
		width: 100vw;
		height: 100vh;
	}
	.kuramotoso .box01-slide01 {
		background: url(../images/sp/box01-01.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box01-slide02 {
		background: url(../images/sp/box01-02.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box01-slide03 {
		background: url(../images/sp/box01-03.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box01-slide04 {
		background: url(../images/sp/box01-04.jpg) no-repeat center 0;
		background-size: cover;
	}

	.kuramotoso .box01-inner {
		width: 100vw;
		height: 100vh;
		overflow: hidden;
		margin: auto;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.kuramotoso .box01-inner h2 {
		font-size: 12px;
		border-left: 1px solid #fff;
		padding: 21px 0 40px 13px;
		margin: 0 0 0 6.25vw;
	}
	.kuramotoso .box01-inner p {
		font-size: 20px;
		line-height: 50px;
		padding: 0 0 0 13px;
		margin: -25px 0 0 6.25vw;
	}
}
@media print, screen and (min-width: 641px) {
	.kuramotoso .box01-slide div {
		width: 100%;
		height: 100vh;
	}
	.kuramotoso .box01-slide01 {
		background: url(../images/pc/box01-01.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box01-slide02 {
		background: url(../images/pc/box01-02.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box01-slide03 {
		background: url(../images/pc/box01-03.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box01-slide04 {
		background: url(../images/pc/box01-04.jpg) no-repeat center 0;
		background-size: cover;
	}


	.kuramotoso .box01-inner {
		width: 980px;
		height: 100vh;
		overflow: hidden;
		margin: auto;
		padding: 0 20px;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.kuramotoso .box01-inner h2 {
		font-size: 24px;
		border-left: 1px solid #fff;
		padding: 42px 0 80px 30px;
		margin: 0 0 0 370px;
	}
	.kuramotoso .box01-inner p {
		font-size: 30px;
		line-height: 90px;
		padding: 0 0 0 31px;
		margin: -48px 0 0 370px;
	}
}






/*box02*/
.kuramotoso .box02-slide {
	background: #000;
	height: 100vh;
	overflow: hidden;
}
@media only screen and (max-width: 640px) {
	.kuramotoso .box02-slide div {
		width: 100vw;
		height: 100vh;
	}
	.kuramotoso .box02-slide01 {
		background: url(../images/sp/box02-01.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box02-slide02 {
		background: url(../images/sp/box02-02.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box02-slide03 {
		background: url(../images/sp/box02-03.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box02-slide04 {
		background: url(../images/sp/box02-04.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box02-inner {
		width: 100vw;
		height: 100vh;
		overflow: hidden;
		margin: auto;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.kuramotoso .box02-inner2 {
		margin: -50px 0 0;
	}






	.kuramotoso .box02-inner .box02-line {
		background: #fff;
		width: 1px;
		height: 78px;
		margin: 0 0 0 6.25vw;
	}
	.kuramotoso .box02-inner p {
		font-size: 3.75vw;
		line-height: 2.5;
		padding: 0 6.25vw;
		margin: -50px 0 0 4.0625vw;
	}
}
@media print, screen and (min-width: 641px) {
	.kuramotoso .box02-slide div {
		width: 100%;
		height: 100vh;
	}
	.kuramotoso .box02-slide01 {
		background: url(../images/pc/box02-01.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box02-slide02 {
		background: url(../images/pc/box02-02.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box02-slide03 {
		background: url(../images/pc/box02-03.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box02-slide04 {
		background: url(../images/pc/box02-04.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box02-inner {
		width: 980px;
		height: 100vh;
		overflow: hidden;
		margin: auto;
		padding: 0 20px;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.kuramotoso .box02-inner .box02-line {
		background: #fff;
		width: 1px;
		height: 158px;
		margin: 0 0 0 33px;
	}
	.kuramotoso .box02-inner p {
		font-size: 20px;
		line-height: 60px;
		padding: 0 0 0 31px;
		margin: -78px 0 0 62px;
	}
}







/*box03*/
@media only screen and (max-width: 640px) {
	.kuramotoso .box03 {
		background: url(../images/sp/box03.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box03-inner .column-l h2 {
		font-size: 30px;
		font-weight: 400;
		text-align: center;
		margin: 0 0 6px;
	}
	.kuramotoso .box03-inner .column-l .box03-line {
		background: #fff;
		width: 102px;
		height: 1px;
		margin: 0 auto 30px;
	}
	.kuramotoso .box03-inner .column-r figure {
		width: 70vw;
		margin: auto;
	}
}
@media print, screen and (min-width: 641px) {
	.kuramotoso .box03 {
		background: url(../images/pc/box03.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box03-inner {
		width: 980px;
		height: 100vh;
		overflow: hidden;
		margin: auto;
		padding: 0 20px;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		display: flex;
		align-items: center;
		justify-content: space-between;
	}
	.kuramotoso .box03-inner .column-l h2 {
		font-size: 60px;
		font-weight: 400;
		margin: 400px 0 14px 94px;
	}
	.kuramotoso .box03-inner .column-l .box03-line {
		background: #fff;
		width: 204px;
		height: 1px;
		margin: 0 0 0 38px;
	}
	.kuramotoso .box03-inner .column-r {
		width: 448px;
		height: 593px;
	}
	.kuramotoso .box03-inner .column-r figure {
		width: 448px;
		margin: 40px 0 0 0;
	}
}






/*box04*/
.kuramotoso .box04 {
	background: #dad9d4;
	color: #000;
}

@media only screen and (max-width: 640px) {
	.kuramotoso .box04-line {
		background: #000;
		width: 1px;
		height: 30px;
		margin: 0 auto 4px;
	}
	.kuramotoso .box04-inner h2 {
		font-size: 30px;
		font-weight: 400;
		text-align: center;
		margin: 0 0 18px;
	}
	.kuramotoso .box04-inner2 figure {
		/*width: 78.125vw;*/
		width: 80vw;
		margin: 0 auto 12px;
	}
	.kuramotoso .box04-inner2 figure figcaption {
		text-align: right;
		margin: 6px auto 0;
	}
	.kuramotoso .box04-inner p {
		font-size: 16px;
		text-align: center;
		margin: 0 0 12px;
	}
}

@media print, screen and (min-width: 641px) {
	.kuramotoso .box04-inner {
		text-align: center;
		width: 980px;
		height: 100vh;
		overflow: hidden;
		margin: auto;
		padding: 0 20px;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		display:-ms-flexbox;
		display: flex;
		-ms-flex-align: center;
		align-items: center;
		-ms-flex-pack: center;
		justify-content: center;
	}
	.kuramotoso .box04-inner2 {
	}
	.kuramotoso .box04-line {
		background: #000;
		width: 1px;
		height: 59px;
		margin: 0px auto 6px;
	}
	.kuramotoso .box04-inner h2 {
		font-size: 26px;
		font-weight: 400;
		margin: 0 0 37px;
	}
	.kuramotoso .box04-inner2 figure {
		width: 500px;
		margin: 24px auto;
	}
	.kuramotoso .box04-inner2 figure figcaption {
		text-align: right;
		margin: 6px auto 0;
	}
	.kuramotoso .box04-inner p {
		font-size: 20px;
	}
}






/*box05*/
@media only screen and (max-width: 640px) {
	.kuramotoso .box05 {
		background: url(../images/sp/box05.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box05-inner {
		width: 87.5vw;
		margin: auto;
	}
	.kuramotoso .box05-inner h2 {
		font-size: 20px;
		font-weight: 400;
		text-align: center;
		margin: 0 0 26px;
		padding: 12.5vw 0 0;
	}
	.kuramotoso .gallery-box {
		/*display: flex;
		flex-wrap:wrap;
		justify-content: space-between;*/
	}
	.kuramotoso .gallery-box figure {
		/*flex-basis: 40.625vw;*/
		float: left;
		width: 40.625vw;
		margin: 0 0 20px;
	}
	.kuramotoso .gallery-box figure:nth-of-type(2n) {
		float: right;
	}

}
@media print, screen and (min-width: 641px) {
	.kuramotoso .box05 {
		background: url(../images/pc/box05.jpg) no-repeat center 0;
		background-size: cover;
	}
	.kuramotoso .box05-inner {
		width: 980px;
		min-height: 100vh;
		margin: auto;
		padding: 0 20px;
		/*position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;*/
		display:-ms-flexbox;
		display: flex;
		-ms-flex-align: center;
		align-items: center;
		-ms-flex-pack: center;
		justify-content: center;
	}
	.kuramotoso .box05-inner h2 {
		font-size: 30px;
		font-weight: 400;
		text-align: center;
		margin: 0 0 44px;
		padding: 80px 0 0;
	}
	.kuramotoso .gallery-box {
		width: 940px;
		margin: auto;
		/*display:-ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap:wrap;
		-ms-flex-pack: justify;
		justify-content: space-between;*/
	}
	.kuramotoso .gallery-box figure {
		/*-ms-flex-preferred-size: 216px;
		flex-basis: 216px;*/
		float: left;
		width: 216px;
		margin: 0 25px 27px 0;
	}
	.kuramotoso .gallery-box figure:nth-of-type(4n) {
		margin-right: 0;
	}
}




/*マージンの調整*/
@media only screen and (max-width: 640px) {
}
@media print, screen and (min-width: 641px) {
	.kuramotoso .arasuji-box .mt01 {
		margin-top: 14px;
	}
	.kuramotoso .arasuji-box .mb0 {
		margin-bottom: 0;
	}
	.kuramotoso .arasuji-box .mb01 {
		margin-bottom: 25px;
	}
	.kuramotoso .arasuji-box .mb02 {
		margin-bottom: 35px;
	}
	.kuramotoso .arasuji-box .mb03 {
		margin-bottom: 16px;
	}
}
