@charset "utf-8";

/*//////////////////////////////////////////////////

style.css

Copyright (C) 2017 Impress Corporation, an Impress Group company. All rights reserved.
----------------------------------------
Content

  1. calendar
  2. header
  3. navigation
  4. contents
    1. information
    3. lead
    4. chairman
    5-1. pickup-K-1
    5-2. pickup-lecturer
    5-3. pickup
    6. sponsor
    7. overview
    8. timetable
    9. exhibition
  5. footer
  6. Media Query
  7. "colorbox.js" Setting
  8. "swiper.js" Setting

//////////////////////////////////////////////////*/

html,body,h1,h2,h3,h4,h5,h6,p,ul,ol,li,dl,dt,dd,table,th,td,div,figure {
  margin: 0;
  padding: 0;
  font-size: 100%;
}
body {
  background-color: #1c1c1c;
  background-attachment: fixed;
  font-family: 'メイリオ',Meiryo,'ヒラギノ角ゴ Pro','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック',sans-serif;
  -webkit-text-size-adjust:100%;
}
h1 { line-height: 0; text-align: center; }
h2 { font-size: 150%; margin: 1.5em 0 .5em; }
h3 { font-size: 120%; margin: 1.5em 0 .5em; }
p { margin: 1em 0; }
a,dd { word-break: break-all; }
ul,ol{ margin-left: 1.5em; }
em { font-style: normal; }
img { max-width: 100%; border:none; }
table,tr,th,td {
  box-sizing: border-box;
}
table {
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse;
  border: 1px solid #aaa;
}
th {
  padding: 4px;
  background-color: #666666;
  color: #ffffff;
  font-weight: bold;
  text-align: center;
  vertical-align: top;
}
td {
  text-align: left;
  vertical-align: middle;
  padding: 1em;
}

#calendar,
#header,
#contents,
#footer {
  width: auto;
}
.wrapper {
  margin: 0 auto;
}

ol.olLst01 {
  list-style-type: none;
  margin: 0;
  padding: 0;
}
ol.olLst01 li {
  padding-left: 2em;
  text-indent: -1.8em;
}

/* 注意書き用スタイル */
ul.note,
#overview ul.note{
	padding: 0px;
	margin-top: 0px;
	margin-right: 0px;
	margin-left: 0px;
	margin-bottom: 1em;
	list-style-type: none;
	line-height: 1.4;
	color: #333333;
	font-size: 90%;
}

ul.note li,
p.note {
	padding-left: 1em;
	text-indent: -1em;
}



/*====================================================================================
 clearfix
=====================================================================================*/
.clearfix:after,
.enterprise-1:after,
.enterprise-2:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

.clearfix,
.enterprise-1,
.enterprise-2 {
  min-height: 1px;
	position: relative;
}

* html .clearfix,
* html .enterprise-1,
* html .enterprise-2 {
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}



/*====================================================================================
 header
=====================================================================================*/

/* --- #header --- /////////////////////////////////////////////////*/
.h1-mobile,
.h1-pc { display: none; }

#header {
  background:#000 url(../images/header-bg.jpg) no-repeat 50% 50%;
  background-size:cover;
}

/* --- #navigation --- /////////////////////////////////////////////*/
#navigation {
  text-align: center;
  background-color: #3c3c3c;
}
#navigation ul {
  width: 100%;
  margin: 0;
	display: flex;
	list-style-type: none;
}
#navigation nav > .wrapper li {
  width: 33.3%;
}
#navigation .sub-nav .wrapper li {
	width: 50%
}

#navigation .sub-nav {
	background-color: #303030;
}
#navigation .sub-nav ul li {
	padding-top: 0.5em;
	padding-bottom: 0.5em;
}

#navigation a {	
	display: flex;
	align-content: center;
	justify-content: center;
	flex-wrap: wrap;
	height: 100%;
	text-decoration: none;
	color: #fff;
	padding: 0.9em 0.9em 0.8em 0.9em;
	box-sizing: border-box;
}
#navigation a:hover {
  background: #444;
}

#navigation .event-name {
  display: none;
  font-size: 75%;
  line-height: 1;
  color: #bdc0c2;
  margin: 0;
  padding: .5em;
}
#navigation .nav-top {
  min-width: 4em;
}

#navigation br {
  display: none;
}

.submit {
  text-decoration: none;
	line-height: 1.3;
  color: #ffffff;
  background-color: #F19D00 !important;
  text-shadow: 0 0 3px rgba(0,0,0,.5);
  padding: 0.5em 0.5em 0.4em 0.5em !important;
	margin: 0 0.5em;
  border-radius: 5px;
  box-sizing: border-box;
}
.submit:hover {
  background-color: #f4c033 !important;
}

.sub-nav li:last-child .submit {
	background-color: #3F9EDB !important;
}

.submit.close,
.sub-nav li:last-child .submit.close {
  background-color: #999999 !important;
	pointer-events: none;
}

.submit span {
	display: inline-block;
	margin-left: 0.5em;
	font-size: 87.5%;
}

#navigation.fixed {
  position: fixed;
  top: 0;
  z-index: 1000;
  width: 100%;
}
#navigation.fixed a:hover {
  background: #393939;
}
#navigation.fixed .active,
#navigation.fixed .active:hover {
  position: relative;
  color: #ffffff;
  background: #565656;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}
#navigation.fixed .event-name {
  display: block;
	background: #000000;
}

@media only screen and (max-width: 1030px) {
	.submit {
		margin-right: 0.4em;
	}
}

@media only screen and (max-width: 768px) {
	.submit span {
		display: block;
		width: 100%;
		font-size: 0.75rem;
		margin-left: 0;
	}
}

@media only screen and (max-width: 400px) {
	.sub-nav li:first-child .submit span {
		display: none;
	}
}

@media (max-width: 350px) {
	.submit {
		font-size: 0.875rem;
	}
}



/*====================================================================================
 contents
=====================================================================================*/

/* --- #contents --- ///////////////////////////////////////////////*/
#contents .wrapper {
  padding-left: .8em;
  padding-right: .8em;
  box-sizing: border-box;
}
#contents {
  position: relative;
  color: #444444;
  background-color: #ffffff;
}
#contents h2 {
  position: relative;
  text-align: center;
  color: #2f4858;
  margin: 0 0 .8em;
}
#contents h2:before,
#contents h2:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #9baebc;
}
#contents h2:before { top: 12px; }
#contents h2:after { top: 15px; }
#contents h2 span {
  position: relative;
  display: inline-block;
  padding: 0 .5em;
  background-color: #ffffff;
  z-index: 100;
}
#contents h2 + p {
  font-size: 90%;
  line-height: 1.5;
}

#lead,
#feature,
.btn-entry-body {
  padding: 3.5em 0 3.5em;
}

