@charset "utf-8";

body {
  font-size: 16px;
}

/* header title */
header div.title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  background-color: #2a73cc;
  min-height: 122px;
  color: #ffffff;
  text-align: center;
  min-width: 1100px;
  margin: 0 auto;
  padding: 85px 0 0;
}
header div.title p.tagline {
  font-size: 26px;
  font-weight: bold;
  line-height: 1;
  text-align: left;
  margin: 20px auto;
}

header div.title .subtitle {
  font-size: 24px;
  font-weight: bold;
  line-height: 1;
  margin: 0 auto 20px;
}
header div.title .info {
  font-size: 20px;
  line-height: 1;
  margin: 20px auto;
}
header div.title .info > span {
  display: inline-block;
  margin-left: 18px;
}


/* main */
main {
  padding: 0;
}

h2 {
  font-size: 40px;
  font-weight: bold;
  line-height: 1;
  position: relative;
  text-align: center;
  margin-bottom: 50px;
}
/*h2:before {*/
/*  content: "";*/
/*  display: block;*/
/*  width: 178px;*/
/*  height: 2px;*/
/*  background: #0f4b8f;*/
/*  position: absolute;*/
/*  top: 38px;*/
/*  left: 50%;*/
/*  transform: translateX(-50%);*/
/*}*/
h2 > span {
  font-size: 16px;
  display: block;
  margin-top: 20px;
}

/* for fixed nav */
/*#greeting::before,*/
/*#outline::before,*/
/*#program::before,*/
/*#access::before {*/
/*  content: "";*/
/*  display: block;*/
/*  height: 70px;*/
/*  margin-top: -70px;*/
/*  visibility: hidden;*/
/*}*/

/* greeting */
#greeting {
  padding: 70px 0;
  min-width: 1100px;
}
#greeting p {
  line-height: 2em;
}

/* outline */
#outline {
  width: 100%;
  background-color: #f0f0f0;
  padding: 70px 0 70px;
}
#outline h2 {
  margin: 40px 0 50px;
  font-size: 40px;
}
#outline .wrap {
  width: 1300px;
  margin: 0 auto;
  max-width: 98%;
}
#outline .outline_inner {
	display: flex;
	justify-content: center;
	gap: 40px;
	align-items: center;
}
#outline .outline_inner p {
	width: 66%;
	font-size: 16px;
	line-height: 1.8;
}
#outline .outline_inner .photo {
	width: 42%;
}
#outline .outline_inner .photo img {
	width: 100%;
	height: auto;
	border-radius: 10px;
}
#outline .outline_inner h3 {
	background: #E6201C;
	color: #fff;
	font-size: 22px;
	font-weight: bold;
	padding: 10px 15px;
	margin: 40px 0 20px;
}
#outline table {
  margin: 0 auto;
  width: 85%;
}

#outline table tr th {
  width: 130px;
  font-weight: bold;
  border-top: 1px solid #E6201C;
  padding: 15px 0 15px 10px;
  color: #E6201C;
  vertical-align: top;
  font-size: 22px;
  line-height: 1.6;
}

#outline table tr:first-child th {
  border-top: none;
}

#outline table tr td {
  border-top: 1px solid #E6201C;
  padding: 15px 0;
  font-size: 22px;
  line-height: 1.6;
}

#outline table tr:first-child td {
  border-top: none;
}

#outline table tr td a {
  color: #000000;
  text-decoration: underline;
}

#outline table tr td a:hover {
  text-decoration: none;
}

/* program */
#program .wrap {
  width: 1100px;
  max-width: 95%;
  padding-top: 70px;
}

/* access */
#access {
  min-width: 1100px;
  padding: 70px 0 0;
}
#access .wrap {
  background-color: #eeeeee;
  padding: 70px 0;
  width: 100%;
}
#access .access-content {
  position: relative;
  margin: 0 auto;
}
#access .access-map {
  overflow: hidden;
}
#access .access-box {
  position: absolute;
  overflow: hidden;
  top: -40px;
  right: -40px;
  background-color: #fff;
  padding: 25px 35px;
  line-height: 1.8em;
}
#access .access-box .space {
  font-size: 20px;
  font-weight: bold;
}
#access .access-box .address {
  margin: 10px 0;
}
#access .access-box .address a {
  text-decoration: underline;
  color: #000;
}
#access .access-box .address a:hover {
  text-decoration: none;
}




/* special */

#special {
	background: url(../images/common/top_special_bg.png) no-repeat center/cover;
	padding: 80px 0;
}
#special h2 {
	color: #fff;
	margin: 0 0 60px;
	font-size: 40px;
}

