@charset "UTF-8";
/* 変数 */
body.top .container {
  margin-bottom: 0;
}
body.top #main-visual {
  position: relative;
  display: block;
  overflow: hidden;
}
body.top #main-visual .slide-item {
  position: relative;
}
body.top #main-visual .slide-item .slide-item-mv {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 430px;
  /*background-color: rgba(0, 0, 0, 0.3);*/
}
@media only screen and (max-width: 1200px) {
  body.top #main-visual .slide-item .slide-item-mv {
    height: auto;
  }
}
body.top #lead {
  margin-bottom: 0;
  padding: 36px 0 40px;
}
body.top #lead .lead-row {
  display: flex;
  align-items: center;
  margin: 0 -12px;
}
@media only screen and (max-width: 1200px) {
  body.top #lead .lead-row {
    display: block;
    margin: 0;
  }
}
body.top #lead .lead-row .lead-col {
  width: calc(50% - 24px);
  margin: 0 12px;
}
@media only screen and (max-width: 1200px) {
  body.top #lead .lead-row .lead-col {
    width: 100%;
    margin: 0;
  }
}
@media only screen and (max-width: 1200px) {
  body.top #lead .lead-row .lead-col:first-child {
    margin: 0 0 50px;
  }
}
body.top #lead .lead-row .lead-infos .lead-infos-txt {
  margin: 0 0 24px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  color: #000000;
}
body.top #lead .lead-row .lead-infos .lead-infos-txt span {
  color: #e6001e;
}
body.top #lead .lead-row .lead-infos .lead-infos-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 270px;
  height: 40px;
  margin: 0 auto;
  font-size: 16px;
  font-weight: 400;
  color: #000000;
  border: 1px solid #000000;
  border-radius: 24px;
  transition: 0.3s ease all;
}
body.top #lead .lead-row .lead-infos .lead-infos-link:hover {
  opacity: 0.7;
}
body.top #link .link-group {
  position: relative;
  margin: 0 0 56px;
  padding: 36px 24px 30px;
  border: 2px solid #394653;
}
@media only screen and (max-width: 1200px) {
  body.top #link .link-group {
    padding: 36px 20px 24px;
  }
}
@media only screen and (max-width: 480px) {
  body.top #link .link-group {
    padding: 24px 10px;
  }
}
body.top #link .link-group .link-group-ttl {
  position: absolute;
  left: 32px;
  top: -16px;
  display: flex;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0;
  padding: 0 8px;
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  color: #394653;
  background-color: #ffffff;
  border-bottom: none;
  white-space: nowrap;
}
@media only screen and (max-width: 1200px) {
  body.top #link .link-group .link-group-ttl {
    left: 50%;
    transform: translateX(-50%);
  }
}
body.top #link .link-group .link-group-ttl span {
  font-size: 32px;
}
body.top #link .link-group .link-group-list {
  display: flex;
  margin: 0 -12px;
}
@media only screen and (max-width: 1200px) {
  body.top #link .link-group .link-group-list {
    display: block;
    margin: 0 0;
  }
}
body.top #link .link-group .link-group-list .link-group-item {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: calc(25% - 24px);
  margin: 0 12px;
  padding: 18px;
  background-color: #394653;
  transition: 0.3s ease all;
}
body.top #link .link-group .link-group-list .link-group-item:hover {
  opacity: 0.7;
}
@media only screen and (max-width: 1200px) {
  body.top #link .link-group .link-group-list .link-group-item {
    flex-direction: row;
    width: 100%;
    margin: 0 0 12px;
    padding: 4px 10px;
  }
}
@media only screen and (max-width: 480px) {
  body.top #link .link-group .link-group-list .link-group-item {
    padding: 4px;
  }
}
body.top #link .link-group .link-group-list .link-group-item.red {
  background-color: #e6001e;
}
body.top #link .link-group .link-group-list .link-group-item.yellow {
  background-color: #efc819;
}
body.top #link .link-group .link-group-list .link-group-item.gray {
  background-color: #bbbcbe;
}
@media only screen and (max-width: 1200px) {
  body.top #link .link-group .link-group-list .link-group-item .link-group-item-icon {
    width: 45px;
  }
}
@media only screen and (max-width: 480px) {
  body.top #link .link-group .link-group-list .link-group-item .link-group-item-icon {
    width: 30px;
  }
}
body.top #link .link-group .link-group-list .link-group-item .link-group-item-icon img {
  display: block;
}
body.top #link .link-group .link-group-list .link-group-item .link-group-item-text {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 100%;
  height: 60px;
  margin: 0;
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.2;
  color: #ffffff;
}
@media only screen and (max-width: 1200px) {
  body.top #link .link-group .link-group-list .link-group-item .link-group-item-text {
    display: block;
    width: -moz-fit-content;
    width: fit-content;
    height: auto;
    margin: 0 0 0 10px;
  }
}
@media only screen and (max-width: 480px) {
  body.top #link .link-group .link-group-list .link-group-item .link-group-item-text {
    font-size: 18px;
    margin: 0 0 0 4px;
  }
}
body.top #link .link-group .link-group-list .link-group-item .link-group-item-text span {
  display: block;
  font-size: 18px;
}
@media only screen and (max-width: 1200px) {
  body.top #link .link-group .link-group-list .link-group-item .link-group-item-text span {
    display: inline;
  }
}
@media only screen and (max-width: 480px) {
  body.top #link .link-group .link-group-list .link-group-item .link-group-item-text span {
    font-size: 14px;
  }
}
body.top #info {
  padding: 0 0 50px;
}
body.top #info .info-ttl {
  margin: 0;
  padding: 5px;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  background-color: #e6001e;
}
body.top #info .info-tbl {
  width: 100%;
  /*table-layout: fixed;*/
}
body.top #info .info-tbl tr {
  width: 100%;
  border-collapse: collapse;
}
body.top #info .info-tbl tr td {
  padding: 3px 10px;
  border: 1px solid #394653;
}
body.top #info .info-tbl tr td.date {
  width: 120px;
  text-align: center;
  font-size: 16px;
  line-height: 1;
  color: #000000;
  background-color: #bbbcbe;
}
@media only screen and (max-width: 480px) {
  body.top #info .info-tbl tr td.date {
    width: 100px;
    font-size: 14px;
  }
}
body.top #info .info-tbl tr td.link {
  width: calc(100% - 120px);
  overflow: hidden;
  text-overflow: ellipsis;
}
@media only screen and (max-width: 480px) {
  body.top #info .info-tbl tr td.link {
    width: calc(100% - 100px);
  }
}
body.top #info .info-tbl tr td.link a {
  max-width: 100%;
  /*white-space: nowrap;*/
  font-size: 16px;
  line-height: 1;
  color: #000000;
  text-decoration: underline !important;
  transition: 0.3s ease all;
}
body.top #info .info-tbl tr td.link a:hover {
  opacity: 0.7;
}
@media only screen and (max-width: 480px) {
  body.top #info .info-tbl tr td.link a {
    font-size: 14px;
  }
}
body.top #news {
  padding: 0 0 60px;
}
body.top #news .news-row {
  display: flex;
  margin: 0 -12px;
}
@media only screen and (max-width: 1200px) {
  body.top #news .news-row {
    display: block;
    margin: 0;
  }
}
body.top #news .news-row .news-col {
  width: calc(50% - 24px);
  margin: 0 12px;
}
@media only screen and (max-width: 1200px) {
  body.top #news .news-row .news-col {
    width: 100%;
    margin: 0 0 48px;
  }
}
@media only screen and (max-width: 1200px) {
  body.top #news .news-row .news-col:last-child {
    margin: 0;
  }
}
body.top #news .news-row .news-info .news-info-ttl {
  margin: 0 0 40px;
  padding: 0 0 10px;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
  border-bottom: 2px solid #394653;
}
body.top #news .news-row .news-info .news-info-lead {
  display: flex;
}
body.top #news .news-row .news-info .news-info-lead .news-info-lead-icon {
  width: 90px;
}
body.top #news .news-row .news-info .news-info-lead .news-info-lead-text {
  width: calc(100% - 90px);
  padding: 0 0 0 30px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  color: #000000;
}
body.top #news .news-row .news-figure {
  display: block;
}
@media only screen and (max-width: 1200px) {
  body.top #news .news-row .news-figure img {
    display: block;
    margin: 0 auto;
  }
}
body.top #photo .photo-list {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -12px;
}
body.top #photo .photo-list .photo-item {
  width: calc(25% - 24px);
  margin: 0 12px 24px;
}
@media only screen and (max-width: 768px) {
  body.top #photo .photo-list .photo-item {
    width: calc(50% - 24px);
  }
}
body.top #feedbox {
  font-size: 13px;
  border: 1px solid #ccc;
  padding: 10px;
  margin-top: 20px;
  height: 140px;
  overflow-y: scroll;
}
body.top #feedbox ul {
  padding-left: 0;
  margin-left: 0;
  clear: both;
}
body.top #feedbox ul li {
  border-bottom: 1px dotted #ccc;
  margin-bottom: 5px;
  text-align: left;
}
body.top #feedbox ul li a {
  color: black;
}
body.top #feedbox ul li a span.feed-date {
  color: #000;
  margin-right: 15px;
  font-weight: bold;
}
body.top #bottom h4 {
  text-align: center;
}
body.top .slider {
  display: none; /*読み込み時は非表示*/
}
body.top .bx-viewport .slider {
  display: block !important; /*JSが読み込まれたら表示*/
}