#enterprise,
#pickup-K-1,
#pickup-lecturer,
#pickup,
#sponsor,
#overview,
#timetable,
#exhibition,
.btn-entry-body {
  padding: 4.5em 0 0;
}
#enterprise {
  padding-bottom: 3em;
}
#information + #timetable,
#information + #exhibition {
  padding-top: 1em;
}
.closed {
	text-align: center;
	font-weight: bold;
	margin-bottom: 3em;
	padding: 2em;
	background-color: #FFFFFF;
	color: #000000;
	border: 1px solid #DF0003;
	font-size: 16px;
}

.lecturer-company,
.lecturer-division,
.lecturer-post {
  line-height: 1.2;
  margin: .3em 0;
}
.lecturer-company {
  font-size: 115%;
  margin-bottom: .5em;
}
.lecturer-name {
  font-size: 150%;
  font-weight: bold;
  margin: 0;
}
.lecturer-name:after {
  content: "氏";
  font-size: 65%;
  font-weight: normal;
  margin-left: .5em;
}
.lecturer-name.en:after {
  content: none;
}
.lecturer-name span {
  font-size: 75%;
}

.notice {
  font-size: 90%;
}
.btn-submit {
  text-align: center;
  margin-top: 3em;
}
.btn-submit a {
  letter-spacing: .1em;
}

/* --- #lead --------------------*/
#lead,
#lead h2 {
  color: #fff;
}
#lead {
  font-size: 90%;
  background-color: #0a3164;
  /*background: url(../images/top/lead-bg.jpg), linear-gradient(#0b4085, #09264b);*/
	background-image: url(../images/top/lead-bg.jpg);
  background-repeat: no-repeat,repeat-x;
  background-position: center center;
  background-size: contain;
}
@media only screen and (max-width: 1680px) {
	#lead {
		background-size: cover;
	}
}

#lead h2:before,
#lead h2:after {
  content: none;
}
#lead h2 span {
  padding: 0;
  background: transparent;
  z-index: auto;
  width: auto;
}
#lead h2 span .subTitle {
  font-size: 80%;
}

#lead h2 + p {
  font-size: inherit;
  margin: 0;
}
@media only screen and (min-width: 769px) {
  #lead {
    font-size: 110%;
  }
}

/* --- #feature --------------------*/
#feature {
  color: #fff;
  background-color: #186C97;
  background-image: url(../images/top/enterprise-bg.png);
  padding-left: 0.8em;
  padding-right: 0.8em;
  box-sizing: border-box;
}

#feature h2 {
  color: #fff;
	max-width: 1024px;
	padding-left: 0.8em;
	box-sizing: border-box;
	border: 0 solid #75AFBB;
  border-width: 1px 0;
	margin-top: 0.5em;
	margin-left: auto;
	margin-right: auto;
  margin-bottom: 1.5em;
}
#feature h2 span {
  padding: .3em 0;
  background:transparent;
}
#feature h2:before,
#feature h2:after {
  background-color: #75AFBB;
}
#feature h2:before { top: -4px; }
#feature h2:after { top: auto; bottom: -4px; }


#feature .closed {
	max-width: 1024px;
	margin-left: auto;
	margin-right: auto;
}

#feature .closed + h2 {
	margin-top: 80px;
}

@media only screen and (max-width: 768px) {
	#feature .closed + h2 {
		margin-top: max(8vw, 40px);
	}	
}

/* --- #point ------------*/
#point,
#point h2 {
  color: #e9eaec;
}
#point {
	background-color: #212d42;
	padding-top: 2em;
	padding-bottom: 2em;
}
#point h2 {
  font-size: 125%;
  margin-bottom: 1.3em;
  padding: 0 0 .3em;
  border: 0 solid #646c7b;
  border-width: 0 0 1px;
}
#point h2:before,
#point h2:after { content:none; }
#point h2 span {
  padding: 0;
  background: transparent;
}
#point .point-detail-inner {
  font-size: 90%;
  line-height: inherit;
}
#point .point-detail {
  display: table;
  width: 102%;
  margin-left: -1%;
  margin-right: -1%;
  box-sizing: border-box;
}
#point .point-detail .point-detail-inner {
	display: table-cell;
	vertical-align: top;
	width: 33%;
	padding-top: 1.5em;
	padding-right: 2.5%;
	padding-left: 2.5%;
	padding-bottom: 1.5em;
	box-sizing: border-box;
	background-color: #314362;
	border: 10px solid #212d42;
}
#point .point-detail:nth-of-type(2) .point-detail-inner {
	padding-top: 2em;
}

#point .point-detail .point-detail-inner ul {
  margin-top: 1em;
  margin-bottom: 1em;
}

/* --- #enterprise --------------------*/
#enterprise,
#enterprise h2 {
  color: #fff;
}

#enterprise {
	background-color: #18869e;
  background-image: url(../images/top/enterprise-bg.png);
  background-position: center bottom;
  background-repeat: repeat-y;
}

/*.enterprise-1,
.enterprise-2 {
  width: 48%;
  margin-bottom: 1.5em;
}
.enterprise-1 {
  float: left;
}
.enterprise-2 {
  float: right;
}*/

/* list */
/* 4column */
/*#enterprise ul {
	max-width: 1024px;
	margin-top: 0;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 0;
	display: flex;
	flex-wrap: wrap;
	list-style-type: none;
}
#enterprise ul li {
	width: 22%;
	box-sizing: border-box;
	margin-right: 4%;
	margin-bottom: 50px;
}*/
/*#enterprise ul li:nth-of-type(4n) {
	margin-right: 0;
}*/

/* 3column */
/*#enterprise ul {
	max-width: 840px;
	margin-top: 0;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 0;
	display: flex;
	flex-wrap: wrap;
	list-style-type: none;
}
#enterprise ul li {
	width: 30%;
	box-sizing: border-box;
	margin-right: 5%;
	margin-bottom: 50px;
}

#enterprise ul li:nth-of-type(3n) {
	margin-right: 0;
}

#enterprise ul li img {
	width: 100%;
	height: auto;
	display: block;
	margin-bottom: 1em;
}
/**/

/* 2column */
/*#enterprise ul {
	max-width: 800px;
	margin-top: 0;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 0;
	display: flex;
	flex-wrap: wrap;
	list-style-type: none;
	justify-content: center;
}
#enterprise ul li {
	width: 35%;
	box-sizing: border-box;
	margin-right: 10%;
	margin-bottom: 50px;
}

#enterprise ul li:nth-of-type(2n) {
	margin-right: 0;
}

#enterprise ul li img {
	width: 100%;
	height: auto;
	display: block;
	margin-bottom: 1em;
}*/
/**/


/* 2024年9月開催用 */

#enterprise .wrapper {
	max-width: 920px;
}

#enterprise ul {
	list-style-type: none;
	margin: 0;
}

#enterprise ul li {
	padding: clamp(0.938rem, 0.597rem + 1.7vw, 1.875rem);
	padding-bottom: 0;
	margin-bottom: clamp(0.938rem, 0.597rem + 1.7vw, 1.875rem);
	background-color: hsla(0,0%,100%,0.18);
}

