/* CSS Document */


#main #fv h2 {
	font-size: 120%;
	width: 480px;
	gap: 15px;
}

#lead h3,
#overview h3,
#ticket h3,
#sponsor h3,
#stores h3 {
	font-size: 120%;
	line-height: 1.2;
	color: #42361a;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 5px;
	margin: 20px 0 40px;
}
#lead h3 strong,
#dc5525 h3 strong,
#ticket h3 strong,
#sponsor h3 strong,
#stores h3 strong {
	font-family: 'Black Ops One';
	font-size: 200%;
	font-weight: 500;
	display: flex;
	align-items: baseline;
}


#main .bubble {
	margin: 0;
}

#lead {
	padding: 40px 0;
}
#lead .inner {
	max-width: 1100px;
}
#lead h3 {
	font-size: 220%;
	font-weight: 900;
}
#lead h3 strong {
	font-size: 220%;
}
#lead h3 strong span {
	font-family: 'Noto Sans JP';
	font-size: 30%;
	font-weight: 900;
	color: #fff;
	background: #42361a;
	border-radius: 100%;
	width: 35px;
	height: 35px;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	top: -5px;
}
#lead dl {
	display: flex;
	gap: 40px;
	margin: 50px 0;
}
#lead dl dt {
	width: 400px;
}
#lead dl dd {
	width: calc(100% - 400px - 40px);
}
#lead dl dd .lead {
	font-size: 110%;
	font-weight: 600;
	line-height: 1.8;
	text-align: justify;
	flex-shrink: 0;
}
#lead dl dd .lead {
	font-size: 110%;
	font-weight: 600;
	line-height: 1.8;
	text-align: justify;
	flex-shrink: 0;
}
#lead dl dd ul.btn li {
	margin: 15px 0;
}
#lead dl dd ul.btn a {
	font-size: 110%;
	font-weight: 600;
	line-height: 1.2;
	text-align: center;
	color: #a47b00;
	background: #fff;
	display: inline-block;
	width: 240px;
	padding: 10px;
	border-radius: 40px;
	box-sizing: border-box;
	position: relative;
}

#lead dl dd .banner {
  margin: 40px 0 0;
}
#lead dl dd .banner a {
	font-size: 110%;
  line-height: 1.4;
  text-align: left;
  color: #fff;
  background: #42a68a;
  display: inline-block;
  padding: 8px 100px 8px 20px;
  outline: 2px solid #42a68a;
  outline-offset: 1px;
  position: relative;
}
#lead dl dd .banner a strong {
	font-size: 200%;
  font-weight: 600;
  letter-spacing: 3px;
  color: #ff0;
  display: block;
}
#lead dl dd .banner a::after {
	content: url("/module/img/symbol_2.svg");
	width: 75px;
	position: absolute;
	top: -5px;
	right: 15px;
}





#overview {
	padding: 80px 0 120px;
	border-top: 30px solid #dc5525;
}
#overview dl {
	max-width: 980px;
  margin: auto;
	display: flex;
	flex-wrap: wrap;
}
#overview dl dt,
#overview dl dd {
	line-height: 1.6;
	border-bottom: 1px solid #666;
	padding: 20px 15px;
	box-sizing: border-box;
}
#overview dl dt {
  font-weight: 600;
	color: #dc5525;
  width: 200px;
}
#overview dl dd {
	width: calc(100% - 200px);
}
#overview dl dd a {
	text-decoration: underline;
}
#overview dl dd ul li {
	line-height: 1.4;
	margin: 5px 0;
}




