@charset "utf-8";

/* 基礎レイアウト・プリセットスタイル
========================================================= */

img { width: 100%; height: auto; vertical-align: top; }
.anchorMargin { padding-top: 110px; margin-top: -110px; }

@media screen and (max-width: 1000px) {
	.anchorMargin { padding-top: 80px; margin-top: -80px; }
}

@media screen and (max-width: 767px) {
	.anchorMargin { padding-top: 60px; margin-top: -60px; }
}

#festival2025 {
	color: #000000;
	font-family: "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", sans-serif;
	line-height: 1;
	font-feature-settings: "palt" 1;
	font-weight: 500;
}





/* インデックス
========================================================= */

#festival2025 .idxInfo { padding: 30px calc(20/320 * 100%); }
#festival2025 .idxInfo a {
	width: 100%;
	max-width: 1400px;
	display: block;
	border: solid 3px #eb3933;
	text-decoration: none;
	box-sizing: border-box;
	padding: 1em 2em;
	margin: 0 auto;
}
#festival2025 .idxInfo a p {
	display: table;
	font-size: 20px;
	line-height: 1.5;
	font-weight: 700;
	margin: 0 auto;
}
#festival2025 .idxInfo a:hover { background-color: #eb3933; color: #ffffff; transition: 0.2s;}

#festival2025 .idxMain { width: 100%; max-width: 1400px; margin: 0 auto; position: relative; }
#festival2025 .idxMain img:nth-child(2) { display: none; }

#festival2025 .idxMain .anchLink a {
	width: calc(230/1400 * 100%);
	display: block;
	border-radius: 20px 20px 0 0;
	background-color: #000000;
	color: #ffffff;
	font-size: 18px;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
	padding: calc(16/1400 * 100%) 0 26px 0;
	position: absolute;
	right: calc(150/1400 * 100%);
	bottom: 0;
}
#festival2025 .idxMain .anchLink a:after {
	content: "";
	width: 10px;
	height: 10px;
	border-right: solid 2px #ffffff;
	border-bottom: solid 2px #ffffff;
	transform: rotate(45deg);
	position: absolute;
	right: 0;
	bottom: 12px;
	left: 0;
	margin: auto;
}
#festival2025 .idxMain .anchLink a:hover { background-color: #ffffff; color: #000000; transition: 0.3s; }
#festival2025 .idxMain .anchLink a:hover:after {
	border-right: solid 2px #000000;
	border-bottom: solid 2px #000000;
	transition: 0.3s;
}

#festival2025 .idxMain .traffic a {
	width: calc(160/1400 * 100%);
	display: block;
	border-radius: 115px;
	border: solid 5px #cedb00;
	background-color: #ffffff;
	padding: calc(160/1400 * 100%) 0 0 0;
	position: absolute;
	left: calc(120/1400 * 100%);
	bottom: calc(70/1400 * 100%);
}
#festival2025 .idxMain .traffic a p {
	width: 100%;
	color: #000000;
	font-size: 24px;
	line-height: 1.2;
	font-weight: 700;
	text-align: center;
	transform: translateY(-40%);
	position: absolute;
	top: 50%;
}

#festival2025 .idxMain .traffic a:hover { background-color: #cedb00; transition: 0.3s; }
#festival2025 .idxMain .traffic a:hover p { color: #ffffff; transition: 0.3s; }

#festival2025 .idxPageLink { width: 100%; max-width: 1400px; margin: 0 auto; }
#festival2025 .idxPageLink ul {
	width: 100%;
	max-width: 1400px;
	min-height: 280px; 
	background: #e7ecec;
	box-sizing: border-box;
	padding: 25px calc(20/320 * 100%);
	margin: 6px 0 0 0;
}
#festival2025 .idxPageLink ul li { width: 100%; max-width: 720px; margin: 0 auto; }
#festival2025 .idxPageLink ul li img:nth-child(2) { display: none; }
#festival2025 .idxPageLink ul li div { width: 100%; display: table; margin: 10px 0 0 0; }
#festival2025 .idxPageLink ul li div div:nth-child(1) {
	width: calc(500/720 * 100%);
	float: left;
	font-size: 17px;
	line-height: 1.8;
}
#festival2025 .idxPageLink ul li div div:nth-child(2) {
	width: calc(175/720 * 100%);
	float: right;
	margin: 10px 5px 0 0;
}
#festival2025 .idxPageLink ul li div div:nth-child(2) a {
	width: 100%;
	height: 70px;
	display: block;
	border: solid 1px #000000;
	border-radius: 16px;
	position: relative;
}
#festival2025 .idxPageLink ul li div div:nth-child(2) a p {
	width: 100%;
	font-size: 15px;
	text-align: center;
	font-weight: 700;
	transform: translate(-50%, -50%);
	position: absolute;
	top: 50%;
	left: 50%;
}
#festival2025 .idxPageLink ul li div div:nth-child(2) a:after {
	content: "";
	width: 5px;
	height: 8px;
	display: block;
	background-color: #000000;
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	transform: translateY(-50%);
	position: absolute;
	top: 50%;
	right: 13%;
}
#festival2025 .idxPageLink ul li div div:nth-child(2) a + p {
	font-size: 14px;
	text-align: center;
	padding: 10px 0 0 0;
}
#festival2025 .idxPageLink ul li div div:nth-child(2) a:hover { background-color: #000000; transition: 0.3s; }
#festival2025 .idxPageLink ul li div div:nth-child(2) a:hover p { color: #ffffff; transition: 0.3s; }
#festival2025 .idxPageLink ul li div div:nth-child(2) a:hover:after { background-color: #ffffff; transition: 0.3s; }