#enterprise ul li .enterprise-title {
	width: 100%;
}

#enterprise .enterprise-title .session-category {
  display: inline-block;
  font-size: 0.75rem;
  line-height: 1;
  color: #fff;
	margin-top: 0;
  margin-right: 0;
  margin-left: 0;
  margin-bottom: .1em;
  padding: .5em .8em;
  background-color: #126071;
  border-radius: 3px;
}

#enterprise ul li .enterprise-title h3 {
	margin-top: 0.3em;
}

#enterprise ul li .enterprise-contents {
	display: flex;
	align-items: center;
	padding-bottom: 20px;
	margin-right: 20px;
	box-sizing: border-box;
}

#enterprise ul li .enterprise-contents:last-child {
	margin-right: 0;
}

#enterprise ul li:nth-of-type(1),
#enterprise ul li:nth-of-type(3) {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-start;
}
#enterprise ul li:nth-of-type(1) .enterprise-contents {
	flex: 1;
}
#enterprise ul li:nth-of-type(3) .enterprise-contents {
	display: block;
	margin-right: clamp(1.25rem, 0.568rem + 3.41vw, 3.125rem);
}
#enterprise ul li:nth-of-type(3) .enterprise-contents:last-child {
	margin-right: 0;
}
#enterprise ul li:nth-of-type(3) .enterprise-contents dt {
	margin-bottom: 0;
}

@media only screen and (max-width: 768px) {

	#enterprise ul li:nth-of-type(1),
	#enterprise ul li:nth-of-type(3) {
		display: block;
	}
	
	#enterprise ul li:nth-of-type(1) .enterprise-contents {
		width: 100%;
	}

	#enterprise ul li:nth-of-type(3) .enterprise-contents {
		display: flex;
		width: 100%;
	}
	
	#enterprise ul li:nth-of-type(3) .lecturer-company br {
		display: none;
	} 

}

#enterprise .company-logo {
	padding-bottom: 1em;
}
#enterprise .company-logo img {
  float: none;
  width: 50%;
  height: auto;
}
#enterprise h2 {
  /*border: 0 solid #78ACB4;*/
	border: 0 solid hsla(0,0%,100%,0.30);
  border-width: 1px 0;
  margin-bottom: 1.5em;
  margin-top: 0.5em;
}
#enterprise h2 span {
  padding: .3em 0;
  background:transparent;
}

#enterprise h2:before,
#enterprise h2:after {
  background-color: hsla(0,0%,100%,0.30);
}
#enterprise h2:before {
	top: -4px;
}
#enterprise h2:after {
	top: auto; bottom: -4px;
}

#enterprise h3 {
  font-size: 1.25rem;
  margin-top: 1em;
  margin-bottom: 1em;
}
#enterprise h3 span {
  font-size: 1rem;
}

#enterprise ul li .lecturer-img {
	width: 160px;
	margin-right: 20px;
	box-sizing: border-box;
}

@media only screen and (max-width: 640px) {

	#enterprise ul li .lecturer-img {
		width: 23.44vw;
	}
	#enterprise ul li dl {
		flex: 1;
	}

}

#enterprise .lecturer-company {
	font-size: 100%;
	margin-top: 0;
}
#enterprise .lecturer-division,
#enterprise .lecturer-post {
	font-size: 8.75rem;
}
#enterprise .lecturer-name {
	font-size: 1.25rem;
}

/* --- #sponsor ----------------------*/
#sponsor {
  padding-bottom: 2em;
}

#sponsor h2 {
  font-size: 100%;
  line-height: 1;
  padding: .5em;
	margin-bottom: 2em;
  background: #d9e2e8;
  border-radius: 1em;
}

#sponsor h2:not(:first-child) {
  margin-top: 2.5em;
}
#sponsor h2 span {
  background:transparent;
}
#sponsor h2:before,
#sponsor h2:after {
  content:none;
}
#sponsor ul {
  text-align:center;
  letter-spacing:-.4em;
  margin:0 auto;
}
#sponsor li {
  list-style: none;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: normal;
  margin-top: 0px;
  margin-right: 30px;
  margin-left: 30px;
  margin-bottom: 2em;
}

#sponsor .wide-h {
  margin-top:15px;
  margin-bottom:15px;
}

#sponsor li img {
  max-width: 200px;
  max-height: 100%;
}

#sponsor li.xxxsmall img {
  max-width:110px;
}
#sponsor li.xxsmall img {
  max-width:120px;
}
#sponsor li.xsmall img {
  max-width:140px;
}
#sponsor li.small img {
  max-width:160px;
}
#sponsor li.medium img {
  max-width:180px;
}
#sponsor li.large img {
  max-width:220px;
}
#sponsor li.xlarge img {
  max-width:240px;
}
#sponsor li.xxlarge img {
  max-width:250px;
}
#sponsor li.xxxlarge img {
  max-width:260px;
}

/*#sponsor li.ajustH img {
  max-width: 100%;
  max-height: 80px;
}*/

@media only screen and (max-width: 768px) {

  #sponsor {
		padding-top: 2.5em;
    padding-bottom: 2em;
  }

  #sponsor h2 {
		font-size:95%;
  }

	#sponsor h2:not(:first-child) {
		margin-top: 2.5vw;
	}

	#sponsor li {
		margin-top: 0;
	}

}

/* --- #overview --------------------*/
#overview　{
  color: #2f4858;
  background-color: #FFFFFF;
}
#sponsor + #overview,
.btn-entry-body + #overview {
	padding-top: 0;
}

#overview h2 span {
  color: #2f4858;
  background-color: #FFFFFF;
}
#overview figure {
  font-size: 90%;
  line-height: 1.3;
  margin: .8em 0 1em;
}
#overview .level2 p {
  margin: .5em 0;
}
#overview-title .level2 p:first-child {
  font-size: 100%;
}
#overview-title .level2 p {
  font-size: 120%;
}
#overview-place .level2 .venue {
  margin-bottom: 0;
}
#overview-place .level2 .adress {
  margin-top: .2em;
}
#overview-place .level2 .access {
  font-size: 90%;
  line-height: 1.4;
  margin-top: .8em;
}
#overview-place .level2 .access li {
  margin: .5em 0;
}
#overview-place .level2 p.access {
  display: list-item;
  margin-left: 1.5em;
}
#overview-promoter li,
#overview-support li {
  margin: .5em 0;
}
#overview-support .level2 {
	padding-top: 1em !important;
	padding-bottom: 1em !important;
}

#overview-promoter .level2 .logoBox {
  display: flex;
  align-items: center;
  gap: 1.5em;
  /*margin-bottom: 1em;*/
}

#overview-promoter .level2 .logoBox img {
  width: 90px;
  margin-top: 0;
}
#overview-promoter .level2 .logoBox img.logo-size-small {
  width: 85px;
}
#overview-promoter .level2 .logoBox img.logo-size-large {
  width: 110px;
}

