@charset "utf-8";

html,body,div,span,h1,h2,h3,h4,h5,h6,
p,a,address,img,
small,strong,
dl,dt,dd,
ol,ul,li,
article,aside,footer,header,nav,section {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	font-size:100%;
}

footer,
header,
nav,
section {
	display: block;
}

html,
body {
	font-family: serif;
	font-size: 1rem;
	height: 100%;
	width: 100%;
	background: #000c1c url("bgimg8.jpg") no-repeat fixed center top;
	background-size: 1024px auto;
	color: #392f36;
}

ol,
ul {
	list-style: none;
}

a {
	text-decoration: none;
}

h2 {
	font-size: 2em;
	text-align: center;
	padding-top: 10px;
	padding-bottom: 10px;
	border-bottom: solid 1px #eeeeee;
	
}

section>h2::before{/*ヘッダーで隠れないように*/
	content:"";
	display:block;
	height:200px;
	margin-top:-80px;
	visibility:hidden;
}

#wrap {
	background: transparent;	
	line-height: 1.4em;
	min-height: 100%;
	margin: 0 auto;
	width: 1024px;
	max-width: 100%;
	min-width: 400px;
}

#wrap>header {
	height: 40px;
	margin: 0 auto;
	position: sticky;
	top: 0;
	width: 100%;
	z-index: 500;

}

#wrap>header ul {
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	text-align: center;
}

#wrap>header li {
	display: inline-block;
	height: 43px;
	line-height: 43px;
	margin: 0;
	background: #414242;

	width: 150px;
	vertical-align: center;
	flex-grow: 1;
}


#wrap>header li:last-child {
	display: inline-block;
	background: #CA105F;
	margin-left: auto;
	height: 70px;
	line-height: 1.6em;
	padding-top: 10px;
	box-shadow: 0 3px 6px rgba(0, 0, 0, 0.4);
	border-radius: 0 0 3px 3px;
	text-shadow: #e995e5 0px 0px 5px;
	font-family: sans-selif;
	font-weight: 100;
}
#wrap header li:hover{
	background:#636b6b
}
#wrap header li:last-child:hover{
	background:#e61e71;
}

#wrap>header li a {
	font-family: inherit;
	color: #ffffff;

	font-size: 1.1em;
	font-weight: 800;
}


.btninfo {
	font-size: 0.8em;

}


#wrap>footer {
	background: #706e6e;
	color: #ece6ea;
	font-size: 1em;
	height: 1.6em;
	line-height: 1.6em;
	text-align: center;
	width: 100%;
}


.contents {
	margin: 0 auto 0;
	margin-top:100px;
	width: 100%;
}

section {
	background: #ece6ea;
	margin:0px 0px 60px 0px;
	padding:0px 20px 10px 20px;
	width: 100%;

}

#apply{
	text-align:center;
}

#apply div>a {
	color: #fff;
	background: #CA105F;
	font-size: 1.4em;
	font-weight: bold;
	font-family: sans-serif;

	text-shadow:#d02cdf 0px 0px 5px;
	border-radius: 5px;
	text-align: center;
	width: 60%;
	display: block;
	margin: 10px auto 30px;
	padding: 10px 20px;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.6);
}

#apply a:hover{
	background:#e61e71;
}

#apply a.closed{
	background:#8d8282;
}

#apply div a span {
	font-size: 0.7em;
	font-weight: normal;
}


#fv {
	background:radial-gradient(circle, rgba(0, 0, 0, 0)65%, rgba(0, 0, 0, 0.288)66%);
	position: relative;
	width: 100%;
	color: #ffffff;
	padding-bottom: 80px;
	text-align: center;
	z-index: 1;

}


#fv>h1 {
	font-size: 1.4em;
	line-height:2.4em;
	font-weight: bold;
	margin:40px 0 auto;
	
	
}

#fv>span {
	display: inline-block;
	width: 100%;
	padding: 0 5%;
}

#title {
	font-size: 3em;
	color: transparent;
	stroke: 1px #ffffff;
    -webkit-text-stroke: 1px #ffffff;
	text-shadow: #eb89ff 0px 0 10px,5px 1px 2px rgba(44, 229, 253, 0.288);
	background-image:url(flame.png);
	background-size: contain;
	background-clip: text;
	-webkit-background-clip: text;
}

#subtitle {
	font-size: 1.4em;
	line-height: 2em;
	color:#ffffff;
	
	text-shadow: #33dfd68e 3px 1px 2px,-3px 1px 3px rgba(253, 44, 44);
	
}



#abst>div {
	font-size: 1.1em;
	line-height: 1.2em;
	padding: 10px 10px;
	position: relative;
	top: 20px;
	border-top: solid 1px #9b6969;
	margin-bottom:10px;
}


.center{
	display: block;
	text-align:center;
	font-weight: bold;
}

.date{
	font-weight: bold;
}

big {
	font-size: 1.6em;
	line-height: 1.2em;
	font-family:sans-serif;
	font-weight: normal;
}


#abst ul {
	list-style: square;
	text-align: left;
	padding-left: 40px;
	line-height: 1.1em;
	margin-bottom: 0.5em;
}

.profile{
	position:relative;
	min-height:500px;
	width:100%;
	
	display:flex;
	flex-wrap: wrap;
	justify-content: space-around;
	
}

#spkr img{
	
	width:40%;
	max-width:400px;
	object-fit: cover;
	
}

.ptext{
	min-width: 400px;
	width:50%;
	flex-grow:1;
	align-self:flex-end;
	margin:-160px 10px 0px 10px;/*マイナスはwrap表示時に画像と重ねるため*/
}

#spkr .name {
	font-size: 2.0em;
	background-color: #ece6eac9;
	font-weight: bold;
}

#spkr .name_en {
	font-size: 1.2em;
	background-color: #ece6eac9;
	
}

#spkr .position{
	font-weight: normal;
	color: #f5f1ea;
	text-shadow: #f5f1ea 0 0 1px;
	background-color: #CA105F	;

}

#spkr p {
	background-color:  rgba(56, 53, 55, 0.8);
	color: #f5f1ea;
	padding:  10px  20px;
	text-shadow: #392f2f 0 0 5px;
}

#contact dl {
	margin-top: 20px;
}

#contact dt {
	font-size: 1.4em;
	font-weight: bold;
	margin: 10px 0;
}

#access>.fbox {
	display: flex;
	width: 100%;
	flex-wrap: wrap;
	justify-content: space-between;

}

#access div div {
	min-width: 250px;
	flex: 1;
}

#access li {
	font-size: 1.2em;
	text-align: left;
	font-weight: bold;
	margin: 15px 0;

}


#access img {

	align-self: flex-start;
	border: solid 1px #555;
	width: 420px;
	margin: 20px;
}

