@charset "UTF-8";

/* ///////////////////
common
///////////////////*/
.triangle:before {
	content: "";
	border: 40px solid transparent;
	border-top: 40px solid #ffffff;
	height: 0;
	width: 0;
	display: inline-block;
	margin: 0 0 -24px;
}
.triangle_02:before {
	content: "";
	border: 40px solid transparent;
	border-top: 40px solid #F5F3F0;
	height: 0;
	width: 0;
	display: inline-block;
}
.order_btn{
	color: #ffffff;
	background: #E61E0F;
	border-radius: 11px;
	padding: 20px 0;
	margin: 8px auto;
	font-size: 1.2rem;
	line-height: 1;
	font-weight: 900;
	max-width: 400px;
	width: 100%;
	display: block;
	text-decoration: none;
	text-align: center;
}
.cp{
	color: #666666;
	font-size: 0.8rem;
	display: inline-block;
	font-weight: normal;
	line-height: 1.2;
	margin: 4px;
	text-align: left;
	vertical-align: middle;
}
.cp li{
	position: relative;
	padding: 0 0 2px 12px;
}
.cp li:before{
	content: "※";
	margin-left: -12px;
	position: absolute;
}
#eiga-gift{
	font-family: Helvetica, 'Lucida Grande', 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, Arial, sans-serif;
	text-align: center;
	background: #F5F3F0;
	min-width: 320px;
}
/* ///////////////////
main-title
///////////////////*/
.main-title{
	background: #FFC4BF;
	background-image: url("../images/background_sp_top.png") , url("../images/background_sp_bottom.png");
	background-repeat: repeat-x , repeat-x;
	background-position: top , bottom;
	background-size: 320px 50px;
	padding: 40px 24px;
}
.main-title h4{
	background: #fff;
	border-radius: 16px;
	box-shadow: 8px 8px 0px 0 rgb(43 45 66 / 10%);
	display:flex;
	flex-flow: column;
	font-size: 1rem;
    height: 100%;
    min-width: 240px;
	max-width: 400px;
    margin: 0 auto;
    line-height: 2.5rem;
	padding: 16px 0 24px;
	width: 100%;
}
.main-title h4 img{
    height: 80px;
	display: block;
	width: auto;
}
/* ///////////////////
read
///////////////////*/
.read{
	background: #fff;
	font-size: 1rem;
	padding: 24px 8px;
}
.explanation_title{
	width: auto;
	height: auto;
	font-size: 1.6rem;
	margin: 0 0 24px;
}
.read_attention{
	align-items: center;
	color: #E61E0E;
	display: flex;
	font-size: 1.1rem;
    font-weight: 900;
	margin: 0 0 8px;
    line-height: 1;
	justify-content: center;
	white-space: nowrap;
}
.read_attention:before,
.read_attention:after{
	border-top: 4px solid #E61E0E;
	content: " ";
	display: inline-block;
	height: 1px;
	margin: 0 8px;
	width: 24px;
}
/* ///////////////////
explanation
///////////////////*/
.explanation{
	padding: 0 16px 40px;
}
.explanation_inner{
	max-width: 1000px;
	margin: 0 auto 24px;
}
.explanation-inner_title{
	margin: 0;
    line-height: 2rem;
	font-size: 1.5rem;
}
.explanation_card{
	background: #ffffff;
	border-radius: 16px;
	margin: 0 auto 24px;
	max-width: 600px;
	position: relative;
	padding: 32px 8px;
}
.explanation_card a{
	font-size: 1.1rem;
	margin-top: 8px;
	display: inline-block;
}
.explanation_card img{
	margin: 0 0 24px;
	height: 160px;
	width: auto;
}
.explanation_card strong{
	display: inline-block;
	font-size: 1.5rem;
	font-weight: 900;
}
.explanation_text{
	font-size: 1.1rem;
	margin: 16px 0 0;
}
div.cp{
	margin: 16px 0 0;
}
.explanation__price{
	margin: 16px 0 0;
}
.explanation_card a{
	margin-top: 16px;
}
.explanation__price+.cp{
	margin: 0;
	display: block;
	text-align: center;
}
.explanation__price li{
	display: inline-block;
	padding: 0 8px;
}
.explanation__price li span{
	color: #E61E0F;
	font-size: 2.6rem;
    line-height: 2.5rem;
	font-weight: 900;
}
.explanation__price li span.explanation__en{
	font-size: 1.5rem;
}

