@charset 'utf-8';

@font-face { 
  font-family: 'Acumin-Variable-Concept';
  src: url("../font/Acumin-Variable-Concept.woff") format("woff-variations");
	font-weight: 100 900;
	font-display: swap;
}

html {
	font-size: 18px;
	line-height: 1.4;
	color: #fff;
  scroll-behavior: smooth;
}
body {
	font-family: "Acumin-Variable-Concept", sans-serif;
	font-variation-settings: "wght" 450, "wdth" 100, "slnt" 0;
	background-image: url("../img/background_img.jpg");
	background-repeat: no-repeat;
	background-position: center top;
	background-color: #030000;
	margin: 0px;
	padding: 0px;
	font-feature-settings: "palt" 1;
}
/* IEだけに適応 */
_:lang(x)::-ms-backdrop, .selector {
	font-family: "Segoe UI", Meiryo, sans-serif;
}
div,h1,h2,h3,h4,h5,p,img,ul,li {
	margin: 0px;
	padding: 0px;
	border: none;
}
#container {
	width: 900px;
	margin: 0px auto;
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	
	#container {
		width: 100%;
		margin: 0px;
	}
}
@media screen and (max-width: 600px) {
	/* 600px以下に適用されるCSS（タブレット用） */
	
	body {
		background-image: url("../img/background_img02.jpg");
	}
}

p {
	font-size: 0.9rem;
	margin: 0px 20px 10px 20px;
}
.alert {
	font-weight: 600;
	color: #cc0000;
}
.clear {
	font-weight: 600;
	color: #00cc00;
}

#my-video {
	/*border-bottom: solid 1px #999999;
	border-right: solid 1px #999999;
	border-top: solid 1px #999999;*/
	border: solid 1px #999999;
}
.textShadow {
	text-shadow: 0 0 10px #000, 0 0 10px #000, 0 0 10px #024367;
}

/*
Link style -------------------------------------------------------------------------------------------- */
a {
  cursor: pointer;
}
a:link, a:visited {
	text-decoration:none;
	color: #CC0000;
}
a:hover, a:active {
	text-decoration:underline;
	color: #CC0000;
}

.btn {
  display: inline-block;
  border-radius: 3px;
  font-size: 1rem;
  text-align: center;
  padding: 10px 10px 6px;
  color: #ffffff;
	border: 1px solid #FFF;
  opacity: 1;
  transition: .2s;
}
.btn:link, .btn:visited {
	text-decoration:none;
	color: #ffffff;
}
.btn:hover, .btn:active {
  opacity: 1;
	text-decoration:none;
}

.btn_gray {
	background-color: #444444;
}
.btn_gray:hover, .btn_gray:active {
	color: #444444;
	background-color: #FFF;
	border: 1px solid #444444;
}

.btn_blue {
	background-color: #1982c4;
}
.btn_blue:hover, .btn_blue:active {
	color: #1982c4;
	background-color: #FFF;
	border: 1px solid #1982c4;
}

.btn_green {
	background-color: #8ac926;
	color: #000000;
}
.btn_green:hover, .btn_green:active {
	color: #8ac926;
	background-color: #FFF;
	border: 1px solid #8ac926;
}

.btn_yellow {
	background-color: #ffca3a;
	color: #000000;
}
.btn_yellow:hover, .btn_yellow:active {
	color: #ffca3a;
	background-color: #FFF;
	border: 1px solid #ffca3a;
}

.btn_orange {
	background-color: #EF810F;
}
.btn_orange:hover, .btn_orange:active {
	color: #EF810F;
	background-color: #FFF;
	border: 1px solid #EF810F;
}

.btn_red {
	background-color: #ff595e;
}
.btn_red:hover, .btn_red:active {
	color: #ff595e;
	background-color: #FFF;
	border: 1px solid #ff595e;
}

.btn_purple {
	background-color: #6a4c93;
}
.btn_purple:hover, .btn_purple:active {
	color: #6a4c93;
	background-color: #FFF;
	border: 1px solid #6a4c93;
}

/*
page-top -------------------------------------------------------------------------------------------- */
.pagetop {
	text-align: right;
	margin: -6px 0px 20px 0px;
}
.pagetop img {
	border: none;
}