#festival2025 .idxLead { width: 100%; box-sizing: border-box; padding: 0 calc(20/320 * 100%); margin: 70px 0; }
#festival2025 .idxLead p:nth-child(1) { font-size: 28px; line-height: 1.2; font-weight: 700; text-align: center; }
#festival2025 .idxLead p:nth-child(2) {
	font-size: 18px;
	font-weight: 700;
	line-height: 1.7;
	text-align: center;
	padding: 10px 0 0 0;
}

#festival2025 .idxPageLink ul li div div:nth-child(2) div {
	width: 100%;
	height: 70px;
	display: block;
	border: solid 1px #000000;
	border-radius: 16px;
	position: relative;
}
#festival2025 .idxPageLink ul li div div:nth-child(2) div p {
	width: 100%;
	font-size: 15px;
	text-align: center;
	font-weight: 700;
	transform: translate(-50%, -50%);
	position: absolute;
	top: 50%;
	left: 50%;
}

#festival2025 .idxLead p span { display: inline-block; }



@media screen and (max-width: 1400px) {
	#festival2025 .idxMain .anchLink a  { font-size: 1.3vw; }
	#festival2025 .idxMain .traffic a p { font-size: 1.7vw; }
	#festival2025 .idxPageLink ul li div div:nth-child(2) a p { font-size: 14px; }
	#festival2025 .idxPageLink ul li div div:nth-child(2) a + p { font-size: 12px; }
	#festival2025 .idxPageLink ul li div div:nth-child(2) div p { font-size: 14px; }
}
@media screen and (max-width: 640px) {
	#festival2025 .idxMain img:nth-child(1) { display: none; }
	#festival2025 .idxMain img:nth-child(2) { display: block; }
	
	#festival2025 .idxMain .anchLink a {
		width: 135px;
		border-radius: 12px 12px 0 0;
		font-size: 13px;
		padding: 10px 0 20px 0;
		right: 15px;
	}
	#festival2025 .idxMain .anchLink a:after { width: 8px; height: 8px; bottom: 8px; }
	
	#festival2025 .idxMain .traffic a {
		width: 135px;
		border-radius: 12px 12px 0 0;
		border: none;
		background-color: #cedb00;
		padding: 10px 0 20px 0;
		left: 15px;
		bottom: 0;
	}
	#festival2025 .idxMain .traffic a p {
		color: #000000;
		font-size: 13px;
		line-height: 1;
		transform: none;
		position: static;
	}
	#festival2025 .idxMain .traffic a p br { display: none; }
	
	#festival2025 .idxPageLink ul {
		max-width: 1400px;
		min-height: 280px; 
		padding: 25px calc(20/320 * 100%);
		margin: 5px 0 0 0;
	}
	#festival2025 .idxPageLink ul li { max-width: 570px; }
	#festival2025 .idxPageLink ul li img:nth-child(1) { display: none; }
	#festival2025 .idxPageLink ul li img:nth-child(2) { display: block; }
	#festival2025 .idxPageLink ul li div { margin: 5px 0 0 0; }
	#festival2025 .idxPageLink ul li div div:nth-child(1) {
		width: 100%;
		float: none;
		font-size: 14px;
		line-height: 1.5;
	}
	#festival2025 .idxPageLink ul li div div:nth-child(1) br { display: none; }
	#festival2025 .idxPageLink ul li div div:nth-child(2) {
		width: 100%;
		max-width: 570px;
		float: none;
		margin: 15px auto 0;
	}
	#festival2025 .idxPageLink ul li div div:nth-child(2) a { height: 40px; border-radius: 8px; }
	#festival2025 .idxPageLink ul li div div:nth-child(2) a p { font-size: 15px; }
	#festival2025 .idxPageLink ul li div div:nth-child(2) div { height: 40px; border-radius: 8px; }
	#festival2025 .idxPageLink ul li div div:nth-child(2) div p { font-size: 15px; }
	
	#festival2025 .idxLead { margin: 30px 0; }
	#festival2025 .idxLead p:nth-child(1) { font-size: 20px; }
	#festival2025 .idxLead p:nth-child(2) { font-size: 14px; line-height: 1.5; text-align: left; }
	#festival2025 .idxLead p br { display: none; }
}



/* idxEvent
--------------------------------------------------------- */

#festival2025 .idxEvent { width: 100%; max-width: 1400px; margin: 0 auto; }

#festival2025 .idxEvent .title {
	width: 100%;
	max-width: 1400px;
	box-sizing: border-box;
	padding: 0 calc(20/320 * 100%);
	margin: 0 auto 0;
}
#festival2025 .idxEvent .title.green { background-image: linear-gradient(#ffffff 36%, #c3d700 36%); }
#festival2025 .idxEvent .title.blue { background-image: linear-gradient(#c3d700 36%, #00af95 36%); }
#festival2025 .idxEvent .title.pink { background-image: linear-gradient(#00af95 36%, #e3007f 36%); }
#festival2025 .idxEvent .title h2 { width: calc(850/1225 * 100%); max-width: 850px; margin: 0 auto; }
#festival2025 .idxEvent .title h2:nth-child(2) { display: none; }

