@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
    2. register
    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 {
	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 --- /////////////////////////////////////////////////*/
.h1-mobile,
.h1-pc { display: none; }

/*#header {
	background-color: #1B4773;
	background-image: linear-gradient(
    -45deg,
    #1B4773 25%,
    #333 25%, #333 50%,
    #1B4773 50%, #1B4773 75%,
    #333 75%, #333
  );
	background-size: 4px 4px;
}*/
#header {
	background-color: #FFFFFF;
	background-color: #000000;
	background-image: url(../images/top/hdr_bg.jpg);
	background-repeat: repeat-x;
	background-position: center bottom;
}

/* --- #navigation --- /////////////////////////////////////////////*/
.submit {
  display: inline-block;
  text-decoration: none;
  color: #ffffff;
  background-color: #f1b000 !important;
  text-shadow: 0 0 3px rgba(0,0,0,.5);
  padding: 1em 1.5em;
  border-radius: 5px;
  box-sizing: border-box;
}
.submit:hover {
  background-color: #f4c033 !important;
}
.submit i {
  vertical-align: middle;
  margin-right:.2em;
}

/* closeの場合 */
span.submit,
span.submit:hover {
	display: block;
	box-sizing: border-box;
	background-color: #666666 !important;
	cursor: not-allowed;
	padding-left: .4em;
	padding-right: .4em;
}
/**/

#navigation {
  text-align: center;
  background-color: #3c3c3c;
}
#navigation ul {
  display: table;
  width: 100%;
  margin: 0;
}
#navigation li {
  display: table-cell;
  position: relative;
	width: 25%;
  /*width: 33.3%;*/
  /*width: 50%;*/
}
#navigation a {
	display: block;
	text-decoration: none;
	color: #fff;
	padding-top: .8em;
	padding-right: .4em;
	padding-left: .4em;
	padding-bottom: 0.7em;
	box-sizing: border-box;
}
#navigation a:hover {
  background: #444;
}
/*#navigation .active,
#navigation .active:hover {
  position:absolute;
  bottom: 0;
  width: 100%;
  color: #666;
  background-color: #fff;
  border-bottom: 5px solid #fff;
  border-radius: 5px 5px 0 0;
  box-shadow: -2px -2px 2px rgba(0,0,0,.2), 2px -2px 2px rgba(0,0,0,.2);
}*/

#navigation .submit {
  min-width: 5em;
  margin: 0 .5em;
  padding-top: .4em;
  padding-bottom: .4em;
}
#navigation .event-name {
  display: none;
  font-size: 75%;
  line-height: 1;
  color: #bdc0c2;
  margin: 0;
  padding: .5em;
  background-color: #233a48;
}
#navigation .nav-top {
  min-width: 4em;
}
#navigation .nav-overview {
  min-width: 5em;
}
#navigation .nav-timetable {
  /*min-width: 8em;*/
  min-width: 5em;
}
#navigation br {
  display: none;
}
#navigation.fixed {
  position: fixed;
  top: 0;
  z-index: 1000;
  width: 100%;
  background: #2f2f2f;
}
#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;
}

/* --- #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;
}
#register,
#lead,
#enterprise,
#pickup-K-1,
#pickup-lecturer,
#pickup,
/*#sponsor,*/
#overview,
#timetable,
#exhibition {
  /*padding: 2.5em 0 2.5em;*/
	padding: 3.5em 0 0;
}

#sponsor {
  padding: 3.5em 0 0;
	margin-bottom: -20px;
}

/*#exhibition {
	padding: 3.5em 0 2.5em;
}*/

#enterprise {
  padding-bottom: 3em;
}

#lead {
  padding-bottom: 3.5em;
}
/*#information + #timetable,
#information + #exhibition {
  padding-top: 2em;
}*/

@media only screen and (max-width: 768px) {

	#register,
	#lead,
	#enterprise,
	#pickup-K-1,
	#pickup-lecturer,
	#pickup,
	#overview,
	#timetable,
	#exhibition {
		padding: 2.5em 0 0;
	}

	#sponsor {
		padding: 2.5em 0 0;
		margin-bottom: -20px;
	}

	#enterprise {
		padding-bottom: 2em;
	}

	#lead {
		padding-bottom: 2.5em;
	}

}

.closed {
	text-align: center;
	font-weight: bold;
	margin-bottom: 2em;
	padding: 2em;
	background-color: #FFFFFF;
	color: #000000;
	border: 1px solid #DF0003;
	font-size: 16px;
}

.thanks {
	margin-bottom: 3em;
	padding: clamp(1.5rem, 1.318rem + 0.91vw, 2rem) clamp(1rem, 0.636rem + 1.82vw, 2rem);
	background-color: #FFFFFF;
	text-align: center;
	color: #000000;
	border: 1px solid #DF0003;
	font-size: 16px;
	word-wrap: break-word;
}

