@charset "utf-8";
* {
margin: 0;
padding: 0;
box-sizing: border-box;
word-break: break-all;
word-wrap: break-word;
}
html {
font-family: sans-serif;
line-height: 1.15;
-ms-text-size-adjust: 100%;
-webkit-text-size-adjust: 100%;
font-size: 14px;
line-height: 1.3;
}
body {
padding: 0;
margin: 0;
background: #000;
color: #222;
font-size: 100%;
font-family: 'メイリオ','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック';
font-family: 'Noto Sans JP', sans-serif;
font-weight: normal;
width: 100%;
height: 100%;
}
/*font-family: 'Oswald', sans-serif;*/

li{
list-style: none;
}
a {
color: #4769ED;
}
ul::before,
ul::after,
ol::before,
ol::after,
dl::before,
dl::after {
display: none;
}
	@media screen and (max-width: 768px) {
	body {
	}
	}
img {
max-width: 100%;
}

/* wrap
-------------------------------------------------------*/
#wrap {
min-width: 320px;
padding-top: 80px;
background: url("../images/visual_bg.jpg") no-repeat center top / 100% auto, linear-gradient(to right, #f5f5f5, #f5f5f5);
background: #f5f5f5 url("../images/visual_bg.jpg") no-repeat center top / 100% auto;
background-attachment: fixed;
}
#header {
min-width: 320px;
}
#wrap * {
box-sizing: border-box;
}
#wrap img {
vertical-align: top;
max-width: 100%;
height: auto;
}
#wrap .area {
position: relative;
clear: both;
display: block;
z-index: 10;
}
#wrap .area_in {
position: relative;
clear: both;
margin: 0 auto;
padding: 0 20px;
width: 100%;
max-width: 1020px;
}
@media screen and (max-width: 768px) {
	#wrap {
	background: #f5f5f5 url("../images/visual_bg_sp.jpg") no-repeat center top / 100% auto;
	background-attachment: fixed;
	padding-top: 60px;
	}
}
.contents {
position: relative;
background: rgba(0,0,0,0.6);
background: #fff;
}
/*
.contents::before {
position: absolute;
left: 0;
bottom: 100%;
content: "";
width: 100%;
height: 500px;
background: linear-gradient(to bottom, rgba(0,0,0,0.0), rgba(0,0,0,0.6));
z-index: 0;
}
*/
/* header
-------------------------------------------------------*/
#header {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 80px;
z-index: 1;
background: #fff;
box-shadow: 0 2px 10px rgba(0,0,0,0.15);
z-index: 999;
}
#header .area_in {
height: 100%;
max-width: 100%;
display: flex;
flex-flow: row nowrap;
justify-content: flex-start;
align-items: stretch;
padding-right: 0;
}
#header .branding {
position: relative;
flex: 1 0 0%;
align-self: center;
display: flex;
color: #666;
font-size: 70%;
}
#header .branding .txt {
font-size: 80%;
position: absolute;
left: -5px;
top: -10px;
}
#header .logo {
align-self: center;
padding-top: 10px;
padding-top: 0;
}
#header .logo img {
align-self: center;
flex: 0 1 160px;
height: 40px;
}
#header .logo + span {
flex: 1 0 0%;
padding-left: 10px;
line-height: 1.2;
max-width: 400px;
align-self: flex-end;
}
#header a {
transition: 0.5s;
}
	@media screen and (max-width: 768px) {
	#header {
	height: 60px;
	}
	#header .area_in {
	padding-left: 10px;
	padding-right: 50px;
	}
	#header .logo + span br {
	display: none;
	}
	#header .branding .txt {
	font-size: 70%;
	left: 0;
	top: 0;
	}
	}
	@media screen and (max-width: 420px) {
	#header .branding .txt {
	display: none;
	}
	#header .logo {
	padding: 0;
	}
	#header .logo img {
	height: 40px;
	}
	#header .text > * {
	padding-left: 120px;
	}
	}
/* menu
-------------------------------------------------------*/
#menubtn {
display: none;
position: absolute;
z-index: 99999;
width: 30px;
height: 24px;
right: 13px;
top: 17px;
cursor: pointer;
}
#menubtn {
transition: all .2s;
box-sizing: border-box;
}
#menubtn span {
display: inline-block;
transition: all .2s;
box-sizing: border-box;
}
#menubtn span {
position: absolute;
left: 0;
width: 100%;
height: 4px;
background-color: #ddd;
border-radius: 0;
}
#menubtn span:nth-of-type(1) {
top: 0;
}
#menubtn span:nth-of-type(2) {
top: 10px;
}
#menubtn span:nth-of-type(3) {
bottom: 0;
}
#menubtn.active span {
background: #fff;
}
#menubtn.active span:nth-of-type(1) {
-webkit-transform: translateY(10px) rotate(-45deg);
transform: translateY(10px) rotate(-45deg);
}
#menubtn.active span:nth-of-type(2) {
opacity: 0;
}
#menubtn.active span:nth-of-type(3) {
-webkit-transform: translateY(-10px) rotate(45deg);
transform: translateY(-10px) rotate(45deg);
}
	@media screen and (max-width: 768px) {
	#menubtn {
	display: block;
	}
	}