#ticket {
	padding: 80px 0;
  background: #f2f2f2;
}
#ticket .inner {
	max-width: 1040px;
}
#ticket .lead {
	font-size: 105%;
	font-weight: 500;
	line-height: 1.6;
	text-align: center;
}
#ticket ul {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin: 30px 0;
}
#ticket ul li {
	line-height: 1.4;
	border: 1px solid #999;
  background: #fff;
	padding: 15px 20px;
	width: calc(50% - 10px);
	box-sizing: border-box;
	position: relative;
}
#ticket ul li a {
	text-decoration: underline;
}
#ticket ul li h4 {
	font-size: 110%;
	font-weight: 600;
	margin: 0 0 10px;
}
#ticket ul li em {
	font-size: 90%;
	line-height: 1.2;
	color: #fff;
	display: flex;
	gap: 5px;
	position: absolute;
	top: 8px;
  right: 8px;
}
#ticket ul li em span { 
	padding: 2px 8px 4px;
	border-radius: 20px;
}
#ticket ul li em .advance { background: #008CC8;}
#ticket ul li em .day { background: #D4145A;}

#ticket ul li address {
}
#ticket ul li address .add,
#ticket ul li address .tel,
#ticket ul li address time {
	position: relative;
	display: flex;
	align-items: baseline;
  gap: 5px;
}
#ticket ul li address .add::before,
#ticket ul li address .tel::before,
#ticket ul li address time::before {
	width: 20px;
  position: relative;
  top: 4px;
	flex-shrink: 0;
}
#ticket ul li address .add::before { content: url("/module/img/i_map.svg");}
#ticket ul li address .tel::before { content: url("/module/img/i_tel.svg");}
#ticket ul li address time::before { content: url("/module/img/i_time.svg");}

#ticket ul li address .add span {
	font-size: 90%;
}




#stores {
	padding: 80px 0 200px;
}
#stores nav {
  display: flex;
  gap: 10px;
}
#stores nav ul {
  display: flex;
  gap: 20px;
}
#stores nav ul li a {
  text-decoration: underline;
}
#stores .area {
	margin: 20px 0;
}
#stores .area h4 {
  font-size: 120%;
  font-weight: 600;
  line-height: 1.2;
  text-align: center;
	color: #fff;
	background: #999;
	padding: 10px 20px 12px;
	border-radius: 5px;
	position: relative;
  left: 50%;
  transform: translateX(-50%);
}
#stores .area h4::after {
	content: '';
	border-top: 10px solid #999;
	border-left: 8px solid transparent;
	border-right: 8px solid transparent;
	position: absolute;
	top: calc(100% - 1px);
	left: 50%;
	transform: translateX(-50%);
}
#stores #ekinan h4 { background: #688C9D;}
#stores #ekinan h4::after { border-top-color: #688C9D;}
#stores #ekimae h4 { background: #C8A20D;}
#stores #ekimae h4::after { border-top-color: #C8A20D;}
#stores #minamimachi h4 { background: #71AA80;}
#stores #minamimachi h4::after { border-top-color: #71AA80;}
#stores #izumicho h4 { background: #7883BB;}
#stores #izumicho h4::after { border-top-color: #7883BB;}
#stores #keisei h4 { background: #949DCC;}
#stores #keisei h4::after { border-top-color: #949DCC;}
#stores #daikumachi h4 { background: #997396;}
#stores #daikumachi h4::after { border-top-color: #997396;}
#stores #other h4 { background: #a89696;}
#stores #other h4::after { border-top-color: #a89696;}


#stores .acMenu h4 {
	position: relative;
  cursor: pointer;
}
#stores .acMenu h4:hover {
  opacity: .9;
}
#stores .acMenu h4::before {
	content: '';
  border: solid #fff;
  border-width: 0 0 2px 2px;
  height: 13px;
  width: 13px;
  position: absolute;
  top: 10px;
  right: 20px;
  transform: rotate(-45deg);
}
#stores .acMenu h4.active::before {
	border-width: 0 0 2px;
	transform: unset;
  width: 17px;
  height: 10px;
}
#stores .acMenu h4::after {
	top: calc(100% - 11px);
  transition: all .4s;
}
#stores .acMenu h4.active::after {
	top: calc(100% - 1px);
}