#festival2025 .idxEvent .special {
	background-color: #c3d700;
	box-sizing: border-box;
	padding: 35px calc(20/320 * 100%) 120px;
	margin: 0 auto;
}
#festival2025 .idxEvent .collabo {
	background-color: #00af95;
	box-sizing: border-box;
	padding: 35px calc(20/320 * 100%) 120px;
	margin: 0 auto;
}
#festival2025 .idxEvent .limited {
	background-color: #e3007f;
	box-sizing: border-box;
	padding: 35px calc(20/320 * 100%) 100px;
	margin: 0 auto;
}

#festival2025 .idxEvent .contents {
	width: 100%;
	max-width: 1100px;
	border-radius: 50px;
	background-color: #ffffff;
	box-sizing: border-box;
	padding: 50px calc(70/1225 * 100%) 40px;
	margin: 0 auto;
}

#festival2025 .idxEvent .contents h3 { width: 100%; max-width: 960px; margin: 0 auto; }
#festival2025 .idxEvent .contents h3 img:nth-child(2) { display: none; }
#festival2025 .idxEvent .contents h3 span {
	display: block;
	font-size: 18px;
	line-height: 1.7;
	text-align: center;
	margin: 20px auto 50px;
}
#festival2025 .idxEvent .contents h3 .info a {
	display: block;
	color: #1399d1;
	font-size: 20px;
	line-height: 1.5;
	font-weight: 700;
	text-align: center;
	margin: 50px auto 0;
}

#festival2025 .idxEvent .contents ul {
	width: 100%;
	max-width: 960px;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	margin: 0 auto;
}
#festival2025 .idxEvent .contents ul li { width: calc(440/960 * 100%); max-width: 440px; }
#festival2025 .idxEvent .contents ul li:nth-child(2n + 1) { margin: 70px 0 0 0; }
#festival2025 .idxEvent .contents ul li:nth-child(2n) { margin: 70px 0 0 calc(80/960 * 100%); }
#festival2025 .idxEvent .contents ul li:nth-child(1) { margin: 0; }
#festival2025 .idxEvent .contents ul li:nth-child(2) { margin: 0 0 0 calc(80/960 * 100%); }
#festival2025 .idxEvent .contents ul li img.num { width: 30px; display: block; margin: 0 auto 20px; }
#festival2025 .idxEvent .contents ul li img + div { padding: calc(260/440 * 100%) 0 0 0; position: relative; }
#festival2025 .idxEvent .contents ul li img + div img { position: absolute; top: 0; bottom: 0; margin: auto; }
#festival2025 .idxEvent .contents ul li dl { margin: 15px auto 0; }
#festival2025 .idxEvent .contents ul li dl dt {
	background-color: #000000;
	color: #ffffff;
	font-size: 18px;
	line-height: 1.3;
	font-weight: 700;
	text-align: center;
	padding: 3px 0.5em;
}
#festival2025 .idxEvent .contents ul li dl dt span { display: inline-block; }
#festival2025 .idxEvent .contents ul li dl dt + dd {
	border-bottom: solid 1px;
	font-size: 18px;
	line-height: 1.3;
	font-weight: 700;
	text-align: center;
	padding: 10px 0;
}
#festival2025 .idxEvent .contents ul li dl dt + dd .small {
	font-size: 12px;
	font-weight: 500;
	padding: 0.5em 0 0 0;
}
#festival2025 .idxEvent .contents ul li dl dt + dd span { display: inline-block; }
#festival2025 .idxEvent .contents ul li dl dd + dd { font-size: 16px; line-height: 1.6; margin: 20px 0 0 0; }
#festival2025 .idxEvent .contents ul li dl dd + dd .small {
	font-size: 13px;
	text-indent: -1em;
	padding: 0 0 0 1em;
}
#festival2025 .idxEvent .contents ul li dl dd + dd .list { margin: 0.5em 0 0 0; }
#festival2025 .idxEvent .contents ul li dl dd + dd table { border-spacing: 0; margin: 0.5em 0 0 0; }
#festival2025 .idxEvent .contents ul li dl dd + dd table th { font-weight: 500; white-space: nowrap; }
#festival2025 .idxEvent .special .contents ul li dl dd + dd span { color: #c3d700; }
#festival2025 .idxEvent .collabo .contents ul li dl dd + dd span { color: #00af95 }
#festival2025 .idxEvent .special .contents ul li dl dd + dd a { color: #abb912; }

#festival2025 .idxMap { width: 100%; box-sizing: border-box; padding: 0 calc(20/320 * 100%); margin: 120px auto 0; }
#festival2025 #googlemap_area { width: 100%; max-width: 1086px; margin: 0 auto 10px; }
#festival2025 .idxMap p {
	width: 100%;
	max-width: 1086px;
	font-size: 17px;
	line-height: 1.5;
	margin: 0 auto;
}
#festival2025 .idxMap p span { display: inline-block; text-indent: -1em; padding: 0 0 0 1em; margin: 0 1em 0 0; }



@media screen and (max-width: 767px) {
	#festival2025 .idxInfo { padding: 15px calc(20/320 * 100%); }
	#festival2025 .idxInfo a { border: solid 2px #eb3933; padding: 1em; }
	#festival2025 .idxInfo a p { font-size: 15px; }
}

