body #row {
  display: flex;
  flex-flow: column;
}
header {
  display: flex;
  width: 100%;
  height: 100px;
  align-items: center;
}
.warp {
  width: 1200px;
  margin: 0 auto;
}
#row {
  margin: 0 auto;
}
.title {
  margin-right: auto;
  margin-left: 30px;
  font-size: 18px;
}
.menu-group {
  padding: 0px;  
}
.menu-item {
  list-style: none;
  display: inline-block;
  padding-left: 80px;
  padding-top: 12px;
  padding-bottom: 20px;
  width: 170px;
  margin-right: 50px;
  background-image: url("../images/n_1.png");
  background-repeat: no-repeat;
}
.menu-item a {
  color: white;
  text-decoration: none;
  font-size: 24px;
}
#main_banner {
  margin-bottom: -10px;
}
#g_navi {
  background: rgb(56,92,160);
}
#g_navi ul {
  display: flex;
  margin: 0 auto;
  padding: 0;
  list-style-type: none;
}
#g_navi ul li {
  position: relative;
  width: 20%;
  margin: 16px auto 10px;
}

#g_navi ul li+ li {
  position: relative;
}
#g_navi ul li+ li::before {
  border-left: 1px solid #FFFFFF;
  content: "";
  display: block;
  height: 60px;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
}

#g_navi ul li a {
  display: block;
  padding: 17px 10px;
  color: #fff;
  text-align: center;
  text-decoration: none;
  font-size: 18px;
  font-weight: bold;
}
#active::after {
  content: '';
  display: block;
  position: absolute;
  left: 50%;
  transform: translate(-50%);
  bottom: 0px;
  width: 150px;
  height: 2px;
  background-color: #FFFFFF;
}
#sub_banner {
  margin-top: 40px;
}
#sub_title {
  margin-left: 40px;
  margin-right: 40px;
  border-bottom: 2px solid rgb(56,92,160);
}
#sub_title h2 {
  border-left: 14px solid rgb(56,92,160);
  padding-top: 10px;
  padding-bottom: 10px;
  padding-left: 20px;
}
#content {
  margin-left: 40px;
  margin-right: 40px;
}
#content h3 {
  font-size: 20px;
}
#content ul {
  padding: 0;
  list-style-type: none;
}
#content ul li {
  padding-left: 40px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgb(220,220,220); 
}
#content span {
  display: block;
  margin-bottom: 10px;
}
#contact {
  margin: 20px auto;
}
#contact_sub {
  margin: 20px auto;
}
#contact_btn {
  box-sizing: unset;
}
.parent {
  display: flex;
  align-items: center;
}
.sub {
  align-items: stretch;
  padding: 30px 0;
}
.message {
  padding-right: 20px;
  flex: 1;
}
.message span {
  color: grey;
}
.emphasis {
  color: black !important;
  font-weight: bold;
}

.border {
  border-left: 2px solid rgb(56,92,160);
  padding-left: 30px;
}

figure {
  margin: 20px 0 0;
}
#date {
  display: block;
  text-align: right;
  margin-right: 20px;
}
.table {
  border-spacing: 0px;
  border-collapse: collapse;
}
.tb_title {
  background: rgb(56,92,160);
  font-weight: normal !important;
  padding: 20px 20px 20px 20px;
  color: white;
  border: 1px solid white;
}
.tb_body {
  font-weight: normal !important;
  color: black;
  padding: 10px 10px 10px 20px;
  border: 1px solid;
}
footer {
  text-align: center;
  background: rgb(56,92,160);
  color: #FFFFFF;
  font-size: 15px;
  font-weight: normal;
}