@charset "utf-8";

/*********** HEADER ***********/

header .menu-btn {
	position: fixed;
	top: 10px;
	right: 30px;
	z-index: 9999;
}
header .ft-btn {
	position: fixed;
	width: 185px;
	bottom: 15px;
	right: 15px;
	z-index: 9999;
}
header .x-btn {
	position: fixed;
	width: 20px;
	top: 50%;
	right: 25px;
	transform: translateY(-50%);
	z-index: 9999;
}


/*********** KV ***********/

#kv {
	position: relative;
	width: 100%;
	background: url("../images/top/kv_bg.jpg") no-repeat center bottom / cover;
	display: block;
	z-index: 999;
}
#kv > h1{
	position: absolute;
	width: 630px;
	top: 0;
	left: 0;
	right: 0;
	margin: auto;
}
#kv > .kv_illust {
	width: 95%;
	margin: auto;
	padding-top: 360px;
}


/*********** ABOUT ***********/

.about_box {
	width: 100%;
	position: relative;
}
.about_box .inner_M {
	position: relative;
	z-index: 10;
}
.about_box .txt_lead {
	text-align: center;
	font-size: 22px;
	font-weight: 600;
	line-height: 2.2;
	margin: 40px auto;
}
.about_box .txt_lead span {
	color: #1749bb;
}
.about_box .flow_box {
	margin: 100px auto 50px;
}
.about_box .flow_box img {
	margin-top: -40px;
}
.about_box .award_box ul li {
	width: 30%;
}
.about_box .award_box ul li img {
	margin-bottom: 1.0em;
}
.about_box .award_box ul li p {
	margin-bottom: 0.5em;
}
.about_box .outer_box {
	position:relative;
	z-index: 10;
}
.about_box .outer_box .flow_box,.about_box .outer_box .award_box {
	position:relative;
	z-index: 10;
}
.about_box .bg_element1 {
	position: absolute;
	width: 380px;
	height: auto;
	top: 200px;
	left: 0;
	z-index: 1;
}
.about_box .bg_element2 {
	position: absolute;
	width: 310px;
	height: auto;
	top: 50px;
	right: 0;
	z-index: 1;
}
.about_box .outer_box .bg_element3 {
	position:absolute;
	width: 320px;
	height: auto;
	top: 370px;
	rileft: 0;
	z-index: 1;
}
.about_box .outer_box .bg_element4  {
	position:absolute;
	width: 345px;
	height: auto;
	top: 150px;
	right: 0;
	z-index: 1;
}

/*********** PROGRAM ***********/

.program_box {
	width: 100%;
	padding: 0;
}
.program_box .bg_pattern {
	width: 100%;
	background: url("../images/top/bg_program.png") center;
	padding: 80px 0;
}
.program_box .txt_lead {
	text-align: center;
	font-size: 1.2rem;
	font-weight: 700;
	line-height: 2.0;
	margin: 40px auto 20px;
}
.program_box .video {
    position: relative;
    width: 100%;
    padding-top: 56.25%; /* 16:9のアスペクト比 */
    height: 0;
}

.program_box .video iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.program_box dl {
	border: 1px solid #000;
	border-radius: 3px;
	display: flex;
	text-align: center;
	font-size: 1.1rem;
	font-weight: 700;
	background-image: linear-gradient(90deg, #9bfcc2 0%, #f5f588 100%);
}
.program_box dl dt {
	width: 130px;
	background: #000;
	color: #FFF;
	padding: 0.2em 0;
}
.program_box dl dd {
	width: calc(100% - 150px);
	padding: 0.2em 0;
}

.program_box .cast_box {
	margin-top: 80px;
	text-align: center;
	position: relative;
}
.program_box .cast_box p {
	font-size: 1.2rem;
	font-weight: 700;
	margin: 1.0em 0;
}
.program_box .cast_box .border_box_bk {
	width: 100%;
	border: 2px solid #000;
	border-radius: 3px;
	box-sizing: border-box;
	background-image: linear-gradient(90deg, #fff9b1 0%, #fffbe3 100%);
	padding: 2.0em;
	margin-top: -50px;
}
.program_box .cast_box ul.col2_box {
	justify-content: center;
}
.program_box .cast_box ul.col2_box li {
	width: 50%;
}
.program_box .cast_box ul.col2_box li p span {
	font-size: 1.0rem;
	display: inline-block;
	background-image: linear-gradient(90deg, #9afcc2 0%, #f5f588 100%);
	padding: 0 0.2em;
	line-height: 1.3;
}
.program_box .cast_box .bg_element1 {
	position: absolute;
	width: 72px;
	height: auto;
	top: 120px;
	left: -70px;
	z-index: 1;
}
.program_box .cast_box .bg_element2 {
	position: absolute;
	width: 40px;
	height: auto;
	bottom: 0;
	right: -39px;
	z-index: 1;
}



/*********** UTAHIME ***********/

.utahime_box p a {
	color: #f75898;
}
.project_box {
	width: 100%;
	background: url("../images/top/bg_utahime.jpg") no-repeat center / 100%;
	padding-bottom: 50px;
}
.letter_box {
	width: 100%;
	background: url("../images/top/bg_letter.png") no-repeat center / 100%;
	margin-bottom: 100px;
}
.letter_box .sign {
	width: 180px;
	margin: 1.0em 0 0 auto;
}

.operation .f_logo {
	display: flex;
	justify-content: center;
}
.operation .f_logo div {
	margin: 30px;
}
.operation .f_logo div:first-child {
	width: 282px;
}
.operation .f_logo div:last-child {
	width: 185px;
}



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

/*********** HEADER ***********/

header .menu-btn {
	position: fixed;
	top: 5px;
	right: 15px;
	z-index: 9999;
}
header .ft-btn {
	position: fixed;
	width: 165px;
	bottom: 10px;
	right: 10px;
	z-index: 9999;
}
header .x-btn {
	position: fixed;
	width: 30px;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	z-index: 9999;
}
	
	
/*********** KV ***********/

#kv {
	position: relative;
	width: 100%;
	background: url("../images/top/kv_bg_sp.jpg") no-repeat center bottom / cover;
	display: block;
	z-index: 999;
}
#kv > h1{
	position: absolute;
	width: 60%;
	top: 20px;
	left: 0;
	right: 0;
	margin: auto;
}
#kv > .kv_illust {
	width: 100%;
	margin: auto;
	padding-top: 35%;
}
	
	
/*********** ABOUT ***********/