.thanks .thanksTtl {
	color: #CC0000;
	font-size: 1.25em;
	text-align: center;
	font-weight: bold;
	margin-bottom: 0.5em;
}

@media only screen and (max-width: 800px) {

	.thanks{
		text-align: left;
	}

	.thanks .pcnly {
		display: none;
	}

}

.thanksBtn {
	text-align: center;
}
.thanksBtn a {
  display: inline-block;
  text-decoration: none;
  color: #ffffff;
  background-color: #E59512;
  padding: 1em 1.5em;
  border-radius: 8px;
  box-sizing: border-box;
}
.thanksBtn a:hover {
  background-color: #EFAA38;
}

.thanksBtn a::after {
  font-family: "Font Awesome 5 Free";
	content: '\f35d';
  font-weight: 600;
	margin-left: 0.3em;
	color: hsla(0,0%,100%,0.8)
}

.thanksBtn a br {
	display: none;
}

@media only screen and (max-width: 400px) {
	.thanksBtn a br {
		display: block;
	}
}

.lecturer-company,
.lecturer-division,
.lecturer-post {
  line-height: 1.2;
  /* line-height: 1.3; */
  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;
}
.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-color: #00547E;*/
	background-color: #118AB8;
  /*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;
}

#lead p:last-of-type {
	margin-bottom: 0
}

@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%;
  }
}


/* --- #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: #2f609e;*/
  background-color: #118AB8;
  background-image: url(../images/top/enterprise-bg.jpg);
  background-position: center bottom;
  background-repeat: no-repeat;
}

/*.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;
}*/
/**/

#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 #3BA8D4;
  border-width: 1px 0;
  margin-bottom: 1.5em;
  margin-top: 0.5em;
}
#enterprise h2 span {
  padding: .3em 0;
  background:transparent;
}
#enterprise h3 {
  font-size: 125%;
  margin-top: 1em;
  margin-bottom: 1em;
	/*height: 7.2em;*/
}
#enterprise h3 span {
  font-size: 1rem;
}
#enterprise h2:before,
#enterprise h2:after {
  /*background-color: #78ACB4;*/
  background-color: #3BA8D4;
}
#enterprise h2:before { top: -4px; }
#enterprise h2:after { top: auto; bottom: -4px; }

#enterprise .session-category {
  display: inline-block;
  font-size: 75%;
  line-height: 1;
  color: #fff;
  margin-top: 1em;
  margin-right: 0;
  margin-left: 0;
  margin-bottom: .1em;
  padding: .5em .8em;
  /*background-color: #32717a;*/
  background-color: #254874;
  border-radius: 3px;
}

#enterprise .lecturer-company {
	font-size: 100%;
}
#enterprise .lecturer-division,
#enterprise .lecturer-post {
	font-size: 87.5%;
}
#enterprise .lecturer-name {
	font-size: 125%;
}

/* --- #overview --------------------*/
#overview　{
  color: #2f4858;
  background-color: #FFFFFF;
}
#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,
#overview-support2 li{
  margin: .5em 0;
}
#overview-promoter .level2,
#overview-support .level2,
#overview-support2 .level2{
	padding-top: 1em !important;
	padding-bottom: 1em !important;
}
#overview-promoter .level2 img {
	/*width: 130px; Digital X Logo*/
	width: 110px; /*Cloud Watch Logo*/
  height: auto;
	vertical-align: baseline;
}

#overview-support .level2 img {
	width: auto;
  /*height: 40px;
	height: 34px;*/
	height: 45px;
	vertical-align: top;
}
#overview-support2 .level2 img {
	width: auto;
  height: 40px;
	vertical-align: top;
}

#overview-support .level2 ul,
#overview-support2 .level2 ul {
  list-style-type: none;
  margin-left: 0;
}
#overview-support .level2 ul li,
#overview-support2 .level2 ul li {
  display: inline-block;
  margin-right: 2em;
}
#overview-benefit .level2 img {
	width: auto;
  height: 280px;
}

/* --- #sponsor --------------------*/
#sponsor h2 {
    font-size:90%;
    line-height:1;
    padding:.3em;
    background:#d9e2e8;
    border-radius:1em;
}
#sponsor h2:not(:first-child) {
    margin-top:2em;
}
#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:20px 30px;
}
#sponsor #sponsor-gold li:nth-of-type(4),
#sponsor #sponsor-gold li:nth-of-type(5) {
    margin:10px 60px;
}