#menu ul {
display: flex;
width: 100%;
height: 100%;
max-width: 800px;
align-items: center;
font-size: 90%;
}
#menu ul li.sns {
display: flex;
justify-content: center;
}
#menu ul li.sns a {
padding: 10px;
}
#menu ul li.sns img {
max-width: 30px;
vertical-align: bottom;
}
#menu ul li a {
display: inline-block;
width: 100%;
height: 100%;
color: #A6AA7D;
text-decoration: none;
text-align: center;
font-weight: bold;
padding: 10px;
}
#menu li a.comp span {
display: inline-block;
background: linear-gradient(to left, rgba(0,145,178,1) 50%, rgba(27,162,61,1));
background: #A6AA7D;
background: linear-gradient(45deg, #DBD894, #BBB85E, #908B3E, #BBB85E, #DBD894);
padding: 10px 20px;
border-radius: 30px;
font-weight: bold;
color: #fff;
text-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
}
#menu li a.comp:hover {
opacity: 0.7;
}
#menu li a.comp.contact_end span {
background: #999;
}
	@media screen and (max-width: 1000px) {
	}
	@media screen and (max-width: 800px) {
	#menu ul {
	max-width: 600px;
	}
	}
	@media screen and (max-width: 768px) {
	#menu ul li a {
	padding: 5px;
	font-size: 90%;
	color: #fff;
	}
	#menu li a.comp span {
	padding: 10px 10px;
	border-radius: 30px;
	}
	#menu {
	position: fixed;
	left: 100%;
	top: 0;
	height: 100%;
	width: 100%;
	padding: 60px 0 0 0;
	background: linear-gradient(to bottom, rgba(0,145,178,1) 50%, rgba(27,162,61,1));
	background: #A6AA7D;
	transition: all 0.3s linear;
	z-index: 100;
	border-right: none;
	height: 100%;
	}
	#menu.active {
	left: 0;
	}
	#menu ul {
	border: none;
	display: block;
	width: 100%;
	max-width: 100%;
	}
	#menu ul li {
	display: block;
	}
	#menu ul li a {
	border: none;
	width: 100%;
	font-size: 130%;
	}
	#menu li > a > * {
	padding: 20px;
	color: #fff;
	}
	#menu ul li a.comp {
	padding: 20px;
	}
	#menu ul li a.comp span {
	display: block;
	background: #fff;
	color: #A6AA7D;
	}
	#menu ul li.sns .fb span {
	display: inline-block;
	background: url("../images/icon_f_w.png") no-repeat center center / contain;
	}
	#menu ul li.sns .tw span {
	display: inline-block;
	background: url("../images/icon_t_w.png") no-repeat center center / contain;
	}
	#menu ul li.sns .tw span img,
	#menu ul li.sns .fb span img {
	opacity: 0;
	}
	}

/* type2 */
@media screen and (min-width: 768px) {
#menu ul li {
height: 100%;
min-width: 90px;
}
#menu ul li a {
display: flex;
height: 100%;
width: 100%;
border-left: 1px solid #ddd;
padding: 0;
align-items: center;
justify-content: center;
color: #222;
font-size: 120%;
font-weight: normal;
}
#menu li a.comp span {
display: flex;
height: 100%;
width: 100%;
align-items: center;
justify-content: center;
border-radius: 0;
}
}
@media screen and (min-width: 950px) {
#menu ul li {
min-width: 120px;
}
}
/* visual
-------------------------------------------------------*/
#visual {
width: 100%;
height: auto;
position: relative;
background: none;
}
#visual .area_in {
position: relative;
z-index: 10;
padding: 0;
align-items: center;
justify-content: center;
height: 100%;
width: 100%;
max-width: 1200px;
background: url("../images/visual.png") no-repeat center center / auto 100%;
}
#visual .area_in img {
margin: 0 auto;
width: 1200px;
height: 630px;
opacity: 0;
/*
height: calc(100vw * (630 / 1200));
*/
}
.sp {
display: none;
}
.pc {
display: block;
}
	@media screen and (min-width: 1200px) {
	}
	@media screen and (min-width: 768px) and (max-width: 1200px) {
	#header .area_in {
	padding-left: 10px;
	}
	#header .branding {
	display: block;
	}
	#header .logo + span {
	padding: 0;
	line-height: 1.1;
	font-size: 70%;
	letter-spacing: -0.1em;
	}
	#header .branding br {
	display: none;
	}
	}
	@media screen and (max-width: 1200px) {
	#visual .area_in img {
	height: calc(100vw * (630 / 1200));
	}
	}
	@media screen and (max-width: 768px) {
	#visual {
	background: none;
	height: auto;
	}
	#visual .area_in {
	padding: 0;
	background: url("../images/visual_sp.png") no-repeat center center / auto 100%;
	}
	#visual .area_in img {
	width: 100%;
	height: calc(100vw * (600 / 800));
	}
	.sp {
	display: block;
	}
	.pc {
	display: none;
	}
	}

	@media screen and (max-width: 320px) {
	#visual .area_in img {
	width: 100%;
	height: auto;
	}
	}
/* footer
-------------------------------------------------------*/
/*
#company_area {
background: linear-gradient(to bottom, rgba(255,255,255,0), rgba(255,255,255,1));
}
#company_area .logo {
padding: 30px;
text-align: center;
}
#company_area .logo img {
width: 140px;
height: auto;
}
.techlogo, .companylogo {
padding: 30px;
text-align: center;
max-width: 200px;
margin: 0 auto;
}
*/
#footer {
background: #fff;
padding: 50px 0;
}
#footer .text {
text-align: center;
}
#footer .copy {
text-align: center;
font-size: 90%;
padding: 20px;
color: #222;
}
#nav {
clear: both;
padding: 20px;
}
#nav ul {
display: flex;
flex-flow: row nowrap;
justify-content: center;
align-items: stretch;
line-height: 1;
}
#nav ul li {
border-right: 1px solid #ccc;
}
#nav ul li:last-child {
border-right: none;
}
#nav ul li a {
color: #222;
display: inline-block;
padding: 0 20px;
text-decoration: none;
}
#nav ul li a.contact_end {
opacity: 0.3;
}
#nav ul li a:hover {
text-decoration: underline;
}
.footer_link {
text-align: center;
font-size: 90%;
}
.footer_link a {
color: #222;
text-decoration: none;
}
.footer_link a:hover {
text-decoration: underline;
}
	@media screen and (max-width: 768px) {
	#nav {
	padding: 0 0 20px 0;
	}
	#nav ul {
	flex-flow: column wrap;
	justify-content: flex-start;
	}
	#nav ul li {
	border-right: none;
	border-bottom: 1px solid rgba(255,255,255,0.3);
	border-bottom: 1px solid #ccc;
	}
	#nav ul li:last-child {
	}
	#nav ul li a {
	display: block;
	padding: 20px 0;
	text-decoration: none;
	}
	}

