@charset "UTF-8";

body {
	text-align: center;
    color: #000;
    animation: fadeIn 2s ease 0s 1 normal;
}

@keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

@-webkit-keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

a{
	color: #000;
	transition: 0.3s;
	}
a:hover {
	opacity: 0.7;
	}

img{
	width: 100%;
}
.wrap {
	max-width: 1000px;
	margin: 0 auto;
	text-align: center;
	padding: 100px 20px;
}
#sec01 h1 {
	max-width: 500px;
	margin: 0 auto 50px auto;
}
#sec01 .leadTxt {
	font-size: 40px;
	font-weight: 900;
	margin-bottom: 50px;
	line-height: 1.2;
}

#sec02 h2 {
	font-size: 30px;
	font-weight: 900;
	line-height: 1.2;
	}
#sec02 h2 span {
	display: block;
	font-size: 20px;
	}
#sec02 .access {
	background-color: #eee;
	font-size: 20px;
	margin-bottom: 20px;	
	width: 300px;
	border-radius: 50px;
	margin: 10px auto;
	}
#sec02 .txt {
	font-size: 20px;
	margin: 30px auto;
	}
#sec02 .campaign {
	max-width: 760px;
	margin: 0 auto 20px auto;
	padding: 30px;
	border-radius: 20px;
	border: #FC2C2F 2px solid;
	}
#sec02 .campaign .ttl {
	font-size: 30px;
	font-weight: bold;
	color: #FC2C2F;
	}
#sec02 .campaign .txt {
	font-size: 25px;
	font-weight: bold;
	margin: 0 0 20px 0;
	color: #FC2C2F;
	}
#sec02 .campaign ul {
	text-align: left;
	margin-bottom: 10px;
	text-indent: -1em;
    padding-left: 1em;
	letter-spacing: -0.01em;
	}
#sec02 .campaign .note {
	text-align: left;
	font-size: 14px;
	color: #333;
	text-indent: -1.5em;
    padding-left: 1.5em;
	}
#sec03 {
	border-top: 1px solid #000;
	padding-top: 20px;
	margin-top: 50px;
	}
#sec03 .profile {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
	flex-wrap: wrap;
	}
#sec03 figure {
	max-width: 400px;
	}
#sec03 h3 {
	font-size: 28px;
	font-weight: bold;
	line-height: 1.2;	
	margin-bottom: 10px;
	}
#sec03 .data {
	display: block;
	font-size: 20px;
	}

#sec04 {
	border-top: 1px solid #000;
	padding-top: 50px;
	margin-top: 50px;
	}

#sec04 ul {
	display: flex;
	gap:5px 10px;
	justify-content: center;
	margin-top: 30px;
	flex-wrap: wrap;
	}

#sec04 ul li {
	background-color: #000;
	padding: 5px 20px;
	border-radius: 50px;
	color: #fff;
	font-weight: bold;
	font-size: 18px;
	margin-bottom: 10px;
	}
#sec04 .note,#sec05 .note {
	color: #FC2C2F;
	}

#sec05 {
	border-top: 1px solid #000;
	padding-top: 50px;
	margin-top: 50px;
	}

#sec05 table {
	text-align: left;
	margin-top: 30px;
	}
#sec05 table th,#sec05 table td {
	border: 1px solid #000;
	padding: 10px;
	vertical-align: middle;
	}
#sec05 table th {
	background-color:#F5F5F5;
	font-size: 20px;
	}
#sec05 table th span {
	display: block;
	font-size: 14px;
	}
	

#sec06 {
	border-top: 1px solid #000;
	padding-top: 50px;
	margin-top: 50px;
	}
#sec06 .contact {
	font-size: 20px;
	margin: 30px 0;
	}

.hd02 {
	position: relative;
	padding: 30px 0;
	font-size: 26px;
	text-align: center;
	font-weight: 900;	
}

.hd02 span {
	position: relative;
	z-index: 2;
}

.hd02::before {
	content: attr(data-en);
	position: absolute;
	top: 5px;
	left: 50%;
	transform: translateX(-50%);
	color: rgba(0,0,0,0.15);
	font-size: 60px;
	font-weight: 900;
	font-style: italic;
}


@media screen and (max-width: 767px) {
#sec01 .leadTxt {
	font-size: 22px;
}
	
#sec02 .campaign {
	padding: 10px;
	border-radius: 10px;
	}
#sec02 .campaign .ttl {
	font-size: 20px;
	}
#sec02 .campaign .txt {
	margin: 0 0 10px 0;
	}

sec03 h3 {
    font-size: 22px;
	}
	
#sec03 .data {
    font-size: 16px;
}	
#sec04 ul li {
    font-size: 15px;
	}
#sec04 .note, #sec05 .note {
    font-size: 14px;
}	
#sec05 table {
	border-bottom: 1px solid #000;
}	
#sec05 table th, #sec05 table td {
    border: 1px solid #000;
    display: block;
	}
#sec05 table th, #sec05 table td {
	border-bottom: none;
}
	

}
  
