@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&display=swap');

/* 	quiz2025.css
============================================================================================== */
body {
	min-width: 100%;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 400;
	color: #554600;
}
p{
	font-weight: 500;
}

img {
	max-width: 100%;
	height: auto;
}

.sp {
	display: none;
}

.pc {
	display: block;
}

rt {
		translate: 0 .5em;
	}

	@-moz-document url-prefix() {
		rt {
			position: relative;
			top: .7em;
		}
	}

.wrapper {
	background: url(../images/2025/quiz/bg_wall.jpg) repeat-y center / cover;
}

.contentsbox.quiz2025 {
	margin: 0 auto;
	width: 100%;
	overflow: visible !important;
}

.visual img {
	width: 100%;
}

.visual_header {
	background: #fff;
}

.visual_logo {
	display: flex;
	align-items: center;
	gap: 20px;
	max-width: 1000px;
	width: calc(100% - 40px);
	box-sizing: border-box;
	margin: auto;
	justify-content: space-between;
}

.visual_nav {
	max-width: 229px;
}

.visual_date {
	background: #e6002d;
	text-align: center;
	color: #fff;
	font-size: clamp(1.25rem, 0.5rem + 3.75vw, 3.313rem);
	padding: 10px;
	font-weight: 500;
	letter-spacing: 0.05em;
}

.visual_date span {
	font-size: clamp(0.875rem, 0.602rem + 1.36vw, 1.625rem);
}

.visual_deadline {
	border: 1px solid #fff;
	display: inline-block;
	padding: 5px;
	position: relative;
	top: -5px;
	margin: 0 10px 0 15px;
}

.btn {
	max-width: 410px;
	margin: auto;
}

.btn a {
	color: #fff;
	background: #5fb86d;
	display: block;
	padding: 10px 10px 10px 50px;
	font-size: clamp(1.125rem, 0.807rem + 1.59vw, 2rem);
	text-decoration: none;
	font-weight: 500;
	border-radius: calc(1px / 0);
	transition: all ease .3s;
}

.btn span {
	position: relative;
}

.btn span::before {
	position: absolute;
	content: "";
	display: inline-block;
	background: url(../images/2025/quiz/btn_icon@2x.png) no-repeat center / cover;
	width: 56px;
	height: 56px;
	left: -60px;
	top: -18px;
	transition: all ease .3s;
}

.btn a:hover {
	background: #666;
}

.btn a:hover span:before {
	animation: poyopoyo 1.5s ease-out infinite;
	opacity: 1;
}

.btn_not{
	background: #a6a6a6;
	padding: 10px;
	font-size: clamp(1.125rem, 0.807rem + 1.59vw, 2rem);
	font-weight: 500;
	border-radius: calc(1px / 0);
	color: #dcdcdc;
	max-width: 410px;
	margin: auto;
}

.btn_top {
	max-width: 290px;
	margin: 0 auto 50px;
}

.btn_top a {
	background: #f79a03;
	display: block;
	color: #fff;
	padding: 10px;
	font-size: clamp(1.125rem, 0.989rem + 0.68vw, 1.5rem);
	font-weight: 500;
	border-radius: calc(1px / 0);
	text-align: center;
	text-decoration: none;
	transition: all ease .3s;
}

.btn_top a:hover {
	background: #ff8400;
}

@keyframes poyopoyo {

	0%,
	40% {
		transform: skew(0deg, 0deg);
	}

	5% {
		transform: skew(5deg, 5deg);
	}

	10% {
		transform: skew(-4deg, -4deg);
	}

	15% {
		transform: skew(3deg, 3deg);
	}

	20% {
		transform: skew(-2deg, -2deg);
	}

	25% {
		transform: skew(1deg, 1deg);
	}

	30% {
		transform: skew(-0.6deg, -0.6deg);
	}

	35% {
		transform: skew(0.3deg, 0.3deg);
	}
}

.detail {
	background: #fff;
	max-width: 1000px;
	width: calc(100% - 40px);
	box-sizing: border-box;
	margin: 50px auto;
	padding: 40px 30px 30px;
	border-radius: 10px;
}

.detailin {
	text-align: center;
}

.detailin h2 {
	margin-bottom: 20px
}

.detailbox_date {
	background: #fffae1;
	max-width: 660px;
	margin: 40px auto;
	border-radius: 5px;
	filter: drop-shadow(0 0 3px rgba(0, 0, 0, .2));
	padding: 15px;
	position: relative;
	text-align: center;
}

.detailbox_date::before {
	clip-path: polygon(0 100%, 50% 0, 100% 100%);
	top: -15px;
	background-color: #fffae1;
	content: "";
	height: 15px;
	position: absolute;
	width: 20px;
}

.detailbox_start {
	font-size: clamp(1.25rem, 0.795rem + 2.27vw, 2.5rem);
	font-weight: 500;
	color: #e6002d;
}

.detailbox_start span {
	font-size: clamp(0.875rem, 0.716rem + 0.8vw, 1.313rem);
}

.detailbox_secretariat {
	font-size: 16px;
	font-weight: 500;
}

.detailbox_tel {
	background: #000;
	border-radius: 3px;
	color: #fff;
	padding: 0 10px;
	display: inline-block;
	margin: 0 5px 0 15px;
	font-size: clamp(0.75rem, 0.659rem + 0.45vw, 1rem);
}

