@charset "UTF-8";
/*----------------------------------------------------------------------
ブラウザデフォルトスタイルリセット
----------------------------------------------------------------------*/
body,
h1, h2, h3, h4, h5, h6,
div,
p,
ul, ol, dl,
form, fieldset,
table,
address,
blockquote,
noscript,
pre,
tr,
td,
input,
textarea {
  margin: 0;
  padding: 0;
  line-height: 1;
  font-style: normal;
}

body {
  font-size: 10px;
}

* html body {
  font-size: 62.5%;
}

* + html body {
  font-size: 62.5%;
}

/* start \*/
html:\66irst-child body {
  font-size: 62.5%;
}

/* end */
body:first-of-type {
  font-size: 62.5%;
}

body > iframe {
  display: none;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 1em;
  font-weight: normal;
}

small {
  font-size: 1em;
}

mark {
  background: none;
}

fieldset {
  border: none;
}

legend {
  display: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0px;
  font-size: inherit;
  font: 100%;
}

li {
  list-style-type: none;
}

dd {
  margin: 0;
}

a,
abbr,
acronym,
em,
strong,
span,
img,
sub,
sup,
input,
button,
textarea,
select,
label,
caption {
  font-weight: normal;
  font-style: normal;
}

a {
  text-decoration: none;
}

img {
  border: none;
  vertical-align: bottom;
}
@media screen and (max-width: 768px) {
  img {
    width: 100%;
  }
}

caption, th {
  font-weight: normal;
  text-align: left;
}

th, td {
  padding: 0px;
}

input, textarea, select {
  font-family: inherit;
  font-size: inherit;
}

textarea {
  vertical-align: top;
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block;
}

header, footer, article, section, aside,
nav,
figure, figcaption {
  display: block;
  margin: 0;
  padding: 0;
}

/*----------------------------------------------------------------------
HTMLタグ
----------------------------------------------------------------------*/
html,
body {
  height: 100%;
  min-width: 1260px;
}
@media screen and (max-width: 768px) {
  html,
  body {
    min-width: 100%;
  }
}

body {
  font-size: 16px;
  font-family: "Noto Sans JP", "Helvetica Neue", "Helvetica", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif";
  color: #231815;
  line-height: 1.4;
  -webkit-text-size-adjust: 100%;
}