@media screen and (max-width: 640px) {
	#festival2025 .idxEvent .title.blue { background-image: linear-gradient(#c3d700 20%, #00af95 20%); }
	#festival2025 .idxEvent .title.pink { background-image: linear-gradient(#00af95 20%, #e3007f 20%); }
	#festival2025 .idxEvent .title h2 { width: 100%; max-width: 640px; }
	#festival2025 .idxEvent .title h2:nth-child(1) { display: none; }
	#festival2025 .idxEvent .title h2:nth-child(2) { display: block; }
	#festival2025 .idxEvent .title h2 span {
		display: table;
		color: #ffffff;
		font-size: 14px;
		line-height: 1.5;
		text-align: center;
		margin: 10px auto 0;
	}
	
	#festival2025 .idxEvent .special { padding: 20px calc(20/320 * 100%) 60px; }
	#festival2025 .idxEvent .collabo { padding: 20px calc(20/320 * 100%) 60px; }
	#festival2025 .idxEvent .limited { padding: 20px calc(20/320 * 100%) 30px; }
	
	#festival2025 .idxEvent .contents { border-radius: 20px; padding: 20px calc(70/1225 * 100%) 30px; }
	
	#festival2025 .idxEvent .contents h3 { max-width: 540px; }
	#festival2025 .idxEvent .contents h3 img:nth-child(1) { display: none; }
	#festival2025 .idxEvent .contents h3 img:nth-child(2) { display: block; }
	#festival2025 .idxEvent .contents h3 span { font-size: 14px; line-height: 1.5; margin: 10px auto 20px; }
	#festival2025 .idxEvent .contents h3 .info a {
		font-size: 16px;
		line-height: 1.5;
		text-align: left;
		margin: 20px auto 0;
	}
	#festival2025 .idxEvent .contents h3 .info a br { display: none; }
	
	#festival2025 .idxEvent .contents ul { max-width: 440px; flex-direction: column; }
	#festival2025 .idxEvent .contents ul li { width: 100%; }
	#festival2025 .idxEvent .contents ul li:nth-child(2n + 1) { margin: 50px 0 0 0; }
	#festival2025 .idxEvent .contents ul li:nth-child(2n) { margin: 50px 0 0 0; }
	#festival2025 .idxEvent .contents ul li:nth-child(1) { margin: 0; }
	#festival2025 .idxEvent .contents ul li:nth-child(2) { margin: 50px 0 0 0; }
	#festival2025 .idxEvent .contents ul li img.num { width: 24px; margin: 0 auto 12px; }
	#festival2025 .idxEvent .contents ul li img + div { padding: 0; }
	#festival2025 .idxEvent .contents ul li img + div img { position: static; }
	#festival2025 .idxEvent .contents ul li dl { margin: 10px auto 0; }
	#festival2025 .idxEvent .contents ul li dl dt { font-size: 16px; }
	#festival2025 .idxEvent .contents ul li dl dt + dd { font-size: 16px; }
	#festival2025 .idxEvent .contents ul li dl dd + dd { font-size: 14px; margin: 10px 0 0 0; }
	#festival2025 .idxEvent .contents ul li dl dd + dd .small { font-size: 12px; }
	
	#festival2025 .idxMap { margin: 60px auto 0; }
}



/* idxBottom
--------------------------------------------------------- */

#festival2025 .idxBottom {
	width: 100%;
	max-width: 1400px;
	box-sizing: border-box;
	padding: 0 calc(20/320 * 100%);
	margin: 0 auto;
}

#festival2025 .idxBottom h2 { font-size: 30px; font-weight: 700; text-align: center; }

#festival2025 .idxBottom .sponsor {
	width: 100%;
	max-width: 1120px;
	margin: calc(150/1225 * 100%) auto 0;
	position: relative;
}
#festival2025 .idxBottom .sponsor div { display: flex; flex-direction: row; flex-wrap: wrap; }
#festival2025 .idxBottom .sponsor div img { width: calc(220/1120 * 100%); margin: 30px 0 0 calc(80/1120 * 100%); }
#festival2025 .idxBottom .sponsor div img:nth-child(4n + 1) { margin: 30px 0 0 0; }
#festival2025 .idxBottom .sponsor p { font-size: 14px; position: absolute; right: 15px; bottom: 5px; }

#festival2025 .idxBottom .sponsor2 {
	width: 100%;
	max-width: 1120px;
	display: table;
	margin: calc(150/1225 * 100%) auto 0;
}
#festival2025 .idxBottom .sponsor2 div {
	width: calc(520/1120 * 100%);
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	margin: 0 auto;
}
#festival2025 .idxBottom .sponsor2 div img { width: calc(220/520 * 100%); }
#festival2025 .idxBottom .sponsor2 div img:nth-child(1) { margin: 30px 0 0 0; }
#festival2025 .idxBottom .sponsor2 div img:nth-child(2) { margin: 30px 0 0 calc(80/520 * 100%); }