.detailbox_number {
	font-size: clamp(1rem, 0.773rem + 1.14vw, 1.625rem);
}

.detailbox_reception {
	font-size: clamp(0.75rem, 0.659rem + 0.45vw, 1rem);
	font-weight: 600;
}

.charter {
	background: url(../images/2025/quiz/bg.jpg) no-repeat center top;
	text-align: center;
	padding: 40px 30px 50px;
}

.charter_text {
	font-size: 18px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.1em;
}

.charter dl {
	position: relative;
	border: 2px solid #ee86b4;
	background: #fff;
	padding: 30px 80px;
	margin-top: 60px;
	width: 100%;
	margin: 30px auto 0;
	max-width: 711px;
	box-sizing: border-box;
}

.charter dl::before {
	content: "";
	display: inline-block;
	position: absolute;
	left: 0;
	top: -95px;
	width: 98px;
	height: 93px;
	background: url(../images/2025/quiz/img_child01.png) no-repeat center / cover;
}

.charter dl::after {
	content: "";
	display: inline-block;
	position: absolute;
	right: 0;
	top: -99px;
	width: 91px;
	height: 97px;
	background: url(../images/2025/quiz/img_child02.png) no-repeat center / cover;
}

.charter dt {
	position: absolute;
	margin: auto;
	top: -15px;
	left: 0;
	right: 0;
	background: #ee86b4;
	width: 150px;
	font-size: 20px;
	color: #fff;
}

.charter dd {
	text-align: left;
	font-size: clamp(1.125rem, 0.989rem + 0.68vw, 1.5rem);
	font-weight: 500;
	line-height: 2;
	margin-top: 10px;

}

.charter dd span {
	background: #ee86b4;
	color: #fff;
	padding: 5px;
	line-height: 1;
	box-sizing: border-box;
	display: inline-block;
	margin-right: 5px;
}

.charter dd:nth-of-type(2) span {
	background: #f89507;
}

.charter dd:nth-of-type(3) span {
	background: #87b85f;
}

.losnon {
	width: 100%;
	background: #fff;
}

.losnon .content_area {
	border: none;
	max-width: 1000px;
	width: calc(100% - 40px);
	height: auto;
	margin: auto;
	box-sizing: border-box;
	padding: 15px 0;
	font-size: clamp(0.75rem, 0.614rem + 0.68vw, 1.125rem);
}

.losnon .content_area p span {
	color: #e6002d;
}

.losnon .content_area p::after {
	content: "";
	display: block;
	clear: both;
}

.losnon .content_area p img {
	margin: 0 20px 0 0;
	float: left;
}


.footerin {
	max-width: 1000px;
	width: calc(100% - 40px);
	margin: auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.footerin p {
	color: #fff;
}

.sns {
	float: none;
	height: 22px !important;
}

.footer_fix {
	position: fixed;
	bottom: 50px;
	right: 0;
}

.footer_fix a {
	padding: 20px 15px;
	font-size: clamp(1rem, 0.818rem + 0.91vw, 1.5rem);
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	border-radius: 10px 0 0 10px;
	text-decoration: none;
	width: 57px;
	box-sizing: border-box;
}

.footer_fix a span {
	display: block;
	position: relative;
}

.footer_fix a span::before {
	right: 0px;
	left: 0;
	margin: auto;
	top: -40px;
	width: 36px;
	height: 36px;
}
.footer_fix.btn_not{
	padding: 20px 10px;
	font-size: clamp(1rem, 0.818rem + 0.91vw, 1.5rem);
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	border-radius: 10px 0 0 10px;
	text-decoration: none;
	width: 47px;
	box-sizing: border-box;
	color: #dcdcdc;
}
@media screen and (max-width: 767px) {
	.sp {
		display: block;
	}

	.pc {
		display: none;
	}

	.btn_top {
		margin-bottom: 30px;
	}

	.visual_logo{
		width: calc(100% - 20px);
	}

	.visual_header {
		padding: 10px 0;
	}

	.visual_deadline {
		padding: 2px 10px;
		margin: 0 5px 0 0;
	}

	.detail {
		margin: 20px auto;
		padding: 30px 20px;
	}

	.detailbox_date {
		margin: 20px 0;
	}

	.charter {
		padding: 40px 20px 20px;
		background-color: #feefea;
		background-image: url(../images/2025/quiz/bg_sp.jpg), url(../images/2025/quiz/bg_sp_bottom.jpg);
		background-repeat: no-repeat, no-repeat;
		background-position: center top, center bottom;
	}

	.charter_text {
		font-size: 14px;
	}

	.charter dl {
		padding: 20px;
	}

	.charter dd {
		font-size: 14px;
		line-height: 1.3;
	}

	.charter dl::before {
		top: -47px;
		width: 49px;
		height: 47px;
	}

	.charter dl::after {
		top: -49px;
		width: 46px;
		height: 49px;
	}

	.footerin {
		display: block;
	}

	.sns {
		margin: 10px 0 0;
	}

	.footer_fix {
		bottom: 20px;
	}

	.footer_fix a {
		width: 40px;
		padding: 15px 10px 10px;
	}
	.footer_fix a span::before {
    right: 0px;
    left: 0;
    margin: auto;
    top: -30px;
    width: 27px;
    height: 27px;
}

	.footerin p {
		font-size: 12px;
	}

}