#sponsor li img {
    max-width:180px;
    max-height:60px;
}
#sponsor li img.adjustW {
	max-width: 140px;
}
#sponsor li img.adjustH {
	max-height: 34px;
  /*margin-top: 0.5em;*/
}
/*#sponsor .wide-h {
    margin-top:15px;
    margin-bottom:15px;
}*/
#sponsor-platinum li img {
    /* max-width:300px; */
    max-width:175px;
    max-height:100%;
  margin-top: 1em;
}
#sponsor-platinum li img.adjustH {
    max-height: 56px !important;
}
#sponsor-all,
#sponsor-gold,
#sponsor-silver {
  max-width: 95%;
}
#sponsor-lecture li {
    margin:10px 40px;
}
#sponsor-lecture li img {
    max-height: 60px;
}
#sponsor-lecture li img.adjustW {
    max-width: 230px;
}
/*
#sponsor .sponsor-gold li,
#sponsor-media2 li {
    margin-top:0;
}
#sponsor-silver li,
#sponsor-lecture li {
    margin-bottom:0;
}
*/
@media screen and (min-width: 584px) {
    #sponsor-media1 {
        /*max-width: 650px; 最後のロゴだけ改行されるのを解消するため*/
			width: 95%;
    }
}

/* --- #timetable --------------------*/
#timetable h3 {
  font-size: 75%;
  text-align: center;
  line-height: 1;
  color: #fff;
  margin: 1em 0;
}
#timetable h4 {
  font-size: 110%;
  line-height: 1.2;
  color: #2f4858;
  margin: .5em 0 0;
}
#timetable h4 span {
  display: block;
  font-size: 85%;
  margin: .3em 0 0;
}
#timetable h5 {
  position: relative;
  font-size: 95%;
  line-height: 1;
  color: #2f4858;
  padding: .4em .3em;
  border-left: 8px solid #cdd9e0;
}
#timetable header + h5 {
	margin-top: 1.5em;
}

#timetable i {
  vertical-align: middle;
}
#timetable nav i {
  color: #999;
  margin: 0 .5em .1em .2em;
}
#timetable .btn-detail i,
#timetable .btn-profile i {
  margin-right: .2em;
}
#timetable .btn-timetable-navi i {
  margin-right: .3em;
}
#timetable nav {
  margin-top: 1.5em;
  margin-bottom: 1.8em;
}
#timetable nav dt {
  font-size: 65%;
  text-align: center;
  line-height: 1;
  color: #ffffff;
  padding: .5em;
}
#timetable nav dd {
  padding: .3em;
}
#timetable nav p {
  font-size: 70%;
  margin: 0;
}
#timetable nav dd > a:not(:first-child) p {
  margin-top: .3em;
}
#timetable nav b {
  color: #555555;
}
#timetable nav span + b {
  margin-left: .2em;
}
#timetable nav a {
  text-decoration: none;
  color: #444444;
}
#timetable nav a:hover p {
  background: #eeeeee;
}
#timetable nav .timetable-date,
#timetable nav .level2,
#timetable nav .session-id {
  vertical-align: middle;
}
#timetable nav .session-id {
  font-size: 85%;
  margin-right: .3em;
}

#timetable nav .session-class {
  display: inline-block;
  font-size: 85.9%;
  line-height: 1;
  color: #ffffff;
  margin: .2em 0;
  padding: .5em .8em;
  background-color: #5a6871;
  border-radius: 3px;
}