/*
header -------------------------------------------------------------------------------------------- */
div#header {
	margin-bottom: 40px;
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	
	div#header {
		margin: 0px 10px 40px;
	}
}
h1 {
	font-size: 5.1rem;
	line-height: 1;
	color: #f0da43;
	font-variation-settings: "wght" 800, "wdth" 100, "slnt" 0;
	margin: 20px 0px;
}
h1 div {
	font-size: 3.8rem;
	line-height: 1;
}
.headerText01 {
	font-size: 1.5rem;
	line-height: 1.2;
	color: #f4b6c1;
	font-variation-settings: "wght" 800, "wdth" 100, "slnt" 0;
	text-indent: -1rem;
	margin: 10px 0px 10px 1rem;
}
.headerText02 {
	font-size: 0.9rem;
	line-height: 1.2;
	color: #fff;
	font-variation-settings: "wght" 500, "wdth" 100, "slnt" 0;
	margin: 0px 0px 10px;
}
.headerText03 {
	font-size: 2.2rem;
	line-height: 1.2;
	color: #fff;
	font-variation-settings: "wght" 800, "wdth" 100, "slnt" 0;
}
.headerText04 {
	font-size: 1.6rem;
	line-height: 1.2;
	color: #fff;
	font-variation-settings: "wght" 500, "wdth" 100, "slnt" 0;
}


@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	h1 {
		font-size: 4.2rem;
		line-height: 1;
		font-variation-settings: "wght" 800, "wdth" 100, "slnt" 0;
		margin: 20px 0px;
	}
	h1 div {
		font-size: 3rem;
		line-height: 1;
	}
}

@media screen and (max-width: 650px) {
	/* 650px以下に適用されるCSS（タブレット用） */
	h1 {
		font-size: 3rem;
		line-height: 1;
		font-variation-settings: "wght" 800, "wdth" 100, "slnt" 0;
		margin: 20px 0px;
	}
	h1 div {
		font-size: 2rem;
		line-height: 1;
	}
	.headerText01 {
		font-size: 1rem;
		font-variation-settings: "wght" 600, "wdth" 100, "slnt" 0;
	}
	.headerText03 {
		font-size: 1.6rem;
		font-variation-settings: "wght" 800, "wdth" 100, "slnt" 0;
	}
	.headerText04 {
		font-size: 1.2rem;
		font-variation-settings: "wght" 500, "wdth" 100, "slnt" 0;
	}
}


/*
contents -------------------------------------------------------------------------------------------- */
#contents {
	margin: 0px;
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	
	#contents {
		margin: 0px 10px;
	}
}

#btnArea {
	display: flex;
	justify-content: center; 
}
#loginError {
	color: #CC0000;
	font-variation-settings: "wght" 800, "wdth" 100, "slnt" 0;
	text-align: center;
	text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
              -1px 1px 0 #FFF, 1px -1px 0 #FFF,
              0px 1px 0 #FFF,  0-1px 0 #FFF,
              -1px 0 0 #FFF, 1px 0 0 #FFF;
}
#registError {
	color: #CC0000;
	font-variation-settings: "wght" 800, "wdth" 100, "slnt" 0;
	text-align: center;
	text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
              -1px 1px 0 #FFF, 1px -1px 0 #FFF,
              0px 1px 0 #FFF,  0-1px 0 #FFF,
              -1px 0 0 #FFF, 1px 0 0 #FFF;
}

