@charset "UTF-8";

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var,
b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video, dialog {
	-webkit-font-smoothing: antialiased;
	margin: 0;
	padding: 0;
	border: 0;
}

*, *::before, *::after {
	box-sizing: border-box;
}

html {
	-webkit-text-size-adjust: 100%;
}

body {
	line-height: 1.8;
	font-family: "RocknRoll One", sans-serif;
	font-size: 16px;
	color: #333;
	background: #c21529;
}
button, input, textarea {
	font-family: "RocknRoll One", sans-serif;
}
ul {
	list-style-type: none;
}
img {
	vertical-align: bottom;
}

header {
	padding: 0 10px;
	height: 64px;
	display: flex;
	align-items: center;
	background: #fff;
}
h1 img.pc {
	display: block;
	width: 571px;
	height: 53px;
}
h1 img.sp {
	display: none;
	width: auto;
	margin: 0 auto;
}
.eyecatch h2 {
	background: #c21529 url(/event/images/pt_present_20/bg_pt_present_20th.jpg) center center no-repeat;
	background-size: cover;
	text-align: center;
}
.eyecatch .date {
	font-size: min(28px, 4.5vw);
	text-align: center;
	border-top: 4px solid #940011;
	border-bottom: 4px solid #940011;
	background: linear-gradient(to bottom, #fdffd0 0%,#fbfdc7 50%,#ddbd6c 51%,#fbfdc7 100%);
	text-shadow: 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff;
	padding: 6px 2px 8px;
	line-height: 1.2;
}
.eyecatch .date span {
	font-size: 115%;
}
main {
	width: 992px;
	padding: 0 30px;
	margin: 0 auto;
	padding-bottom: 70px;
}
.leadText {
	color: #fff;
	text-align: center;
	margin: 50px 0;
	font-size: min(20px, 4vw);
}
.leadText span {
	color: #fff200;
	font-size: 120%;
}
.cardContainer {
	display: flex;
	gap: 50px 40px;
	flex-wrap: wrap;
	margin-bottom: 70px;
}
.card {
	position: relative;
	background: #fff;
	border: 4px solid #c21529;
	box-shadow: 10px 10px 15px rgba(0, 0, 0, 0.15);
	border-radius: 12px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: baseline;
	line-height: 1;
	padding: 20px 10px 20px 102px;
	gap: 10px 8px;
}
.card.gold {
	width: 100%;
}
.card:not(.gold) {
	width: calc((100% - 40px) / 2);
}
.card img.ribbon {
	position: absolute;
	top: -12px;
	left: 8px;
	width: 96px;
	height: auto;
}
.card img.coin {
	transform: translateY(8%);
}
.card.gold img.coin {
	transform: translateY(8%);
	width: 102px;
	height: auto;
}
.card.silver img.coin {
	margin-right: -6px;
	width: 64px;
	height: auto;
}
.card.bronze img.coin {
	margin-right: -6px;
	width: 42px;
	height: auto;
}
.card .point {
	color: #c21529;
	letter-spacing: -0.05em;
}
.card.gold .point {
	font-size: 56px;
}
.card.gold .point span {
	font-size: 196%;
}
.card:not(.gold) .point {
	font-size: 34px;
}
.card:not(.gold) .point span {
	font-size: 176%;
}
.card .number {
	background: #c21529;
	color: #fff;
}
.card.gold .number {
	font-size: min(30px, 2.8vw);
	padding: 6px 20px 10px;
	border-radius: 30px;
	transform: translateY(-7px);
}
.card.gold .number span {
	font-size: 126%;
}
.card:not(.gold) .number {
	font-size: 23px;
	padding: 4px 16px 8px;
	border-radius: 30px;
}
.card:not(.gold) .number span {
	font-size: 122%;
}

.card.more {
	width: 100%;
	justify-content: flex-start;
	align-items: center;
	margin-top: 50px;
	padding: 12px;
	gap: 12px 16px;
	height: auto;
	position: relative;
}
.card.more img.moreover {
	width: 124px;
	height: 49px;
	position: absolute;
	top: -50px;
	left: -20px;
}
.card.more img.ribbon {
	position: relative;
	top: 0;
	left: 0;
	width: 154px;
	height: 69px;
}
.card.more .text {
	font-size: 22px;
	margin: 0 16px;
}
.card.more .number {
	transform: translateY(8px);
}

.button_text {
	font-size: 18px;
	color: #fff;
	text-align: center;
	margin-bottom: 16px;
}
.button_text span {
	color: #fff200;
}
.button_text.ranking {
	font-size: 125%;
	margin-top: 30px;
}
button.entry {
	appearance: none;
	outline: none;
	cursor: pointer;
	display: block;
	border: 4px solid #ae1325;
	box-shadow: 10px 10px 15px rgba(0, 0, 0, 0.15);
	background: linear-gradient(to bottom,  #fdffd0 0%,#fbfdc7 50%,#ddbd6c 51%,#fbfdc7 100%);
	height: 116px;
	border-radius: 58px;
	max-width: 770px;
	width: 100%;
	margin: 0 auto;
	font-size: 48px;
	text-shadow: 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff, 0 0 4px #fff;
	cursor: pointer;
	color: #333;
}
button.entry:hover {
	filter: brightness(0.95);
}
button.entry.done {
	filter: grayscale(1);
	pointer-events: none;
	box-shadow: none;
	border-color: #999;
	color: #999;
}

aside {
	background: #fff;
	padding: 60px 0 100px;
}
aside div {
	width: 600px;
	margin: 0 auto;
}
aside h3 {
	font-size: 20px;
}

footer {
	background: #fff;
	font-size: 12px;
	text-align: center;
	padding: 4px;
}
footer a {
	color: #333;
}

aside, footer {
	font-family: sans-serif;
}

@media (max-width: 992px) {
	header {
		overflow: hidden;
	}
	.eyecatch h2 img {
		width: 90%;
		height: auto;
	}
	main {
		width: 100%;
		padding: 0 3vw 14vw;
	}
	.leadText {
		line-height: 1.7;
	}
	.leadText div {
		display: inline;
	}
	.cardContainer {
		gap: 6.5vw;
		margin-bottom: 14vw;
	}
	.card {
		padding: 3vw 1vw 3vw 15vw;
		gap: 1vw;
		box-shadow: 2vw 2vw 3vw rgba(0, 0, 0, 0.15);
		border-radius: 10px;
	}
	.card.gold {
		height: auto;
	}
	.card:not(.gold) {
		width: 100%;
		height: auto;
	}
	.card.gold img.ribbon {
		width: 12.5vw;
		height: auto;
	}
	.card.gold img.ribbon {
		top: -2vw;
		left: 1vw;
	}
	.card.gold img.coin {
		width: 12vw;
	}
	.card.silver img.coin {
		width: 12vw;
	}
	.card.bronze img.coin {
		width: 7vw;
	}
	.card.gold .point {
		font-size: 6vw;
	}
	.card:not(.gold) .point {
		font-size: 5.5vw;
	}
	.card.gold .number {
		font-size: 2.8vw;
		padding: 1vw 2vw 1.2vw;
		transform: translateY(-1vw);
	}
	.card:not(.gold) img.ribbon {
		width: 11.5vw;
		height: auto;
	}
	.card:not(.gold) .number {
		font-size: 2.5vw;
		padding: 1vw 2vw 1.5vw;
		transform: translateY(-1vw);
	}
	.card.more {
		padding: 2.5vw;
		gap: 2vw 2vw;
		justify-content: center;
		margin-top: 10vw;
	}
	.card.more img.moreover {
		width: 20vw;
		height: auto;
		top: -8vw;
		left: -3vw;
	}
	.card.more img.ribbon {
		width: 18vw;
	}
	.card.more .text {
		font-size: 3.5vw;
		margin: 0 1.5vw;
		width: calc(100% - 25vw);
	}
	.card.more .number {
		transform: translateY(1.5vw);
	}
	aside {
		padding: 8vw 0 12vw;
		font-size: 15px;
	}
	aside h3 {
		font-size: 18px;
	}
	aside div {
		width: 100%;
		padding: 0 3vw;
	}
	.button_text {
		font-size: min(18px, 3.5vw);
		margin-bottom: 2vw;
	}
	button.entry {
		font-size: min(48px, 7.5vw);
	}
}

@media (max-width: 480px) {
	header {
		height: 50px;
		justify-content: center;
	}
	h1 img.pc {
		display: none;
	}
	h1 img.sp {
		display: block;
		width: 217px;
		height: 30px;
	}
	.eyecatch .date {
		border-width: 3px;
	}
	.leadText {
		margin: 9vw 0;
	}
	.card {
		border-radius: 8px;
	}
	button.entry {
		height: 82px;
	}
}