/* pagetop
-------------------------------------------------------*/
#pagetop {
position: fixed;
right: 10px;
bottom: -100px;
transition: all 0.3s linear;
opacity: 0;
z-index: 20;
}
#pagetop.active {
bottom: 10px;
opacity: 0.9;
}
#pagetop:hover {
opacity: 0.6;
}
#pagetop a {
display: block;
width: 60px;
height: 60px;
border-radius: 30px;
background: rgba(0,0,0,0.6);
text-indent: -9999px;
}
#pagetop a:before {
content: "";
position: absolute;
right: 50%;
top: 50%;
width: 15px;
height: 15px;
margin: -6px -9px 0 0;
border-top: 3px solid #fff;
border-right: 3px solid #fff;
transform: rotate(-45deg);
}
	@media screen and (max-width: 768px) {
	#pagetop.active,
	#pagetop:hover {
	opacity: 0.8;
	}
	#pagetop a {
	width: 40px;
	height: 40px;
	border-radius: 20px;
	}
	#pagetop a:before {
	width: 10px;
	height: 10px;
	margin: -4px -6px 0 0;
	}
	}
/* lead
-------------------------------------------------------*/
#lead_area {
clear: both;
padding: 0 0 50px;
background: linear-gradient(to bottom, rgba(237,140,85,0), rgba(237,140,85,0.7));
background: none;
}
#lead_area .txt {
color: #fff;
font-size: 120%;
line-height: 1.6;
padding: 0;
}
#lead_area .lead_img {
display: block;
text-align: center;
}
.lead_box {
background: rgba(107,28,7,0.4);
background: rgba(0,0,0,0.4);
background: linear-gradient(to top, rgba(0,0,0,0.5), rgba(0,0,0,1));
box-shadow: 0 0 10px rgba(0,0,0,0.2);
padding: 50px;
}
@media screen and (max-width: 768px) {
.lead_box {
padding: 30px;
}
}
@media screen and (max-width: 400px) {
.lead_box {
padding: 20px;
}
}
/* contact
-------------------------------------------------------*/
.contact_area {
clear: both;
padding: 0 20px;
padding: 40px 20px;
background: #f2f2f2;
background: linear-gradient(to bottom, rgba(0,0,0,0.0), rgba(0,0,0,0.2), rgba(0,0,0,0.4));
background: linear-gradient(to bottom, rgba(255,255,255,0.0), rgba(255,255,255,0.5), rgba(255,255,255,1));
}
.contact_btn_box {
text-align: center;
padding: 0 20px;
font-size: 90%;
}
.logolist_box + .contact_btn_box {
padding: 50px 20px 120px;
}
.contact_btn_box .txt {
display: block;
text-align: center;
padding-top: 20px;
font-size: 100%;
color: #fff;
}
	@media screen and (max-width: 768px) {
	.contact_area {
	padding: 20px;
	}
	.contact_btn_box {
	padding-bottom: 0;
	}
	.logolist_box + .contact_btn_box {
	padding: 50px 20px 120px;
	}
	}