#stores .area ul {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin: 20px 0 80px;
  padding: 10px 15px;
}
#stores .area ul li {
  line-height: 1.5;
  width: calc(50% - 10px);
  box-sizing: border-box;
  display: flex;
  gap: 15px;
  position: relative;
}
#stores .area ul li a em {
  font-size: 85%;
  font-weight: 500;
  line-height: 1;
  color: #333;
  background: #fff100;
  padding: 2px 5px 4px;
  position: absolute;
  top: -5px;
  left: -5px;
}
#stores .area ul li img {
  width: 200px;
  aspect-ratio: 4/3;
  object-fit: cover;
}
#stores .area ul li dl {
  width: calc(100% - 200px - 15px);
  margin: 5px 0 0;
}
#stores .area ul li dl dt {
  font-size: 120%;
  font-weight: 500;
  line-height: 1.4;
  margin: 0 0 5px;
  letter-spacing: 0;
}
#stores .area ul li dl dt span {
  font-size: 80%;
  font-weight: 400;
  display: inline-block;
}
#stores .area ul li dl dt a {
  text-decoration: underline;
}
#stores .area ul li.private {
  opacity: .6;
  color: #f00;
}
#stores .area ul li.private dl dt a {
  color: #f00;
}
#stores .area ul li dl dd {
  text-align: justify;
}

#stores .hours {
	max-width: 680px;
	margin: 80px auto;
	padding: 40px 20px;
	border: 2px solid #ccc;
	border-radius: 10px;
	box-sizing: border-box;
}
#stores .hours h4.time {
	font-size: 110%;
  font-weight: 600;
  line-height: 1;
	color: #666;
  display: flex;
	flex-direction: column;
  align-items: center;
  gap: 5px;
}
#stores .hours h4.time::before {
	content: url("../../module/img/time.svg");
	width: 50px;
}
#stores .hours ul.btn {
	margin: 30px 0 0;
  display: flex;
	justify-content: center;
	align-items: center;
}
#stores .hours ul.btn li {
	margin: 0 10px;
}
#stores .hours ul.btn li a {
	font-size: 110%;
  font-weight: 600;
  line-height: 1.2;
  text-align: center;
  color: #fff;
  background: #dc5525;
  display: inline-block;
  width: 180px;
  padding: 12px;
  border-radius: 40px;
  box-sizing: border-box;
  position: relative;
}
#stores .hours ul.btn li a span {
	font-size: 80%;
}
#stores .hours ul.btn li a::after {
	content: '';
	border-left: 7px solid #fff;
	border-top: 5px solid transparent;
	border-bottom: 5px solid transparent;
	position: absolute;
	top: 50%;
	right: 15px;
	transform: translateY(-50%);
}

#stores .storesMap {
  width: 100%;
  height: 640px;
  margin: 80px 0 0;
  border: 1px solid #2e312f;
  border-radius: 5px;
  box-sizing: border-box;
}



#sponsor {
	padding: 60px 0 100px;
	background: #FFF9F3;
}
#sponsor ul {
	display: flex;
	flex-wrap: wrap;
  justify-content: center;
	gap: 10px;
	margin: 30px 0;
}
#sponsor ul li {
}
#sponsor ul.banner li a {
	font-size: 80%;
	line-height: 1.4;
	text-align: center;
	border-radius: 10px;
}
#sponsor ul.banner li a img {
	height: 50px;
  border: 1px solid #eee;
}
#sponsor ul.banner li a span {
  font-weight: 500;
  color: #666;
  background: #fff;
	padding: 0 10px;
  border: 1px solid #ccc;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

#sponsor .support {
  margin: 60px 0 0;
}
#sponsor .support h3 {
  margin: 20px 0;
}
#sponsor .support ul {
  flex-direction: column;
  align-items: center;
  gap: 5px;
  margin: 20px 0;
}
#sponsor .support ul li {
}
#sponsor .support ul li a {
  font-weight: 500;
  text-decoration: underline;
  /*color: #fff;*/
}