/* ///////////////////
scene
///////////////////*/
.scene{
	background: #fff;
	font-size: 1rem;
	margin: 0;
	padding: 0 16px 40px;
}
.scene_inner{
	margin: -40px auto 0;
	max-width: 1000px;
}
.scene_title{
	font-size: 1.6rem;
    line-height: 2rem;
	font-weight: 900;
	margin: 16px 0;
}
.scene_title span{
	display: inline-block;
}

.scene_list{
	max-width: 600px;
	margin: 0 auto;
}
.scene_list li{
	background-color: #F5F3F0;
	border-radius: 16px;
	margin: 16px auto 0;
	padding: 16px;
}
.scene_list li span{
	display: inline-block;
}
.scene_img{
	background-color: #fff;
    width: 120px;
    height: 120px;
    border-radius: 50%;
	margin: 0 auto;
	line-height: 100px;
}
.scene_list dl dt{
	font-size: 1.5rem;
    line-height: 2rem;
	font-weight: 900;
	margin-top: 10px;
	position: relative;
}
.scene_list dl dt::after {
	content: '';
	display: block;
	max-width: 40px;
	height: 6px;
	margin: 8px auto;
	background-color: #E61E0F;
}
.scene_list dl dd{
	line-height: 1.5;
	font-size: 1.1rem;
}
/* ///////////////////
reason
////////////////// */
.reason{
	padding: 0 16px 40px;
}
.reason_inner{
	background-color: #fff;
	border-radius: 16px;
	margin: 0 auto;
	max-width: 600px;
}
.reason_title{
	border-bottom: 4px #666 dotted;
	padding: 24px 8px;
}
.reason_title h5{
	font-size: 2.0rem;
    line-height: 2rem;
	font-weight: 900;
	position: relative;
}
.reason_title h5:after {
	background-color: #F0786E;
	content: '';
	display: block;
	height: 6px;
	margin: 16px auto;
	width: 80px;
}
.reason_txt{
	font-size: 1.1rem;
	display: block;
	margin: 0 0 1px;
	padding: 0 0 16px;
}
.reason_txt span{
	display: inline-block;
}
.reason_txt_st{
	font-size: 3.2rem;
}
.reason_txt_st , .reason_txt_red{
	color: #E61E0E;
}
.reason_list{
	display: inline-block;
	padding: 24px 0;
	position: relative;
	max-width: 400px;
	margin: 0 auto;
}
.reason_list li{
	font-size: 1.3rem;
	line-height: 1.5;
	text-align: left;
	font-weight: 900;
	padding: 0 0 0 40px;
	margin: 16px 0 0;
	display: flex;
	align-items: center;
	height: 48px;
	width: 100%;
}
.reason_list li:nth-child(1){
	background:  url("../images/reason_1_number.svg") left center no-repeat;
	background-size: auto 32px;
}
.reason_list li:nth-child(2){
	background:  url("../images/reason_2_number.svg") left center no-repeat;
	background-size: auto 32px;
}
.reason_list li:nth-child(3){
	background:  url("../images/reason_3_number.svg") left center no-repeat;
	background-size: auto 32px;
}
.reason_list li:nth-child(4){
	background:  url("../images/reason_4_number.svg") left center no-repeat;
	background-size: auto 32px;
}
.reason_list li img{
	margin: 0 0 0 8px;
}
.reason_list li div{
	padding-top: 16px;
}
.reason_list li .cp{
	margin: -24px 0 0;
}

