@charset "UTF-8";



/* -------------------------------------------

layout

------------------------------------------- */
.kv,
main,
footer {
	width: 37.6rem;
	margin-left: auto;
	margin-right: auto;
	background: #fafafa;
}
main {
	background: url(../img/contents-bg.jpg) top center;
	background-size: 100% auto;
}
.kv {
	margin-top: 9rem;
}
@media screen and (max-width: 768px) {
	.kv,
	main,
	footer {
		width: 100%;
	}
	.kv {
		margin-top: 0;
	}
}
/* pagetop */
#page-top {
    position: fixed;
	bottom: 1rem;
	right: 1rem;	
	z-index: 999;	
}
#page-top a {
	background: var(--prime);
	border-radius: 50%;
	color: #fff;	
	font-size: 1rem;
	width: 3.6rem;
	height: 3.6rem;
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 1;
	padding-left: 0.1rem;
}



/* -------------------------------------------

left

------------------------------------------- */
.left {
	position: fixed;
	left: 0;
	top: 0;
	width: calc((100% - 37.6rem) / 2);	
	z-index: 10;
	padding: 1.5rem;
}
.left .logo {
	width: 10rem;
	margin-bottom: 3rem;
}
.left nav {
	padding-left: 1.5rem;
	font-weight: bold;
}
.left ul {
	display: flex;
	flex-direction: column;
	align-items: flex-start;	
}
.left li:not(:last-child) {
	margin-bottom: 2rem;
}
.left li a {
	display: flex;
	align-items: center;
}
.left li a::before {
	content: "";
	width: 2.4rem;
	height: 2.4rem;
	margin-right: 0.3rem;
}
.left li:nth-child(1) a::before {
	background: url(../img/gnav-atten-1.png) no-repeat center / contain;
}
.left li:nth-child(2) a::before {
	background: url(../img/gnav-atten-2.png) no-repeat center / contain;
}
.left li:nth-child(3) a::before {
	background: url(../img/gnav-atten-3.png) no-repeat center / contain;
}
.left li:nth-child(4) a::before {
	background: url(../img/gnav-atten-4.png) no-repeat center / contain;
}
.left li:nth-child(5) a::before {
	background: url(../img/gnav-atten-5.png) no-repeat center / contain;
}
.left li:nth-child(6) a::before {
	background: url(../img/gnav-atten-6.png) no-repeat center / contain;
}
.left li:nth-child(7) a::before {
	background: url(../img/gnav-atten-7.png) no-repeat center / contain;
}
.left li:nth-child(8) a::before {
	background: url(../img/gnav-atten-8.png) no-repeat center / contain;
}