body * {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

/*----------------------------------------------------------------------
共通部分
----------------------------------------------------------------------*/
.pc_none {
  display: none;
}
@media screen and (max-width: 768px) {
  .pc_none {
    display: block;
  }
}

.sp_none {
  display: block;
}
@media screen and (max-width: 768px) {
  .sp_none {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  img {
    max-width: 100%;
  }
}

.mod-inner {
  margin: 0 auto;
  padding: 40px 0 80px;
  width: 1180px;
}
@media screen and (max-width: 1180px) {
  .mod-inner {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .mod-inner {
    padding: 30px 15px;
    width: 100%;
  }
}

.mod-bg {
  background: rgba(70, 130, 180, 0.2);
}

.mod-title {
  text-align: center;
  margin: 0 0 30px;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.3;
  color: #4682B4;
}
.mod-title span {
  font-size: 20px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .mod-title span {
    font-size: 16px;
  }
}
.mod-title span.middletitle {
  display: block;
  margin: 50px 0 0;
  padding: 50px 0 0;
  border-top: solid 1px #000;
  font-size: 24px;
}
@media screen and (max-width: 768px) {
  .mod-title span.middletitle {
    margin: 10px 0 0;
    padding: 30px 0 0;
  }
}
@media screen and (max-width: 768px) {
  .mod-title {
    font-size: 22px;
  }
}

.mod-txt {
  margin: 0 0 20px;
}
.mod-txt span {
  display: block;
  text-align: center;
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 700;
}
.mod-txt p {
  text-align: center;
  font-size: 16px;
  line-height: 1.8;
}
.mod-txt p em {
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .mod-txt p {
    text-align: left;
    font-size: 14px;
  }
}

.mod-btn a {
  display: flex;
  justify-content: center;
  margin: 0 auto 10px;
  padding: 18px 0 20px;
  width: 300px;
  border-radius: 10px;
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 0.05em;
  background: #4682B4;
  color: #FFF;
  transition: all 0.3s ease 0s;
}
@media screen and (max-width: 768px) {
  .mod-btn a {
    font-size: 18px;
  }
}
.mod-btn a:hover {
  opacity: 0.7;
}

/* 概要 */
.mod-list {
  display: flex;
  justify-content: center;
}
.mod-list ul {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media screen and (max-width: 768px) {
  .mod-list ul {
    gap: 10px;
  }
}
.mod-list ul li dl {
  display: flex;
  align-items: center;
  gap: 10px;
}
.mod-list ul li dl dt {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 3px 0 5px;
  width: 80px;
  height: 30px;
  font-size: 16px;
  font-weight: bold;
  background: #747474;
  color: #FFF;
}
@media screen and (max-width: 768px) {
  .mod-list ul li dl dt {
    padding: 4px 0 5px;
    height: auto;
    font-size: 14px;
  }
}
.mod-list ul li dl dd {
  width: calc(100% - 90px);
  font-size: 18px;
  font-weight: bold;
  line-height: 1.4;
}
@media screen and (max-width: 768px) {
  .mod-list ul li dl dd {
    font-size: 16px;
  }
}
.mod-list ul li dl dd span {
  font-size: 16px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .mod-list ul li dl dd span {
    font-size: 14px;
  }
}
.mod-list ul li dl dd br {
  display: none;
}

.mgb10 {
  margin: 0 0 10px !important;
}

.mgb50 {
  margin: 0 0 50px !important;
}

/*----------------------------------------------------------------------
#header
----------------------------------------------------------------------*/
.header {
  background: #4682B4;
}

.header-inner {
  margin: 0 auto;
  padding: 50px 0;
  width: 1180px;
}
@media screen and (max-width: 1180px) {
  .header-inner {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .header-inner {
    padding: 30px 15px;
    width: 100%;
  }
}
.header-inner h1 {
  text-align: center;
  font-size: 30px;
  font-weight: 700;
  color: #FFF;
}
@media screen and (max-width: 768px) {
  .header-inner h1 {
    font-size: 22px;
    line-height: 1.3;
  }
}

/*----------------------------------------------------------------------
#content
----------------------------------------------------------------------*/
/* 概要 */
.overview {
  display: flex;
  justify-content: center;
  padding: 40px 0;
}
@media screen and (max-width: 768px) {
  .overview {
    padding: 20px 15px;
  }
}

/*----------------------------------------------------------------------
#footer
----------------------------------------------------------------------*/
.footer {
  background: #4682B4;
}

.footer-inner {
  margin: 0 auto;
  padding: 50px 20px;
  width: 1180px;
}
@media screen and (max-width: 1180px) {
  .footer-inner {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .footer-inner {
    padding: 30px 15px;
    width: 100%;
  }
}

.footer-title {
  display: block;
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 700;
  color: #FFF;
}
@media screen and (max-width: 768px) {
  .footer-title {
    font-size: 16px;
  }
}

.footer-list ul li {
  font-size: 16px;
  line-height: 1.8;
  color: #FFF;
}
@media screen and (max-width: 768px) {
  .footer-list ul li {
    font-size: 14px;
  }
}

/*----------------------------------------------------------------------
11.	ページ別個別設定
----------------------------------------------------------------------*/
/* 開催日程 */
.schedule-table table {
  margin: 0 auto;
  width: 980px;
}
@media screen and (max-width: 768px) {
  .schedule-table table {
    width: 100%;
  }
}
.schedule-table table tr {
  border: solid 1px #CCC;
}
@media screen and (max-width: 768px) {
  .schedule-table table tr {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    margin: 0 0 10px;
  }
}
.schedule-table table tr:first-child {
  background: #E6E6E6 !important;
}
.schedule-table table tr:nth-child(odd) {
  background: #F6F6F6;
}
.schedule-table table tr th, .schedule-table table tr td {
  text-align: center;
  padding: 15px 10px;
  letter-spacing: 0.05rem;
  line-height: 1.3;
  color: #333;
}
.schedule-table table tr th:not(:last-child), .schedule-table table tr td:not(:last-child) {
  border-right: solid 1px #CCC;
}
@media screen and (max-width: 768px) {
  .schedule-table table tr th:not(:last-child), .schedule-table table tr td:not(:last-child) {
    border-right: none;
  }
}
@media screen and (max-width: 768px) {
  .schedule-table table tr th, .schedule-table table tr td {
    padding: 10px 5px;
    width: 33.3%;
    font-size: 12px;
  }
  .schedule-table table tr th:nth-child(-n+3), .schedule-table table tr td:nth-child(-n+3) {
    border-bottom: solid 1px #CCC;
  }
  .schedule-table table tr th:nth-child(2), .schedule-table table tr th:nth-child(5), .schedule-table table tr td:nth-child(2), .schedule-table table tr td:nth-child(5) {
    border-right: solid 1px #CCC;
    border-left: solid 1px #CCC;
  }
}
.schedule-table table tr th span, .schedule-table table tr td span {
  font-size: 14px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .schedule-table table tr th span, .schedule-table table tr td span {
    font-size: 11px;
  }
}
.schedule-table table tr th {
  font-size: 16px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .schedule-table table tr th {
    font-size: 14px;
  }
}
.schedule-table table tr td {
  font-size: 14px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .schedule-table table tr td {
    display: flex;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    font-size: 12px;
  }
}
.schedule-table table tr td a {
  font-size: 15px;
  font-weight: bold;
  color: #1d3994;
}
@media screen and (max-width: 768px) {
  .schedule-table table tr td a {
    font-size: 13px;
  }
}
.schedule-table table tr td a:hover {
  opacity: 0.7;
}
.schedule-table table tr td.schedule-table__nolink {
  font-size: 12px;
  line-height: 1.4;
  color: #999;
}

/* お問い合わせ */
.contact .mod-list ul li span {
  width: 100px;
}
.contact .mod-list ul li p {
  width: calc(100% - 110px);
}

.contact-list-title {
  display: block;
  text-align: center;
  margin: 40px 0 20px;
  font-size: 20px;
  font-weight: bold;
}