/* ///////////////////
order-flow
////////////////// */
.order-flow{
	background-color: #fff;
	padding: 40px 16px;
}
.order-flow_title{
	margin: 0 auto;
	max-width: 600px;
}
.order-flow_title p{
	background-color: #333333;
	border-radius: 100px;
	color: #ffffff;
	font-size: 1.3rem;
	font-weight: 900;
	line-height: 1;
	padding: 12px 8px;
}
.order-flow_title:after {
	border: 16px solid transparent;
	border-top: 16px solid #333;
	content: "";
	display: inline-block;
	height: 0;
	margin: 0 auto;
	width: 0;
}
.order-flow_list{
	margin: -16px auto 0;
	max-width: 600px;
}
.order-flow_list > li:nth-child(n+2):before {
	content: "";
	background: url("../images/flow_arrow.svg") no-repeat center;
	background-size: contain;
	display: block;
	height: 28px;
	width: auto;
}
.order-flow-inner{
	border-radius: 16px;
	display: flex;
	flex-direction: column;
	font-size: 1.3rem;
	font-weight: 900;
	line-height: 1;
	text-align: left;
	padding: 12px 8px 8px 8px;
}
.order-flow_customer .order-flow-inner{
	border: solid #999999 2px;	
}
.order-flow_mw .order-flow-inner{
	border: solid #E61E0E 2px;
	color: #E61E0E;
}
.order-flow-inner img{
	height: 40px;
	margin: -4px 8px 0;
	vertical-align: middle;
	width: auto;
}
.order-flow-number{
	display: inline-flex;
	align-items: center;
	flex: 1 1 auto;
	line-height: 1.2;
    vertical-align: middle;
}
.order-flow-inner .cp{
	flex: 1 1 auto;
}

/* ///////////////////
gift-flow
////////////////// */
.gift-flow{
	background-color: #fff;
	padding: 40px 16px;	
}
.gift-flow_title{
	margin: 0 auto;
	max-width: 600px;
}
.gift-flow_title p{
	background-color: #333333;
	border-radius: 100px;
	color: #ffffff;
	font-size: 1.3rem;
	font-weight: 900;
	line-height: 1;
	padding: 12px 8px;
}
.gift-flow_title p span{
	display: inline-block;
}
.gift-flow_title:after {
	border: 16px solid transparent;
	border-top: 16px solid #333;
	content: "";
	display: inline-block;
	height: 0;
	margin: 0 auto;
	width: 0;
}
.gift-flow_list{
	margin: -16px auto 0;
	max-width: 600px;
}
.gift-flow_list > li:nth-child(n+2):before {
	content: "";
	background: url("../images/flow_arrow.svg") no-repeat center;
	background-size: contain;
	display: block;
	height: 28px;
	width: auto;
}
.gift-flow-inner{
	border: solid #999999 2px;	
	border-radius: 16px;
	font-size: 1.1rem;
	text-align: left;
	padding: 0px 8px 16px;
}
.gift-flow-inner img{
	display: block;
	margin: 8px auto 0;
	max-width: 320px;
}
.gift-flow-number{
	display: flex;
	align-items: center;
	line-height: 2;
    vertical-align: middle;
	flex: 1 1 auto;
}
.gift-flow-number img{
	height: 40px;
	margin: -4px 12px 0 8px;
	vertical-align: middle;
	width: auto;
}
.gift-flow-number p{
	margin: 12px 0;
}
.gift-flow-number p strong{
	display: block;
	font-size: 1.3rem;
	font-weight: 900;
	line-height: 1.2;
	margin: 8px 0;
}
.gift-flow-number br{
	display: none;
}	
.gift-flow-number strong span{
	color: #E61E0F;
}
/* ///////////////////
gift-faq
////////////////// */
.gift-faq{
	padding: 40px 16px;
}
.gift-faq_inner{
	margin: 0 auto;
	max-width: 600px;
}
.gift-faq-title{
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.5rem;
}
.gift-faq-title::before,
.gift-faq-title::after{
	content: "";
	height: 3px;
	width: 3px;
	background: #333;
	flex: 1 1 1px;
	display: block;
	margin: 0 8px;
}
/* .gift-faq-list{
	padding: 8px;
} */
.gift-faq-list dt{
	display:block;
	font-size: 1.1rem;
	line-height:1.2;
	text-align:left;
	cursor:pointer;
	background: #fff url("../images/faq_open.svg") 98% center no-repeat;
	margin: 8px 0 0;
	border-radius: 16px;
	padding: 24px 40px 24px 48px;
	font-weight: 900;
	position: relative;
}
.gift-faq-list dt span{
	line-height: 0.1;
    font-size: 1.8rem;
    vertical-align: middle;
    position: absolute;
    left: 12px;
    top: 0;
    bottom: 0;
    margin: auto;
    height: 1px;
}
.gift-faq-list dd{
	background: #fff;
	border-radius: 0 0 16px 16px;
	line-height:1.6;
	text-align:left;
	display:none;
	margin: -12px 0 0;
	padding: 8px 24px;
	position: relative;
	font-size: .8rem;
}
.gift-faq-list dd .cp{
	display: block;

}
.gift-faq-list dt.active{
	background: #fff url("../images/faq_close.svg") 98% center no-repeat;
}
/* ///////////////////
gift-tickets
////////////////// */
.gift-tickets{
	background: #F5F3F0;
	padding: 0 8px 40px;
}
.gift-tickets a img{
	width: 100%;
	height: auto;
	border: #999999 1px solid;
	max-width: 400px;
}
/* .gift-tickets .order_btn{
	background-color: #E61E0F;
} */

