/*TOPページ*/
.topnews {
  width: 100%;
  max-width: 578px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 25px;
  padding: 0 15px;
}

.topnews .youtube {
  padding-top: 70%;
}

.whatsnew {
  width: 1200px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 75px;
}

h2.wn_h2 {
  margin-bottom: 15px;
}

.activereport{
  width: 1200px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 75px;
}


.corona {
  width: 960px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 75px;
  margin-top: 25px;
}


.wn_right,
.ar_right {
  float: right;
  padding-right: 0px;
}

.wn_right {
  width: 45%;
}

.wn_right_h3,
.ar_right_h3,
.ar_left_h3 h3 {
  background-color: #0095E5;
  padding: 10px;
  width: 100%;
  border-bottom: solid 3px #FFF000;
  margin-bottom: 25px;
}

.wn_right_h3 h3,
.ar_right_h3 h3,
.ar_left_h3 h3 {
  color: #FFF;
  font-size: 16px;
}

span.newdate {
  background-color: #022B5F;
  color: #FFF;
  padding: 0px 5px;
}

#news_content {
  margin-bottom: 20px;
}

.news_contents {
  height: 300px;
  overflow: auto;
}

.wn_content1 {
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 25px;
}

.wn_content2 {
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}

.wniframe {
  width: 578px;
}


.ar_contents {
  display: flex;
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  justify-content: space-between
}

.ar_contents:before,
.ar_contents:after {
  display: none;
}

#ar_content,
#arl_content {
  padding: 10px;
  border: solid 1px #CCC;
  margin-bottom: 20px;
}

.ar_image {
  margin-bottom: 10px;
}

#ar_content p {
  width: 200px;
}

.ar_left_h3 {
  position: relative;
}

.ar_left_h3 h3 {
  padding-left: 120px;
}

.ar_left_h3 img {
  position: absolute;
  top: -25px;
  left: 10px;
}

.arl_image {
  margin-bottom: 20px;
}

.arl_link {
  margin-top: 20px;
  margin-bottom: 15px;
}

.arl_link a {
  font-size: 18px;
  text-decoration: none;
}

.front_sidecontent {
  width: 1200px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 65px;
  display: grid;
  grid-template-columns: repeat(auto-fill , minmax(225px , 1fr));
  margin-bottom: 65px;
}

.front_sidecontent a {
  position: relative;
}

.front_sidecontent:before,
.front_sidecontent:after {
  display: none;
}

.widget:before,
widget_text:before,
sidebar2:before {
  display: none;
}
.sidebar2 {
  margin-bottom: 10px;
}


.front_sns {
  width: 840px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 65px;
  display: flex;
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  justify-content: space-between;
}

.front_sns:before,
.front_sns:after {
  display: none;
}

.sns_facebook {
  width: 400px;
  height: 300px;
}

.front_blog {
  width: 400px;
}

.youtube_jc {
  margin-bottom: 15px;
}