.about_box .txt_lead {
	text-align: center;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.8;
	margin: 20px auto;
}
.about_box .flow_box {
	margin: 50px auto;
}
.about_box .flow_box img {
	margin-top: 0;
}
.about_box .award_box ul li {
	width: 100%;
}
.about_box .bg_element1 {
	position: absolute;
	width: 100px;
	height: auto;
	top: 15%;
	left: -15px;
	z-index: 1;
}
.about_box .bg_element2 {
	position: absolute;
	width: 100px;
	height: auto;
	top: 25%;
	right: -10px;
	z-index: 1;
}
.about_box .outer_box .bg_element3 {
	position:absolute;
	width: 100px;
	height: auto;
	top: 200px;
	rileft: 0;
	z-index: 1;
}
.about_box .outer_box .bg_element4  {
	position:absolute;
	width: 100px;
	height: auto;
	top: 280px;
	right: -15px;
	z-index: 1;
}
	
	
/*********** PROGRAM ***********/
	
.program_box .bg_pattern {
	width: 100%;
	background: url("../images/top/bg_program_sp.png") center;
	padding: 20px 0 40px;
}
.program_box .txt_lead {
	text-align: center;
	font-size: 1.2rem;
	font-weight: 700;
	line-height: 2.0;
	margin: 20px auto;
}
.program_box dl {
	border: 1px solid #000;
	border-radius: 3px;
	display: block;
	text-align: center;
	font-size: 1.2rem;
	font-weight: 700;
	background-image: linear-gradient(90deg, #9bfcc2 0%, #f5f588 100%);
}
.program_box dl dt {
	width: 100%;
	background: #000;
	color: #FFF;
	padding: 0.2em 0;
	line-height: 1.3;
}
.program_box dl dd {
	width: 100%;
	padding: 0.2em 0;
}
.program_box .cast_box {
	margin-top: 50px;
	text-align: center;
	position: relative;
}
.program_box .cast_box p {
	font-size: 1.2rem;
	font-weight: 700;
	margin: 1.0em 0;
}
.program_box .cast_box .border_box_bk {
	width: 90%;
	border: 2px solid #000;
	border-radius: 3px;
	box-sizing: border-box;
	background-image: linear-gradient(90deg, #fff9b1 0%, #fffbe3 100%);
	padding: 2.0em;
	margin: -50px auto 0;
}
.program_box .cast_box ul.col2_box li {
	width: 100%;
	margin-top: -1em;
}
.program_box .cast_box .bg_element1 {
	position: absolute;
	width: 50px;
	height: auto;
	top: 80px;
	left: -30px;
	z-index: 1;
}
.program_box .cast_box .bg_element2 {
	position: absolute;
	width: 30px;
	height: auto;
	bottom: 0;
	right: -15px;
	z-index: 1;
}
	
	
/*********** UTAHIME ***********/

.project_box {
	width: 100%;
	background: url("../images/top/bg_utahime_sp.png") no-repeat top / 100%;
	padding-bottom: 50px;
}
.letter_box {
	width: 100%;
	background: url("../images/top/bg_letter_sp.png") no-repeat top left / 40%;
	margin-bottom: 50px;
}
.letter_box .sign {
	width: 150px;
	margin: 2.0em 0 0 auto;
}
	
/*********** FOOTER ***********/
	
footer .inner_M {
	border-top: 1px solid #adadad;
	padding: 65px 0 90px;
}

	
}