#festival2025 .idxBottom .outline { width: 100%; max-width: 1100px; margin: calc(150/1225 * 100%) auto; }
#festival2025 .idxBottom .outline table {
	width: 100%;
	border-bottom: solid 1px #b3b3b3;
	border-collapse: collapse;
	border-spacing: 0;
	font-size: 16px;
	line-height: 1.5;
	font-feature-settings: "palt" 1;
	margin: 40px 0 0 0;
}
#festival2025 .idxBottom .outline table th {
	width: calc(180/1100 * 100%);
	border-top: solid 1px #b3b3b3;
	font-weight: 700;
	text-align: center;
	white-space: nowrap;
	box-sizing: border-box;
	padding: 1.1em 1em;
}
#festival2025 .idxBottom .outline table td { border-top: solid 1px #b3b3b3; padding: 1.1em 1em; }
#festival2025 .idxBottom .outline table td.event { width: calc(290/1100 * 100%); white-space: nowrap; }
#festival2025 .idxBottom .outline table td.taR { text-align: right; padding: 0.5em 0.5em 3em 0; }
#festival2025 .idxBottom .outline table td span { display: inline-block; }



@media screen and (max-width: 1000px) {
	#festival2025 .idxBottom .outline table { font-size: 1.6vw; }
}

@media screen and (max-width: 767px) {
	#festival2025 .idxBottom h2 { font-size: 20px; }
	
	#festival2025 .idxBottom .sponsor { margin: 60px auto 0; }
	#festival2025 .idxBottom .sponsor div { margin: 0; }
	#festival2025 .idxBottom .sponsor div img { margin: 20px 0 0 calc(70/1110 * 100%); }
	#festival2025 .idxBottom .sponsor div img:nth-child(4n + 1) { margin: 20px 0 0 0; }
	#festival2025 .idxBottom .sponsor p { font-size: 12px; }
	
	#festival2025 .idxBottom .sponsor2 { margin: 60px auto 0; }
	#festival2025 .idxBottom .sponsor2 div { width: calc(520/1110 * 100%); margin: 0 auto; }
	#festival2025 .idxBottom .sponsor2 div img:nth-child(1) { margin: 20px 0 0 0; }
	#festival2025 .idxBottom .sponsor2 div img:nth-child(2) { margin: 20px 0 0 calc(70/520 * 100%); }
	
	#festival2025 .idxBottom .outline { margin: 60px auto; }
	#festival2025 .idxBottom .outline table {
		border-bottom: solid 1px #cccccc;
		font-size: 14px;
		margin: 20px 0 0 0;
	}
	#festival2025 .idxBottom .outline table th {
		width: auto;
		border-top: solid 1px #cccccc;
		font-weight: 700;
		padding: 0.5em 1.5em 0.5em 0;
	}
	#festival2025 .idxBottom .outline table td { border-top: solid 1px #cccccc; padding: 0.5em 0; }
	#festival2025 .idxBottom .outline table td.event {
		width: auto;
		display: block;
		font-weight: 700;
		padding: 0.5em 0 0 0;
	}
	#festival2025 .idxBottom .outline table td + td { display: block; border-top: none; padding: 0 0 0.5em 0; }
	#festival2025 .idxBottom .outline table td.taR {
		font-size: 12px;
		text-align: right;
		padding: 0.5em 0 2em 0; 
	}
}

@media screen and (max-width: 640px) {
	#festival2025 .idxBottom .sponsor div img { width: 32%; margin: 20px 0 0 2%; }
	#festival2025 .idxBottom .sponsor div img:nth-child(4n + 1) { margin: 20px 0 0 2%; }
	#festival2025 .idxBottom .sponsor div img:nth-child(3n + 1) { margin: 20px 0 0 0; }
	
	#festival2025 .idxBottom .sponsor2 div { width: 66%; }
	#festival2025 .idxBottom .sponsor2 div img { width: 48.5%; }
	#festival2025 .idxBottom .sponsor2 div img:nth-child(1) { margin: 20px 0 0 0; }
	#festival2025 .idxBottom .sponsor2 div img:nth-child(2) { margin: 20px 0 0 3%; }
}





/* スマイルステージ
============================================================================================================ */

#festival2025 .smileWrap {
	width: 100%;
	max-width: 1400px;
	box-sizing: border-box;
	padding: 0 calc(20/320 * 100%);
}

#festival2025 .smileMain {
	width: 100%;
	max-width: 1400px;
	background-image: url(/images/festival/2025/smile_main_bg.gif);
	background-size: 100%;
	background-repeat: no-repeat;
	background-position: center top;
	margin: 0 auto;
}

#festival2025 .smileNav {
	width: 100%;
	max-width: 1065px;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	padding: calc(30/1225 * 100%) 0 0 0;
	margin: 0 auto;
}
#festival2025 .smileNav a {
	width: calc(240/1065 * 100%);
	display: block;
	border-radius: 25px;
	background: #000000;
	color: #828282;
	font-size: 20px;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
	padding: 15px 0;
	position: relative;
}
#festival2025 .smileNav a + a { margin: 0 0 0 calc(35/1065 * 100%); }
#festival2025 .smileNav a.blank:after {
	content: "";
	width: 12px;
	height: 10px;
	display: block;
	background-image: url(/images/festival/2025/icon_blank.gif);
	background-repeat: no-repeat;
	background-size: cover;
	position: absolute;
	top: 50%;
	right: calc(20/240 * 100%);
	transform: translateY(-50%);
	opacity: 0.5;
}
#festival2025 .smileNav a.visit { color: #cedb00; }
#festival2025 .smileNav a:hover { color: #ffffff; }
#festival2025 .smileNav a.blank:hover:after { opacity: 1; }

#festival2025 .smileBottom { width: 100%; max-width: 1400px; padding: 170px 0 70px 0; margin: 0 auto; }
#festival2025 .smileBottom p { width: 100%; max-width: 450px; margin: 0 auto 60px; }