#timetable nav .lecturer {
  font-size: inherit;
}
#timetable .level1,
#timetable .level2,
#timetable .level3 {
  border: 0 solid #9baebc;
  box-sizing: border-box;
}
#timetable .level1 {
  display: table;
  width: 100%;
}
#timetable .level2 {
  border-bottom-width:1px;
}
#timetable nav .level1:first-child .level2,
#timetable section.level1:nth-of-type(1) {
  border-top-width: 1px;
}
#timetable .timetable-date,
#timetable .level2 {
  display: table-cell;
  vertical-align: top;
}
#timetable .level3,
#timetable .single .level2 {
  padding: .8em .5em;
}
#timetable .timetable-date {
  width: 3em;
  background-color: #9baebc;
}
#timetable .level1:nth-child(odd) .timetable-date {
  background-color: #8a9ead;
}
#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 .session-id,
#timetable .session-category,
#timetable .session-info {
  display: inline-block;
  font-size: 75%;
  line-height: 1;
  color: #ffffff;
  margin: .1em 0;
  padding: .5em .8em;
  background-color: #5a6871;
  border-radius: 3px;
}
#timetable .session-id {
  text-align: center;
  display: inline-block;
}
#timetable .session-id.track1 { background-color: #942828; }
#timetable .session-id.track2 { background-color: #296322; }
#timetable .session-id.track3 { background-color: #014f92; }
#timetable .btn-detail {
  position: relative;
  margin-bottom: 0;
  padding-top: .6em;
}
#timetable .btn-detail:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  width: 5em;
  height: 6px;
  background-color: #cdd9e0;
  border-radius: 6px;
}
#timetable .btn-detail a {
  font-size: 95%;
  text-decoration: none;
  color: #444444;
}
#timetable .btn-detail a:hover {
  text-decoration: underline;
}
#timetable .btn-detail a i {
  color: #999999;
}
#timetable .session-info {
  line-height: 1.3;
  color: inherit;
  padding-left: .2em;
  background: transparent;
}
#timetable a.btn-profile {
	display: inline-block;
  padding-left: 0.5em;
  padding-right: 0.5em;
	height: 24px;
	color: #FFFFFF;
	text-align: center;
	line-height: 24px;
	background-size: 4px 4px;
	-moz-border-radius: 5px; /* Firefox v1.0+ */
	-webkit-border-radius: 5px; /* Safari v3.0+ and by Chrome v0.2+ */
	border-radius: 5px; /* Firefox v4.0+ , Safari v5.0+ , Chrome v4.0+ , Opera v10.5+  and by IE v9.0+ */
	text-decoration: none;
  margin: 0px !important;
	background-color: #aaaaaa;
	background-image: linear-gradient(
    -45deg,
    #aaaaaa 25%,
    #666666 25%, #666666 50%,
    #aaaaaa 50%, #aaaaaa 75%,
    #666666 75%, #666666
  );
}
#timetable a.btn-profile:hover {
  -webkit-transition: all .3s;
  transition: all .3s;
	text-decoration: none;
	color: #FFFFFF;
	opacity: 0.8;
	filter: alpha(opacity=80); /* ie lt 8 */
	-ms-filter: "alpha(opacity=80)"; /* ie 8 */
	-moz-opacity: 0.8; /* FF lt 1.5, Netscape */
	-khtml-opacity: 0.8; /* Safari 1.x */
	zoom: 1;
}
#timetable .btn-timetable-navi {
  display: inline-block;
  position: fixed;
  bottom: 10px;
  right: 5em;
  margin: 0;
  z-index: 1000;
}
#timetable .btn-timetable-navi a {
  display: block;
  text-decoration: none;
  line-height: 1;
  color: #ffffff;
  padding: .8em;
  background-color: #738da0;
  background: rgba(115,141,160,.9);
  border-radius: 3px;
}
#timetable .btn-timetable-navi a:hover {
  opacity: .8;
}
#timetable .lecturer {
  font-size: 85%;
  color: #555555;
  margin: 1em 0 0;
  z-index: 1;
  position: relative;
}
#timetable .lecturer-pic {
  float: left;
  width: 80px;
  height: 80px;
  margin-right: 1em;
}
#timetable .level1:not(.single) .lecturer-company {
  font-size: 105%;
  margin-bottom: .1em;
}
#timetable .level1:not(.single) .lecturer-name {
  font-size: 130%;
}


#timetable .single .lecturer-list .lecturer {
	border-bottom: 1px solid #DCE2EA;
	padding: 0 0.5em 1em 0.5em;
	margin-left: 0.5em;
	margin-right: 0.5em;
}

#timetable .single .lecturer-list .lecturer:last-child {
	border-bottom: none;
}

#timetable dl.lecturer-list dt {
  font-size: 75%;
  font-weight: bold;
  line-height: 1;
  color: #2f4858;
  margin: 1.3em 0 0;
  padding: .3em .8em;
  background-color: #cdd9e0;
  border-radius: 1em;
}
#timetable .session-detail {
  margin-top: 1em;
}
#timetable .session-overview p {
  font-size: 90%;
  line-height: 1.4;
  margin: .8em 0;
}
#timetable .session-overview {
  position: relative;
  margin-top: 1em;
}
#timetable .lecturer-profile {
  font-size: 90%;
  line-height: 1.4;
  margin: 1em 0;
}
#timetable .lecturer-profile dt {
  font-size: 110%;
  font-weight: bold;
}
#timetable .lecturer-profile dd {
  padding-left: .3em;
  border-left: 8px solid transparent;
}
#timetable .lecturer-profile dd p {
  font-size: 90%;
  line-height: 1.4;
}
#timetable .lecturer-profile .lecturer-workspace {
  margin: .3em 0 0;
}
#timetable .lecturer-profile .lecturer-biography {
  margin: 1em 0 0;
}
#timetable .lecturer-profile .part {
  display: inline-block;
  font-size: 75%;
  color: #2f4858;
  margin-bottom: .3em;
  padding-right: 2em;
  border-bottom: 3px solid #cdd9e0;
}
#timetable .lecturer + h4 {
  margin-top: 1.5em;
}
#timetable .outlineBox h3 {
	display: inline-block;
	color: #FFFFFF;
	background-color: #4A82A6;
	font-size: 75%;
	text-align: left;
	padding-top: 0.5em;
	padding-right: 0.8em;
	padding-left: 0.8em;
	padding-bottom: 0.5em;
	margin-bottom: 0em;
  margin-top: 2em;
	font-weight: normal;
	border-radius: 3px;
	line-height: 100%;
}
#timetable .outlineBox h3 + p {
  margin-top: 0.5em;
}