h2 {
	color: #f1da43;
	font-size: 1.8rem;
}
h2 hr {
	margin: -16px 0px 0px;
	border-bottom: 2px solid #f1da43;
  border-image: linear-gradient(to right, #f1da43 0%, #fff 100%);
  border-image-slice: 1;
}
h3 {
	font-size: 1rem;
	color: #fff;
	font-variation-settings: "wght" 800, "wdth" 100, "slnt" 0;
}

h4 {
	font-size: 0.9rem;
	color: #000;
	text-align: center;
	font-variation-settings: "wght" 800, "wdth" 100, "slnt" 0;
	background-color: #f1da43;
	padding: 2px 0px;
}
.submitBtns {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.noteText {
	text-align: right;
	font-size: 0.9rem;
	margin-bottom: 10px;
}
.program {
	display: flex;
	justify-content: space-between;
	margin: 0px;
}
.program hr {
	border: 1px solid #fff;
}
.separate {
}
.programText {
	font-size: 0.9rem;
	margin: 0px 0px 6px 16px;
}
.moderators {
	display: flex;
	justify-content: center; 
}
.moderator {
	display: flex;
	width: 50%;
	margin: 10px;
}
.speakers {
	display: flex;
	justify-content: center; 
}
.speaker {
	display: flex;
	width: 50%;
	margin: 10px;
}
.facePhoto {
	margin-right: 10px;
}
.facePhoto img {
	border: solid 1px #fff;
}
.national {
	margin-bottom: 6px;
}
.national img {
	vertical-align: middle;
	margin-right: 10px;
}
.fullName {
	font-size: 1.6rem;
}
.belongs {
	font-size: 0.9rem;
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	
	.program {
		display: block;
		margin: 0px 0px 0px 100px;
	}
	.program hr {
		border: none;
	}
	.separate {
		border:none;
		padding: 0px;
	}
	.moderators {
		flex-direction: column;
	}
	.moderator {
		width: 100%;
	}
	.speakers {
		flex-direction: column;
	}
	.speaker {
		width: 100%;
	}
	
}
ul.annai {
	margin:0px 20px 20px 20px;
}
ul.annai li {
	font-size: 0.9rem;
	margin: 0px 0px 10px 10px;
}

#video-container {
	margin: -20px 20px 20px;
}

/*
footer -------------------------------------------------------------------------------------------- */
#footer {
	border-top: #fff solid 2px;
}
#footer p {
	line-height: 120%;
	text-align: center;
	margin: 0px;
	padding: 10px 0px 10px 0px;
	color: #FFF;
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
	
	#footer {
		margin: 0px 10px;
	}
}

/*
loginform -------------------------------------------------------------------------------------------- */
#login {
  display: flex;
  flex-wrap:wrap;
  justify-content: space-between;
}
#loginform {
	display: none;
  width: 60%;
  border: #ff6486 solid 1px;
  border-radius: 5px;
  padding: 10px;
	margin: 10px auto;
}
#registform {
	display: none;
  width: 60%;
  border: #005ca2 solid 1px;
  border-radius: 5px;
  padding: 10px;
	margin: 10px auto;
}

#loginform h5 {
  background-color: #ff6486;
}
#registform h5 {
  background-color: #005ca2;
}

#loginSubmitBtn {
  display: inline-block;
  padding: 1rem 1.4rem;
  font-size: 1rem;
	font-weight: 600;
  color: #fff;
  user-select: none;
  border: 0px #130CB7 solid;
	background:linear-gradient(135deg, #fec8d4 0%,#ff6486 100%);
  border-radius: 3px;
  box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.14), 0 1px 2px 0 rgba(0, 0, 0, 0.12);
}
#registSubmitBtn {
  display: inline-block;
  padding: 1rem 1.4rem;
  font-size: 1rem;
	font-weight: 600;
  color: #fff;
  user-select: none;
  border: 0px #130CB7 solid;
	background:linear-gradient(135deg, #addafc 0%,#005ca2 100%);
  border-radius: 3px;
  box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.14), 0 1px 2px 0 rgba(0, 0, 0, 0.12);
}
#loginSubmitBtn:hover,
#registSubmitBtn:hover {
  box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.2), 0 1px 8px 0 rgba(0, 0, 0, 0.12);
}
#registerForm {
	width: 90%;
	margin: 0px auto;
	font-size: 0.9rem;
}
@media screen and (max-width: 900px) {
	/* 900px以下に適用されるCSS（タブレット用） */
  #loginform {
    width: 90%;
  }
  #registform {
    width: 90%;
  }
}

.inputform {
	width: 80%;
	margin: 0px auto 10px;
}
.inputform input {
	box-sizing: border-box;
	width: 100%;
	padding: 0.6rem;
	letter-spacing: 1px;
	color: #333333;
	border: 1px solid #999999;
	background-color: #fff;
	border-radius: 5px;
}

.inputform input:focus {
	border: 1px solid #da3c41;
	outline: none;
	background-color: #FFF0F0;
	box-shadow: 0 0 5px 1px rgba(218,60,65, .5);
}
	