#festival2025 .smileMain .title h2 {
	width: calc(720/1225 * 100%);
	max-width: 570px;
	padding: calc(75/1225 * 100%) 0 0 0;
	margin: 0 auto;
}
#festival2025 .smileMain .title h2 img:nth-child(2) { display: none; }

#festival2025 .smileMain .info a {
	width: calc(570/1225 * 100%);
	display: table;
	color: #1399d1;
	font-size: 20px;
	line-height: 1.8;
	font-weight: 700;
	text-align: center;
	font-feature-settings: "palt" 1;
	margin: calc(50/1370 * 100%) auto 0;
}
#festival2025 .smileMain .close {
	display: table;
	color: #ed0000;
	font-size: 20px;
	line-height: 1.5;
	font-weight: 700;
	text-align: center;
	font-feature-settings: "palt" 1;
	margin: calc(50/1370 * 100%) auto 0;
}

#festival2025 .smileMain .lead {
	font-size: 18px;
	line-height: 1.8;
	text-align: center;
	margin: calc(50/1225 * 100%) auto 0;
}

#festival2025 .smileMain .schedule {
	width: 100%;
	max-width: 1400px;
	position: relative;
	box-sizing: border-box;
	padding: 0 calc(20/320 * 100%);
}
#festival2025 .smileMain .schedule div {
	width: calc(720/1225 * 100%);
	max-width: 720px;
	margin: calc(60/1225 * 100%) auto 0;
}



#festival2025 .smileContents { width: 100%; max-width: 1400px; margin: 0 auto; }
#festival2025 .smileContents .performer {
	font-size: 26px;
	font-weight: 700;
	text-align: center;
	padding: calc(110/1225 * 100%) 0 0 0;
}

#festival2025 .smileContents .contentsList {
	width: 100%;
	box-sizing: border-box;
	padding: 0 calc(20/320 * 100%);
	position: relative;
}
#festival2025 .smileContents .contentsList.style1 { margin: calc(100/1400 * 100%) 0 0 0; }
#festival2025 .smileContents .contentsList.style2,
#festival2025 .smileContents .contentsList.style3,
#festival2025 .smileContents .contentsList.style4,
#festival2025 .smileContents .contentsList.style5,
#festival2025 .smileContents .contentsList.style6,
#festival2025 .smileContents .contentsList.style7 { margin: calc(160/1400 * 100%) 0 0 0; }
#festival2025 .smileContents .contentsList .bg,
#festival2025 .smileContents .contentsList .bg1,
#festival2025 .smileContents .contentsList .bg2 {
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-size: 100%;
	position: absolute;
}
#festival2025 .smileContents .contentsList.style1 .bg {
	background-image: url(/images/festival/2025/smile_style1_bg.png);
	background-position: left top;
	padding: calc(180/1400 * 100%) 0 0 0;
	bottom: 0;
	left: 0;
}
#festival2025 .smileContents .contentsList.style2 .bg {
	background-image: url(/images/festival/2025/smile_style2_bg.png);
	background-position: left bottom;
	padding: 0 0 calc(90/1400 * 100%) 0;
	top: 0;
	left: 0;
}
#festival2025 .smileContents .contentsList.style4 .bg {
	background-image: url(/images/festival/2025/smile_style4_bg.png);
	background-position: left top;
	padding: calc(190/1400 * 100%) 0 0 0;
	bottom: 0;
	left: 0;
}
#festival2025 .smileContents .contentsList.style5 .bg1 {
	background-image: url(/images/festival/2025/smile_style5_bg1.png);
	background-position: left top;
	padding: calc(140/1400 * 100%) 0 0 0;
	bottom: 0;
	left: 0;
}
#festival2025 .smileContents .contentsList.style5 .bg2 {
	background-image: url(/images/festival/2025/smile_style5_bg2.png);
	background-position: left bottom;
	padding: 0 0 calc(100/1400 * 100%) 0;
	top: 0;
	left: 0;
}
#festival2025 .smileContents .contentsList.style6 .bg {
	background-image: url(/images/festival/2025/smile_style6_bg.png);
	background-position: left bottom;
	padding: 0;
	top: 0;
	left: 0;
}
#festival2025 .smileContents .contentsList.style7 .bg {
	background-image: url(/images/festival/2025/smile_style7_bg.png);
	background-position: left top;
	padding: calc(90/1400 * 100%) 0 0 0;
	bottom: 0;
	left: 0;
}

#festival2025 .smileContents .contentsList section {
	width: 100%;
	max-width: 720px;
	margin: 0 auto;
	position: relative;
}
#festival2025 .smileContents .contentsList section ul li .text {
	font-size: 18px;
	line-height: 1.8;
	text-shadow: 1px 1px 0 #ffffff, -1px 1px 0 #ffffff, -1px -1px 0 #ffffff, 1px -1px 0 #ffffff;
}
#festival2025 .smileContents .contentsList section ul li .cap {
	font-size: 13px;
	line-height: 1.5;
	text-align: center;
	margin: 5px 0 0 0;
}
#festival2025 .smileContents .contentsList section ul li.flL { float: left; }
#festival2025 .smileContents .contentsList section ul li.flR { float: right; }
#festival2025 .smileContents .contentsList section ul li.w260 { width: calc(260/720 * 100%); }
#festival2025 .smileContents .contentsList section ul li.w430 { width: calc(430/720 * 100%); }
#festival2025 .smileContents .contentsList section ul li.w240 { width: calc(240/720 * 100%); }
#festival2025 .smileContents .contentsList section ul li.w450 { width: calc(450/720 * 100%); }
#festival2025 .smileContents .contentsList section ul li.w330 { width: calc(330/720 * 100%); }
#festival2025 .smileContents .contentsList section ul li.w360 { width: calc(360/720 * 100%); }