#special h3 {
	color: #fff;
	align-items: center;
	display: flex; 
	justify-content: center;
	position: relative;
	font-size: 20px;
}
#special h3::before,
#special h3::after {
  background: #fff;
  content: "";
  height: 1px;
  width: 60px;
}
#special h3::before {
  margin-right: 15px;
}
#special h3::after {
  margin-left: 15px;
}
#special .guest_list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 40px;
	margin: 30px 0 60px;
}
#special .guest_list li {
	width: 270px;
}
#special .guest_list li .photo {
	width: 100%;
	margin: 0 0 15px;
}
#special .guest_list li .photo img {
	width: 100%;
	height: auto;
	border-radius: 50%;
}
#special .guest_list li p{
	color: #fff;
	text-align: center;
	line-height: 1.8;
}
#special .guest_list li p.name {
	font-weight: bold;
	font-size: 26px;
	
}
#special .guest_list li p.position {
	font-size: 17px;
	font-feature-settings: "palt";
}


/* btn area */
.btn_area {
	background: #f0f0f0;
	padding: 80px 0;
}
.btn_area ul {
	display: flex;
	justify-content: center;
	gap: 0 130px;
}
.btn_area ul li {
	width: 280px;
}
.btn_area ul li a {
	display: flex;
	width: 100%;
	align-items: center;
	justify-content: center;
	padding: 20px 0;
	border-radius: 60px;
	font-size: 22px;
	font-weight: bold;
	transition: filter 0.3s ease;
}

.btn_area li a svg {
  margin-left: 6px;
  vertical-align: middle;
  margin-top: 3px
  
}
.btn_area ul li:nth-child(1) a {
	background: #fff;
	border: 1px solid #ccc;
	color: #333;
}
.btn_area ul li:nth-child(2) a {
	background: #DA291B;
	border: 1px solid #ccc;
	color: #fff;
}
.btn_area li:last-child a:hover {
  filter: brightness(1.2);
}
.btn_area li:first-child a:hover {
  background-color: #f5f5f5;
}

/* sponsor */

#sponsor {
	background: #fff;
	padding: 80px 0;
}
#sponsor .wrap {
	width: 1300px;
	max-width: 95%;
}
#sponsor h2 {
	font-size: 40px;
	margin: 40px 0;
}
#sponsor h3 {
	color: #000;
	margin: 20px 0 40px;
	text-align: center;
	font-size: 30px;
}
#sponsor .sponsor_list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin: 0 0 60px;
}
#sponsor .sponsor_list li {
	border: 1px solid #ccc;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
}
#sponsor .sponsor_list li img {
	width: 100%;
	height: auto;
}
#sponsor .sponsor_list li a:hover {
	opacity: 0.7;
}
#sponsor .sponsor_list li span {
	font-size: 14px;
	color: #000;
	display: block;
	width: 100%;
	margin: 20px 0 0;
}
#sponsor .sponsor_list.silver li span {
	font-size: 12px;
}
#sponsor .sponsor_list.platinum {
	gap: 60px;
}
#sponsor .sponsor_list.platinum li {
	padding: 60px 40px;
	width: 28%;
	min-height: 200px;
}
#sponsor .sponsor_list.gold {
	gap: 40px;
}
#sponsor .sponsor_list.gold li {
	padding: 40px 30px;
	width: 21%;
	min-height: 200px;
}
#sponsor .sponsor_list.silver {
	gap: 20px;
}
#sponsor .sponsor_list.silver li {
	padding: 30px 25px;
	width: 18%;
	min-height: 138px;
}
#sponsor .sponsor_list li img.ctc {
	width: 90%;
}
#sponsor .sponsor_list li img.netone_p {
	width: 55%;
}
#sponsor .sponsor_list li img.networld {
	width: 90%;
}
#sponsor .sponsor_list li img.netone {
	width: 70%;
}
#sponsor .sponsor_list li img.mitsui {
	width: 85%;
}
#sponsor .sponsor_list li img.uniadex {
	width: 90%;
}
#sponsor .sponsor_list li img.ricoh {
	width: 80%;
}
#sponsor .sponsor_list li img.hcnet {
	width: 75%;
}
#sponsor .sponsor_list li img.kanematsu {
	width: 70%;
}
#sponsor .sponsor_list li img.sharp {
	width: 85%;
}
#sponsor .sponsor_list li img.datacontrol {
	width: 90%;
}
#sponsor .sponsor_list li img.netwave {
	width: 90%;
}
#sponsor .sponsor_list li img.hitachi_so {
	width: 90%;
}
#sponsor .sponsor_list li img.nesic {
	width: 100%;
}
#sponsor .sponsor_list li img.takabun {
	width: 90%;
}
#sponsor .sponsor_txt {
	text-align: right;
}