.outlineBox + h5 {
  margin-top: 2em;
}

#timetable .social-gathering {
	background-color: #EDF1F3;
}

#timetable .social-gathering h4 {
	margin-bottom: 0.5em;
}

/* 講演概要ポップアップ */
#timetable .lecturerProfBox {
	margin-top: 8px;
}

#timetable .lecturerOutlineBox {
  display: inline-block;
  padding-top: 35px;
  padding-left: 1em;
  padding-right: 1.8em;
	float: left;
  margin-top: .8em;
  z-index: 2;
  position: relative;
}
#timetable .lecturerOutlineBox.plural { /* パネラーが複数の場合 */
  padding-top: 0px;
  margin-bottom: 1.8em;
  float: none;
}

#timetable a.lecturerOutlineBtn {
	display: block;
	width: 160px;
	height: 40px;
	color: #FFFFFF;
	text-align: center;
	line-height: 40px;
	background-size: 4px 4px;
	-moz-border-radius: 5px; /* Firefox v1.0+ */
	-webkit-border-radius: 5px; /* Safari v3.0+ and by Chrome v0.2+ */
	border-radius: 5px; /* Firefox v4.0+ , Safari v5.0+ , Chrome v4.0+ , Opera v10.5+  and by IE v9.0+ */
	text-decoration: none;
	background-color: #5688AE;
	background-image: linear-gradient(
    -45deg,
    #5688AE 25%,
    #285E88 25%, #285E88 50%,
    #5688AE 50%, #5688AE 75%,
    #285E88 75%, #285E88
  );
}
#timetable a.lecturerOutlineBtn:hover {
  -webkit-transition: all .3s;
  transition: all .3s;
	text-decoration: none;
	color: #FFFFFF;
	opacity: 0.8;
	filter: alpha(opacity=80); /* ie lt 8 */
	-ms-filter: "alpha(opacity=80)"; /* ie 8 */
	-moz-opacity: 0.8; /* FF lt 1.5, Netscape */
	-khtml-opacity: 0.8; /* Safari 1.x */
	zoom: 1;
}

/* 講師プロフィールポップアップ */
#timetable .level2 header + p {
  font-size: 90%;
  line-height: 1.4;
  margin-bottom: .5em;
}
#timetable .single .lecturer-pic {
  width: 120px;
  height: 120px;
}
#timetable .single .lecturer-name,
#timetable .single .btn-profile {
  display: inline-block;
  vertical-align: middle;
}
#timetable .single .btn-profile {
  margin-left: .3em;
}

/* --- #exhibition --------------------*/
#exhibition {
	padding-bottom: clamp(1.25rem, 0.341rem + 4.55vw, 3.75rem);
}

#exhibition .level1 {
    margin:2em 0;
    padding-bottom:2em;
    border-bottom:1px solid #cdd9e0;
}
#exhibition .level1:nth-of-type(2) {
    margin-top:2.5em;
}
#exhibition h3 {
    position:relative;
    text-align:center;
    color:#2f4858;
    margin:0 0 1.5em;
    padding-bottom:.5em;
}
#exhibition h3:after {
    content:"";
    display:block;
    position:absolute;
    left:0;
    right:0;
    bottom:-6px;
    width:30%;
    max-width:256px;
    height:6px;
    margin:auto;
    background:#cdd9e0;
    border-radius:6px;
}
#exhibition h3 span {
    display:inline-block;
}
#exhibition h4 {
    font-size:110%;
    font-weight:bold;
    margin-bottom:.8em;
    padding:.3em;
    border-left:8px solid #cdd9e0;
}
#exhibition .booth-logo {
    text-align: center;
}
#exhibition .booth-logo img {
	width: 100%; 
	height: 100%;
    max-width: 220px;
    max-height: 100px;
    margin:0 auto;
}
#exhibition .booth-logo img.adjustH {
	width: auto;
    max-height: 40px;
}
#exhibition .booth-logo img.adjustW {
	max-width: 150px;
	height: auto;
}
#exhibition .booth-logo img.adjustW2 {
	max-width: 190px;
	height: auto;
}
#exhibition .booth-info {
	display: none; /* 詳細が入るまで非表示 */
    font-size:90%;
}
#exhibition .booth-info p {
    line-height:1.4;
    margin:0 0 .8em;
}

#exhibition .booth-detail {
	margin: 0 -1.5em;
}

#exhibition ul + .booth-detail {
	margin-top: 0.8em;
}