/* ///////////////////
float-button
////////////////// */
.float-button{
	background: rgba(255, 255, 255, 60%);
	padding: 0 16px;
	position: fixed;
	left: 0;
	right: 0;
	margin: 0 auto;
	bottom: 0;
	z-index: 99;
}
.float-button .order_btn{
	border: #fff 3px solid;
    margin: 8px auto;
    padding: 16px 0;
	max-width: 920px;
}



@media screen and (min-width:320px) {
    /*　画面サイズが320pxからはここを読み込む　*/

}
@media screen and (min-width:521px) and ( max-width:768px) {
    /*　画面サイズが521pxから768pxまではここを読み込む　*/
	.main-title{
		background: #FFC4BF url("../images/background_pc.png") center top;
		background-repeat: repeat;
		background-size: 240px;
		padding: 24px 0;
	}
	.explanation_text span{
		display: inline-block;
	}
	.reason_list li{
		font-size: 1.5rem;
	}
}
@media screen and (min-width:769px) {
    /*　画面サイズが769pxからはここを読み込む　*/
	.triangle:before {
		border: 60px solid transparent;
		border-top: 60px solid #ffffff;
		margin: 0 0 -40px;
	}
	.triangle_02:before {
		border: 60px solid transparent;
		border-top: 60px solid #F5F3F0;
	}
	.order_btn {
		font-size: 1.5rem;
		padding: 24px 0;
	}
	.main-title{
		background: #FFC4BF url("../images/background_pc.png") center top;
		background-repeat: repeat;
		background-size: 240px;
		padding: 24px 0;
	}
	.main-title h4{
		font-size: 1.1rem;
		padding: 18px 0 26px;
	}
	.main-title h4 img{
		height: 100px;
		margin: 8px auto 0;
	}
	.explanation_inner{
		display: flex;
		flex-direction: row;
		justify-content: center;
		align-items: stretch;
	}
	.read_attention{
		font-size: 1.5rem;
	}
	.read{
		font-size: 1.1rem;
	}
	.explanation_title p span.explanation_readtxt{
		font-size: 1.1rem;
	}
	.explanation_inner{
	    margin: 0 auto 24px;	
	}
	.explanation_card{
		flex: 1 1 50%;
		margin: 0 8px;
		padding: 32px 0;
	}
	.explanation_batch{
		width: 108px;
		height: 108px;
		font-size: 1.5rem;
		left: 12px;
		top: 40px;
	}
	.explanation_title strong{
		font-size: 2rem;
	}
	.explanation_card img{
		height: 160px;
	}
	.explanation__price{
		margin: 16px 0 0;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.explanation__price li{
		color: #E61E0F;
		font-size: 2.6rem;
		font-weight: 900;
	}
	.explanation_text span{
		display: inline-block;
	}	
	.scene{
		padding: 0 16px 60px;
	}
	.scene_inner{
		margin: -60px auto 0;
	}
	.scene_title span{
		font-size: 2rem;
	}
	.scene_list{
		display: flex;
		flex-direction: row;
		justify-content: center;
		align-items: stretch;
		max-width: 1000px;
	}
	.scene_list li{
		flex: 1 1 25%;
		margin: 0 8px;
	}
	.reason {
		padding: 0 16px 60px;
	}
	.reason_inner{
		display: flex;
		flex-direction: row;
		margin: 0 auto;
		max-width: 768px;
		padding: 0;
		align-items: center;
	}
	.reason_title{
		padding: 24px;
		border-bottom: none;
		flex: 1 1 auto;
	}
	.reason_txt{
		line-height: 1;
	}
	.reason_txt_st{
		font-size: 3.8rem;
		margin: 0 0 16px;
	}
	.reason_title-icon{
		height: 92px;
	}
	.reason_list{
		border-left: 4px #666 dotted;
		padding: 8px 16px 16px 40px;
		flex: 0 0 auto;
	}
	.reason_list li{
		font-size: 1.6rem;
		background-size: auto 52px , 52px;
		margin: 16px 0 0;
	}
	.reason_list li:nth-child(1),
	.reason_list li:nth-child(2),
	.reason_list li:nth-child(3),
	.reason_list li:nth-child(4){
		background-size: 32px auto;
	}
	.reason_list li img{
		margin: 0 8px;
		height: auto;
		width: 52px;
	}
	.order-flow_list{
		max-width: 768px;
	}
	.order-flow{
		padding: 60px 16px;
	}
	.order-flow_title p{
		font-size: 2rem;
		padding: 16px 0;
	}
	.order-flow-inner{
		font-size: 2rem;
		display: flex;
		flex-direction: row;
		padding: 16px 0 16px 16px;
	}
	.order-flow-inner img{
		margin: -2px 12px 0 0;
	}
	.order-flow_mw .order-flow-inner{
		margin: 0 0 0 52px;
	}
	.order-flow-number{
		margin-right: 16px;
	}
	.gift-flow_list{
		max-width: 768px;
	}
	.gift-flow_title p{
		font-size: 2rem;
		padding: 16px 0;
	}
	.gift-flow-number{
		line-height: 1.2;
		flex: 0 0 50%;
		margin: 0 40px 0 0;
	}
	.gift-flow-number br{
		display: block;
	}
	.gift-flow-inner{
		display: flex;
		flex-direction: row;
		align-items: center;
		padding: 16px 8px;
	}
	.float-button{
		padding: 8px;
	}
	.gift-flow-number p strong{
		font-size: 2rem;
	}
	.gift-faq_inner{
		max-width: 768px;
	}
	.gift-faq-list dt{
		font-size: 1.5rem;
	}
}
/* CSS Document */

   /*　パンくず　*/
.breadcrumbs{
background-color:#FFF;
}

.breadcrumbs ul{
    padding: 12px 20px 13px;
    font-size: 14px;
    max-width: 1200px;
    text-decoration: none;
    line-height: 18px;
    margin: 0 auto;
}

.breadcrumbs ul li{
display: inline; 
margin: 0 5px 5px 0;
}

.breadcrumbs ul li a{
text-decoration:none;
}