.contact_btn {
position: relative;
margin: 0 auto;
display: flex;
width: 100%;
height: 80px;
max-width: 600px;
border-radius: 40px;
background: #A6AA7D;
box-shadow: 0 0 10px rgba(211,209,141,0.8);
box-shadow: 0 0 10px rgba(0,0,0,0.1);
font-weight: bold;
text-decoration: none;
}
.contact_btn span {
display: flex;
width: 100%;
height: 80px;
align-items: center;
justify-content: center;
background: #A6AA7D;
background: linear-gradient(45deg, #908B3E, #BBB85E, #DBD894, #BBB85E, #908B3E, #BBB85E, #DBD894, #BBB85E, #908B3E);
border: 2px solid #908B3E;
text-shadow: 0 0 10px rgba(0,0,0,0.2);
text-align: center;
color: #fff;
font-size: 180%;
transition: 0.3s;
border-radius: 40px;
}
.contact_btn span:hover {
opacity: 0.6;
}
.contact_btn > *:before {
content: "";
position: absolute;
right: 20px;
top: 50%;
width: 10px;
height: 10px;
margin-top: -9px;
border-bottom: 3px solid #fff;
border-right: 3px solid #fff;
transform: rotate(-45deg);
}
.contact_btn.contact_end {
background: #999;
}
	@media screen and (max-width: 768px) {
	.contact_area .title {
	font-size: 150%;
	}
	}
	@media screen and (max-width: 520px) {
	.contact_area .title {
	}
	.contact_area .title > * {
	display: inline;
	}
	.contact_btn {
	}
	}
	@media screen and (max-width: 420px) {
	.contact_btn {
	height: 65px;
	}
	.contact_btn > *:before {
	width: 10px;
	height: 10px;
	right: 15px;
	margin-top: -7px;
	border-bottom: 3px solid #fff;
	border-right: 3px solid #fff;
	}
	.contact_btn span {
	height: 65px;
	border-radius: 33px;
	font-size: 130%;
	}
	}
.contact_area .title {
text-align: center;
font-size: 200%;
margin: 0 auto;
padding-bottom: 20px;
line-height: 1.4;
max-width: 760px;
}
.contact_area .title > * {
display: inline-block;
}
.contact_area .title b {
font-weight: normal;
color: #BBB85E;
}
	@media screen and (max-width: 768px) {
	.contact_area .title {
	font-size: 150%;
	}
	}
	@media screen and (max-width: 520px) {
	.contact_area .title {
	font-size: 120%;
	}
	.contact_area .title > * {
	display: inline;
	}
	}
/* bar
-------------------------------------------------------*/
.base_tit {
position: relative;
padding: 40px 0 20px;
margin-bottom: 40px;
text-align: center;
color: #fff;
}
/*
.base_tit > b::before {
content: "";
position: absolute;
left: 50%;
bottom: 0;
width: 50px;
height: 3px;
background: #101F49;
transform: translate(-50%,0);
}
*/
.base_tit > * {
display: block;
text-align: center;
}
.base_tit > b {
font-size: 250%;
}
.base_tit > span {
font-size: 100%;
}
@media screen and (max-width: 768px) {
	.base_tit {
	}
	.base_tit > b {
	font-size: 150%;
	}
	.base_tit > span {
	font-size: 80%;
	}
}
.base_bar {
padding: 30px 0 10px 0;
margin-bottom: 30px;
border-bottom: 1px solid #333;
color: #333;
font-size: 170%;
font-weight: bold;
}
/*
.base_bar {
position: relative;
padding: 40px 0;
color: #333;
font-size: 170%;
}
.base_bar {
}
.base_bar > b {
position: relative;
display: block;
padding-left: 20px;
line-height: 1;
}
.base_bar > b::before {
content: "";
position: absolute;
left: 0;
top: 50%;
width: 5px;
height: 30px;
border-radius: 3px;
background: #444444;
transform: translate(0,-50%);
}
.base_bar > b > span {
display: inline-block;
}
*/
.base_text {
line-height: 1.6;
margin-bottom: 1.6em;
}
	@media screen and (max-width: 420px) {
	.base_title {
	font-size: 180%;
	padding: 20px 0;
	}
	}

/* popup
-------------------------------------------------------*/
.popup_contents {
display: none;
}
.mfp-content {
max-width: 700px!important;
}
.mfp-close {
position: fixed!important;
top: 15px!important;
right: 15px!important;
width: 30px!important;
height: 30px!important;
opacity: 1!important;
text-indent: -9999px;
position: relative;
}
.mfp-close:before,
.mfp-close:after {
position: absolute;
left: 0;
top: 50%;
content: "";
width: 30px;
height: 2px;
background: #fff;
}
.mfp-close:before {
transform: rotate(45deg);
}
.mfp-close:after {
transform: rotate(-45deg);
}
.mfp-close:hover {
opacity: 0.7!important;
}
.popup_box {
background: #fff;
border-radius: 5px;
padding: 20px;
padding: 0 0 20px;
margin: 60px 10px 10px 10px;
}
.popup_box.type_speaker {
padding: 0 20px 20px;
}
.popup_box .date {
display: flex;
align-items: center;
justify-content: space-between;
background: #eee;
padding: 20px;
font-weight: bold;
border-radius: 5px 5px 0 0;
}
.popup_box .date > b {
display: inline-block;
font-size: 130%;
margin-right: 20px;
font-weight: bold;
}
.popup_box .date > span {
font-size: 130%;
display: inline-block;
margin-right: 20px;
}
.popup_box .date > em {
font-size: 130%;
display: inline-block;
margin-right: 20px;
font-style: normal;
}
/*
.popup_box .date > *:nth-child(2) {
font-size: 130%;
}*/
.popup_box .date > *.time {
flex: 1 0 0%;
text-align: right;
}
.popup_box .title {
line-height: 1.4;
padding: 20px 20px 0;
position: relative;
padding-right: 60px;
}
.popup_box .title .ico {
display: inline-block;
margin: 5px 5px 5px 0;
line-height: 1;
}
.popup_box .title .ico > * {
display: flex;
align-items: center;
justify-content: center;
background: #242D48;
font-size: 80%;
padding: 5px 10px;
color: #fff;
height: inherit;
font-weight: normal;
border-radius: 2px;
letter-spacing: 0.05em;
}
.popup_box .title .ico > * * {
font-weight: normal;
}
.popup_box .title .id {
display: inline-block;
margin: 5px 5px 5px 0;
line-height: 1;
display: none;
}
.popup_box .title .id > * {
display: flex;
align-items: center;
justify-content: center;
background: #242D48;
font-size: 80%;
padding: 0 10px 0 10px;
color: #fff;
height: 30px;
font-weight: normal;
border-radius: 5px;
margin-right: 5px;
letter-spacing: 0.05em;
}
.popup_box .title .tit {
display: block;
font-size: 150%;
}
.popup_box .txt.gaiyou {
padding: 20px 20px 0;
line-height: 1.6;
font-size: 120%;
}
.popup_box .layout {
display: flex;
padding: 20px 0 0;
}
.popup_box .layout .photo {
flex: 0 1 220px;
padding-right: 20px;
}
.popup_box .layout .info {
flex: 1 0 0%;
}
.popup_box .name_bar {
display: inline-block;
padding-bottom: 10px;
}
.popup_box .name_bar > * {
display: flex;
align-items: center;
justify-content: center;
background: #fff;
border: 2px solid #A6AA7D;
padding: 3px 10px 0 10px;
color: #A6AA7D;
height: 26px;
font-weight: bold;
}
.popup_box .txt .job {
line-height: 1.6;
margin-bottom: 10px;
}
.popup_box .txt .name {
line-height: 1.6;
font-size: 130%;
margin-bottom: 10px;
}
.popup_box .txt.prof {
padding: 20px 0 0;
line-height: 1.6;
}
.popup_box .layout_box {
padding: 0 20px;
}
/*
.popup_box .layout .name_bar {
display: none;
}
.popup_box .txt.gaiyou + .layout .name_bar,
.popup_box .txt.gaiyou + .layout + .layout .name_bar {
display: inline-block;
}
.popup_box.type_a .title .ico > *,
.popup_box.type_a .title .id > * {
background: #4569E2;
}
.popup_box.type_a .title .tit {
color: #4569E2;
}
.popup_box.type_b .title .ico > *,
.popup_box.type_b .title .id > * {
background: #772594;
}
.popup_box.type_b .title .tit {
color: #772594;
}
*/
.popup_box .layout + .layout {
padding-top: 20px;
margin-top: 20px;
border-top: 1px solid #ddd;
}
	@media screen and (max-width: 768px) {
	.popup_box .date {
	text-align: center;
	}
	.popup_box .layout {
	display: block;
	}
	.popup_box .layout .photo {
	padding: 0 0 20px;
	text-align: center;
	margin: 0 auto;
	}
	.popup_box .layout .photo img {
	max-width: 100%;
	}
	.popup_box .layout .info {
	flex: 1 0 0%;
	}
	}
	@media screen and (max-width: 510px) {
	.popup_box .date {
	flex-flow: row wrap;
	}
	.popup_box .date > b,
	.popup_box .date > span,
	.popup_box .date > em {
	font-size: 100%;
    margin-right: 10px;
	}
	/*
	.popup_box .date > .time {
	flex: 1 0 100%;
	text-align: center;
    width: 100%;
	}
	*/
	}
.popup_box .date {
background: #D9E9FA;
color: #A6AA7D;
}
/* speakers_area
-------------------------------------------------------*/
#speakers_area {
position: relative;
/*
background: url("../images/bg03.jpg") repeat-y center top / 100% auto;
background-attachment: fixed;
*/
}
/*
#speakers_area::before {
content: "";
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
background: linear-gradient(to bottom, rgba(1,176,255,0.0), rgba(1,176,255,0.5)); 
}
*/
#speakers_area .area_in {
/*
max-width: inherit;
max-width: 1600px;
*/
}
.photolist_box {
padding: 0 0 100px 0;
padding: 0;
}
.photolist_bar {
text-align: center;
line-height: 1;
}
.photolist_bar b {
font-weight: normal;
display: inline-block;
padding: 10px 20px;
border-radius: 20px;
background: #091E42;
background: rgba(255,255,255,0.1);
color: #fff;
}
.photolist {
display: flex;
flex-flow: row wrap;
justify-content: center;
}
.photolist li {
flex: 0 1 25%;
flex: 0 1 20%;
padding: 10px;
}
.photolist li > *.link,
.photolist li > *.nolink,
.photolist li > *.popup {
transition: .3s;
cursor: pointer;
display: block;
padding: 0;
height: 100%;
/*
color: #fff;
border: 3px solid #fff;
border: none;
background: none;
color: #fff;
*/
}
.photolist li > *:hover {
opacity: 0.7;
/*
box-shadow: 0 0 15px rgb(23 184 255 / 30%);
background: #fff;
border: 3px solid #287AFF;
border-image: linear-gradient(to right, #287AFF 0%, #59E0F6 100%);
border-image: linear-gradient(to right, #19B8FF 0%, #59E0F6 100%);
border-image-slice: 1;
*/
}
.photolist li > * .layout {
text-align: center;
height: 100%;
padding-bottom: 10px;
display: block;
}
.photolist li .photo {
/*
border-radius: 0;
overflow: hidden;
border: 3px solid #287AFF;
border-image: linear-gradient(to right, #287AFF 0%, #59E0F6 100%);
border-image: linear-gradient(to right, #19B8FF 0%, #59E0F6 100%);
border-image-slice: 1;
*/
}
.photolist img {
width: 100%;
height: auto;
}
.photolist .company {
line-height: 1.2;
padding: 10px 0;
color: #fff;
}
.photolist .company .job + br {
display: none;
}
.photolist .company > * {
display: block;
margin-bottom: 5px;
}
.photolist .company .name {
display: inline-block;
font-style: normal;
font-size: 120%;
}
.photolist .company .job {
font-size: 80%;
line-height: 1.4;
}
.photolist.slide2 li {
flex: 0 1 14%;
font-size: 80%;
}