#exhibition .booth-info dl {
	float: left;
	width: calc(50% - 3em);
	margin: 1em 1.5em;
}

#exhibition .booth-info .single dl {
	float: none;
	width: calc(100% - 3em);
	/*margin: 1em 1.5em;*/
}

#exhibition .booth-info dt {
	font-size:110%;
	font-weight:bold;
	margin-bottom: 0.5em;
}

@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-info dl {
		float: none;
		width: calc(100% - 3em);
		margin-bottom: 2em;
	}

}


/*#exhibition .booth-info ul {
	margin-top:1em;
}*/
#exhibition .booth-info li:not(:first-child) {
	margin-top: 0.5em;
}

/* --- #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: 420px) {
  /*.h1-mobile { display:block; }*/
  #pickup h2 {
    margin-bottom: 1em;
  }
  #timetable > .wrapper:not(:first-child) {
    padding-right: 0;
    padding-left: 0;
  }
}
@media (min-width: 421px) {
  /*.h1-pc {
    display: inline-block;
    width: 100%;
    max-width: 1024px;
  }*/
  #timetable nav dd {
    padding-right: .5em;
    padding-left: .5em;
  }
  #timetable nav .level2 {
    border-right-width: 1px;
  }
}
@media (max-width: 460px) {
  #timetable .single .lecturer-pic {
    float: none;
    margin: 0 0 .5em;
  }
  .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) {
  #navigation br {
    display: block;
  }
  #navigation li {
    vertical-align: middle;
  }
  #navigation a {
    height: 4.6em;
  }
  .nav-top a,
  .nav-overview a,
	.nav-booth a {
    line-height: 3em;
  }
  
  #navigation a.submit {
    height: auto;
  }
  #navigation .active,
  #navigation .active:hover {
    height: 5em;
  }
  #lead h2 {
    text-align: left;
  }

}


@media only screen and (max-width: 768px) {
  .h1-mobile { display:block; }
  .footer-logo {
    width: 40px;
    height: auto;
  }

  .btn-submit a {
    width: 80%;
  }

  #contents {
    font-size: 115%;
    line-height: 1.3;
  }
  #overview {
    /*padding-top: 1.5em;*/
    /*padding-bottom: 1em;*//* for ".page-top" */
  }
  #timetable {
    /*padding-top: 1.5em;*/
    /*padding-bottom: 3em;*//* for ".page-top" */
  }

	/*#exhibition .booth-logo img.adjustW {
		max-width: 220px;
	}*/
	/*#exhibition .booth-logo img.adjustW2 {
		max-width: 220px;
	}*/

	#exhibition h2 + p {
		text-align:center;
	}
	#exhibition .booth-logo {
		margin:1em 0;
	}

  #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;*/
  }
  
  .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:last-of-type {
		margin-bottom: 0;
	}
	
	#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;
  }

	#timetable .wrapper {
		padding-left: 0;
		padding-right: 0;
	}
	#timetable .wrapper h2,
	#timetable .wrapper h2 + p {
		margin-left: .8em;
		margin-right: .8em;
		box-sizing: border-box;
	}
	/*#timetable h3 {
    position: -webkit-sticky;
    position: sticky;
    top: 5.5em;
  }*/
  #timetable h4 span {
    margin-top: .5em;
  }
  #timetable nav dd > a:not(:first-child) p {
    margin-top: .5em;
  }
  #timetable nav p > .lecturer:not(:nth-last-child(2)) {
    display: block;
  }
  #timetable .level3,
  #timetable .single .level2 {
    padding-top: .5em;
  }
  #timetable .level2 > .level3:not(:first-child) {
    border-top-width: 1px;
  }
  #timetable .lecturer-company {
    font-size: 110%;
  }
  #timetable .btn-profile {
    font-size: 90%;
  }
  #timetable .btn-timetable-navi {
    font-size: 80%;
  }

	#timetable .single .lecturer-list + h5 {
    margin-top: 1em;
  }
  #timetable .single .lecturer-list .lecturer-company br {
    display: none;
  }

  /*#timetable .single .lecturer-list .lecturer {
	border-bottom: 1px solid #DCE2EA;
    padding: 0 0.5em 1em 0.5em;
    margin-left: 0.5em;
    margin-right: 0.5em;
  }*/

  /* 講演概要ポップアップ */
  #timetable .lecturerOutlineBox {
    padding-top: 0px;
    padding-left: 0em;
    padding-right: 0em;
    float: none;
  }

  #footer .page-top {
    font-size: 80%;
  }
  .swiper-slide img {
    width: 100%;
  }
}