#overview-promoter .level2 img {
	width: 100px;
  height: auto;
	vertical-align: baseline;
	margin-top: 0.5em;
}

#overview-support .level2 img {
	width: auto;
  /*height: 40px;*/
	height: 34px;
	vertical-align: top;
}

#overview-support .level2 ul {
  list-style-type: none;
  margin-left: 0;
}
#overview-support .level2 ul li {
  display: inline-block;
  margin-right: 2em;
}
#overview-benefit .level2 img {
	width: auto;
  height: 280px;
}



/*====================================================================================
 timetable
=====================================================================================*/

/*@media only screen and (min-width: 769px) {
  #timetable {
    padding-bottom:6.5em;
  }
}*/


/* --- #timetable title area --- /////////////////////////////////////////////////*/
#timetable p.note {
  text-align: center;
}

@media only screen and (max-width: 769px) {
	#timetable p.note {
		font-size: 70%;
	}
}

#timetable .timetable-day {
  font-size: 125%;
  color: #2f4858;
  font-weight: bold;
  text-align: center;
  margin-top: 0;
}


/* --- #timetable table --- /////////////////////////////////////////////////*/
#timetable .level1,
#timetable .level2,
#timetable .level3 {
  border: 0 solid #a1b0bc;
  box-sizing: border-box;
}
#timetable .level1 {
  display: table;
  width: 100%;
}
#timetable .level2 {
  border-bottom-width: 1px;
}

#timetable section > .level1:first-of-type .level2 {
  border-top-width: 1px;
}

#timetable .level2 {
  display:table-cell;
  vertical-align:top;
}
#timetable .level3,
#timetable .single .level2 {
  padding:.8em .5em;
}

@media only screen and (min-width: 769px) {

  #timetable .level1 {
    width: 99%;
    max-width: 1024px;
    margin: 0 auto;
  }

  #timetable .level2 {
    width: 91%;
    border-right-width: 1px;
  }

  #timetable .level3 {
    float: left;
    vertical-align: top;
    width: 50%;
    border-left-width: 1px;
  }

  #timetable .level3,
  #timetable .single .level2 {
    padding-right: .8em;
    padding-left: .8em;
  }

  #timetable .level2 > .level3:first-child {
    border-left-width:0;
  }

}

@media screen and (max-width: 1024px) {

  #timetable .level3 {
    width: 50%;
    border-top: 1px dashed #B3C0CB;
    border-left: 1px dashed #B3C0CB;
  }

  #timetable .level2 .level3:nth-of-type(1),
  #timetable .level2 .level3:nth-of-type(2) {
    border-top-style: none;
  }
  #timetable .level2 .level3:nth-of-type(3) {
    border-left-style: none;
    border-bottom-style: none;
  }

}

@media only screen and (max-width: 768px) {

  #timetable .level3,
  #timetable .single .level2 {
    padding-top:.5em;
  }

  #timetable .level2 > .level3:not(:first-child) {
    border-top-width:1px;
  }

  #timetable .level3 {
    width:100%;
    border-left-style: none;
  }

  #timetable .level2 .level3:nth-of-type(2) {
    border-top: 1px dashed #C0CBD4;
  }

}


/* --- #timetable repeat box --- /////////////////////////////////////////////////*/
#timetable .level2.timetable-repeat {
  padding: 0 !important;
}
#timetable .level2.timetable-repeat .timetable-repeat-box {
  border-bottom: 1px dashed #a1b0bc;
}

#timetable .level2.timetable-repeat .timetable-repeat-box.groupSession {
  border-bottom-style: none;
}

@media only screen and (min-width: 769px) {
  #timetable .level2.timetable-repeat .timetable-repeat-box {
    padding: 0.8em;
  }
}

@media only screen and (max-width: 768px) {
  #timetable .level2.timetable-repeat .timetable-repeat-box {
    padding: 0.5em;
  }
}


/* --- #timetable session id & category --- /////////////////////////////////////////////////*/
#timetable .session-id,
#timetable .session-category,
#timetable .session-info {
  display:inline-block;
  font-size: 75%;
  line-height: 1;
  color:#fff;
  margin: .1em 0;
  padding: .5em .8em;
  background: #65737b;
  border-radius: 3px;
}

/* --- session category --------------------*/
#timetable .session-category.tsuuyaku {
	  background-color: #84497c;
}
#timetable .session-category.lunch {
	  background-color: #5E99B9;
}
#timetable .session-category.ex1 {
    background-color: #00c894;
}
#timetable .session-category.ex2 {
    background-color: #666cd3;
}
#timetable .session-category.special {
  background-color: #F0972D;
  color: #ffffff;
}
#timetable br + .session-category {
    margin-top: 1.5em;
}

/* --- session id --------------------*/
#timetable .session-id {
    width:2.8em;
    text-align:center;
}

#timetable .session-id.track1 { background-color:#942828; }
#timetable .session-id.track2 { background-color:#296322; }
#timetable .session-id.track3 { background-color:#014f92; }
#timetable .session-id.track4 { background-color: #925B00; }

@media only screen and (max-width: 768px) {
  #timetable .session-category,
  #timetable .session-id {
    line-height:1.2;
  }
}


/* --- #timetable date(time) --- /////////////////////////////////////////////////*/
#timetable .timetable-date {
  display: table-cell;
  vertical-align: top;
  width: 3em;
  background: #8196a6;
}

#timetable .level1:nth-child(odd) .timetable-date {
  background-color: #a1b0bc;
}
#timetable .timetable-date span {
  display: block;
}
#timetable .timetable-date span:nth-of-type(2) {
  display: inline-block;
  transform: rotate(90deg);
}
#timetable .timetable-date span:nth-of-type(4) {
  font-size: 90%;
  font-weight: normal;
  margin-top: .5em;
}

#timetable .timetable-date h4 {
  font-size: 75%;
  text-align: center;
  line-height: 1;
  color: #fff;
  margin: 1em 0;
}

@media only screen and (min-width: 769px) {

  #timetable .timetable-date {
    width: 8%;
    vertical-align: top;
  }

  #timetable .timetable-date h4 {
    font-size: 85%;
  }

}
@media only screen and (max-width: 768px) {
  #timetable .timetable-date h4 {
    position:-webkit-sticky;
    position:sticky;
    top: 6.2em;
  }
}


/* --- .lecturer --- /////////////////////////////////////////////////*/
#timetable .lecturer {
  display: flex;
  flex-grow: 1;
  font-size: 85%;
  color: #555;
}
#timetable .single section[id$="-opening"] .lecturer {
  margin-top: 1.5em;
}
#timetable .level1:not(.single) .lecturer + .lecturer {
  margin-top: 2em;
}

@media screen and (max-width: 1024px) {
  #timetable .single .lecturer + .lecturer {
    margin-top: 2.5em;
  }
}

@media screen and (max-width: 460px) {
  #timetable .single .lecturer {
    flex-direction: column;
    gap: 1em;
  }
}