@media screen and (max-width: 768px) {
	.photolist_box {
	padding: 0 0 40px 0;
	}
	.photolist_box > .bar {
	font-size: 140%;
	}
	.photolist li {
	flex: 0 1 50%;
	flex: 0 1 33%;
	}
	.photolist li > * {
	padding: 20px 10px 0;
	}
	.photolist .company .name {
	font-size: 90%;
	}
}
.slide-arrow {
max-width: 40px!important;
position: absolute;
top: 50%;
top: 40%;
z-index: 10;
cursor: pointer;
padding: 0;
transform: translateY(-20px);
}
.prev-arrow {
left: 0;
}
.next-arrow {
right: 0;
}
.slick-dots {
bottom: 0!important;
}
.slick-list {
padding-top: 10px!important;
}
.slick-dots li button:before,
.slick-dots li.slick-active button:before {
color: #101F49!important;
}
.slick-dotted.slick-slider {
margin-bottom: 0!important;
}
.slick-track {
margin: 0 auto;
}

/* program_area
-------------------------------------------------------*/
#timetable_area {
background: #eee;
padding: 50px 0;
background: none;
}
.program_box {
margin-bottom: 20px;
}
.program_table {
margin: 0 auto;
margin-bottom: 20px;
max-width: 980px;
background: #fff;
border: none;
box-shadow: 0 0 10px rgba(0,0,0,0.1);
box-shadow: none;
border: 3px solid #ccc;
}
.program_table dl.program {
display: flex;
flex-flow: row wrap;
background: #fff;
border-radius: 0;
}
.program_table dl.program:not(:last-child) {
border: none;
border-bottom: 1px solid #ccc;
}
.program_table dt {
flex: 0 1 20%;
display: flex;
background: #f2f2f2;;
align-items: center;
justify-content: center;
border-right: 1px solid #ccc;
padding: 20px 0;
font-weight: bold;
font-size: 110%;
letter-spacing: 0.05em;
}
.program_table dt > *:not(.time) {
display: none;
}
/*
.program_table dl.col1 dd {
width: 80%;
flex: 1 0 0;
}
*/
.program_table dd {
flex: 1 0 0%;
background: #fff;
}
.program_table dd > *.nolink,
.program_table dd > *.box {
display: block;
padding: 20px 20px 10px 20px;
}
.program_table dd > *.popup {
display: block;
padding: 20px;
cursor: pointer;
transition: .3s;
height: 100%;
position: relative;
}
@media screen and (min-width: 768px) {
.program_table dd > *.popup:hover {
background: rgba(80,132,196,0.1);
background: #D9E9FA;
}
}
.program_table dd .date {
display: none;
}
.program .title {
line-height: 1.4;
padding-bottom: 10px;
}
.program .title .id {
display: inline-block;
display: none;
margin: 5px 5px 5px 0;
line-height: 1;
}
.program .title .id > * {
display: flex;
align-items: center;
justify-content: center;
background: #242D48;
padding: 0 10px 0 10px;
color: #fff;
height: 30px;
font-weight: normal;
border-radius: 5px;
margin-right: 5px;
}
.program .title .ico {
display: inline-block;
margin: 5px 5px 5px 0;
line-height: 1;
}
.program .title .ico > * {
display: flex;
align-items: center;
justify-content: center;
background: #A6AA7D;
font-size: 100%;
padding: 5px 10px;
color: #fff;
height: inherit;
font-weight: normal;
border-radius: 2px;
letter-spacing: 0.05em;
}
.program .title .tit {
display: inline;
font-size: 150%;
}
.popup_box .title .ico > * .mark,
.program .title .ico > * .mark {
position: absolute;
right: 10px;
top: 50%;
transform: translate(0,-50%);
width: 40px;
height: 40px;
background: url("../images/item00.png") no-repeat center center / contain;
text-indent: -9999px;
}
.popup_box.type_0 .title .ico > *,
.program .type_0 .title .ico > * {
background: #EC6D65;
}
.program .txt.gaiyou {
font-size: 110%;
margin-bottom: 20px;
line-height: 1.6;
}
.program .layout {
display: flex;
padding-bottom: 20px;
}
.program .layout + .layout {
padding-top: 20px;
border-top: 1px solid #ddd;
}
.program .layout .photo {
flex: 0 1 200px;
}
.program .layout .photo + .info {
padding-left: 20px;
flex: 1 0 0%;
}
.program .layout_bar {
background: #eee;
padding: 10px;
margin-bottom: 10px;
font-weight: bold;
}
.program .txt .job {
line-height: 1.2;
font-size: 90%;
margin-bottom: 10px;
}
.program .txt .name {
line-height: 1.6;
font-size: 130%;
margin-bottom: 10px;
}
.program .txt.prof {
position: relative;
padding: 0 20px;
margin-top: 10px;
border-left: 2px solid #eee;
border-right: 2px solid #eee;
font-size: 90%;
}
.program .txt.prof::before,
.program .txt.prof::after {
content: "";
width: 5px;
height: calc(100% - 4px);
position: absolute;
left: 0;
top: 0;
border-top: 2px solid #eee;
border-bottom: 2px solid #eee;
}
.program .txt.prof::after {
left: inherit;
right: 0;
}
/*
.program .txt.prof {
display: none;
}
.program .name_bar {
display: none;
}
.program .txt.gaiyou + .layout .name_bar,
.program .txt.gaiyou + .layout + .layout .name_bar {
display: inline-block;
}
*/

	@media screen and (max-width: 768px) {
	.program_table dl.program {
	display: block;
	}
	/*
	.program_table dl.program > * {
	display: block;
	}
	*/
	.program_table dt.time {
	text-align: center;
	padding: 20px;
	border-right: none;
	font-size: 110%;
	}
	.program_table dd {
	}
	.program .title .ico > * {
	font-size: 80%;
	text-align: center;
	}

	/*
	.program_table dt.time > * {
	display: inline;
	}*/
	.program .box {
	padding: 20px;
	}
	}
	@media screen and (max-width: 520px) {
	/*
	.program .layout {
	display: block;
	}
	*/
	.program .title .tit {
	font-size: 130%;
	}
.program .layout {
display: block;
padding-bottom: 20px;
}
	.program .layout .photo {
	flex: 0 1 60px;
	padding: 0 10px 20px 0;
	text-align: center;
	margin: 0 auto;
	}
	.program .layout .info {
	flex: 1 0 0%;
	}
	}