#festival2025 .smileContents .contentsList.style1 section .title { width: 100%; display: table; }
#festival2025 .smileContents .contentsList.style1 section .title p { width: 76px; float: left; padding: 8px 0; }
#festival2025 .smileContents .contentsList.style1 section .title h3 {
	width: 100%;
	max-width: 380px;
	float: left;
	margin: 0 0 0 70px;
}
#festival2025 .smileContents .contentsList.style1 section ul { width: 100%; display: table; margin: 40px 0 0 0; }

#festival2025 .smileContents .contentsList.style2 section > p { width: 76px; }
#festival2025 .smileContents .contentsList.style2 section + section > p { margin: 0 0 0 calc(270/720 * 100%); }
#festival2025 .smileContents .contentsList.style2 section ul { display: table; margin: 20px 0 0 0; }
#festival2025 .smileContents .contentsList.style2 section + section { margin: 55px auto 0; }
#festival2025 .smileContents .contentsList.style2 section ul li h3 {
	width: 100%;
	max-width: 440px;
	margin: 0 0 20px 0;
}

#festival2025 .smileContents .contentsList.style3 section > p { width: 162px; }
#festival2025 .smileContents .contentsList.style3 section ul { display: table; margin: 20px 0 0 0; }
#festival2025 .smileContents .contentsList.style3 section ul li h3 {
	width: 100%;
	max-width: 195px;
	margin: 0 0 20px 0;
}
#festival2025 .smileContents .contentsList.style3 section ul li .img { display: none; }

#festival2025 .smileContents .contentsList.style4 section > p { width: 76px; margin: 0 0 0 calc(360/720 * 100%); }
#festival2025 .smileContents .contentsList.style4 section ul { display: table; margin: 20px 0 0 0; }
#festival2025 .smileContents .contentsList.style4 section ul + ul { margin: 50px 0 0 0; }
#festival2025 .smileContents .contentsList.style4 section ul li h3 {
	width: 100%;
	max-width: 300px;
	margin: 0 0 20px 0;
}

#festival2025 .smileContents .contentsList.style5 section > p { width: 162px; }
#festival2025 .smileContents .contentsList.style5 section h3 {
	width: 100%;
	max-width: 470px;
	margin: 20px 0 0 0;
}
#festival2025 .smileContents .contentsList.style5 section ul { display: table; margin: 20px 0 0 0; }
#festival2025 .smileContents .contentsList.style5 section ul li + li { margin: 25px 0 0 0; }

#festival2025 .smileContents .contentsList.style6 section > p { width: 76px; }
#festival2025 .smileContents .contentsList.style6 section h3 {
	width: 100%;
	max-width: 420px;
	margin: 20px 0 0 0;
}
#festival2025 .smileContents .contentsList.style6 section ul { display: table; margin: 20px 0 0 0; }
#festival2025 .smileContents .contentsList.style6 section ul li + li {
	width: 100%;
	max-width: 590px;
	margin: 20px auto 0;
}

#festival2025 .smileContents .contentsList.style7 section > p { width: 76px; margin: 0 0 0 calc(270/720 * 100%); }
#festival2025 .smileContents .contentsList.style7 section ul { display: table; margin: 20px 0 0 0; }
#festival2025 .smileContents .contentsList.style7 section ul li h3 {
	width: 100%;
	max-width: 250px;
	margin: 0 0 20px 0;
}



@media screen and (max-width: 1400px) {
	#festival2025 .smileNav a { font-size: 1.4vw; }
	#festival2025 .smileMain .lead { font-size: 1.3vw; }
}

@media screen and (max-width: 767px) {
	#festival2025 .smileNav { padding: 10px 0 0 0; }
	#festival2025 .smileNav a {
		width: 49%;
		border-radius: 5px;
		color: #ffffff;
		font-size: 15px;
		padding: 10px 0;
	}
	#festival2025 .smileNav a:nth-child(2n + 1) { margin: 6px 0 0 0; }
	#festival2025 .smileNav a:nth-child(2n) { margin: 6px 0 0 2%; }
	#festival2025 .smileNav a.blank:after { opacity: 1; }
	
	#festival2025 .smileBottom { padding: 70px 0; }
	#festival2025 .smileBottom p { margin: 0 auto 10px; }
}