.inputform input:valid {
	/*background: transparent;*/
} 
.inputform label {
	display:block;
	margin-bottom: 4px;
	font-size: 0.9rem;
	font-weight: 600;
}

.r-label {
  display: inline-block;
  border-radius: 2px;
  font-size: 0.7rem;
  text-align: center;
  cursor: pointer;
  padding: 3px 6px;
  background: #D9534F;
  color: #ffffff;
  line-height: 1em;
}
.o-label {
  display: inline-block;
  border-radius : 2px;
  font-size: 0.7rem;
  text-align: center;
  cursor: pointer;
  padding: 3px 6px;
  background: #5CB85C;
  color: #ffffff;
  line-height: 1em;
}


.subBtn {
	text-align: center;
}
#submitBtn {
  display: inline-block;
  padding: 1rem 1.4rem;
  font-size: 1rem;
	font-weight: 600;
  color: #fff;
  user-select: none;
  border: 0px #130CB7 solid;
	background:linear-gradient(135deg, #8395eb 0%,#2643d4 100%);
  border-radius: 3px;
  box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.14), 0 1px 2px 0 rgba(0, 0, 0, 0.12);
}
#submitBtn:hover {
  box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.2), 0 1px 8px 0 rgba(0, 0, 0, 0.12);
}

.closeBtn {
	text-align: center;
}
@media screen and (min-width: 790px) {
	/* 798px以上に適用されるCSS */
	.closeBtn {
		display: none;
	}
}

#qaform {
	background-color: #FFFFFF;
	padding: 20px;
	margin: 10px 10px;
	border-radius: 5px;
	box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.2), 0 1px 8px 0 rgba(0, 0, 0, 0.12);
	color: #000;
}
.qaTextBox {
	background-color: #FFFFFF;
	padding: 20px;
	margin: 10px 10px;
	border-radius: 5px;
	box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.2), 0 1px 8px 0 rgba(0, 0, 0, 0.12);
}
.qaTextBox h6 {
	display: flex;
	font-size: 0.8rem;
	line-height: 1.2;
	color: #FFF;
	background-color: #040d26;
	margin: 0px 0px 6px 0px;
	padding: 4px 10px;
}
.qaTextBox02 {
	background-color: #FFFFFF;
	padding: 20px;
	margin: 10px 10px;
	border-radius: 5px;
	box-shadow: 0 3px 3px 0 rgba(0, 0, 0, 0.2), 0 1px 8px 0 rgba(0, 0, 0, 0.12);
}
.qaTextBox02 h6 {
	display: flex;
	font-size: 1rem;
	line-height: 1.2;
	color: #000;
	background-color: #040d26;
	margin: 0px 0px 6px 0px;
	padding: 4px 10px;
}
.qaTextBox02 p {
	font-size: 1.2rem;
}
.inputform textarea {
	box-sizing: border-box;
	width: 100%;
	height: 150px;
	padding: 1rem;
	letter-spacing: 1px;
	color: #333333;
	border: 1px solid #999999;
	border-radius: 5px;
}
.gg-arrow-up-r {
 box-sizing: border-box;
 position: relative;
 display: inline-block;
 width: 20px;
 height: 20px;
 border: 2px solid;
 transform: scale(var(--ggs,1));
 border-radius: 4px
}

.gg-arrow-up-r::after {
 content: "";
 display: block;
 box-sizing: border-box;
 position: absolute;
 top: 6px
}

.gg-arrow-up-r::after {
 width: 6px;
 height: 6px;
 border-top: 2px solid;
 border-left: 2px solid;
 transform: rotate(45deg);
 left: 5px
}


 .gg-arrow-right-r {
 box-sizing: border-box;
 position: relative;
 display: inline-block;
 width: 30px;
 height: 30px;
 border: 4px solid;
 transform: scale(var(--ggs,1));
 border-radius: 4px
}

.gg-arrow-right-r::after {
 content: "";
 display: block;
 box-sizing: border-box;
 position: absolute;
 right: 7px
}

.gg-arrow-right-r::after {
 width: 12px;
 height: 12px;
 border-top: 4px solid;
 border-right: 4px solid;
 transform: rotate(45deg);
 bottom: 5px
}