/* area
-------------------------------------------------------*/
#overview_area {
}
.overviewe_box {
margin: 0 auto;
padding-bottom: 50px;
}
.dlist {
border: 3px solid #ccc;
}
.dlist dl {
display: flex;
background: #fff;
}
.dlist dl:nth-child(even) {
background: #f2f2f2;
}
.dlist dl dt {
flex: 0 1 20%;
border-right: 1px solid #ccc;
font-weight: bold;
display: flex;
align-items: center;
justify-content: center;
padding: 20px;
}
.dlist a {
color:#A6AA7D;
text-decoration: underline;
}
.dlist dd {
flex: 1 0 0%;
padding: 20px;
}
.overview_txt {
padding-top: 20px;
}
	@media screen and (max-width: 768px) {
	.dlist dl {
	display: block;
	}
	.dlist dl:nth-child(even) {
	background: #fff;
	}
	.dlist dl dt {
	border: none;
	background: #f2f2f2;
	}
	.dlist dl:not(:first-child) dt {
	border-top: 1px solid #ccc;
	}
	}

/* sponsor_area
-------------------------------------------------------*/
#sponsor_area {
padding-bottom: 50px;
}
.logolist_box {
background: #004C83;
height: 100%;
border-radius: 0;
padding: 10px;
box-shadow: 0 0 10px rgba(0,0,0,0.7);
}
.logolist_box_in {
background: #fff;
padding: 50px;
}
#wrap.page_alldays .logolist_box {background: #004C83;}
#wrap.page_day1 .logolist_box {background: #FF625E;}
#wrap.page_day2 .logolist_box {background: #FF963D;}
#wrap.page_day3 .logolist_box {background: #45A411;}
#wrap.page_day4 .logolist_box {background: #95B30B;}
#wrap.page_day5 .logolist_box {background: #B545BF;}
#wrap.page_day6 .logolist_box {background: #5C7E5C;}
#wrap.page_day7 .logolist_box {background: #416B60;}
#wrap.page_day8 .logolist_box {background: #C45D09;}
#wrap.page_day9 .logolist_box {background: #664899;}
#wrap.page_day10 .logolist_box {background: #2A7286;}

.logolist_box ul {
display: flex;
flex-flow: row wrap;
justify-content: center;
margin: 0 auto;
max-width: 870px;
padding-bottom: 30px;
}
.logolist_box ul > * {
flex: 0 1 33%;
padding: 10px;
text-align: center;
}
.logolist_box.type03 ul > * {
flex: 0 1 24.8%;
}
.logolist_box a {
display: block;
transition: all 0.2s linear;
}
.logolist_box a:hover {
opacity: 0.7;
}
.logolist_box img {
}
.logolist_box .bar {
text-align: center;
padding: 20px;
margin-bottom: 20px;
background: #f4f4f4;
}
.logolist_txt {
text-align: right;
padding: 0 20px;
}
@media screen and (max-width: 900px) {
	.logolist > ul > * {
	flex: 0 1 50%!important;
	}
}
@media screen and (max-width: 768px) {
	.logolist > * > *:not(:last-child) {
	margin-bottom: 10px;
	}
	.logolist_box_in {
	padding: 20px;
	}
}
@media screen and (max-width: 420px) {
	.logolist > ul > * {
	flex: 0 1 100%!important;
	padding: 0;
	}
}