/* --- lecturer-category --------------------*/
#timetable .lecturer-category {
  font-weight: bold;
}

/* --- lecturer-pic --------------------*/
#timetable .single .lecturer-pic {
  width: 110px;
  height: 110px;
  min-width: 110px;
}

#timetable .lecturer-pic {
  width: 80px;
  height: 80px;
  min-width: 80px;
  margin-right: 0.7em;
}

/* --- lecturer-company --------------------*/
#timetable .lecturer-company {
  margin-top: 0;
  font-size: 110%;
}
#timetable .level1:not(.single) .lecturer-company {
  font-size: 110%;
  margin-bottom: 0.1em;
}
#timetable .lecturer .lecturer-company:not(:first-of-type) {
  margin-top: 0.5em;
}

/* --- lecturer-name --------------------*/
#timetable .single .lecturer-name {
  display: inline-block;
  vertical-align: middle;
}


/* --- .lecturer-list --- /////////////////////////////////////////////////*/
#timetable .lecturer-list {
  display: flex;
}
#timetable .level1:not(.single) .lecturer-list {
  flex-direction: column;
}

#timetable p + .lecturer-list {
  margin-top: 2em;
}

@media screen and (min-width: 1025px) {
  #timetable .single .lecturer-list:not(:first-of-type) {
    margin-top: 1.5em;
  }
}

@media screen and (max-width: 1024px) {

  #timetable .single .lecturer-list {
    flex-direction: column;
  }
  #timetable .single .lecturer-list + .lecturer-list {
    margin-top: 2.5em;
  }

}

@media only screen and (min-width: 769px) {

  #timetable .single .lecturer-list {
    width: 100%;
    margin-top: 0.8em;
  }

  #timetable .single .lecturer-list .lecturer:last-of-type {
    padding-right: 0em;
  }

}


/* --- .lecturer .btn-detail --- /////////////////////////////////////////////////*/
#timetable .btn-detail {
  display: inline-block;
  margin-bottom: 0;
  padding-top: 0.6rem;
}

#timetable .btn-detail a {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 1rem;
  font-weight: bold;
  text-decoration: none;
  color: #444 !important;
  background: #cdd9e0;
  border-radius: 1.2rem;
  padding: 0.3rem 1.25rem 0.3rem 0.3rem;
  line-height: 100%;
  position: relative;
}
#timetable .btn-detail a::before {
  content: "";
  width: 1.8rem;
  height: 1.8rem;
  background: #fff;
  border-radius: calc(1.8rem / 2);
}

#timetable .btn-detail a::after {
  content: "";
  width: 1.4rem;
  height: 1.4rem;
  background-image: url(../images/ico-session-info.svg);
  background-repeat: no-repeat;
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
}

#timetable .btn-detail a:hover {
  text-decoration:underline;
}


/* --- .lecturer title --- /////////////////////////////////////////////////*/
#timetable header h5 {
  font-size: 120%;
  line-height: 1.2;
  color: #2f4858;
  margin: 0.5em 0 1.5em;
  font-weight: bold;
}

#timetable header h5 span {
  display: block;
  font-size: 85%;
  margin: 0.3em 0 0;
}
#timetable header h5 span.subTtl {
  font-weight: normal;
}

#timetable .session-maesub + h5 {
	margin-top: 0.2em;
}

#timetable .lecturer h5 {
  margin-bottom: 1em;
}
#timetable .lecturer + h5 {
  margin-top: 1.5em;
  padding-top: 1em;
  border-top: 1px solid #CCCCCC;
}

@media only screen and (min-width: 769px) {
  #timetable .single h5 {
    font-size: 135%;
  }
}

@media only screen and (max-width: 768px) {
  #timetable h5 span {
    margin-top: 0.5em;
  }
}

/* --- 前サブタイトル --------------------*/
.session-maesub {
	font-weight: bold;
	font-size: 85%;
	margin-bottom: 0;
	color: #2f4858;
}


/* --- .lecturer .inline-contents（詳細ボタンクリックで開く内容）--- /////////////////////////////////////////////////*/
.inline-contents {
  display: none;
}

/* --- colorbox.js" Setting --------------------*/

/* colorbox defaults */
#cboxLoadedContent {
	overflow-x: hidden !important;
}

/* colorbox session-detail */
#colorbox .session-detail {
  color: #333;
}

#colorbox .session-detail h6 {
  margin-top: 1.5em;
  padding: 0.4em 0.3em;
  font-size: 95%;
  line-height: 1;
  color: #2f4858;
  border-left: 8px solid #cdd9e0;
}

#colorbox .session-detail header p {
  margin-top: 0;
  padding: 0.4em 0.3em;
  font-size: 100%;
  border-left: 8px solid #cdd9e0;
}

#colorbox .session-detail p,
#colorbox .session-detail ul,
#colorbox .session-detail ol {
  font-size: 90%;
  line-height: 1.4;
  margin-top: 1em;
  margin-bottom: 1em;
}
#colorbox .session-detail ul {
  list-style-type: disc;
  margin-left: 0;
}

#colorbox .session-detail .lecturer-profile {
  color:#555;
  margin-top: 1em;
}
#colorbox .session-detail .lecturer-profile .lecturer-pic {
  width: 90px;
  height: 90px;
}

#colorbox .lecturer-profile dt {
  font-size: 110%;
  font-weight: bold;
}
#colorbox .lecturer-profile dd p,
#colorbox .lecturer-profile dd li {
  font-size: 90%;
  line-height: 1.4;
}
#colorbox .lecturer-profile .lecturer-pic {
	float: left;
	width: 120px;
	height: 120px;
	margin-top: 0;
	margin-right: 10px;
	margin-left: 0;
	margin-bottom: 0.5em;
}

/* --- lecturer-category --------------------*/
#colorbox .lecturer-category {
  font-size: 87.5%;
}

#colorbox .lecturer-profile dt .lecturer-pic + span {
  font-size: 87.5%;
}

#colorbox .lecturer-profile .lecturer-workspace {
  margin: 0.3em 0 0;
}
#colorbox .lecturer-profile .lecturer-biography {
  width: 100%;
  margin: 1.5em 0 0;
  clear: both;
}

@media only screen and (min-width:1024px) {

  #colorbox .session-detail {
    width: 700px;
    max-width: 800px;
  }

  #colorbox .session-detail .lecturer-profile .lecturer-pic {
    width: 120px;
    height: 120px;
  }

}

@media only screen and (min-width:769px) {

  #colorbox .session-detail {
    width: 600px;
    max-width: 600px;
    padding-top: 1em;
    padding-right: 3%;
    padding-left: 3%;
    padding-bottom: 0;
    box-sizing: border-box;
  }

  #colorbox .session-detail .lecturer-profile {
    display: inline-block;
    vertical-align: top;
    font-size: 90%;
    width: 49%;
  }

  #colorbox .session-detail .lecturer-profile.single {
    width: 100%;
  }

  #colorbox .session-detail .lecturer-profile.single + .lecturer-profile.single {
    margin-top: 2em;
  }

  #colorbox .session-detail .lecturer-profile p {
    line-height: 1.3;
  }

}

