@charset "utf-8";

/* 総合トップで消す */
.cv-btn {
	display: none;
}

/* header */
header div.header-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 17px 0 16px;
  top: 0;
  left: 0;
  background: #fff;
  z-index: 5000;
  box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.15);
}

/* header title */
header div.title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  background-color: #2a73cc;
  height: 122px;
  color: #ffffff;
  text-align: center;
  width: 1100px;
  max-width: 98%;
  margin: 0 auto;
  padding: 0;
  text-align: center;
}
header div.title p.tagline {
  font-size: 26px;
  font-weight: bold;
  line-height: 1;
  text-align: left;
  margin: 0 auto 50px;
}
header div.title h1 {
  font-size: 48px;
  font-weight: bold;
  line-height: 1;
  margin: 0;
  border: none;
  padding: 0;
}
header div.title .subtitle {
  font-size: 24px;
  font-weight: bold;
  line-height: 1;
  margin: 0 auto 60px;
}
header div.title .info {
  font-size: 20px;
  line-height: 1;
}
header div.title .info > span {
  display: inline-block;
  margin-left: 18px;
}
#main_kv {
  min-height: 552px;
}

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

/* greeting */
#greeting {
  padding: 30px 0 70px;
  width: 100%;
  background: linear-gradient(180deg, #f0f0f0 0%, #f0f0f0 70%, #ffffff 70%, #ffffff 100%);
}
#greeting .wrap {
	width: 100%;
}
#greeting h2 {
	margin: 0 0 40px;
	font-size: 40px;
}

#greeting h2 em {
	color: #E6201C;
	font-style: normal;
	font-weight: 900;
}
#greeting h2 span {
	font-size: 32px;
}
#greeting p {
  line-height: 1.6;
  font-size: 20px;
  text-align: center;
}

/* outline */
#outline {
  width: 100%;
  background-color: #fff;
  padding: 80px 0;
}
#outline h2 {
  margin: 0 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: flex-start;
}
#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 table {
  margin: 0 auto;
  width: 100%;
}

#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;
}
#outline .outline_inner h3 {
	background: #E6201C;
	color: #fff;
	font-size: 22px;
	font-weight: bold;
	padding: 10px 15px;
	margin: 40px 0 20px;
}
/* event */

.venue {
	background: #f0f0f0;
	padding: 80px 0;
}
.venue .venue_list {
	width: 100%;
	display: flex;
	justify-content: center;
	gap: 0 100px;
}
.venue .venue_list li {
	width: 450px;
	position: relative;
	z-index: 2;
	background: url(../images/common/top_link_bg.png) no-repeat center bottom /cover;
	color: #fff;
	padding: 30px 0 80px;
}

.venue .venue_list li .icon {
	text-align: center;
	font-size: 50px;
	font-weight: bold;
	margin: 0 0 15px;
}
.venue .venue_list li p {
	text-align: center;
	font-size: 32px;
	font-weight: bold;
}
.venue .venue_list li p.date {
	font-size: 36px;
	margin-bottom: 10px;
}
.venue .venue_list li .place {
	font-size: 20px;
	font-weight: normal;
}
.venue .venue_list li .linkbtn {
	width: 260px;
	margin: 10px auto 0;
}
.venue .venue_list li .linkbtn a {
	display: block;
	width: 100%;
	padding: 8px 0;
	text-align: center;
	color: #DA291C;
	font-size: 18px;
	border-radius: 45px;
	background: #fff;
	font-weight: bold;
}
.venue .venue_list li .linkbtn a:hover {
	opacity: 0.7;
}

table.event {
  width: 100%;
  font-size: 14px;
  margin: 30px 0 100px 0;
}
table.event tr th.date,
table.event tr th.title,
table.event tr th.place {
  background-color: #0f4b8f;
  border-left: 1px solid #eee;
  border-bottom: 1px solid #fff;
  text-align: center;
  padding: 15px;
  color: #fff;
  font-size: 16px;
}
table.event tr th.date {
  width: 194px;
}
table.event tr th.place {
  width: 295px;
}
table.event tr th.title {
  width: auto;
}
table.event tr td {
  border: 1px solid #dddddd;
  padding: 15px;
  vertical-align: top;
  font-size: 16px;
}
table.event tr td.title h3 {
  font-size: 20px;
  margin: 8px 0;
}
table.event tr td.title p.tagline,
table.event tr td.title p.subtitle,
table.event tr td.title p.info {
  margin: 4px 0;
}
table.event tr td div a,
table.event tr td a {
  color: #0f4b8f;
  text-decoration: underline;
}
table.event tr td a:visited {
  color: #0f4b8f;
}
table.event tr td div a:hover,
table.event tr td 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";
}

/* slide */

  .slider-section { padding: 0 0 50px; overflow: hidden; }

  .swiper { width: 100%; padding: 40px 0 70px !important; }

  .swiper-slide {
    width: 560px;
    border-radius: 10px;
    overflow: hidden;
    /*will-change: transform, opacity;*/
  }

  .swiper-slide img {
    width: 100%;
    height: 373px;
    object-fit: cover;
    display: block;
  }

  .swiper-pagination-bullet { background: #555; opacity: 1; }
  .swiper-pagination-bullet-active { background: #ff0000; }
  .swiper-button-prev, .swiper-button-next { color: #ffffff; }