/* temp
-------------------------------------------------------*/
.base_pcdin { display: inline!important;}
.base_pcdinb { display: inline-block!important;}
.base_pcdblock { display: block!important;}
.base_pcdno {display: none!important;}
	@media screen and (max-width: 768px) {
	.base_spdin { display: inline!important;}
	.base_spdinb { display: inline-block!important;}
	.base_spdblock { display: block!important;}
	.base_spdno {display: none!important;}
	}
.base_din { display: inline!important;}
.base_dinb { display: inline-block!important;}
.base_dblock { display: block!important;}
.cf:before { content:""; display:table;}
.cf:after { content:""; display:table; clear:both;}
.cf { zoom:1;}
.base_textstr { color: rgba(235,0,70,1);}
.base_texterr { color: rgba(235,0,70,1);}
.base_textem { color: #444444;}
.base_textno { color: #ccc;}
.base_textmarker { background: #FFFF99;}
.base_sizess { font-size: 70%;}
.base_sizes { font-size: 80%;}
.base_sizem { font-size: 100%;}
.base_sizel { font-size: 120%;}
.base_sizell { font-size: 150%;}
.base_sizelll { font-size: 200%;}
.base_fl { float: left;}
.base_fr { float: right;}
.base_fn { float: none;}
.base_tl { text-align: left;}
.base_tr { text-align: right;}
.base_tc { text-align: center;}
.base_m0 { margin: 0!important;}
.base_m5 { margin: 5px!important;}
.base_m10 { margin: 10px!important;}
.base_m20 { margin: 20px!important;}
.base_m30 { margin: 30px!important;}
.base_m40 { margin: 40px!important;}
.base_m50 { margin: 50px!important;}
.base_mt0 { margin-top: 0!important;}
.base_mt5 { margin-top: 5px!important;}
.base_mt10 { margin-top: 10px!important;}
.base_mt20 { margin-top: 20px!important;}
.base_mt30 { margin-top: 30px!important;}
.base_mt40 { margin-top: 40px!important;}
.base_mt50 { margin-top: 50px!important;}
.base_mb0 { margin-bottom: 0!important;}
.base_mb5 { margin-bottom: 5px!important;}
.base_mb10 { margin-bottom: 10px!important;}
.base_mb20 { margin-bottom: 20px!important;}
.base_mb30 { margin-bottom: 30px!important;}
.base_mb40 { margin-bottom: 40px!important;}
.base_mb50 { margin-bottom: 50px!important;}
.base_ml0 { margin-left: 0!important;}
.base_ml5 { margin-left: 5px!important;}
.base_ml10 { margin-left: 10px!important;}
.base_ml20 { margin-left: 20px!important;}
.base_ml30 { margin-left: 30px!important;}
.base_ml40 { margin-left: 40px!important;}
.base_ml50 { margin-left: 50px!important;}
.base_mr0 { margin-right: 0!important;}
.base_mr5 { margin-right: 5px!important;}
.base_mr10 { margin-right: 10px!important;}
.base_mr20 { margin-right: 20px!important;}
.base_mr30 { margin-right: 30px!important;}
.base_mr40 { margin-right: 40px!important;}
.base_mr50 { margin-right: 50px!important;}
.base_p0 { padding: 0!important;}
.base_p5 { padding: 5px!important;}
.base_p10 { padding: 10px!important;}
.base_p20 { padding: 20px!important;}
.base_p30 { padding: 30px!important;}
.base_p40 { padding: 40px!important;}
.base_p50 { padding: 50px!important;}
.base_pt0 { padding-top: 0!important;}
.base_pt5 { padding-top: 5px!important;}
.base_pt10 { padding-top: 10px!important;}
.base_pt20 { padding-top: 20px!important;}
.base_pt30 { padding-top: 30px!important;}
.base_pt40 { padding-top: 40px!important;}
.base_pt50 { padding-top: 50px!important;}
.base_pb0 { padding-bottom: 0!important;}
.base_pb5 { padding-bottom: 5px!important;}
.base_pb10 { padding-bottom: 10px!important;}
.base_pb20 { padding-bottom: 20px!important;}
.base_pb30 { padding-bottom: 30px!important;}
.base_pb40 { padding-bottom: 40px!important;}
.base_pb50 { padding-bottom: 50px!important;}
.base_pl0 { padding-left: 0!important;}
.base_pl5 { padding-left: 5px!important;}
.base_pl10 { padding-left: 10px!important;}
.base_pl20 { padding-left: 20px!important;}
.base_pl30 { padding-left: 30px!important;}
.base_pl40 { padding-left: 40px!important;}
.base_pl50 { padding-left: 50px!important;}
.base_pr0 { padding-right: 0!important;}
.base_pr5 { padding-right: 5px!important;}
.base_pr10 { padding-right: 10px!important;}

.base_pr20 { padding-right: 20px!important;}
.base_pr30 { padding-right: 30px!important;}
.base_pr40 { padding-right: 40px!important;}
.base_pr50 { padding-right: 50px!important;}
.base_wa { width: auto!important;}
.base_w100p { width: 100%!important;}
.base_w98p { width: 98%!important;}
.base_w96p { width: 96%!important;}
.base_w90p { width: 90%!important;}
.base_w86p { width: 86%!important;}
.base_w80p { width: 80%!important;}
.base_w70p { width: 70%!important;}
.base_w60p { width: 60%!important;}
.base_w50p { width: 50%!important;}
.base_w40p { width: 40%!important;}
.base_w33p { width: 33.33%!important;}
.base_w30p { width: 30%!important;}
.base_w20p { width: 20%!important;}
.base_w10p { width: 10%!important;}
.base_w300 { width: 300px!important;}
.base_w250 { width: 250px!important;}
.base_w200 { width: 200px!important;}
.base_w150 { width: 150px!important;}
.base_w100 { width: 100px!important;}
.base_w80 { width: 70px!important;}
.base_w60 { width: 60px!important;}
.base_w50 { width: 50px!important;}
.base_w30 { width: 30px!important;}
.base_w10 { width: 10px!important;}
.base_ha { height: auto!important;}
.base_h100p { height: 100%!important;}
.base_h98p { height: 98%!important;}
.base_h96p { height: 96%!important;}
.base_h90p { height: 90%!important;}
.base_h86p { height: 86%!important;}
.base_h80p { height: 80%!important;}
.base_h70p { height: 70%!important;}
.base_h60p { height: 60%!important;}
.base_h50p { height: 50%!important;}
.base_h40p { height: 40%!important;}
.base_h33p { height: 33.33%!important;}
.base_h30p { height: 30%!important;}
.base_h20p { height: 20%!important;}
.base_h10p { height: 10%!important;}
.base_h300 { height: 300px!important;}
.base_h250 { height: 250px!important;}
.base_h200 { height: 200px!important;}
.base_h150 { height: 150px!important;}
.base_h100 { height: 100px!important;}
.base_h80 { height: 70px!important;}
.base_h60 { height: 60px!important;}
.base_h50 { height: 50px!important;}
.base_h30 { height: 30px!important;}
.base_h10 { height: 10px!important;}
	@media screen and (max-width: 768px) {
	.base_sp_p0 { padding: 0!important;}
	.base_sp_pb0 { padding-bottom: 0!important;}
	.base_sp_pt0 { padding-top: 0!important;}
	.base_sp_m0 { margin: 0!important;}
	.base_sp_mb0 { margin-bottom: 0!important;}
	.base_sp_mt0 { margin-top: 0!important;}
	}
	
.flow {

}
.flowList {
display: flex;
flex-flow: row nowrap;
align-items: flex-start;
justify-content: center;
padding: 20px 0;
}
.flowList .item {
position: relative;
width: 25%;
padding: 0 20px;
}
.flowList .item:not(:last-child)::after {
content: "";
position: absolute;
right: 0;
top: 100px;
transform: rotate(-45deg) translate(50%,-10%);
width: 15px;
height: 15px;
border-right: 3px solid #ccc;
border-bottom: 3px solid #ccc;
}
.flowList .item .title {
position: relative;
background: #111;
background: linear-gradient(transparent, rgba(255,255,255,0.3)),#111;
width: 200px;
height: 200px;
color: #fff;
text-align: center;
display: flex;
flex-flow: column nowrap;
align-items: center;
justify-content: center;
border-radius: 100px;
padding: 20px;
margin: 0 auto;
}
.flowList .item .title > * {
display: block;
text-align: center;
}
.flowList .item .title > span {
font-size: 200%;
padding-bottom: 10px;
}
.flowList .item .title > b {
width: 100%;
border-top: 1px solid #fff;
padding: 20px 0 0 0;
min-height: 100px;
font-weight: normal;
}
.flowList .item .text {
text-align: left;
padding: 20px 0;
font-size: 110%;
}
	@media screen and (max-width: 1000px) {
    .flowList .item .title {
    width: 160px;
    height: 160px;
    border-radius: 80px;
    padding: 10px;
    }
    .flowList .item:not(:last-child)::after {
    top: 80px;
    }
    .flowList .item .title > span {
    font-size: 150%;
    padding-bottom: 10px;
    }
    .flowList .item .title > b {
    padding: 10px 0 0 0;
    min-height: 80px;
    }
    .flowList .item .text {
    padding: 10px 0;
    }
    }
	@media screen and (max-width: 800px) {
    .flowList {
    flex-flow: column nowrap;
    }
    .flowList .item {
    width: 100%;
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
    justify-content: space-between;
    padding: 0 0 20px 0;
    }
    .flowList .item .title {
    width: 160px;
    flex: 0 0 160px;
    }
    .flowList .item .text {
    flex: 1;
    padding: 10px 20px;
    }
    .flowList .item .title > * {
    line-height: 1.3;
    }
	.flowList .item:not(:last-child)::after {
	right: 50%;
	top: inherit;
	bottom: 0;
	transform: rotate(45deg) translate(50%,-100%);
	width: 15px;
	height: 15px;
	border-right: 3px solid #ccc;
	border-bottom: 3px solid #ccc;
	}
    }
.blogo {
display: flex;
align-items: center;
justify-content: center;
padding: 30px 0;
}
.blogo > * {
width: 50%;
}
/* effect
-------------------------------------------------------*　/
body #wrap {
opacity: 0;
transition: 0.3s;
}
body.effect_active #wrap {
opacity: 1;
}
body #visual {
opacity: 0;
transition: 2s;
}
body.effect_active #visual {
opacity: 1;
}
.area {
overflow: hidden;
}
.base_tit {
opacity: 0;
transform: translate(2000px,0);
transition: .7s;
}
#wrap:not(.page_alldays) .base_tit {
transform: translate(0,100px);
}
#wrap:not(.page_alldays) .area.effect_active .base_tit {
transform: translate(0,0);
}

.area.effect_active .base_tit {
opacity: 1;
transform: translate(0,0);
}
.photolist_box,
.speakers_ban,
.contact_btn_box,
.schedule_calendar_box,
.banner_box li,
.timetable_box_out,
.dlist,
.logolist_box {
opacity: 0;
transform: translate(0,100px);
transition: .7s;
}
.photolist_box.effect_active,
.speakers_ban.effect_active,
.contact_btn_box.effect_active,
.schedule_calendar_box.effect_active,
.banner_box li.effect_active,
.timetable_box_out.effect_active,
.dlist.effect_active,
.logolist_box.effect_active {
opacity: 1;
transform: translate(0,0);
}

#alldays.timetable_box {
display: none;
}

*/
