/* --------------------------------------------

　　　　CSS  

-------------------------------------------- */
/* ++++++  共通部分  ++++++ */
:root {
  --mainFont: "Montserrat", "Murecho", 'Noto Sans JP', -apple-system, BlinkMacSystemFont, "Helvetica Neue", HelveticaNeue, "Segoe UI", "游ゴシック体", YuGothic, "Yu Gothic M", "游ゴシック Medium", "Yu Gothic Medium", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	--grCol:#468C00;
	--rdCol:#C1272D;
}

#evtWrap{
	width:100%; 
  max-width: 750px;
	margin:0 auto; 
	padding:0 0 10px 0; 
	font-size:1.8125rem; 
	line-height:1.3;
  font-family: var(--mainFont);
	color: #333333;
}
#evtWrap *, #evtWrap *::before, #evtWrap *::after {
	box-sizing: border-box;
}
#evtWrap img, footer img{
	border: none;
  width: 100%;
  height: auto;
	vertical-align: top;
}
#evtWrap a:hover img{
	filter: alpha(opacity=80); 
	-ms-filter: alpha(opacity=80); 
	opacity: 0.8;
}

#evtWrap h2,#evtWrap p, #evtWrap li, #evtWrap div, #evtWrap span, #evtWrap dl, #evtWrap dt, #evtWrap dd{font-family: var(--mainFont);} 

#evtWrap h1{
	width: 100%;
	margin: 0 auto;
	padding: 0;
	background: #B01C21;
}
/**  movie  **/
#evtWrap .movieArea{
	width: 100%;
	margin: 20px auto;
	padding: 0;
}
#evtWrap .movieArea video{
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding: 0;
}

#evtWrap h2{
	width: 100%;
	margin: 0 auto;
	padding: 1.5em 1% 0;
	color: var(--grCol);
	font-size: 200%;
	text-align: center;
	line-height: 1.2;
	font-weight: 900;
	background: url("../images/christmas_mvc2025/app_frame.png") no-repeat 0 0 / 100%;
}
#evtWrap h2 span{
	font-size: 73.77%;
}
#evtWrap .txt{
	font-size: 100%;
	text-align: center;
	width: 100%;
	padding: 0 1%;
	margin: 40px auto 0;
	font-weight: 500;
	line-height: 1.4;
}
#evtWrap .ouboTxt{
	font-size: 134.48%;
	text-align: center;
	width: 100%;
	font-weight: 700;
	padding: 0 1%;
	margin: 50px auto 0;
}
#evtWrap .ouboTxt span{
	font-size: 128.20%;
}
#evtWrap .ouboTxt span.ouboTitle{
	background: var(--rdCol);
	color: #fff;
	text-align: center;
	width: fit-content;
	font-size: 100%;
	display: inline-block;
	padding: 5px 10px;
	margin: 0 0 5px;
}

/**  スタンプ部分  **/
#evtWrap .stampArea{
	width: 90%;
	max-width: 600px;
	margin: 50px auto 0;
	padding: 1em 0;
	border: 5px solid #ccc;
}
#evtWrap .stampArea dl.stampList{
	width: fit-content;
	margin: 0 auto;
	padding: 0;
}
#evtWrap dl.stampList dt, #evtWrap dl.stampList dd{
	font-weight: 700;
	font-size: 120.689%;
	margin: 0;
	padding: 0;
	width: fit-content;
}
#evtWrap dl.stampList dd{
	padding-left: 1.25em;
	margin-bottom: 10px;
	letter-spacing: 0.025em;
}
#evtWrap dl.stampList dd span{
	font-weight: 900;
	font-size: 157.142%;
}
#evtWrap dl.stampList dt::before{
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: " \f559";
	font-size: 120%;
	margin-right: 0.25em;
}
#evtWrap dl.stampList dd:last-of-type{
	margin-bottom: 0;
}
#evtWrap dl.stampList dt:first-of-type::before{color: #D9A300;}
#evtWrap dl.stampList dt:nth-of-type(2)::before{color: #AAAAAA;}
#evtWrap dl.stampList dt:last-of-type::before{color: #774920;}

#evtWrap .btnBox{
	padding: 0;
	width: 86%;
	max-width: 640px;
	border-radius: 50px;
	margin: 30px auto 0;
	font-weight: 800;
	text-align: center;
	box-shadow: 0 4px 8px rgba(0,0,0,0.40);
	transition: 0.3s;
	line-height: 1.2;
}
#evtWrap .btnBox:hover{box-shadow: none;}
#evtWrap .btnBox a{
	color: #fff;
	text-decoration: none;
	display: block;
	padding: 10px 1%;
}
/**----- アイコンフォント使用 -----**/
#evtWrap .btnBox a:after{
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: " \f054";
}
#evtWrap .btnBox.entry{
	background: var(--grCol);
	font-size: 158.62%;
	margin-bottom: 30px;
}
#evtWrap .btnBox.down{
	background: var(--rdCol);
	font-size: 100%;
}

#evtWrap .attTxt{
	width: 86%;
	max-width: 640px;
	font-size: 90%;
	font-weight: 500;
	margin: 5px auto 0;
	padding: 0 0 0 1em;
	text-indent: -1em;
	line-height: 1.5;
}

#evtWrap .telTxt{
	width: 86%;
	max-width: 640px;
	font-size: 100%;
	font-weight: 500;
	margin: 50px auto 0;
	line-height: 1.4;
	text-align: center;
}
#evtWrap .telTxt span{
	display: inline-block;
	width: 100%;
}
#evtWrap .telTxt span:first-of-type{font-size: 127.58%;}
#evtWrap .telTxt span:last-of-type{
	font-size: 155.172%;
	font-weight: 600;
}
footer{
	width: 100%;
	max-width: 750px;
	margin: 50px auto 0;
	padding: 0 0 20px;
	text-align: center;
}
footer .logo{
	width: 61.2%;
	height: auto;
	margin-top: 15px;
}


@media only screen and (max-width: 767px) {
	#evtWrap{font-size: 1rem;}
	#evtWrap .movieArea{margin: 10px auto;}
	#evtWrap .ouboTxt{margin: 30px auto;}
}