@media only screen and (max-width:768px) {
  #colorbox .lecturer-profile .lecturer-pic {
    width: 90px;
    height: 90px;
  }
}


/* --- .lecturer .timetable-lunch --- /////////////////////////////////////////////////*/
#timetable .timetable-lunch .lunch-txt {
  margin: 0.5em 0;
  font-weight: bold;
  color: #2f4858;
}


/* --- .lecturer 講演別設定 --- /////////////////////////////////////////////////*/

/* --- K1-9 --------------------*/
#K1-9 header + p.txt80 {
  margin-top: -1em;
  margin-bottom: 2em;
}



/*====================================================================================
 related-link
=====================================================================================*/

#related-link {
    padding-bottom: 3em;
    text-align: center;
}
#related-link a {
    display: inline-block;
    margin: 5px;
}

#related-link h2::before,
#related-link h2::after {
	display: none;
}

#related-link h2 {
	background-color: #2f4858;
	margin-bottom: 2em;
	padding: 0.5rem !important;
	color: #FFFFFF;
	font-size: 125%;
	font-weight: normal;
	border-radius: 5px;
}
#related-link h2 span {
	background: none;
	font-size: 75%;
	padding: 0;
}

@media (max-width: 768px) {
	#related-link h2 {
		margin-bottom: 1.5em;
	}
}

@media (max-width: 520px) {
	#related-link h2 span {
		display: block;
	}
}



/*====================================================================================
 footer
=====================================================================================*/

#footer .page-top {
  position: fixed;
  bottom: 10px;
  right: 10px;
  margin: 0;
  z-index: 1000;
}
#footer .page-top a {
  display: block;
  padding: .5em 1em;
  background-color: #2f4858;
  background: rgba(47,72,88,.8);
  border-radius: 3px;
  color: #FFFFFF;
  text-align: center;
  text-decoration: none;
}
#footer .page-top a:hover {
  opacity: .8;
}
#footer .page-top i {
  display: block;
}

#footer {
	overflow: hidden;
	width: 100%;
	padding: 1em 0;
	background-color: #000000;
	color: #ffffff;
	font-size: 80%;
	text-align: right;
}
.footer-nav {
	margin-right: .75em;
	float: right;
}

.footer-nav a {
	display: inline-block;
	margin: .5em .25em;
	padding: .5em;
	border: 1px solid #ffffff;
	border-radius: 4px;
	color: #ffffff;
	font-size: 80%;
	text-decoration: none;
	text-align: right;
}
.footer-nav a:hover {
	background-color: #666666;
}

#footer span a {
	border: none;
	border-radius: 0px;
	padding-bottom: .25em;
	border-bottom: 1px solid #fff;
}
.footer-logo {
	float: left;
  margin: 0.5em 1.5em;
  width: 80px;
  height: auto;
}

/* --- Media Query --- //////////////////////////////////////////////*/
@media (max-width: 430px) {
  .h1-mobile { display:block; }
  #pickup h2 {
    margin-bottom: 1em;
  }

}
@media (min-width: 431px) {
  .h1-pc {
    display: inline-block;
    width: 100%;
    max-width: 1024px;
  }

}
@media (max-width: 460px) {
	
  .btn-submit .submit {
    width: 94%;
    box-sizing: border-box;
  }
  .closed {
    text-align: left;
    margin-bottom: 2em;
    padding: 1em;
  }
}
@media (min-width: 461px) {
  #pickup .lecturer-post {
    position: relative;
    display: inline-block;
  }
  #pickup .lecturer-post img {
    position: absolute;
    bottom: 0;
    right: -110px;
    margin-right: .5em;
  }
}

@media (max-width: 600px) {
  #lead h2 {
    text-align: left;
  }
}

@media only screen and (max-width: 768px) {
  .footer-logo {
    width: 40px;
    height: auto;
  }

  .btn-submit a {
    width: 80%;
  }

  #contents {
    font-size: 115%;
    line-height: 1.3;
  }
  #overview {
    padding-top: 2.5em;
    padding-bottom: 0;/* for ".page-top" */
  }

  #navigation {
    font-size: 90%;
  }
  #contents h2 {
    font-size: 130%;
  }
  #SMP_STYLE p {
    margin-bottom: 1.5em;
  }
  #SMP_STYLE dt.title {
    display: block;
    width: 100%;
    padding: 0;
  }
  #SMP_STYLE dd.data {
    display: block;
    width: 100%;
    margin-bottom: 12px;
  }
  #lead {
    padding-top: 3em;
    padding-bottom: 3em;
    background-image:url(../images/top/lead-bg.jpg);
    background-size: 180%;
  }
  #lead h2 {
    margin-bottom: 1em;
  }
  #lead p {
    padding-right: .2em;
    padding-left: .2em;
  }

  #point .point-detail,
  #point .point-detail .point-detail-inner {
    display: block;
    padding: 0;
  }
  #point .point-detail {
    font-size: 90%;
  }
  #point .point-detail .point-detail-inner {
    width: 96%;
    margin-top: 1.5em;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 0.5em;
    padding: 1em;
    border-style: none;
  }
  #point .point-detail:nth-of-type(2) .point-detail-inner {
    padding-top: inherit;
  }
  #point .point-detail .point-detail-inner:first-child {
    margin-top: 2.5em;
  }
  #point .point-detail .point-detail-inner:last-child {
    margin-bottom: 0;
  }

  #enterprise {
    /*background-image: none;*/
    padding-top: 1.5em;
		padding-bottom: 0;
  }
  
  .enterprise-1,
  .enterprise-2 {
    width: auto;
    margin-bottom: 1em;
  }
  /*.enterprise-1 dt br,
  .enterprise-2 dt br {
    display: none;
  }*/
  .enterprise-1,
  .enterprise-2,
  .enterprise-1 img,
  .enterprise-2 img,
  .enterprise-1 dl,
  .enterprise-2 dl {
    float: none;
  }
  #enterprise img {
    width: 100%;
  }
  #enterprise dl {
    margin: .8em 0;
  }
  #enterprise dd p {
    margin: .5em 0;
  }
	#enterprise h3 {
		height: auto;
	}
  #enterprise .company-logo {
    padding-bottom: 0em;
    text-align: center;
    background-color: #FFFFFF;
    margin-bottom: 1em;
  }

	/* list */
	/*#enterprise ul {
		max-width: 100%;
	}
	#enterprise ul li {
		width: 100%;
		margin-right: 0%;
		margin-bottom: 30px;
	}
	#enterprise ul li img {
		margin-bottom: 0;
	}*/
	/**/

  /*#pickup .session-subtitle:after {
    width: 80%;
  }*/
	
  #pickup .lecturer-name {
    font-size: 150%;
  }
  #pickup .lecturer-pic {
    width: 100% !important;
    display: block;
    margin-bottom: 0.5em;
  }

  #overview h3 {
    font-size: 85%;
    line-height: 1;
    color: #fff;
    margin-bottom: .8em;
    margin-right: .3em;
    margin-left: .3em;
    padding: .5em .8em;
    background-color: #9BAEBC;
    border-radius: 1em;
  }
  #overview figure {
    font-size: 85%;
    line-height: 1.4;
    color: #2f4858;
    padding: .5em;
    background-color: #f5f7f9;
  }
  #overview .level2 {
    padding-right: .8em;
    padding-left: .8em;
  }
  #overview-promoter .level2 > ul {
    margin-left: 0;
  }
  #overview-promoter .level2 > ul > li {
    list-style: none;
  }
  #overview-promoter figure {
    margin: 0;
  }
  #overview-promoter figure li {
    margin: .8em 0;
  }
  #overview-promoter figure li:last-child {
    margin-bottom: 0;
  }

  /*
  #footer .page-top {
    font-size: 80%;
  }
  /*.swiper-slide img {
    width: 100%;
  }*/
}

