@charset "UTF-8";
body {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 16px;
    height: 100vh;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
	justify-content: center;
}.sp-only {
	display: none;
}
.pc-only {
	display: block;
}
.txt-right {
	text-align: right;
}
.txt-center {
	text-align: center;
}
.inner {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
}
html {
  scroll-behavior: smooth;
}
main {
	width: 100%;
	background: #F3F8FD;
}
h2 {
    font-size: 20px;
    color: #1173d1;
	margin: 0 0 30px;
}
p {
    font-size: 16px;
    line-height: 1.8;
}
main.main {
    width: 100%;
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.fv {
	background: linear-gradient(
    to bottom,
    #ffffff 0%,
    #ffffff 50%,
    #0066cc 50%,
    #0066cc 100%
  );
}
.fv .inner {
    position: relative;
}
.fv-cta {
    position: absolute;
    right: 3%;
    bottom: 30px;
    width: 39%;
}
	
.information {
	padding: 30px 0 0;
    background: #0066cc;
}
.information .inner {
    padding: 0 0 30px;
    border-bottom: 1px solid #ccc;
}
.summary .inner,
.program .inner,
.speaker .inner {
    padding: 0 0 50px;
    border-bottom: 1px solid #ccc;
}
.information ul.category {
    display: flex;
}
.information ul.category li {
    margin: 0 10px 0 0;
    border: 1px solid #000;
    padding: 5px;
    border-radius: 5px;
    font-size: 14px;
}
.information h1 {
    font-size: 45px;
    line-height: 1.5;
	color: #1173d1;
	color: #fff;
}


.contents {
	width: 100%;
    max-width: 820px;
}
.summary {
    padding: 50px 0 50px;
}
.program {
    padding: 0 0 50px;
}
.summary .inner,
.program .inner,
.speaker .inner {
    display: flex;
}
.summary .inner .title,
.program .inner .title,
.speaker .inner .title {
    width: 180px;
}
.date {
    font-size: 30px;
    margin: 0 0 30px;
    line-height: 1;
}
.date img,
.time img {
    width: 20px;
    margin: 0 5px 0 0;
}
.date span {
    font-size: 20px;
}
.time {
    font-size: 25px;
    margin: 0 0 30px;
    line-height: 1;
}
p.summary-text {
    font-size: 20px;
    line-height: 1.6;
    margin: 20px 0 0;
    font-weight: bold;
}
p.summary-text span {
    font-size: 16px;
    font-weight: normal;
}

.program h3 {
    font-size: 25px;
    line-height: 1.6;
    margin: 30px 0 10px;
}
.program h3 span {
    font-size: 20px;
    margin: 0 0 0 5px;
}
.program ul {
    margin: 0 0 50px;
}
.program ul li {
    font-size: 20px;
    margin: 15px 0 0;
}

.speaker .contents {
    display: flex;
}
.speaker .contents .speaker-photo {
    width: 140px;
    margin: 0 20px 0 0;
}
.speaker h4 {
    font-size: 16px;
    line-height: 2;
    margin: 0 0 5px;
    font-weight: normal;
}
.speaker h4 span {
    font-size: 20px;
}
.speaker p {
    line-height: 1.6;
}
.speaker-text {
    width: 100%;
    max-width: 660px;
}
.cta {
	width: 100%;
    max-width: 390px;
    margin: 50px auto 0;
	padding: 0 10px;
}
footer {
	padding: 30px 20px;
	display: flex;
	justify-content: center;
	font-size: 14px;
}
footer .inner {
	display: flex;
	justify-content: space-between;
}
footer a {
	text-decoration: underline;
	margin: 0 20px 0 0;
}
footer a:hover {
	text-decoration: none;
}
.form_content {
	width: 100%;
	max-width: 1000px;
	margin: 50px auto;
}
table {
	width: 100%;
	max-width: 1000px;
}
#form tr {
	display: block;
	padding: 20px 0;
}
#form th,
#form td,
#form label {
	width: 100%;
    display: flex;
    text-align: left;
    padding: 5px 0;
    font-weight: normal;
    flex-wrap: wrap;}
input[type="text"],
input[type="email"],
input[type="email"],
input[type="tel"],
textarea {
	padding: 10px;
	font-size: 16px;
	width: 100%;
	background: #f5f8fa;
	border: 1px solid #cbd6e2;
    border-radius: 5px;
}
textarea {
	height: 200px;
}
input[type="submit"]#confirm {
    background: #ff7a59;
    padding: 10px;
    border: none;
    border-radius: 5px;
    color: #fff;
}
p.pp {
	font-size: min(3.5vw, 14px);
	margin: 0 0 10px;
}
p.pp a {
	text-decoration: underline;
	color: #0000ff;
}
input[type="submit"]#confirm {
	cursor: pointer;
}
input[type="submit"]#confirm:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}


#content {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 20px;
}
#content h2 {
	margin: 0 0 30px;
}
#content p {
	line-height: 2;
	margin: 0 0 30px;
}
#content th {
	font-weight: normal;
	text-align: left;
	background: #efefef;
}
#content th,
#content td {
	padding: 15px;
	border: 1px solid #cccccc;
}
#content table,
#finish form {
	margin: 0 0 10px;
}

span.required {
	font-size: 12px;
	color: #ff0000;
}
span.optional {
	font-size: 12px;
	margin: 0 0 0 5px;
}
@media screen and (max-width:767px) {
	.sp-only {
		display: block;
	}
	.pc-only {
		display: none;
	}
	.information h1 {
		font-size: 25px;
	}
	.information .inner,
	.summary .inner,
	.program .inner,
	.speaker .inner {
		padding: 0 20px 30px;
		display: block;
	}
	.program h3 {
		font-size: 20px;
		line-height: 2.5;
	}
	.program h3 span {
		font-size: 16px;
		display: block;
		margin: 0
	}
	.program ul li {
		font-size: 16px;
	}
	footer {
		font-size: 3.2vw;
		padding: 30px 10px;
	}
	footer .inner {
		display: block;
	}
	footer .privacypolicy {
		margin: 0 0 10px;
	}
	footer a {
		text-decoration: underline;
		margin: 0 10px 0 0;
	}
	#form,
	#form2 {
		padding: 20px;
	}
}

footer.footer {
    background: #e7e7e7;
    padding: 50px 0;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
	width: 100%;
}
.footer_logo {
    width: 290px;
}
footer a {
    font-size: 14px;
    text-align: center;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
footer img {
    margin: 0 0 10px;
}
footer p {
    width: 100%;
    display: flex;
    justify-content: center;
    font-size: 16px;
    margin: 30px 0 0;
}

.page-thanks {
	
}