@media screen and (max-width: 640px) {
	#festival2025 .smileMain { background-image: url(/images/festival/2025/smile_main_bg2.gif); }
	
	#festival2025 .smileMain .title h2 { width: 100%; max-width: 510px; padding: 40px 0 0 0; }
	#festival2025 .smileMain .title h2 img:nth-child(1) { display: none; }
	#festival2025 .smileMain .title h2 img:nth-child(2) { display: block; }
	
	#festival2025 .smileMain .lead { font-size: 16px; text-align: left; margin: 20px auto 0; }
	#festival2025 .smileMain .lead br { display: none; }
	
	#festival2025 .smileMain .schedule p { display: none; }
	#festival2025 .smileMain .schedule div { width: 100%; margin: 30px auto 0; }
	
	#festival2025 .smileContents .performer { font-size: 20px; padding: 60px 0 0 0; }
	
	#festival2025 .smileContents .contentsList.style1 { margin: 20px 0 0 0; }
	#festival2025 .smileContents .contentsList.style2,
	#festival2025 .smileContents .contentsList.style3,
	#festival2025 .smileContents .contentsList.style4,
	#festival2025 .smileContents .contentsList.style5,
	#festival2025 .smileContents .contentsList.style6,
	#festival2025 .smileContents .contentsList.style7 { margin: 60px 0 0 0; }
	#festival2025 .smileContents .contentsList .bg,
	#festival2025 .smileContents .contentsList .bg1,
	#festival2025 .smileContents .contentsList .bg2 { display: none; }
	
	#festival2025 .smileContents .contentsList section ul li .text {
		font-size: 15px;
		line-height: 1.6;
		text-shadow: none;
	}
	#festival2025 .smileContents .contentsList section ul li.flL { float: none; }
	#festival2025 .smileContents .contentsList section ul li.flR { float: none; }
	#festival2025 .smileContents .contentsList section ul li.w260 { min-width: 200px; margin: 0 auto; }
	#festival2025 .smileContents .contentsList section ul li.w430 { width: 100%; margin: 20px 0 0 0; }
	#festival2025 .smileContents .contentsList section ul li.w240 { min-width: 120px; margin: 10px auto 0; }
	#festival2025 .smileContents .contentsList section ul li.w450 { width: 100%; }
	#festival2025 .smileContents .contentsList section ul li.w330 { width: 100%; }
	#festival2025 .smileContents .contentsList section ul li.w330 img {
		max-width: 200px;
		display: block;
		margin: 10px auto 0;
	}
	#festival2025 .smileContents .contentsList section ul li.w360 { width: 100%; }
	
	#festival2025 .smileContents .contentsList.style1 section .title { width: 100%; display: block; }
	#festival2025 .smileContents .contentsList.style1 section .title p {
		width: 60.8px;
		float: none;
		padding: 0 0 10px 0;
	}
	#festival2025 .smileContents .contentsList.style1 section .title h3 {
		width: calc(380/470 * 100%);
		float: none;
		margin: 0;
	}
	#festival2025 .smileContents .contentsList.style1 section ul { margin: 20px 0 0 0; }

	#festival2025 .smileContents .contentsList.style2 section > p { width: 60.8px; }
	#festival2025 .smileContents .contentsList.style2 section + section > p { margin: 0; }
	#festival2025 .smileContents .contentsList.style2 section ul { display: table; margin: 10px 0 0 0; }
	#festival2025 .smileContents .contentsList.style2 section + section { margin: 40px auto 0; }
	#festival2025 .smileContents .contentsList.style2 section ul li h3 {
		width: calc(440/470 * 100%);
		margin: 0 0 10px 0;
	}
	
	#festival2025 .smileContents .contentsList.style3 section > p { width: 129.6px; }
	#festival2025 .smileContents .contentsList.style3 section ul { margin: 10px 0 0 0; }
	#festival2025 .smileContents .contentsList.style3 section ul li h3 {
		width: calc(195/470 * 100%);
		margin: 0 0 20px 0;
	}
	#festival2025 .smileContents .contentsList.style3 section ul li .img {
		width: 100%;
		max-width: 200px;
		display: block;
		margin: 0 auto;
	}
	#festival2025 .smileContents .contentsList.style3 section ul li .text { padding: 20px 0 0 0; }
	#festival2025 .smileContents .contentsList.style3 section ul li + li { display: none; }
	
	#festival2025 .smileContents .contentsList.style4 section > p { width: 60.8px; margin: 0; }
	#festival2025 .smileContents .contentsList.style4 section ul { display: table; margin: 10px 0 0 0; }
	#festival2025 .smileContents .contentsList.style4 section ul + ul { margin: 40px 0 0 0; }
	#festival2025 .smileContents .contentsList.style4 section ul li h3 {
		width: calc(300/470 * 100%);
		margin: 0 0 10px 0;
	}
	
	#festival2025 .smileContents .contentsList.style5 section > p { width: 129.6px; }
	#festival2025 .smileContents .contentsList.style5 section h3 {
		margin: 10px 0 0 0;
	}
	#festival2025 .smileContents .contentsList.style5 section ul li + li { margin: 20px 0 0 0; }
	
	#festival2025 .smileContents .contentsList.style6 section > p { width: 60.8px; }
	#festival2025 .smileContents .contentsList.style6 section h3 {
		width: calc(420/470 * 100%);
		margin: 10px 0 0 0;
	}
	#festival2025 .smileContents .contentsList.style6 section ul { display: table; margin: 10px 0 0 0; }
	#festival2025 .smileContents .contentsList.style6 section ul li + li { width: 90%; margin: 10px auto 0; }
	
	#festival2025 .smileContents .contentsList.style7 section > p { width: 60.8px; margin: 0; }
	#festival2025 .smileContents .contentsList.style7 section ul { display: table; margin: 10px 0 0 0; }
	#festival2025 .smileContents .contentsList.style7 section ul li h3 {
		width: calc(250/470 * 100%);
		margin: 0 0 10px 0;
	}
}