/* entry button */
.btn-entry-body {
	width: 500px;
	margin-left: auto;
	margin-right: auto;
}

.btn-entry-body a {
	display: block;
	margin-left: auto;
	margin-right: auto;
	padding: 20px;
	/*background-color: #ff9010;*/
	background-color: #f1b000;
	border-radius: 10px;
	font-size: 150%;
	text-align: center;
	text-shadow: 0 0 3px rgb(0 0 0 / 50%);
}
.btn-entry-body span {
	font-size: 75%;
}

.btn-entry-body a:link,
.btn-entry-body a:visited {
	color: #FFFFFF;
	text-decoration: none;
}

.btn-entry-body a:hover {
  background-color: #f4b433;
}

.btn-entry-body a br {
	display: none;
}

@media screen and (max-width: 768px) {

	.btn-entry-body {
		width: 84%;
		padding-top: 2.5em;
		padding-bottom: 2.5em;
	}

	.btn-entry-body a {
		padding: 15px;
		border-radius: 10px;
		font-size: 120%;
	}

}

@media screen and (max-width: 520px) {
	.btn-entry-body span {
		display: block;
	}
}

@media screen and (max-width: 400px) {
	.btn-entry-body a br {
		display: block;
	}
}

@media only screen and (min-width: 769px) {
  .btn-submit {
    max-width: 1024px;
    margin-right: auto;
    margin-left: auto;
  }
  .btn-submit a {
    width: 50%;
  }
  .wrapper {
    max-width: 1024px;
  }
  #overview {
    padding-bottom: 0; /* for ".page-top" */
  }

  #lead {
    padding-top: 4em;
    padding-bottom: 4em;
  }
  #lead h2 {
    text-align: center;
  }
  #lead .wrapper {
    width: 80%;
    max-width: 800px;
  }

  #enterprise .company-logo {
    width: 30%;
    padding-left: 1.8em;
    float: right;
  }
  #enterprise .company-logo img {
    float: none;
    width: 100%;
    height: auto;
  }

  #enterprise dt {
    margin-bottom: .7em;
    padding-bottom: .2em;
  }

  #pickup .pickup-detail {
    display: table;
  }
  #pickup .lecturer-pic,
  #pickup .pickup-detail div {
    display: table-cell;
    vertical-align: middle;
  }
  #pickup .pickup-detail div {
    padding-left: 2em;
  }
  #pickup .session-subtitle span {
    display: inline-block;
  }
  #overview .level1 {
    display: table;
    width: 100%;
    border: 0 solid #9facb5;
    border-width: 0 1px 1px;
    box-sizing: border-box;
  }
  #overview h2 + .level1 {
    margin-top: 1em;
    border-top-width: 1px;
  }
  #overview h3,
  #overview .level2 {
    display: table-cell;
    vertical-align: middle;
  }
  #overview h3 {
    width: 15%;
    font-size: 85%;
    text-align: center;
    margin: 0;
    padding: .5em;
    background-color: #d7dee3;
  }
  #overview .level2 {
    padding: .5em 1em;
    background-color: #FFFFFF;
  }
  #overview-title p:first-child {
    margin-bottom: 0;
  }
  #overview-visitors figure p span {
    display: inline-block;
  }

  #footer .page-top {
    font-size: 120%;
  }

}

@media screen and (min-width:769px) and ( max-width:1024px) {

  .enterprise-1,
  .enterprise-2 {
    width: 47%;
  }
  #enterprise .enterprise-1 img,
  #enterprise .enterprise-2 img {
    width: 100%;
    float: none;
  }

}

@media only screen and (min-width: 1024px) {

  .enterprise-1,
  .enterprise-2 {
    width: 340px;
    margin-bottom: 1.5em;
  }

  .enterprise-1 {
    float: left;
    margin-left: 130px;
  }
  .enterprise-2 {
    float: right;
    margin-right: 130px;
  }

  .enterprise-1 img,
  .enterprise-2 img {
    width: 260px;
    margin-left: 30px;
  }

}



/*====================================================================================
 "swiper.js" Setting
=====================================================================================*/

#lead .closed + .swiper {
  margin-top: 40px;
}
.swiper .swiper-wrapper {
  transition-timing-function: linear;
}

.swiper .swiper-slide {
	width: 15%;
	max-width: 250px;
	min-width: 200px;
	margin-right: 25px;
	color: #FFFFFF;
}

.swiper .lecturer-company {
  font-size: 112.5%;
  font-weight: bold;
  text-align: center;
  color: #FFCE00;
  margin-bottom: 0.3em;
  line-height: 1.3;
} 

.swiper .lecturer-name {
  font-size: 115%;
  font-weight: normal;
	line-height: 1.3;
  text-align: center;
}

.swiper .lecturer-name::after {
	/*display: none; 「氏」非表示 */
}

.swiper .spOnly {
  display: none;
}

@media only screen and (max-width: 768px) {

	.swiper .lecturer-company {
		font-size: 105%;
	} 

	.swiper .lecturer-name {
    font-size: 100%;
	}

	.swiper .swiper-slide {
		margin-right: 20px;
	}

}

@media only screen and (max-width: 640px) {

	.swiper .swiper-slide {
		min-width: auto;
		width: 200px;
		margin-right: 20px;
	}

  .swiper .pcOnly {
    display: none;
  }
  .swiper .spOnly {
    display: block;
  }

}

.swiper .swiper-slide img {
  width: 100%;
  height: auto;
}


/* --- "注目のセッション-高さ調整" --- ///////////////////////////////////*/
@media only screen and (min-width: 769px) {
  .featured-line-fix {
    margin-bottom: 2.6em !important;
  }
}



/*====================================================================================
 exhibition
=====================================================================================*/

/* --- exhibition main title area --- ///////////////////////////////////*/
#exhibition > section h2 + p {
  text-align: center;
}

@media (max-width: 600px) {
  #exhibition > section h2 + p {
    text-align: left;
  }
}


