@charset "UTF-8";

sup {
	font-size: 0.5em;
	vertical-align: super;
}

/**
 * #countdown
 */
#countdown {
	color: #000;
}
@media only screen and (max-width:768px) {
	#countdown {
		display: none;
	}
}

/**
 * #head
 */
#head {
	background-color: #F4F4F4;
	padding: 220px 0 80px 0;
	text-align: center;
}
#head h1 {
	margin-top: -2em;
	letter-spacing: 0.2em;
	font-size: 2.6rem;
	font-weight: 500;
}
#head p {
	margin-top: 50px;
	font-size: 1.8rem;
	font-weight: 500;
}
@media only screen and (max-width:768px) {
	#head {
		padding: 150px 0 60px 0;
	}
	#head h1 {
		font-size: 1.4rem;
	}
	#head p {
		margin-top: 20px;
		text-align: left;
		font-size: 1.2rem;
	}
}

#theme {
	margin-top: 60px;
	background-color: #fff;
	padding: 40px;
}
#theme h2 {
	font-size: 2.6rem;
	letter-spacing: .2em;
	font-weight: 500;
}
#theme p {
	text-align: center;
	margin-top: 30px;
	font-size: 2.6rem;
}
@media only screen and (max-width:768px) {
	#theme {
		margin-top: 30px;
		padding: 30px;
	}
	#theme h2 {
		font-size: 1.4rem;
		font-weight: 500;
	}
	#theme p {
		margin-top: 10px;
		font-size: 1.4rem;
	}
}

/**
 * #prize
 */
#prize {
	padding: 120px 0;
}
#prize table {
	position: relative;
	margin: auto;
	text-align: left;
}
#prize th,
#prize td {
	padding: 2px 10px;
	font-size: 2rem;
	font-weight: 500;
}
#prize th {
	padding-right: 90px;
}
#prize p.note {
	position: relative;
	margin: 50px 0 0 0;
	max-width: 460px;
	text-align: left;
	font-size: 1.4rem;
	font-weight: 300;
	padding-left: 2em;
}
#prize p.note span {
	position: absolute;
	top: 0;
	left: 0;
}
#prize p.note + p.note  {
	margin-top: 0;
}
#prize .inner {
	position: relative;
}
#prize .inner::before {
	position: absolute;
	top: 50%;
	left: 10vw;
	transform: translateY(-50%);
	margin: auto;
	line-height: 0.75;
	letter-spacing: 0;
	font-weight: 500;
	font-size: 20rem;
	color: #F4F4F4;
	content: '賞';
}
.ad #prize .inner::before {
	top: 30px;
	transform: none;
}
#prize .prize-text {
	font-size: 1.4rem;
	font-weight: 300;
	padding-bottom: 20px;
}
#prize tr:last-child .prize-text {
	padding-bottom: 0px;
}
@media only screen and (max-width:768px) {
	#prize {
		padding: 30px 0 60px 0;
	}
	#prize th,
	#prize td {
		padding: 2px 0;
		font-size: 1.2rem;
	}
	#prize th {
		padding-right: 15px;
	}
	#prize p.note {
		margin-top: 30px;
		text-align: left;
		font-size: 1.2rem;
	}
	#prize .inner::before {
		display: block;
		position: static;
		top: 0;
		left: 0;
		transform: none;
		margin-bottom: 20px;
		text-align: center;
		line-height: 1;
		font-size: 8rem;
	}
	#prize .prize-text {
		font-size: 1.2rem;
	}
}



/**
 * #step
 */
#step {
	padding: 80px 0 120px 0;
}
#step li:nth-child(4) {
	align-items: flex-start;
}
#step ol > li {
	margin-top: 4em;
	display: flex;
	align-items: center;
}
#step ol > li a {
	text-decoration: underline;
}
#step li span {
	padding-right: 50px;
	line-height: 0.75;
	letter-spacing: 0;
	font-weight: bold;
	font-size: 20rem;
	color: #F4F4F4;
}
#step li h4 {
	margin-bottom: 1em;
	font-weight: 500;
}
#step .note li {
	position: relative;
	padding-left: 1.75em;
}
#step ul > li + li {
	margin-top: 1em;
}
#step ul.note > li + li {
	margin-top: .2em;
}
#step .note li span {
	position: absolute;
	top: 0;
	left: 0;
	line-height: 2;
	font-size: 1em;
	font-weight: 300;
	color: #333;
}
#step li * + p {
	margin-top: 1em;
}
#step li figure {
	margin-top: 2em;
	margin-bottom: 3em;
}
#step li figure img {
	width: 100%;
}
@media only screen and (max-width:768px) {
	#step {
		padding: 60px 0;
	}
	#step ol > li {
		margin-top: 4em;
		display: block;
	}
	#step li span {
		display: block;
		padding: 0;
		margin-bottom: 20px;
		line-height: 1;
		text-align: center;
		font-size: 8rem;
	}
	#step li figure {
		margin-top: 2em;
		margin-bottom: 3em;
	}
}

/**
 * #faq
 */
#faq {
	background-color: #F4F4F4;
	padding: 80px 0;
}
#faq li {
	margin-top: 2em;
}
#faq li h4,
#faq li p {
	position: relative;
	padding-left: 4em;
}
#faq li span {
	position: absolute;
	top: 0;
	left: 0;
	font-weight: bold;
	font-size: 1.6rem;
}
#faq .btns {
	margin-top: 60px;
	text-align: center;
}
#faq .btns b::after {
	transform: rotate(90deg);
}
@media only screen and (max-width:768px) {
	#faq {
		padding: 60px 0;
	}
	#faq li h4,
	#faq li p {
		padding-left: 3em;
	}
	#faq li span {
		font-size: 1.3rem;
	}
	#faq .btns {
		margin-top: 30px;
	}
}

/**
 * #contact
 */
#contact {
	background-color: #fff;
	padding: 80px 0;
}
#contact p {
	margin-top: 2em;
	text-align: center;
}
@media only screen and (max-width:768px) {
	#contact {
		padding: 60px 0;
	}
	#contact p {
		text-align: left;
	}
}


/* table.styled : 表組 */
main table.styled {
	margin: 3em 0;
	width: 100%;
}
main table.styled th,
main table.styled td {
	padding: 10px 15px;
	border: solid 1px #e5e5e5;
	text-align: center;
	vertical-align: middle;
}
main table.styled.tal td,
main table.styled.tal td th {
	text-align: left;
}
main table.styled th {
	background-color: #fff;
	font-weight: bold;
	white-space: nowrap;
}
main table.styled .ttl {
	font-weight: bold;
}
main table.styled.border tr:nth-child(even) td {
	background-color: #f9f9f9;
}
main table.styled.border tr:nth-child(odd) td {
	background-color: #EDEDED;
}
main table.styled td th,
main table.styled td td {
	padding: 3px 25px 3px 0;
	border: none;
	vertical-align: top;
}
main table.styled td th {
	background-color: transparent;
}
@media only screen and (max-width:768px) {
	main .table_box {
		overflow: scroll;
		margin: 3em 0;
	}
	main .table_box > table {
		min-width: 800px;
		margin: 0 0 1em 0;
	}
}