@media only screen and (min-width: 769px) {
  .h1-pc {
    display: inline-block;
    width: 100%;
    /*max-width: 1024px;*/
		max-width: 1200px;
  }
  .btn-submit {
    max-width: 1024px;
    margin-right: auto;
    margin-left: auto;
  }
  .btn-submit a {
    width: 50%;
  }
  .wrapper {
    max-width: 1024px;
  }
  #overview {
    /*padding-bottom: 1em;*//* for ".page-top" */
    /*padding-top: 3em;*/
  }
  #timetable {
    /*padding-bottom: 3em;*//* for ".page-top" */
    /*padding-top: 3em;*/
  }
  #timetable h2 + p,
	#exhibition h2 + p {
    text-align: center;
  }

  #lead {
    /*padding-top: 4em;
    padding-bottom: 5em;*/
  }
  #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;
  }
  #sponsor h2 {
    letter-spacing: 1px;
  }
  #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;
  }
  #timetable nav,
  #timetable .btn-timetable-navi {
    display: none !important;
  }
  #timetable .single h4 {
    font-size: 125%;
  }
  #timetable .timetable-date {
    width: 8%;
    vertical-align: top;
  }
	#timetable .timetable-date.break {
    vertical-align: middle;
  }
  #timetable .timetable-date h3 {
    font-size: 85%;
  }
  #timetable .level1 {
    width: 100%;
    max-width: 1024px;
    margin: 0 auto;
  }
  #timetable .level2 {
    width: 91%;
    border-right-width:1px;
  }
  #timetable .level3 {
    display: table-cell;
    vertical-align: top;
    width: 33%;
    border-left-width: 1px;
  }
  #timetable .level2 > .level3:first-child {
    border-left-width: 0;
  }
  /*#timetable .single .lecturer-list {
    width: 100%;
		display: flex;
		gap: 0.5em;
  }
  
  #timetable .single .lecturer-list .lecturer {
		display: flex;
		width: 33.3%;
		box-sizing: border-box;
		gap: 0.5em;
  }
	
	#timetable .single .lecturer-list .lecturer .lecturer-pic {
		width: 120px;
	}
	#timetable .single .lecturer-list .lecturer .lecturer-txt {
		width: calc(100% - 120px);
	}*/
  #timetable .single .lecturer-list + h5 {
    margin-top: 1.8em;
  }

	#exhibition h3 {
		font-size:125%;
		line-height:1.4;
	}
	#exhibition .level2 {
		display:table;
		width:100%;
	}
	#exhibition .booth-logo,
	#exhibition .booth-info {
		display:table-cell;
		vertical-align:top;
	}
	#exhibition .booth-logo {
		width: 100%; /* 詳細が入るまでは100%表示 */
		padding-top: 10px; /* 詳細が入ったら削除 */
		/*width:30%;*/
	}

  #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;
  }

  #enterprise  dl,
  #enterprise .lecturer-company,
  #enterprise .lecturer-division,
  #enterprise .lecturer-post,
  #enterprise .lecturer-name  {
    float: none;
    width: 100%;
  }

  /*#timetable .single .lecturer-list .lecturer-pic {
    width: 100%;
    float: none;
    margin-bottom: 0.8em;
  }
  #timetable .single .lecturer-list .lecturer-pic img {
    width: 120px;
    height: auto;
  }
  #timetable .single .lecturer-list .lecturer-company br {
    display: none;
  }*/
}


@media only screen and (max-width: 460px) {
	#timetable .single .lecturer-list .lecturer-pic {
    width: 100%;
    float: none;
    margin-bottom: 0.8em;
  }
  #timetable .single .lecturer-list .lecturer-pic img {
    width: 120px;
    height: auto;
  }
  #timetable .single .lecturer-list .lecturer-company br {
    display: 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;
  }

  #timetable nav.wrapper {
    padding: 0;
  }
  #timetable nav .level1 {
    width: 100%;
  }
  #timetable .level3,
  #timetable .single .level2 {
    padding-right: .8em;
    padding-left: .8em;
  }
}
@media print {
  body,
  #lead,
  #enterprise,
  #pickup-K-1,
  #pickup-lecturer,
  #pickup,
  #overview {
    color: #444;
    background: transparent;
  }
  .wrapper {
    padding-right: 1em;
    padding-left: 1em;
  }
  #header .wrapper,
  #enterprise .wrapper {
    padding: 0;
  }
  /*#calendar,*/
  #navigation,
  #information,
  #register,
  #timetable nav,
  #timetable .session-detail header p,
  #timetable .level1:not(.single) .lecturer-list,
  #timetable .level1:not(.single) header + .lecturer,
  #timetable .btn-detail,
  #timetable .btn-profile,
  #timetable .btn-timetable-navi,
  #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,
  #sponsor,
  #overview {
    padding-bottom: 0;
  }
  #contents div:not(#sponsor) h2,
  #contents div:not(#sponsor) h2 span {
    color: #444444;
    background-color: #ffffff;
  }
  .inline-contents {
    display: block;
  }
  #enterprise img {
    width: 35%;
  }
  #enterprise dl {
    width: 62%;
  }
  #enterprise dt {
    margin-bottom: .7em;
    padding-bottom: .2em;
  }

  #sponsor ul {
    text-align: center;
  }
  #timetable h4 {
    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 {
    margin-top: .8em;
  }
  #timetable .single .lecturer-list .lecturer {
    padding-right: .8em;
    box-sizing: border-box;
  }
  #timetable .session-detail .lecturer-profile {
    display: inline-block;
    vertical-align: top;
    font-size: 90%;
    width: 49%;
  }
  #timetable .session-detail.single .lecturer-profile {
    display: block;
    width: auto;
  }
  #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;
  }
}