@media screen and (max-width: 480px) {
  
	
	#main #fv h2 {
		width: 300px;
	}
	
	#lead h3,
	#overview h3,
	#ticket h3,
	#sponsor h3,
	#stores h3 {
		font-size: 100%;
		margin: 20px 0;
	}
	
	
	
	#lead {
		padding: 10px 0 40px ;
	}
	#lead h3 {
		font-size: 140%;
	}
	#lead h3 strong {
		font-size: 180%;
	}
	#lead h3 strong span {
		font-size: 40%;
		width: 20px;
		height: 20px;
		top: -3px;
	}
	#lead dl {
		flex-direction: column;
		gap: 20px;
		margin: 20px 0;
	}
	#lead dl dt {
		width: auto;
	}
	#lead dl dd {
		width: auto;
		margin: 0 10px;
	}
	#lead dl dd .lead {
		font-size: 100%;
		line-height: 1.6;
	}
	#lead dl dd ul.btn {
		text-align: center;
	}
	#lead dl dd .banner {
    text-align: center;
  }
	
	
	#overview {
		padding: 40px 0 60px;
    border-top: 10px solid #b7d318;
	}
	#overview dl {
		padding: 0;
		flex-direction: column;
	}
	#overview dl dt,
	#overview dl dd {
		width: auto;
		padding: 10px 5px 20px;
		border: none;
	}
	#overview dl dt {
		text-align: center;
		color: #fff;
		background: #72a779;
		padding: 5px;
	}
	#overview dl dd {
	}
	
	
	
	
	
	#ticket {
		padding: 40px 0;
	}
	#ticket .lead {
		font-size: 100%;
		margin: 0 0 20px;
	}
	#ticket ul {
		flex-direction: column;
		gap: 10px;
	}
	#ticket ul li {
		padding: 10px 15px;
		width: auto;
	}
	#ticket ul li h4 {
		font-size: 105%;
		padding-right: 45px;
		margin: 4px 0 8px;
	}
	#ticket ul li em {
		font-size: 80%;
		top: 4px;
		right: 4px;
		flex-direction: column;
		gap: 2px;
	}
	#ticket ul li em span {
		padding: 2px 6px 3px;
	}
	#ticket ul li address .add span {
		font-size: 80%;
	}	
	
	
	
	
	#stores {
		padding: 40px 0 100px;
	}
  #stores h3 {
    margin: 20px 0 30px;
  }
  #stores .area {
    margin: 10px 0;
  }
	#stores .area ul {
    /*flex-direction: column;*/
    gap: 15px;
    margin: 10px 0 30px;
    padding: 10px 5px;
  }
  #stores .area ul li {
    line-height: 1.4;
    width: 100%;
    gap: 10px;
  }
  #stores .area ul li img {
    width: 100px;
    aspect-ratio: 1/1;
  }
  #stores .area ul li dl {
    width: calc(100% - 100px - 10px);
    margin: 0;
  }
  #stores .area ul li dl dt {
    font-size: 105%;
    word-break: break-all;
    margin: 0 0 5px;
  }
  #stores .area ul li dl dt span {
    display: inline;
  }
  #stores .area ul li dl dd {
    font-size: 92%;
    max-height: 5.5em;
    overflow: hidden;
  }
  
	#stores .hours {
		max-width: 300px;
		padding: 20px;
	}
	#stores .hours ul.btn {
		margin: 20px 0 0;
		flex-direction: column;
	}
	#stores .hours ul.btn li {
		margin: 0 10px;
	}
	#stores .hours ul.btn li a {
		width: 200px;
	}
	
  #stores .storesMap {
    height: 480px;
  }
  
  
	#sponsor {
		padding: 30px 0 60px;
	}
	#sponsor ul {
	}
	#sponsor ul li {
	}
	#event #sponsor ul.banner li a img {
    height: 40px;
  }
	
	
}