/* -------------------------------------------

right

------------------------------------------- */
.right {
	position: fixed;
	right: 0;
	top: 0;
	width: calc((100% - 37.6rem) / 2);	
	height: 100vh;
	z-index: 10;
	display: flex;
	align-items: center;
	justify-content: center;
}
.right ul {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.right li {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.right li:not(:last-child) {
	margin-bottom: 4rem;
}
.right .qr {
	margin-bottom: 0.5rem;
	width: 9.6rem;
	height: 9.6rem;
	background: url(../img/qr-bg.png) no-repeat center / contain;
	display: flex;
	align-items: center;
	justify-content: center;
}
.right .qr img {
	width: 6.6rem;
}
.right span {
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: bold;
	font-size: 1.1rem;
}
.right span img {
	width: 1.2rem;
	margin-right: 0.6rem;
	margin-top: 0.1rem;
}



/* -------------------------------------------

kv

------------------------------------------- */
.kv {
	position: relative;
}
h1 {
	position: absolute;
	left: 1rem;
	top: 1rem;
	width: 6rem;
}
@media screen and (max-width: 768px) {
	
}



/* -------------------------------------------

cv

------------------------------------------- */
.cv {
	background: url(../img/cv-bg.jpg) no-repeat center / cover;
	color: #fff;
	padding: 2rem 0;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.cv h2 {
	text-align: center;
	font-size: 2.4rem;
	line-height: 1.1;
	margin-bottom: 1rem;
}
.cv li:not(:last-child) {
	margin-bottom: 1.2rem;
}
.cv a {
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(to right, #d9ba53,#fbeaaa, #d9ba53);
	border: solid 0.3rem #000;
	border-radius: 1rem;
	font-weight: bold;
	font-size: 1.2rem;
	padding: 0.6rem 1rem;
	box-shadow: 0 0.5rem 0 rgba(0,0,0,0.2)
}
.cv a img {
	width: 1.4rem;
	margin-right: 0.5rem;
}
.cv a:hover {
	opacity: 0.6;
	box-shadow: 0 0 0 rgba(0,0,0,0.2)	
}
@media screen and (max-width: 768px) {
	.cv h2 {
		font-size: 2.6rem;
	}	
	.cv a {
		font-size: 1.4rem;
	}	
}



/* -------------------------------------------

benefits

------------------------------------------- */
.benefits {
	padding: 5rem 3rem;
}
.benefits .wrap {
	border: 0.3rem solid;
	border-image: linear-gradient(to right, #c98c00, #fad900, #8c4c00, #c98c00) 1;	
	padding: 3rem 1.5rem;	
}
.benefits li {
	font-weight: bold;
	display: flex;
	align-items: center;
}
.benefits li:not(:last-child) {
	margin-bottom: 1rem;
}
.benefits li::before {
	content: "";
	width: 2rem;
	height: 2rem;
	margin-right: 0.3rem;
}
.benefits li:nth-child(1):before {
	background: url(../img/benefits-attn-1.png) no-repeat center / contain;
}
.benefits li:nth-child(2):before {
	background: url(../img/benefits-attn-2.png) no-repeat center / contain;
}
.benefits li:nth-child(3):before {
	background: url(../img/benefits-attn-3.png) no-repeat center / contain;
}



/* -------------------------------------------

rfp

------------------------------------------- */
.rfp {
	background: url(../img/rfpp-bg.jpg) no-repeat center / cover;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	height: 22rem;
	font-weight: bold;
	font-size: 2.2rem;
	text-align: center;
}



/* -------------------------------------------

theme

------------------------------------------- */
.theme {
	padding: 6rem 0 8rem 0;
	position: relative;
}
.theme::before {
	content: "";
	width: 100%;
	height: 2rem;
	background: url(../img/line.png) no-repeat center / cover;
	position: absolute;
	left: 0;
	bottom: 0;
}
.theme h2 {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	font-size: 2.2rem;
	margin-bottom: 3rem;
}
.theme h2 strong {
	font-size: 3.2rem;
	font-weight: 600;
	line-height: 1;
}
.theme ul {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.theme li:not(:last-child) {
	margin-bottom: 3rem;
}
.theme li img {
	width: auto;
	height: 10rem;
}
@media screen and (max-width: 768px) {
	.theme h2 {
		font-size: 2.8rem;
	}	
	.theme h2 strong {
		font-size: 4rem;
	}	
	.theme li img {
		height: 12rem;
	}	
}



/* -------------------------------------------

acitivity

------------------------------------------- */
.acitivity {
	padding: 6rem 3rem;
}
.acitivity ul {
	margin-bottom: 3rem;
}
.acitivity li {
	border: 0.3rem solid;
	border-image: linear-gradient(to right, #c98c00, #fad900, #8c4c00, #c98c00) 1;	
	position: relative;
}
.acitivity li:not(:last-child) {
	margin-bottom: 3rem;
}
.acitivity dl {
	position: absolute;
	left: 0;
	bottom: 0;
	background: rgba(255,255,255,0.9);
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 1rem 0;
	width: 100%;
}
.acitivity dt {
	font-weight: bold;
	font-size: 1.8rem;
}
.acitivity p {
	text-align: center;
	font-size: 1.3rem;
}



/* -------------------------------------------

reward

------------------------------------------- */
.reward {
	padding: 6rem 3rem 0 3rem;
}
.reward .wrap {
	border: 0.3rem solid;
	border-image: linear-gradient(to right, #c98c00, #fad900, #8c4c00, #c98c00) 1;	
	padding: 3rem 1.5rem;	
}
.reward ul {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.reward li {
	position: relative;
}
.reward li:not(:last-child):after {
	content: "";
	width: 24rem;
	height: 0.1rem;
	background: var(--grd);
	position: absolute;
	left: calc(50% - 12rem);
	bottom: 0;
}
.reward li:not(:last-child) {
	padding-bottom: 2rem;
	margin-bottom: 2rem;
}
.reward dl {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.reward dt {
	font-weight: bold;
	font-size: 1.7rem;
	display: flex;
	align-items: center;
	justify-content: center;
}
.reward dt::before,
.reward dt::after {
	content: "";
	width: 2.4rem;
	height: 2.4rem;
}
.reward dt::before {
	margin-right: 0.5rem;
}
.reward dt::after {
	margin-left: 0.5rem;
}
.reward li:nth-child(1) dt::before,
.reward li:nth-child(1) dt::after {
	background: url(../img/reward-attn-1.png) no-repeat center / contain;
}
.reward li:nth-child(2) dt::before,
.reward li:nth-child(2) dt::after {
	background: url(../img/reward-attn-2.png) no-repeat center / contain;
}
.reward li:nth-child(3) dt::before,
.reward li:nth-child(3) dt::after {
	background: url(../img/reward-attn-3.png) no-repeat center / contain;
}
.reward dd {
	text-align: center;
}
.reward li:last-child dd {
	font-size: 1.2rem;
}



/* -------------------------------------------

requirements

------------------------------------------- */
.requirements {
	padding: 6rem 3rem 8rem 3rem;
	position: relative;
}	
.requirements::before {
	content: "";
	width: 100%;
	height: 2rem;
	background: url(../img/line.png) no-repeat center / cover;
	position: absolute;
	left: 0;
	bottom: 0;
}
.requirements > section:not(:last-of-type) {
	margin-bottom: 4rem;
}
.requirements h3 {
	text-align: center;
	font-size: 1.7rem;
	padding: 0.6rem 0;
	background: linear-gradient(to right,#d6b64b,#fae9aa,#d6b64b);
	margin-bottom: 2rem;
	letter-spacing: 0.15em;
}
.requirements li {
	text-align: center;
	font-size: 1.3rem;
	margin-bottom: 1.5rem;
	padding-bottom: 1.5rem;
	background: url(../img/dot.png) no-repeat left bottom;
	background-size: 100% auto;
}
.requirements li:last-child {
	margin-bottom: 0;
}



/* -------------------------------------------

apply

------------------------------------------- */
.apply {
	padding: 6rem 3rem 8rem 3rem;
	position: relative;
}	
.apply::before {
	content: "";
	width: 100%;
	height: 2rem;
	background: url(../img/line.png) no-repeat center / cover;
	position: absolute;
	left: 0;
	bottom: 0;
}
.apply li {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.apply li:not(:last-child) {
	margin-bottom: 2.5rem;
	padding-bottom: 2.5rem;
	background: url(../img/dot-bk.png) no-repeat left bottom;
	background-size: 100% auto;
}
.apply li img {
	width: 7rem;
	margin-bottom: 1rem;
}
.apply dl {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.apply dt {
	color: #e45681;
	font-weight: bold;
	font-size: 1.8rem;
	margin-bottom: 0.5rem;
}
.apply dd {
	text-align: center;
	font-size: 1.3rem;
}
.apply dd span {
	display: block;
	margin: 3rem 0 1.5rem 0;
	font-size: 1.2rem;
	text-align: center;
}
.apply dd span strong {
	color: #e45681;	
}
.apply dd div {
	color: #fff;
	background: #e45681;
	padding: 1.5rem 0;
	margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
	.apply li img {
		width: 8rem;
	}
	.apply dt {
		font-size: 2.2rem;
	}	
	.apply dd span {
		font-size: 1.3rem;
	}	
	.apply dd {
		font-size: 1.5rem;
	}		
}



/* -------------------------------------------

schedule

------------------------------------------- */
.schedule {
	padding: 6rem 3rem;
}
.schedule dl {
	margin-bottom: 2rem;
	border-bottom: 0.2rem solid;
	border-image: linear-gradient(to right, #d4b345, #f9e7a5, #d4b345) 1;
}
.schedule dt {
	background: linear-gradient(to right, #d4b345, #f9e7a5, #d4b345);
	padding: 1rem 0;
	text-align: center;
}
.schedule dd {
	border-left: solid 0.2rem #d4b345;
	border-right: solid 0.2rem #d4b345;	
	padding: 1.8rem 0 1.9rem 0;
	text-align: center;
}
.schedule > div {
	text-align: center;
	font-size: 1.2rem;
}
@media screen and (max-width: 768px) {
	.schedule dl {
		font-size: 1.6rem;
	}	
}


/* -------------------------------------------

note

------------------------------------------- */
.note {
	background: #000;
	padding: 6rem 3rem;
	color: #fff;
}
.note li {
	position: relative;
	padding-left: 1.5rem;
	font-size: 1.2rem;
}
.note li::before {
	content: "※";
	position: absolute;
	left: 0;
	top: 0;
}
.note li:not(:last-child) {
	margin-bottom: 1.5rem;
}
@media screen and (max-width: 768px) {
	.note li {
		font-size: 1.5rem;
	}	
}



/* -------------------------------------------

footer

------------------------------------------- */
footer {
	background: #000;
	color: #fff;
	padding: 0.7rem 0;
}
small {
	font-size: 1rem;
	display: block;
	text-align: center;
}