/* --- "colorbox.js" Setting --- ///////////////////////////////////*/

/* --- session-detail ----------- */
#colorbox .session-detail {
  color: #333333;
}
#colorbox .session-detail h5,
#colorbox .session-detail header p {
  padding: .4em .3em;
  border-left: 8px solid #cdd9e0;
}
#colorbox .session-detail h5 {
  font-size: 95%;
  line-height: 1;
  color: #2f4858;
}
#colorbox .session-detail header p {
  line-height: 1.2;
}
#colorbox .session-detail p {
  font-size: 90%;
  line-height: 1.4;
}
#colorbox .session-detail header h5 {
  padding-bottom: 0;
}
#colorbox .session-detail header p {
  color: #999999;
  margin-top: 0;
  padding-top: .5em;
}
#colorbox .session-detail .lecturer-profile {
  color: #555555;
}
#colorbox .session-detail .lecturer-profile .lecturer-pic {
  width: 90px;
  height: 90px;
}

/* --- lecturer-profile ----------- */
#colorbox .lecturer-profile {
  color: #333333;
  margin-top: 1em;
}
#colorbox .lecturer-profile dt {
  font-size: 110%;
  font-weight: bold;
}
#colorbox .lecturer-profile dd p {
  font-size: 90%;
  line-height: 1.4;
}
#colorbox .lecturer-profile .lecturer-pic {
  float: left;
  width: 120px;
  height: 120px;
  margin: 0 10px 0 0;
}
#colorbox .lecturer-profile .lecturer-workspace {
  margin: .3em 0 0;
}
#colorbox .lecturer-profile .lecturer-biography {
  margin: 1em 0 0;
}
#colorbox .lecturer-profile .part {
  display: inline-block;
  font-size: 75%;
  color: #2f4858;
  margin-bottom: .3em;
  padding-right: 2em;
  border-bottom: 3px solid #cdd9e0;
}

@media only screen and (max-width:768px) {
  #colorbox .lecturer-profile .lecturer-pic {
    width: 90px;
    height: 90px;
  }
}
@media only screen and (min-width:769px) {
  .session-detail {
    overflow: hidden;
  }
  #colorbox .session-detail,
  #colorbox .booth-detail {
    max-width: 1200px;
    padding: 1em 15% 0;
  }
  #colorbox .session-detail .lecturer-profile {
    display: inline-block;
    vertical-align: top;
    font-size: 90%;
    width: 49%;
  }
  #colorbox .session-detail.single .lecturer-profile {
    display: block;
    width: auto;
  }
  #colorbox .session-detail .lecturer-profile p {
    line-height: 1.3;
  }
}
@media only screen and (min-width:1024px) {
  #colorbox .session-detail .lecturer-profile .lecturer-pic {
    width: 120px;
    height: 120px;
  }
}

/* --- "swiper.js" Setting --- ///////////////////////////////////*/

.swiper-pagination-bullet:not(.swiper-pagination-bullet-active) {
  background-color: #ffffff;
}
.swiper-container-horizontal>.swiper-pagination-bullets,
.swiper-pagination-custom,
.swiper-pagination-fraction {
  bottom: 2px;
}
.swiper-slide figure {
  position: relative;
}
.swiper-slide figure img {
  display: block;
  margin: auto;
}
.swiper-slide figcaption {
  position: absolute;
  bottom: 0;
  width: 100%;
  font-size: 75%;
  line-height:1.3;
  color: #ffffff;
  padding: .5em .5em 22px;
  background: rgba(0,0,0,.8);
  box-sizing: border-box;
}
@media only screen and (min-width: 769px) {
  .swiper-container {
    width: 600px;
  }
  .swiper-slide img,
  .swiper-slide figure {
    width: 400px;
    margin: auto;
  }
}

/* --- "注目のセッション-高さ調整" --- ///////////////////////////////////*/
@media only screen and (min-width: 769px) {
  .featured-line-fix {
    margin-bottom: 2.6em !important;
  }
}