@media screen and (max-width: 640px) {
  /*フロントページ*/
  #main_image {
    margin-bottom: 20px;
  }

  .front_mobile {
    width: 100%;
  }

  .front_mobile ul {
    padding: 0px;
    margin: 0px;
  }

  .whatsnew {
    padding: 0px 15px;
    width: 100%;
    margin: 0px 0px 30px 0px;
  }

  h2.wn_h2 img {
    width: 40%;
  }

  .newsimg {
    padding: 0px;
    margin-bottom: 20px;
    float: none;
  }

  .newsimg a img {
    width: 100%;
  }

  img.wnimg {
    width: 100%;
  }

  .wn_right {
    padding: 0px;
    float: none;
  }

  .wn_content1 {
    display: block;
    margin-bottom: 0px;
  }

  .wn_content2 {
    display: block;
    padding-bottom: 15px;
  }

  .wn_content1 img,
  .wn_content2 img {
    width: 100%;
    margin-bottom: 15px;
  }

  .wniframe {
    width: 100%;
    margin-bottom: 15px;
  }

  .wn_right {
    width: 100%;
  }


  .news_contents {
    height: 200px;
  }

  .activereport {
    width: 100%;
    margin: 0px;
  }

  .wn_right,
  .ar_right,
  .wn_left {
    float: none;
  }

  .ar_right {
    padding: 0px 15px;
  }

  .arl_image img,
  .ar_image img {
    width: 100%;
  }

  #ar_content p {
    width: 100%;
  }

  #ar_content {
    width: 48%;
  }

  .front_sidecontent {
    width: 100%;
    padding: 0px 15px;
    margin: 20px 0px;
    grid-template-columns: repeat(2 , 1fr);
    column-gap: 5%;
  }
  .front_kyosan_wrap {
    width: 100%;
    margin: 0px;
  }

  .front_kyosan_wrap h3 {
    font-size: 14px;
  }

  .front_kyosan_list {
    padding: 0px 15px;
  }

  .front_movie,
  .front_syosin,
  .front_sikkoubu,
  .front_iinkai,
  .front_torikumi,
  .front_sns_mobile {
    padding: 0px 15px;
    margin-bottom: 30px;
  }

  .front_movie h3,
  .front_syosin h3,
  .front_sikkoubu h3,
  .front_iinkai h3,
  .front_torikumi h3 {
    background-color: #0095E5;
    padding: 10px;
    width: 100%;
    border-bottom: solid 3px #FFF000;
    margin-bottom: 25px;
    color: #FFF;
    font-size: 16px;
  }

  .fm_content img {
    width: 100%;
  }

  .front_be_content_common {
    margin-top: 20px;
  }

  .bec_sentence h4 {
    color: #0090D5;
    margin-bottom: 25px;
    font-size: 26px;
    font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  }

  .front_link {
    margin-top: 25px;
  }

  .front_link a {
    display: inline-block;
    padding: 15px;
    background-color: #0095E5;
    color: #FFF;
    text-decoration: none;
    margin: 0px auto;
  }

  .front_link a:before {
    content: "\f18e";
    font-family: FontAwesome;
    margin-right: 10px;
  }

  .front_be_content1 {
    display: flex;
    justify-content: space-between;
  }

  #front_chiefdirector_img {
    width: 40%;
  }

  #front_chiefdirector_img img {
    width: 100%;
  }

  #front_chiefdirector_content {
    width: 57%;
  }

  #frontcd_logo {
    margin-bottom: 15px;
    text-align: center;
  }

  .frontcd_kochi {
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 12px;
  }

  #cd_name{
    font-size: 18px;
    font-weight: bold;
    text-align: center;
  }

  p.frontcd_name {
    font-size: 28px;
    line-height:1.2;
  }

  .front_sikkoubu {
    padding: 0px 15px;
    margin-bottom: 30px;
  }
  .front_sikkoubu .officer_list{
    display:grid;
    place-content: center;
    grid-template-columns: repeat(3, auto);
    gap:12px 8px;
  }
  .front_et {
    padding: 0px;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  .front_et::after {
    content: "";
    display: block;
    width: 30%;
  }

  .front_et:before {
    display: none;
  }

  .front_ic_content2 {
    padding: 0px;
    margin-bottom: 30px;
  }
  .front_icc_content1{
    margin-bottom:30px;
  }
  .front_icc_content1 h4 {
    background-color: #FFFFB6;
    border: solid 2px #0095E5;
    font-size: 16px;
    font-weight:700;
    text-align: center;
    color: #0095E5;
    margin-bottom: 8px;
    padding: 10px 0px;
  }

  .front_icc_content1 img {
    width: 100%;
    border: 2px solid #0095E5;
  }
  .front_icc_content1 a{
    text-decoration: none;
  }
  
  .front_icc_content1 figcaption::before{
    content: "\f0a9";
    font-family: FontAwesome;
    color: #C8BB9B;
    margin:0 5px;
  }

  .ftc_wrap {
    padding: 0px;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  .ftc_content {
    border: solid 3px #0096E6;
    width: 49%;
    color: #0096E6;
    font-weight: bold;
    font-size: 16px;
    margin-bottom: 25px;
  }

  .front_taiiku {
    background: url(/img/ap_img1.png) left center no-repeat;
    padding: 5px;
    padding-left: 70px;
  }

  .front_seiso {
    background: url(/img/ap_img2.png) left center no-repeat;
    padding: 5px;
    padding-left: 70px;
  }

  .front_okyaku {
    background: url(/img/ap_img3.png) left center no-repeat;
    padding: 5px;
    padding-left: 70px;
  }

  .front_seisyonen {
    background: url(/img/ap_img4.png) left center no-repeat;
    padding: 5px;
    padding-left: 70px;
  }

  .front_seiso2 {
    background: url(/img/ap_img5.png) left center no-repeat;
    padding: 5px;
    padding-left: 70px;
  }

  .front_yosakoi {
    background: url(/img/ap_img6.png) left center no-repeat;
    padding: 5px;
    padding-left: 70px;
  }

  .front_hudo {
    background: url(/img/ap_img7.png) left center no-repeat;
    padding: 15px;
    padding-left: 70px;
  }

  .front_hojyo {
    background: url(/img/ap_img8.png) left center no-repeat;
    padding: 15px;
    padding-left: 70px;
  }

  .front_sinyu {
    background: url(/img/ap_img9.png) left center no-repeat;
    padding: 5px;
    padding-left: 70px;
  }

  .front_sns_mobile {
    padding: 0px 15px;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  .front_banner {
    width: 50%;
    margin-bottom: 25px;
  }
}