/* --- exhibition contents --- ///////////////////////////////////*/
#exhibition .level1 {
  margin: 2em 0;
  padding-bottom: 2em;
  border-bottom: 1px solid #cdd9e0;
}
#exhibition .level1:nth-of-type(2) {
  margin-top: 2.5em;
}

#exhibition .level1:last-of-type {
  margin-bottom: 0 !important;
}

@media only screen and (min-width: 769px) {
	#exhibition .level2 {
		display:table;
		width:100%;
	}
}

/* --- title --------------------*/
#exhibition h3 {
  position: relative;
  text-align: center;
  color: #2f4858;
  margin: 0 0 1.5em;
  padding-bottom: 0.5em;
}
#exhibition h3:after {
  content: "";
  display: block;
  width: 30%;
  max-width: 256px;
  height: 6px;
  margin: auto;
  background: #cdd9e0;
  border-radius: 6px;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -6px;
}
#exhibition h3 span {
  display: inline-block;
}

#exhibition h4 {
  font-size: 110%;
  font-weight: bold;
  margin-bottom: 0.8em;
  padding: 0.3em;
  border-left: 8px solid #cdd9e0;
}

@media only screen and (min-width: 769px) {
	#exhibition h3 {
		font-size:125%;
		line-height:1.4;
	}
}

/* --- logo --------------------*/
#exhibition .booth-logo {
  text-align: center;
}
#exhibition .booth-logo img {
	width: 100%; 
	height: 100%;
  /*max-width: 220px;*/
  max-width: 260px;
  max-height: 100px;
  margin: 0 auto;
}

#exhibition .booth-logo img.adjustH {
	width: auto;
  max-height: 40px;
}
#exhibition .booth-logo img.adjustH2 {
	width: auto;
  max-height: 65px;
}
#exhibition .booth-logo img.adjustH3 {
	width: auto;
  max-height: 85px;
}
#exhibition .booth-logo img.adjustW {
	max-width: 140px;
	height: auto;
}
#exhibition .booth-logo img.adjustW2 {
	max-width: 190px;
	height: auto;
}
#exhibition .booth-logo img.adjustW3 {
	max-width: 250px;
	height: auto;
}

@media only screen and (min-width: 769px) {
	#exhibition .booth-logo {
    width:30%;
		display:table-cell;
		vertical-align:top;
	}
}

@media (max-width: 768px) {
	#exhibition .booth-logo {
		margin:1em 0;
	}
}

/* 1枠に2社掲載の場合 */
#exhibition .booth-logo .twoCompany {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

#exhibition .booth-logo .twoCompany a {
  width: 100%;
}

#exhibition .booth-logo .twoCompany a img {
  width: auto;
  max-width: 190px;
  height: auto;
}

@media (max-width: 768px) {

  #exhibition .booth-logo .twoCompany {
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    gap: 30px;
  }

  #exhibition .booth-logo .twoCompany a {
    width: auto;
  }

  #exhibition .booth-logo .twoCompany a img {
    max-width: 140px;
    max-height: 45px;
  }

}

@media (max-width: 400px) {

  #exhibition .booth-logo .twoCompany {
    gap: 20px;
  }

  #exhibition .booth-logo .twoCompany a img {
    max-width: 130px;
    max-height: 40px;
  }

}

/* --- booth-info --------------------*/
#exhibition .booth-info {
  font-size: 90%;
}
#exhibition .booth-info p {
  line-height: 1.4;
  margin: 0 0 .8em;
}

#exhibition .booth-info li:not(:first-child) {
	margin-top: 0.5em;
}

/* --- booth-detai --------------------*/
#exhibition .booth-detail {
	margin: 0 -1.5em;
}

#exhibition ul + .booth-detail {
	margin-top: 0.8em;
}

#exhibition .booth-detail dl {
	float: left;
	width: calc(50% - 3em);
	margin: 1em 1.5em;
}

#exhibition .booth-detail .single dl {
	float: none;
	width: calc(100% - 3em);
}

#exhibition .booth-detail dt {
	font-size:110%;
	font-weight:bold;
	margin-bottom: 0.5em;
}

@media only screen and (min-width: 769px) {
	#exhibition .booth-info {
		display:table-cell;
		vertical-align:top;
	}
}

@media (max-width: 768px) {
	#exhibition .booth-detail dl:last-of-type {
		margin-bottom: 0;
	}
}

@media (max-width: 640px) {

	#exhibition .booth-detail,
	#exhibition ul + .booth-detail {
		margin-top: 2em;
	}

	#exhibition .booth-detail dl {
		float: none;
		width: calc(100% - 3em);
		margin-bottom: 2em;
	}

}



/*====================================================================================
 print
=====================================================================================*/

@media print {
  body,
  #lead,
  #enterprise,
  #pickup-K-1,
  #pickup-lecturer,
  #pickup,
  #overview {
    color: #444;
    background: transparent;
  }

  #timetable .session-detail header p,
  #timetable .btn-detail,
  #timetable .btn-profile,
  #timetable .btn-timetable-navi {
    display: none !important;
  }

  .wrapper {
    padding-right: 1em;
    padding-left: 1em;
  }

  #header .wrapper,
  #enterprise .wrapper {
    padding: 0;
  }

  #navigation,
  #information,
  #footer p,
  #footer .page-top a {
    display: none !important;
  }

  #lead,
  #enterprise .profile,
  #timetable .session-overview,
  #timetable .lecturer-list,
  #timetable .lecturer-profile,
  #footer {
    page-break-inside: avoid;
  }

  #information,
  #lead,
  #enterprise,
  #overview {
    padding-bottom: 0;
  }

  .inline-contents {
    display: none;
  }

  #enterprise img {
    width: 35%;
  }

  #enterprise dl {
    width: 62%;
  }

  #enterprise dt {
    margin-bottom: 0.7em;
    padding-bottom: 0.2em;
  }

  #timetable h5 {
    font-size: 125%;
  }

  #timetable .level1 {
    width: 99%;
    margin: 0 auto;
  }

  #timetable .level2 {
    border-right-width: 1px;
  }
  #timetable .level2 > .level3:not(:first-child) {
    border-top-width: 1px;
  }

  #timetable .single .lecturer-list,
  #pickup .lecturer-list {
    display:table;
    width: 100%;
    margin-top: 0.8em;
  }

  #timetable .single .lecturer-list .lecturer,
  #pickup .lecturer-list .lecturer {
    display:table-cell;
    width: 33%;
    padding-right: 0.8em;
    box-sizing: border-box;
  }

  #timetable .session-detail .lecturer-profile {
    display: inline-block;
    vertical-align: top;
    font-size: 90%;
    width: 49%;
  }

  #footer .logo {
    width: auto;
    height: auto;
    margin: 0 auto;
  }

  #footer .logo img {
    display: none;
  }

  #footer .logo:after {
    display: block;
    content: "(c) 2017 Impress Corporation";
    color: #fff;
  }
}

