@charset "UTF-8";
/**************************
color*/
/*** color ***/
.conteiner .mb-5 {
  margin-bottom: 5em !important;
}
.conteiner .mb-4 {
  margin-bottom: 4em !important;
}
.conteiner .mb-3 {
  margin-bottom: 3em !important;
}
.conteiner .mb-2 {
  margin-bottom: 2em !important;
}
.conteiner .mb-1_5 {
  margin-bottom: 1.5em !important;
}
.conteiner .mb-1 {
  margin-bottom: 1em !important;
}
.conteiner .mb-05 {
  margin-bottom: 0.5em !important;
}
.conteiner .mb-0 {
  margin-bottom: 0 !important;
}
.conteiner .mt-5 {
  margin-top: 5em !important;
}
.conteiner .mt-4 {
  margin-top: 4em !important;
}
.conteiner .mt-3 {
  margin-top: 3em !important;
}
.conteiner .mt-2 {
  margin-top: 2em !important;
}
.conteiner .mt-1_5 {
  margin-top: 1.5em !important;
}
.conteiner .mt-1 {
  margin-top: 1em !important;
}
.conteiner .mt-05 {
  margin-top: 0.5em !important;
}
.conteiner .mt-0 {
  margin-top: 0 !important;
}
.conteiner .mt-5 {
  margin-top: 5em !important;
}
.conteiner .mt-4 {
  margin-top: 4em !important;
}
.conteiner .mt-3 {
  margin-top: 3em !important;
}
.conteiner .mt-2 {
  margin-top: 2em !important;
}
.conteiner .mt-1_5 {
  margin-top: 1.5em !important;
}
.conteiner .mt-1 {
  margin-top: 1em !important;
}
.conteiner .mt-05 {
  margin-top: 0.5em !important;
}
.conteiner .mt-0 {
  margin-top: 0 !important;
}
.conteiner .my-5 {
  margin-left: 5em !important;
  margin-bottom: 5em !important;
}
.conteiner .my-4 {
  margin-left: 4em !important;
  margin-bottom: 4em !important;
}
.conteiner .my-3 {
  margin-left: 3em !important;
  margin-bottom: 3em !important;
}
.conteiner .my-2 {
  margin-left: 2em !important;
  margin-bottom: 2em !important;
}
.conteiner .my-1_5 {
  margin-left: 1.5em !important;
  margin-bottom: 1.5em !important;
}
.conteiner .my-1 {
  margin-left: 1em !important;
  margin-bottom: 1em !important;
}
.conteiner .my-05 {
  margin-left: 0.5em !important;
  margin-bottom: 0.5em !important;
}
.conteiner .my-0 {
  margin-left: 0 !important;
  margin-bottom: 0 !important;
}
.conteiner .mr-5 {
  margin-right: 5em !important;
}
.conteiner .mr-4 {
  margin-right: 4em !important;
}
.conteiner .mr-3 {
  margin-right: 3em !important;
}
.conteiner .mr-2 {
  margin-right: 2em !important;
}
.conteiner .mr-1_5 {
  margin-right: 1.5em !important;
}
.conteiner .mr-1 {
  margin-right: 1em !important;
}
.conteiner .mr-05 {
  margin-right: 0.5em !important;
}
.conteiner .mr-0 {
  margin-right: 0 !important;
}
.conteiner .my-5 {
  margin-top: 5em !important;
  margin-bottom: 5em !important;
}
.conteiner .my-4 {
  margin-top: 4em !important;
  margin-bottom: 4em !important;
}
.conteiner .my-3 {
  margin-top: 3em !important;
  margin-bottom: 3em !important;
}
.conteiner .my-2 {
  margin-top: 2em !important;
  margin-bottom: 2em !important;
}
.conteiner .my-1_5 {
  margin-top: 1.5em !important;
  margin-bottom: 1.5em !important;
}
.conteiner .my-1 {
  margin-top: 1em !important;
  margin-bottom: 1em !important;
}
.conteiner .my-05 {
  margin-top: 0.5em !important;
  margin-bottom: 0.5em !important;
}
.conteiner .my-0 {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
.conteiner .mx-5 {
  margin-left: 5em !important;
  margin-right: 5em !important;
}
.conteiner .mx-4 {
  margin-left: 4em !important;
  margin-right: 4em !important;
}
.conteiner .mx-3 {
  margin-left: 3em !important;
  margin-right: 3em !important;
}
.conteiner .mx-2 {
  margin-left: 2em !important;
  margin-right: 2em !important;
}
.conteiner .mx-1_5 {
  margin-left: 1.5em !important;
  margin-right: 1.5em !important;
}
.conteiner .mx-1 {
  margin-left: 1em !important;
  margin-right: 1em !important;
}
.conteiner .mx-05 {
  margin-left: 0.5em !important;
  margin-right: 0.5em !important;
}
.conteiner .mx-0 {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

body, h1, h2, h3 {
  color: #000;
}

body {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  padding: 0;
  margin: 0;
  min-width: 1200px;
}
@media only screen and (max-width: 767px) {
  body {
    min-width: 320px;
  }
}

h1 {
  margin: 0;
}

h1, h2, h3, h4, h5, p, th, td, li {
  letter-spacing: 0.15ex;
}

._disable {
  pointer-events: none;
}

.root {
  overflow: hidden;
  font-weight: 500;
}
@media only print {
  .root {
    overflow: auto;
    width: 100%;
  }
}

@media only screen and (max-width: 767px) {
  .main {
    margin-top: 15px;
  }
}

@media only screen and (min-width: 768px) {
  .pc_320 {
    min-height: 320px;
  }
}

.mt-2 {
  margin-top: 2em !important;
}

.mt-1_5 {
  margin-top: 1.5em !important;
}

.mt-1 {
  margin-top: 1em !important;
}

.mt-05 {
  margin-top: 0.5em !important;
}

.mt-0 {
  margin-top: 0 !important;
}

a {
  text-decoration: none;
  color: #00a08c;
  cursor: pointer;
}
a:hover {
  color: #a0cd37;
}
a.pdf:before, a.ext:before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 21px;
  background-size: cover;
  background-repeat: no-repeat;
  margin: 0px 5px 0 0;
  transform: translateY(4px);
}
a.pdf:before {
  background-image: url(../img/icon/icon_pdf.webp);
}
a.ext:before {
  background-image: url(../img/icon/icon_ext.webp);
}
a img {
  transition: all 0.2s;
}
a img:hover {
  opacity: 0.8;
}

p {
  margin: 1ex 0;
}

ul, ol {
  padding: 0;
  padding-left: 20px;
}
ul li, ol li {
  margin: 0.25rem 0;
}
@media only screen and (min-width: 768px) {
  ul._2, ol._2 {
    display: flex;
    flex-wrap: wrap;
  }
  ul._2 li, ol._2 li {
    width: 50%;
    box-sizing: border-box;
  }
  ul._2 li:before, ol._2 li:before {
    top: 12px !important;
  }
  ul._3, ol._3 {
    display: flex;
    flex-wrap: wrap;
  }
  ul._3 li, ol._3 li {
    width: 33.33%;
    box-sizing: border-box;
  }
  ul._3 li:before, ol._3 li:before {
    top: 12px !important;
  }
  ul._4, ol._4 {
    display: flex;
    flex-wrap: wrap;
  }
  ul._4 li, ol._4 li {
    width: 25%;
    box-sizing: border-box;
  }
  ul._4 li:before, ol._4 li:before {
    top: 12px !important;
  }
}
ul.none:before, ol.none:before {
  content: none;
}
ul.none:after, ol.none:after {
  content: none;
}

@media only screen and (min-width: 768px) {
  .pc_none {
    display: none !important;
  }
}

@media only screen and (max-width: 767px) {
  .sp_none {
    display: none !important;
  }
}

@keyframes walking {
  0% {
    right: 0;
  }
  6.6% {
    right: 0;
  }
  50% {
    right: 100%;
  }
  56.6% {
    right: 100%;
  }
  100% {
    right: 0%;
  }
}
header .head {
  display: flex;
  justify-content: space-between;
  margin: 20px auto;
  max-width: 1200px;
}
header .head .image {
  height: 70px;
  margin-left: 0px;
}
header .head .image img {
  max-height: 50px;
  height: 100%;
}
@media only screen and (max-width: 767px) {
  header .head .image {
    position: fixed;
    height: 50px;
    top: 5px;
    left: 0px;
  }
}
header .head ul {
  list-style: none;
  display: flex;
  margin: 3px 2rem 0 0;
  font-size: 12px;
}
header .head ul li {
  margin: 0 15px;
}
header .head ul a {
  color: #00a08c;
}
header .head .right_area {
  position: relative;
  width: 100%;
  max-width: 920px;
}
header .head .right_area .right {
  display: flex;
  justify-content: end;
  margin-right: 25px;
}
header .head .tanerin_image_ara {
  position: relative;
}
header .head .tanerin_image_ara ._image {
  pointer-events: none;
  position: absolute;
  bottom: -85px;
  right: 50px;
  height: 80px;
}
header .head .tanerin_image_ara ._image img {
  height: 100px;
}
header .head .tanerin_image_ara ._image .tanerin_image {
  height: 80px;
}
@media only screen and (max-width: 767px) {
  header .head .right_area {
    display: none;
  }
}
header .body {
  height: 45px;
  background-color: #00a08c;
}
@media only screen and (max-width: 767px) {
  header .body {
    display: none;
  }
}
header .body_nav {
  display: flex;
  max-width: 1200px;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  list-style: none;
  height: 100%;
}
header .body_nav li {
  position: relative;
}
header .body_nav li a {
  color: #fff;
  padding: 5px 45px;
  box-sizing: border-box;
  position: relative;
}
header .body_nav li a:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0%;
  height: 1px;
  background-color: #fff;
  transform-origin: 50% 50%;
  transition: all 0.2s;
}
header .body_nav li:not(:last-child):after {
  color: #fff;
  content: "|";
}
header .body_nav li.active a:after, header .body_nav li:hover a:after {
  width: 70%;
}
@media only screen and (max-width: 767px) {
  header {
    height: 60px;
    width: 100%;
    background-color: #fff;
    position: fixed;
    top: 0;
    z-index: 10000;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
  }
}

.shadowed_img img {
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

.searchBox {
  border: none;
  background-color: transparent;
}
@media only screen and (max-width: 767px) {
  .searchBox {
    width: 90%;
  }
}

.header_search_form > div {
  border: 1px solid #63c5b9;
  border-radius: 5px;
  height: 20px;
  padding: 0 5px;
}
.header_search_form > div input {
  padding: 0;
}
.header_search_form input[type=image i] {
  width: 18px;
}
.header_search_form .searchBox {
  transform: translateY(-3px);
}

.title_are {
  margin: 0 auto;
  width: 100%;
  height: 575px;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .title_are {
    height: 200px;
    margin: 60px auto 0;
  }
}
@media print {
  .title_are {
    color: #fff;
  }
}
.title_are img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
}
.title_are h1 {
  position: absolute;
  color: #fff;
  text-shadow: 1px 1px 5px rgba(0, 0, 0, 0.8);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .title_are h1 {
    width: 100%;
    text-align: center;
  }
}
.title_are.none {
  height: auto;
  margin: 1rem auto;
}
.title_are.none img {
  display: none;
}
.title_are.none h1 {
  color: #000;
  position: inherit;
  text-shadow: none;
  box-sizing: border-box;
  text-align: center;
  padding: 20px;
  font-size: 36px;
  top: auto;
  margin: 1rem auto;
  left: auto;
  transform: none;
}

.breadcrumbs_area {
  background-color: #d25532;
  min-height: 20px;
}
.breadcrumbs_area .breadcrumbs {
  width: 1200px;
  margin: 0 auto;
  padding: 0.25em 10px;
  box-sizing: border-box;
  list-style-type: none;
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  .breadcrumbs_area .breadcrumbs {
    margin-top: 0;
    width: auto;
  }
}
.breadcrumbs_area .breadcrumbs a {
  color: #fff;
  text-decoration: underline;
}
.breadcrumbs_area .breadcrumbs li {
  margin: 0;
  padding: 0;
  display: inline-block;
  vertical-align: middle;
  color: #fff;
}
.breadcrumbs_area .breadcrumbs li:before {
  content: none !important;
}
.breadcrumbs_area .breadcrumbs li:after {
  content: "";
  position: inherit;
  top: auto;
  left: auto;
  width: auto;
  height: auto;
  border-radius: 0%;
  background-color: transparent;
}
.breadcrumbs_area .breadcrumbs li:not(:last-child)::after {
  content: "/" !important;
  margin: 0 1ex;
  font-size: 90%;
  color: #b8b8b8;
  display: inline-block;
}

.gnav {
  background-color: #a0cd37;
}
.gnav > div {
  width: 100%;
}
.gnav ul.nav_list li img, .gnav ul.nav_list li .hover_text {
  display: none;
}
.gnav ul.nav_list li a {
  display: inline-block;
}
.gnav ul.nav_list li.logo_img {
  display: none;
}
@media only screen and (min-width: 768px) {
  .gnav.scroll_down > div {
    display: block !important;
    position: fixed;
    background-color: #a0cd37;
    top: -100px;
    transition: all 0.2s;
    z-index: 10000;
  }
  .gnav.scroll_down > div ul.nav_list {
    max-width: inherit;
  }
  .gnav.scroll_down > div ul.nav_list li img, .gnav.scroll_down > div ul.nav_list li .hover_text {
    display: none;
  }
  .gnav.scroll_down > div ul.nav_list li.logo_img {
    display: block;
  }
  .gnav.scroll_down > div ul.nav_list li.logo_img a {
    padding: 0;
  }
  .gnav.scroll_down > div ul.nav_list li.logo_img a:after {
    width: 100%;
    height: 100%;
  }
  .gnav.scroll_down > div ul.nav_list li.logo_img img {
    display: block;
    height: 55px;
    position: relative;
    z-index: 11;
  }
}
@media only screen and (min-width: 768px) {
  .gnav.fixed > div {
    top: 0;
  }
}

.subnav {
  display: none;
}

.sitemap .subnav {
  display: block;
}
.sitemap ul {
  padding-left: 0;
}
.sitemap ul li.li_sub {
  padding-left: 17px !important;
}
.sitemap ul li.li_sub:before {
  content: none !important;
}
.sitemap ul li > ul li {
  padding-left: 17px !important;
}

#header_menubtn {
  display: none;
}
@media only screen and (max-width: 767px) {
  #header_menubtn {
    display: block;
    width: 20px;
    height: 24px;
    position: fixed;
    right: 0;
    top: 0;
    padding: 18px 20px;
    z-index: 10;
  }
  #header_menubtn > span {
    box-sizing: border-box;
    display: block;
    width: 20px;
    height: 24px;
    margin-top: 5px;
    position: relative;
  }
  #header_menubtn > span span {
    display: inline-block;
    box-sizing: border-box;
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #6ea676;
    border-radius: 2px;
  }
  #header_menubtn > span span:nth-of-type(1) {
    top: 0;
  }
  #header_menubtn > span span:nth-of-type(2) {
    top: 6px;
  }
  #header_menubtn > span span:nth-of-type(3) {
    top: 12px;
  }
  .spmenu_active #header_menubtn > span span:nth-of-type(1) {
    top: 6px;
    transform: rotate(45deg) scale(1.2);
  }
  .spmenu_active #header_menubtn > span span:nth-of-type(2) {
    top: 6px;
    transform: rotate(135deg) scale(1.2);
  }
  .spmenu_active #header_menubtn > span span:nth-of-type(3) {
    top: 6px;
    transform: rotate(225deg) scale(1.2);
  }
}

#sp_nav {
  display: none;
}
.spmenu_active #sp_nav {
  opacity: 1;
}
@media only screen and (max-width: 767px) {
  #sp_nav {
    position: fixed;
    top: 60px;
    right: 0;
    opacity: 0;
    z-index: 99999;
    background-color: #fff;
    width: 100%;
    height: calc(100% - 50px);
    overflow: auto;
  }
  #sp_nav .sp_nav_content {
    background-color: #fff;
    border-top: 1px solid #00a08c;
    padding: 20px 10px;
  }
  #sp_nav .sp_nav_content form {
    width: 100%;
    margin: 0;
  }
  .spmenu_active #sp_nav {
    display: block;
  }
  #sp_nav > ul {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    list-style-type: none;
    position: relative;
    background-color: #fff;
  }
  #sp_nav > ul li.hasmenu.active {
    background-color: #eee;
  }
  #sp_nav > ul li.hasmenu .wide.active {
    background-color: #ddd;
  }
  #sp_nav > ul li.hasmenu:nth-child(n+2) {
    border-top: 1px solid #00a08c;
  }
  #sp_nav > ul li.hasmenu > div {
    display: flex;
    position: relative;
  }
  #sp_nav > ul li.hasmenu > div > *:first-child {
    flex-grow: 1;
  }
  #sp_nav > ul li.hasmenu > div > *:last-child {
    width: 50px;
    border: none;
    border-left: 1px solid #cccccc;
  }
  #sp_nav > ul li.hasmenu button {
    content: "";
    display: block;
    width: 50px;
    position: relative;
    cursor: pointer;
  }
  #sp_nav > ul li.hasmenu button::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url("../img/icon/breadcrumbs.webp") 50% 50% no-repeat;
  }
  #sp_nav > ul li.hasmenu button.open::before {
    transform: rotate(90deg);
  }
  #sp_nav > ul li.hasmenu button:hover, #sp_nav > ul li.hasmenu button:active {
    background-color: #ddd;
  }
  #sp_nav > ul ul {
    margin: 0;
    padding: 0 0 0 0px;
    list-style-type: none;
    height: 30px;
    display: none;
    height: 100%;
  }
  #sp_nav > ul li {
    list-style-type: none;
    margin: 0 0;
    padding: 0 0 0 15px;
    border-top: 1px solid #00a08c;
    position: relative;
  }
  #sp_nav > ul li:after {
    content: none;
  }
  #sp_nav > ul li.sp_nav_main button {
    background-color: #ddd;
  }
  #sp_nav > ul li.sp_nav_main button.open {
    background-color: #eeeeee;
  }
  #sp_nav > ul li.sp_nav_main .wide button {
    background-color: #ddd;
  }
  #sp_nav > ul li.sp_nav_main .wide button.open {
    background-color: #ddd;
  }
  #sp_nav > ul li.sp_nav_main a {
    background: url("../img/icon/breadcrumbs.webp") 10px 50%/9px 13px no-repeat;
  }
  #sp_nav > ul li.sp_search_container {
    padding: 20px 0px;
    box-sizing: border-box;
    background-color: #fff;
  }
  #sp_nav > ul li.sp_search_container form {
    width: 280px;
    margin: 0 auto;
  }
  #sp_nav > ul li.sp_nav_icons {
    padding: 0 0 0 15px;
    box-sizing: border-box;
  }
  #sp_nav > ul li.sp_nav_icons a {
    position: relative;
  }
  #sp_nav > ul li.sp_nav_icons a::before {
    top: 19px;
    left: 13px;
    content: "";
    display: block;
    position: absolute;
    width: 10px;
    height: 13px;
    background-image: url("../img/icon/link.webp");
    background-repeat: no-repeat;
    background-size: contain;
  }
  #sp_nav > ul a {
    margin: 0;
    padding: 1.2ex 15px 1.2ex 28px;
    font-weight: bold;
    vertical-align: middle;
    display: block;
    position: relative;
    text-decoration: none;
    transition: 0.3s all;
    color: #231815;
  }
  #sp_nav > ul a:hover, #sp_nav > ul a:active {
    color: rgb(232, 112, 33);
  }
  #sp_nav .hidden_nav {
    display: none;
  }
  #sp_nav .sp_nav_overlay {
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1;
  }
}
#sp_nav span.pdf:after, #sp_nav span.ext:after {
  content: "";
  background-size: contain;
  margin-left: 5px;
  display: inline-block;
  background-repeat: no-repeat;
}
#sp_nav span.ext:after {
  width: 16px;
  height: 13px;
  background-image: url(../img/icon/icon_ext.webp);
}
#sp_nav span.pdf:after {
  width: 13px;
  height: 17px;
  background-image: url(../img/icon/icon_pdf.webp);
}

.nav_list {
  display: flex;
  justify-content: center;
  list-style: none;
  max-width: 1200px;
  height: 100%;
  margin: 0 auto;
  padding: 10px 0;
}
@media only screen and (max-width: 767px) {
  .nav_list {
    flex-wrap: wrap;
  }
}
.nav_list li {
  position: relative;
}
.nav_list li a {
  color: #fff;
  padding: 5px 30px;
  box-sizing: border-box;
  font-size: 120%;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .nav_list li a {
    padding: 5px 10px;
    display: block;
    box-sizing: border-box;
    font-size: 100%;
  }
}
.nav_list li a:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0%;
  height: 3px;
  background-color: #fff;
  transform-origin: 50% 50%;
  transition: all 0.2s;
}
.nav_list li:not(:last-child):after {
  font-size: 130%;
  color: #fff;
  content: "|";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .nav_list li:nth-child(3):after {
    content: none;
  }
}
.nav_list li.active a:after, .nav_list li:hover a:after {
  width: 70%;
}
@media only screen and (max-width: 767px) {
  .nav_list li {
    width: 33.33%;
    text-align: center;
    margin-bottom: 10px;
    box-sizing: border-box;
  }
}

@media only screen and (min-width: 768px) {
  .pagelink_area {
    padding-top: 40px;
  }
}

.pagelinkList {
  padding: 0;
  list-style: none;
}
@media only screen and (min-width: 768px) {
  .pagelinkList {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0 0 70px;
  }
}
.pagelinkList li {
  margin: 0px 10px;
  padding: 0ex 25px 0.6ex 0px !important;
  font-size: 18px;
  font-weight: 500;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .pagelinkList li {
    margin: 0px;
  }
}
.pagelinkList li:before {
  content: none !important;
}
.pagelinkList li:after {
  left: auto;
  border-radius: 0%;
  background-color: transparent;
}
.pagelinkList li a {
  position: relative;
}
@media only screen and (min-width: 768px) {
  .pagelinkList li a {
    padding-left: 20px;
  }
  .pagelinkList li a:before {
    top: 5px;
    left: 0px;
    content: "";
    display: block;
    position: absolute;
    width: 16px;
    height: 16px;
    mask-image: url(../img/icon/pagelink_icon.webp);
    -webkit-mask-image: url(../img/icon/pagelink_icon.webp);
    -webkit-mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    background-size: contain;
    background-color: #00a08c;
    background-size: contain;
  }
}
@media only screen and (max-width: 767px) {
  .pagelinkList li a {
    padding-left: 20px;
  }
  .pagelinkList li a:before {
    top: 5px;
    left: 0px;
    content: "";
    display: block;
    position: absolute;
    width: 16px;
    height: 16px;
    mask-image: url(../img/icon/pagelink_icon.webp);
    -webkit-mask-image: url(../img/icon/pagelink_icon.webp);
    -webkit-mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    background-size: contain;
    background-color: #00a08c;
    background-size: contain;
  }
}
.pagelinkList li a:hover:before {
  background-color: #a0cd37;
}

.center {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

@media only screen and (max-width: 767px) {
  .sp_center {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
  }
}

.alignLeft {
  text-align: left;
}

.alignCenter {
  text-align: center;
}
.alignCenter > img {
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1em;
}

.clear {
  clear: both;
}

.alignRight {
  text-align: right;
}

@media only screen and (max-width: 767px) {
  .alignLeft_sp {
    text-align: left;
  }
  .alignCenter_sp {
    text-align: center;
  }
  .alignRight_sp {
    text-align: right;
  }
}
.main_content {
  max-width: 1200px;
  min-height: 300px;
  margin: 0 auto 20px;
  padding: 0 10px;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  .main_content {
    padding: 0 10px;
  }
}
.main_content.main_content_fixed {
  padding-top: 55px;
}
.main_content ul {
  list-style: none;
  margin-top: 1em 0;
}
.main_content ul li {
  position: relative;
}
.main_content ul li:before {
  content: "";
  width: 12px;
  height: 12px;
  background-color: #00a08c;
  display: inline-block;
  margin-right: 10px;
}
.main_content ul.link_list li {
  position: relative;
}
.main_content ul.link_list li:before {
  content: "";
  width: 9px;
  height: 13px;
  background-color: transparent;
  background-image: url(../img/icon/breadcrumbs.webp);
  background-size: contain;
}
.main_content ol {
  list-style: none;
  margin-top: 1em 0;
}
.main_content ol li {
  position: relative;
  counter-increment: number;
  padding-left: 20px;
}
.main_content ol li:after {
  content: counter(number);
  background-color: #d25532;
  border-radius: 50%;
  color: #fff;
  font-weight: bold;
  display: block;
  position: absolute;
  width: 18px;
  height: 18px;
  font-size: 70%;
  top: 3px;
  left: -6px;
  white-space: nowrap;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  letter-spacing: normal;
}
.main_content ol._2 li, .main_content ol._3 li {
  box-sizing: border-box;
}
.main_content ol._2 li:after, .main_content ol._3 li:after {
  top: 10px;
}
@media only screen and (max-width: 767px) {
  .main_content ol._2 li:after, .main_content ol._3 li:after {
    top: 5px;
  }
}

ul._2 li, ul._3 li {
  box-sizing: border-box;
}
ul._2 li:after, ul._3 li:after {
  top: 10px;
}
@media only screen and (max-width: 767px) {
  ul._2 li:after, ul._3 li:after {
    top: 5px;
  }
}

h1, h2, h3, h4, h5 {
  font-weight: 600;
}

h3:first-child, h4:first-child, h5:first-child {
  margin-top: 2rem;
}

h1 {
  font-size: 40px;
}
@media only screen and (max-width: 767px) {
  h1 {
    font-size: 32px;
  }
}

h2 {
  position: relative;
  box-sizing: border-box;
  text-align: center;
  padding: 20px;
  font-size: 25px;
  margin-bottom: 10px;
  color: #fff;
  z-index: 10;
}
@media only screen and (max-width: 767px) {
  h2 {
    padding: 10px 5px;
    font-size: 20px;
  }
}
h2:not(:first-child) {
  margin-top: 5rem;
}
@media only screen and (max-width: 767px) {
  h2:not(:first-child) {
    margin-top: 3.5rem;
  }
}
h2:first-child {
  margin-top: 0;
}
h2:before {
  content: "";
  width: 200vw;
  height: 100%;
  display: block;
  position: absolute;
  left: -50vw;
  top: 0;
  background-color: #00a08c;
  z-index: -1;
}
h2.green:before {
  background-color: #00a08c;
}
h2.red:before {
  background-color: #d25532;
}
h2.yellowgreen:before {
  background-color: #a0cd37;
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

h3 {
  color: #00a08c;
  border-bottom: 2px solid #01a08c;
  padding-bottom: 10px;
  font-size: 20px;
  clear: both;
  margin-top: 2rem;
  margin-bottom: 1rem;
}
@media only screen and (max-width: 767px) {
  h3 {
    font-size: 16px;
  }
}

h2 + ul {
  margin-top: 2rem;
}

h2 + p {
  margin-top: 2rem;
}

h2 + h3 {
  margin-top: 2rem;
}

p + h3 {
  margin-top: 2rem;
}

h4, h5, h6 {
  margin-top: 0;
}

h4 {
  color: #00a08c;
  margin-top: 1rem;
  margin-bottom: 0.75rem;
  font-size: 100%;
}

h5 {
  margin-bottom: 0.75rem;
  margin-top: 1rem;
  color: #00a08c;
  font-size: 90%;
}

h6 {
  color: #00a08c;
  margin-bottom: 0.75rem;
  font-size: 80%;
}

.btn {
  margin: 1rem auto;
  font-weight: 500;
}
.btn a {
  border-radius: 30px;
  margin: 1rem auto;
  text-align: center;
  transition: all 0.2s;
  transform-origin: 50% 50%;
  position: relative;
  padding: 8px 40px;
  display: inline-block;
  width: 100%;
  width: auto;
  letter-spacing: 0.3ex;
}
@media only screen and (max-width: 767px) {
  .btn a {
    padding: 8px 20px;
  }
}
.btn a span {
  position: relative;
  z-index: 10;
}
.btn a:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 30px;
  transform-origin: 50% 50%;
  transition: all 0.2s;
  transform: scale(0);
}
.btn a:hover span {
  color: #fff;
}
.btn a:hover:after {
  transform: scale(1.03);
}
.btn a.green {
  border: solid 2px #01a08c;
  color: #00a08c;
}
.btn a.green:hover:after {
  background-color: #01a08c;
}
.btn a.yellowgreen {
  border: solid 2px #a0cd37;
  color: #a0cd37;
}
.btn a.yellowgreen:hover:after {
  background-color: #a0cd37;
}
.btn a.red {
  border: solid 2px #d25532;
  color: #d25532;
}
.btn a.red:hover:after {
  background-color: #d25532;
}
.btn a.pdf:before, .btn a.ext:before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 21px;
  background-size: cover;
  background-repeat: no-repeat;
  margin: 0px 5px 0 0;
  transform: translateY(4px);
  position: relative;
  z-index: 10;
}
.btn a.pdf:before {
  background-image: url(../img/icon/icon_pdf.webp);
}
.btn a.ext:before {
  background-image: url(../img/icon/icon_ext.webp);
}
.btn a:hover.pdf:before {
  background-image: url(../img/icon/icon_pdf_white.webp);
}
.btn a:hover.ext:before {
  background-image: url(../img/icon/icon_ext_white.webp);
}

.pc_column1,
.pc_column2,
.pc_column3,
.pc_column4,
.pc_column5,
.pc_column6 {
  display: flex;
  flex-wrap: wrap;
}
.pc_column1 > div,
.pc_column2 > div,
.pc_column3 > div,
.pc_column4 > div,
.pc_column5 > div,
.pc_column6 > div {
  padding: 0 10px;
  box-sizing: border-box;
  margin-bottom: 1rem;
}
@media only screen and (max-width: 767px) {
  .pc_column1 > div,
  .pc_column2 > div,
  .pc_column3 > div,
  .pc_column4 > div,
  .pc_column5 > div,
  .pc_column6 > div {
    width: 100% !important;
  }
}

.pc_column2 > * {
  width: 50%;
}

.pc_column3 > * {
  width: 33.33%;
}

.pc_column4 > * {
  width: 25%;
}

.pc_column5 > * {
  width: 20%;
}

.pc_column6 > * {
  width: 16.66%;
}

.topics_list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 1000px;
  margin: 1rem auto 0;
}
@media only screen and (max-width: 767px) {
  .topics_list {
    padding-left: 0;
  }
}
.topics_list li {
  display: inline-block;
  padding: 5px 10px !important;
  margin-bottom: 20px;
}
.topics_list li:before {
  content: none !important;
}
@media only screen and (max-width: 767px) {
  .topics_list li {
    padding: 5px !important;
  }
}
.topics_list li a {
  border: 2px solid #00a08c;
  padding: 5px 10px;
  box-sizing: border-box;
  transition: all 0.2s;
}
.topics_list li a:hover, .topics_list li a.selected {
  background: #00a08c;
  color: #fff;
}

.img_max figure {
  width: 100%;
}
.img_max figure img {
  width: 100%;
}

.color_box {
  background-color: #ecf5d7;
  padding: 10px 20px 20px;
  box-sizing: border-box;
  margin: 0;
}
.color_box ul {
  padding-left: 0;
}

.midashi {
  background-color: #d9ebaf;
  color: #00a08c;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 30px;
  margin-bottom: 0;
  box-sizing: border-box;
}

img {
  max-width: 100%;
}

table {
  margin: 2rem 0 1rem;
  width: 100%;
  border: 2px solid #00a08c;
  border-collapse: collapse;
  table-layout: fixed;
}
table.auto {
  table-layout: auto;
}
table:first-child {
  margin-top: 0;
}
table td {
  border: none;
}
table th, table td {
  border: 2px solid #00a08c;
  padding: 5px 10px;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  table th, table td {
    padding: 5px;
  }
}
table thead th {
  background-color: #00a08c;
  color: #fff;
}
table thead th:not(:last-child) {
  border-right: 2.1px solid #fff;
}
table thead th a {
  color: #fff;
}
table.kinyu {
  border: 2px solid #d25532;
}
table.kinyu th, table.kinyu td {
  border: 2px solid #d25532;
}
table.kinyu thead th {
  background-color: #d25532;
}
@media only screen and (max-width: 767px) {
  table.sp_columned thead th:not(:last-child) {
    border-bottom: 2px solid #fff !important;
  }
}
table tbody th {
  background-color: #ecf5d7;
  color: #00a08c;
  width: 20% !important;
}
@media only screen and (max-width: 767px) {
  table tbody th {
    width: 100%;
    width: 25% !important;
  }
}
@media only screen and (max-width: 767px) {
  table.sp_columned {
    display: block;
    box-sizing: border-box;
    text-align: center;
    overflow: hidden;
  }
  table.sp_columned thead,
  table.sp_columned tbody,
  table.sp_columned tr,
  table.sp_columned th,
  table.sp_columned td {
    display: block;
    box-sizing: border-box;
  }
  table.sp_columned td, table.sp_columned th {
    border: none !important;
    border-bottom: 2px solid #00a08c !important;
    width: 100% !important;
  }
  table.sp_columned tr:last-child td:last-child {
    border-bottom: none !important;
  }
}

._filter {
  display: none;
}

@media only screen and (max-width: 767px) {
  .res {
    overflow-x: scroll;
    position: relative;
  }
  .res._fixed {
    overflow: hidden;
    margin-bottom: 1rem;
  }
  .res ._filter {
    display: block;
    position: absolute;
    top: 0px;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 50;
  }
  .res ._filter img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    max-width: 100px;
  }
  .responsive_wrapper {
    min-width: 700px;
  }
  .responsive_wrapper table {
    margin: 0;
  }
  .sp_columned {
    display: block;
    box-sizing: border-box;
    text-align: center;
    overflow: hidden;
  }
  .sp_columned thead,
  .sp_columned tbody,
  .sp_columned tr,
  .sp_columned th,
  .sp_columned td {
    display: block;
    box-sizing: border-box;
  }
  .sp_columned td, .sp_columned th {
    width: 100% !important;
  }
}
.wp-block-columns:first-child {
  margin-top: 3rem;
}

@media only screen and (max-width: 767px) {
  .wp-block-columns + .btn {
    margin-top: -1rem;
  }
  .wp-block-columns + .btn a {
    margin-top: -1rem;
  }
}
.pagelink_area + .wp-block-columns {
  margin-top: 2rem;
}

p + .wp-block-columns {
  margin-top: 2rem;
}

h2 + .wp-block-columns {
  margin-top: 3rem;
}
@media only screen and (max-width: 767px) {
  h2 + .wp-block-columns {
    margin-top: 2rem;
  }
}

h3 + .wp-block-columns {
  margin-top: 2rem;
}
@media only screen and (max-width: 767px) {
  h3 + .wp-block-columns {
    margin-top: 1rem;
  }
}

@media only screen and (max-width: 767px) {
  .wp-block-column .btn {
    margin: 0 auto;
  }
  .wp-block-column .btn a {
    margin: 0 auto;
  }
}
.wp-block-column h3:first-child, .wp-block-column h4:first-child, .wp-block-column p:first-child {
  margin-top: 0;
}

h4 + table {
  margin-top: 1rem;
}

.gray_border img {
  border: 1px solid #dddddd;
}

figcaption {
  text-align: center;
}

.content_red.content_red, .content_green.content_red, .content_yellowgreen.content_red {
  background-color: #d25532;
}
.content_red.content_green, .content_green.content_green, .content_yellowgreen.content_green {
  background-color: #00a08c;
}
.content_red.content_yellowgreen, .content_green.content_yellowgreen, .content_yellowgreen.content_yellowgreen {
  background-color: #a0cd37;
}
.content_red a, .content_green a, .content_yellowgreen a {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 40px;
  min-height: 100px;
  box-sizing: border-box;
  font-weight: bold;
  font-size: 18px;
  color: #fff;
  max-width: 380px;
  margin: 0 auto;
}
@media only screen and (max-width: 767px) {
  .content_red a, .content_green a, .content_yellowgreen a {
    padding: 20px;
  }
}
.content_red a.pdf:before, .content_red a.ext:before, .content_green a.pdf:before, .content_green a.ext:before, .content_yellowgreen a.pdf:before, .content_yellowgreen a.ext:before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 21px;
  background-size: cover;
  background-repeat: no-repeat;
  margin: 0px 5px 0 0;
  transform: translateY(2px);
  position: relative;
  z-index: 10;
}
.content_red a span, .content_green a span, .content_yellowgreen a span {
  position: relative;
}
.content_red a span:after, .content_green a span:after, .content_yellowgreen a span:after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  width: 0%;
  height: 2px;
  background-color: #fff;
  transform-origin: 50% 50%;
  transition: all 0.2s;
}
.content_red a.active span:after, .content_red a:hover span:after, .content_green a.active span:after, .content_green a:hover span:after, .content_yellowgreen a.active span:after, .content_yellowgreen a:hover span:after {
  width: 100%;
}
.content_red a.pdf:before, .content_green a.pdf:before, .content_yellowgreen a.pdf:before {
  background-image: url(../img/icon/icon_pdf_white.webp);
}
.content_red a.ext:before, .content_green a.ext:before, .content_yellowgreen a.ext:before {
  background-image: url(../img/icon/icon_ext_white.webp);
}

footer {
  background: url(../img/footer_bg.webp);
  background-repeat: no-repeat;
  background-position: top;
  margin-top: 60px;
  clear: both;
}
footer .link_area {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 110px 0 40px;
}
@media only screen and (max-width: 767px) {
  footer .link_area {
    min-width: 320px;
  }
}

.footer_link {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  margin-left: 25px;
  margin: 0 0 10px 0px;
}
@media only screen and (max-width: 767px) {
  .footer_link {
    display: block;
  }
}
.footer_link li {
  margin-right: 25px;
  font-size: 12px;
  margin: 0px 25px 10px 0;
}
@media only screen and (max-width: 767px) {
  .footer_link li {
    display: block;
  }
}
.footer_link a {
  color: #fff;
  position: relative;
}
.footer_link a:after {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 50%;
  transform: translate(-50%) scale(0);
  transform-origin: center;
  transition: all 0.1s;
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
}
.footer_link a:hover:after {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 50%;
  transform: translate(-50%) scale(1);
  transition: all 0.1s;
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
}

.footer_wrap {
  display: flex;
  justify-content: space-between;
}
@media only screen and (max-width: 767px) {
  .footer_wrap {
    flex-direction: column;
  }
}

.coryright {
  color: #fff;
  margin-left: 20px;
  font-size: 80%;
  opacity: 0.7;
  padding-bottom: 10px;
}

.footer_num {
  color: #fff;
  text-align: right;
  margin-right: 20px;
  font-size: 100%;
  padding-bottom: 10px;
}

.totop {
  z-index: 90;
  position: relative;
  padding: 0;
  margin: 0 auto;
  max-width: 1200px;
}
@media print {
  .totop {
    display: none;
  }
}
.totop a {
  margin: 0;
  padding: 0;
  background: none;
  text-decoration: none;
}
@media only screen and (max-width: 767px) {
  .totop {
    width: auto;
    height: 0px;
  }
}
@media print {
  .totop {
    display: none;
  }
}
.totop > div {
  margin: 0 0 0 auto;
}
@media only screen and (max-width: 767px) {
  .totop > div {
    margin: 0 auto;
  }
}
.totop a {
  display: block;
  position: absolute;
  bottom: -200px;
  bottom: -90px !important;
  right: 10px;
  transition: 0.25s all;
}
@media only screen and (max-width: 767px) {
  .totop a {
    margin: 0 auto;
    bottom: -50px !important;
    right: 2%;
    width: 70px;
  }
}
.totop a:hover img {
  opacity: 1;
}
.totop a.finished {
  position: absolute;
  bottom: -90px !important;
}
@media only screen and (max-width: 767px) {
  .totop a.finished {
    bottom: -50px !important;
  }
}
.totop a img {
  width: 100%;
  display: block;
  margin: auto;
}
.totop a img.hover {
  display: none;
}
.totop a.finished {
  position: absolute;
}

#fullcalendar {
  margin-top: 3rem;
}
#fullcalendar h2 {
  color: #000;
}
#fullcalendar h2:before {
  content: none;
}

.event_contents {
  margin-bottom: 3.5rem;
}

.event_column {
  background-color: #f6fafa;
  box-sizing: border-box;
}
@media only screen and (min-width: 768px) {
  .event_column {
    padding: 20px;
    display: flex;
  }
}
@media only screen and (max-width: 767px) {
  .event_column {
    padding: 10px;
    display: inline-block;
    width: 100%;
  }
}
.event_column > * {
  box-sizing: border-box;
}
@media only screen and (min-width: 768px) {
  .event_column > * {
    padding: 30px;
  }
}
@media only screen and (min-width: 768px) {
  .event_column .left {
    width: 50%;
  }
}
.event_column .left ._event {
  display: flex;
  margin-bottom: 20px;
}
@media only screen and (max-width: 767px) {
  .event_column .left ._event {
    margin-bottom: 10px;
  }
}
.event_column .left ._event p {
  margin: 0;
}
.event_column .left .title {
  background-color: #00a08c;
  color: #fff;
  border-radius: 3px;
  margin-right: 20px;
  min-width: 50px;
  padding: 0 5px;
  height: 24px;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (min-width: 768px) {
  .event_column .left {
    position: relative;
  }
  .event_column .left:after {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
    display: block;
    width: 2px;
    height: 80%;
    background-color: #dcdcdc;
  }
}
@media only screen and (max-width: 767px) {
  .event_column .left {
    margin-bottom: 30px;
  }
}
.event_column .right {
  display: flex;
  flex-direction: column;
}
@media only screen and (min-width: 768px) {
  .event_column .right {
    width: 50%;
  }
}
.event_column .right p {
  text-align: left;
}
.event_column .right p:first-child {
  margin-top: 0;
}
.event_column img.alignleft, .event_column img .alignright {
  margin-bottom: 1ex;
}
@media only screen and (max-width: 767px) {
  .event_column img.alignleft, .event_column img .alignright {
    float: none;
    margin: 0 auto;
  }
}

.event_list + h2 {
  clear: both;
}

.footer_banner_area {
  box-sizing: border-box;
  padding: 0 40px;
  position: relative;
}
.footer_banner_area .footer_banner_container {
  overflow: hidden;
}

.footer_banner {
  margin-top: 30px;
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (min-width: 768px) {
  .footer_banner {
    justify-content: space-between;
  }
}
.footer_banner .footer_slide {
  margin-bottom: 10px;
  box-sizing: border-box;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .footer_banner .footer_slide {
    transform: translateX(-50%);
  }
}
@media (max-width: 630px) {
  .footer_banner .footer_slide {
    transform: translateX(-54%);
  }
  .footer_banner .footer_slide a {
    padding-left: 3px;
    box-sizing: border-box;
  }
}
@media (max-width: 380px) {
  .footer_banner .footer_slide {
    transform: translateX(0%);
  }
}
.footer_banner .footer_slide img {
  width: 100%;
}
.footer_banner .swiper-wrapper {
  align-items: center;
  margin-left: -6px;
}
@media only screen and (max-width: 767px) {
  .footer_banner .swiper-wrapper {
    margin-left: -3px;
  }
}
@media (max-width: 379px) {
  .footer_banner .swiper-wrapper {
    margin-left: -6px;
  }
}
.footer_banner .swiper-button-next:after, .footer_banner .swiper-button-prev:after {
  content: "＞";
  color: #00a08c;
  z-index: 11;
  font-size: 24px;
}
.footer_banner .swiper-button-next {
  right: 10px;
  transform: rotateY(50deg) translateY(8px);
}
@media only screen and (max-width: 767px) {
  .footer_banner .swiper-button-next {
    right: 10px;
  }
}
.footer_banner .swiper-button-prev {
  left: 10px;
  transform: rotateY(130deg) translateY(8px);
}
@media only screen and (max-width: 767px) {
  .footer_banner .swiper-button-prev {
    left: 10px;
  }
}

ul.list_5_4 {
  margin: 0 auto;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
}
ul.list_5_4 > li {
  box-sizing: border-box;
  text-align: center;
}
ul.list_5_4 > li:before {
  content: none !important;
}
@media only screen and (min-width: 768px) {
  ul.list_5_4 > li {
    width: 20%;
    padding: 0 10px;
  }
}
@media only screen and (max-width: 767px) {
  ul.list_5_4 > li {
    width: 25%;
    padding: 0 5px;
  }
}

@media all and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
    color: inherit;
    text-decoration: inherit;
  }
}
.no_list {
  margin-top: 1.5rem;
  font-size: 115%;
}

.topics_year_selecter {
  display: flex;
  justify-content: center;
  background-color: #01a08c;
  margin: 1rem auto;
  font-weight: 500;
  border-radius: 30px;
  margin: 1rem auto;
  text-align: center;
  transition: all 0.2s;
  transform-origin: 50% 50%;
  position: relative;
  padding: 8px 40px;
  letter-spacing: 0.3ex;
  box-sizing: border-box;
  width: 55%;
  font-size: 15px;
}
@media only screen and (max-width: 767px) {
  .topics_year_selecter {
    width: 100%;
    padding: 8px 20px;
    flex-direction: column;
  }
}
.topics_year_selecter select {
  padding: 2px 5px;
  font-size: 15px;
  transform: translateY(1px);
}
.topics_year_selecter span {
  color: #fff;
  margin-right: 0.25em;
}
@media only screen and (min-width: 768px) {
  .topics_year_selecter > div:first-child {
    margin-right: 1em;
  }
}
@media only screen and (min-width: 768px) {
  .topics_year_selecter button {
    margin-left: 2em;
  }
}
@media only screen and (max-width: 767px) {
  .topics_year_selecter button {
    width: 100px;
    margin: 0.5em auto 0;
  }
}

@media only screen and (max-width: 767px) {
  .main_content .sp_calendar .lead {
    margin-top: 0.25rem;
    padding-bottom: 0.25em;
    border-bottom: 2px solid #009d85;
    display: flex;
    justify-content: space-between;
  }
  .main_content .sp_calendar h2 {
    margin-top: 2rem;
  }
  .main_content .sp_calendar h2.page_title {
    font-size: 32px;
    font-weight: bold;
    padding-bottom: 0;
    margin-bottom: 0;
    white-space: nowrap;
    margin: 0 -50%;
    color: #000;
  }
  .main_content .sp_calendar h2.page_title:before {
    content: none;
  }
  .main_content .sp_calendar .calender_btn {
    color: #009d85;
    font-size: 18px;
    font-weight: bold;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
  }
  .main_content .sp_calendar .calender_btn::after {
    content: "▼";
    transform: rotateZ(-90deg);
    font-size: 70%;
    display: inline-block;
    margin-left: 0.5rem;
  }
  .main_content .sp_calendar .calender_btn.left {
    float: left;
  }
  .main_content .sp_calendar .calender_btn.left::before {
    content: "▼";
    font-size: 70%;
    display: inline-block;
    margin-right: 0.5rem;
    transform: rotateZ(90deg);
  }
  .main_content .sp_calendar .calender_btn.left::after {
    content: none;
  }
  .main_content .sp_calendar ul.sp_event_list {
    padding: 0;
    margin-top: 0;
  }
  .main_content .sp_calendar ul.sp_event_list li {
    border-bottom: 2px solid #dddddd;
    margin: 0;
    display: flex;
    padding: 0;
  }
  .main_content .sp_calendar ul.sp_event_list li:before {
    content: none;
  }
  .main_content .sp_calendar ul.sp_event_list .calendar_left {
    width: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-display: swap;
    font-weight: 500;
    line-height: 1.3;
    padding: 1em 0;
  }
  .main_content .sp_calendar ul.sp_event_list .calendar_right {
    width: calc(100% - 50px);
  }
  .main_content .sp_calendar ul.sp_event_list .calendar_right ul li {
    border-bottom: 1px solid #dddddd;
  }
  .main_content .sp_calendar ul.sp_event_list .calendar_right ul li:last-child {
    border-bottom: none;
  }
  .main_content .sp_calendar ul.sp_event_list .calendar_right ul li a {
    width: 100%;
  }
  .main_content .sp_calendar ul.sp_event_list .calendar_right ul li .event_body {
    width: 100%;
    margin: 0;
    padding: 1em 15px;
    text-decoration: none;
    transition: all 0.2s;
  }
  .main_content .sp_calendar ul.sp_event_list .calendar_right ul li .event_body p {
    color: #000;
  }
}
.list-tr {
  display: none;
}

.blog_date {
  padding: 5px 10px;
  margin-bottom: 10px;
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
}
.blog_date .date {
  color: #00bca4;
  margin-right: 10px;
  margin-bottom: 5px;
}
@media only screen and (max-width: 767px) {
  .blog_date .date {
    display: block;
  }
}
.blog_date .icon_area {
  display: flex;
}
.blog_date .icon {
  color: #fff;
  background-color: #00a08c;
  box-sizing: border-box;
  text-align: center;
  margin: 0px 5px 0px 0;
  padding: 2px 10px;
  background-color: #00a08c;
  border-radius: 10px;
  font-size: 80%;
  display: none;
}
.blog_date .icon:last-child {
  margin-right: 0;
}
.blog_date .icon.activity_blog_event, .blog_date .icon.activity_blog_other, .blog_date .icon.activity_blog_activity, .blog_date .icon.activity_blog_female, .blog_date .icon.activity_blog_youth {
  display: inline-block;
}

.activity_blog_topic .icon_new {
  background-color: #d25532;
  color: #fff;
  padding: 0 5px;
  margin-left: 0.25ex;
  font-size: 14.4px;
}
.activity_blog_topic h3 {
  margin-top: 0.5rem;
}
.activity_blog_topic .date {
  font-size: 90%;
  margin-top: 1.5rem;
}
.activity_blog_topic .icon_area {
  display: flex;
  margin-top: 1rem;
}
.activity_blog_topic .icon_area span {
  border-radius: 20px;
  font-size: 12px;
}
.activity_blog_topic .icon_area span.label {
  color: #fff;
  background-color: #00a08c;
  padding: 2px 15px;
  box-sizing: border-box;
  display: block;
  text-align: center;
  margin: 0px 5px 0px 0;
  padding: 2px 20px;
}
@media only screen and (min-width: 768px) {
  .activity_blog_topic .icon_area span.label {
    width: 150px;
  }
}
@media only screen and (max-width: 767px) {
  .activity_blog_topic .icon_area span.label {
    width: 120px;
  }
}
@media only screen and (max-width: 767px) {
  .activity_blog_topic .icon_area span.label {
    margin: 2px 5px 5px 0;
    padding: 2px 10px;
  }
}
.activity_blog_topic .icon_area span.label._activity_important {
  background-color: #d25532;
}
.activity_blog_topic .icon_area span.label._activity_event {
  background-color: #a0cd37;
}
.activity_blog_topic .icon_area span.label._activity_impor_campaigntant {
  background-color: #00a08c;
}
.activity_blog_topic .icon_area span.label._activity_news {
  background-color: #fff;
  border: 2px solid #00a08c;
  color: #00a08c;
}
.activity_blog_topic .icon_area span.label._important {
  background-color: #d25532;
}
.activity_blog_topic .icon_area span.label._event {
  background-color: #a0cd37;
}
.activity_blog_topic .icon_area span.label._impor_campaigntant {
  background-color: #00a08c;
}
.activity_blog_topic .icon_area span.label._news {
  background-color: #fff;
  border: 2px solid #00a08c;
  color: #00a08c;
}

.activity_column a {
  color: #000;
  padding: 10px;
  box-sizing: border-box;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .activity_column a {
    display: flex !important;
  }
}
.activity_column a:hover {
  color: #000;
  background-color: #ecf5d7;
}
.activity_column .image {
  width: 200px;
  margin-right: 1rem;
}
@media only screen and (max-width: 767px) {
  .activity_column .image {
    margin: 0 auto;
  }
}
.activity_column .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.activity_column .text {
  width: 100%;
  line-height: 2;
}

@media print {
  @page {
    margin: 7.5mm 5mm;
    size: A4 portrait;
  }
  .root {
    max-width: calc(100% - 20mm);
    margin-left: 2.5mm;
  }
  .prev_window,
  .totop {
    display: none !important;
  }
  h2 {
    overflow: hidden;
  }
  .conteiner h2 {
    page-break-before: always;
  }
  .conteiner h2:first-of-type {
    page-break-before: avoid;
    margin-top: 2em;
  }
  .pagelinkList {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 2em 0 70px;
    padding: 0;
    list-style: none;
  }
  .pagelinkList li {
    margin: 0px 10px;
    padding: 0ex 25px 0.6ex 0px !important;
    font-size: 18px;
    font-weight: 500;
    position: relative;
  }
  .pagelinkList li:before {
    content: none !important;
  }
  .pagelinkList li:after {
    left: auto;
    border-radius: 0%;
    background-color: transparent;
  }
  .pagelinkList li a {
    position: relative;
    padding-left: 20px;
  }
  .pagelinkList li a:before {
    top: 5px;
    left: 0px;
    content: "";
    display: block;
    position: absolute;
    width: 16px;
    height: 16px;
    mask-image: url(../img/icon/pagelink_icon.webp);
    -webkit-mask-image: url(../img/icon/pagelink_icon.webp);
    -webkit-mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    background-size: contain;
    background-color: #00a08c;
    background-size: contain;
  }
  table + h3,
  .btn + h3 {
    page-break-before: always;
  }
  .index_list._2 {
    margin-left: -10px;
    margin-right: -10px;
  }
  .index_list._2 li {
    width: 50%;
    padding: 0 10px;
  }
  .index_list._3 {
    margin-left: -15px;
    margin-right: -15px;
  }
  .index_list._3 li {
    width: 33.333%;
    padding: 0 15px;
  }
  .index_list._4 {
    margin-left: -20px;
    margin-right: -20px;
  }
  .index_list._4 li {
    width: 25%;
    padding: 0 20px;
  }
  .wp-block-columns {
    display: flex;
    flex-wrap: nowrap;
  }
  .title_are h1 {
    color: #fff;
    text-shadow: none;
  }
  .pc_320 {
    min-height: 320px;
  }
  ul._2, ol._2 {
    display: flex;
    flex-wrap: wrap;
  }
  ul._2 li, ol._2 li {
    width: 50%;
    box-sizing: border-box;
  }
  ul._2 li:before, ol._2 li:before {
    top: 12px !important;
  }
  ul._3, ol._3 {
    display: flex;
    flex-wrap: wrap;
  }
  ul._3 li, ol._3 li {
    width: 33.33%;
    box-sizing: border-box;
  }
  ul._3 li:before, ol._3 li:before {
    top: 12px !important;
  }
  ul._4, ol._4 {
    display: flex;
    flex-wrap: wrap;
  }
  ul._4 li, ol._4 li {
    width: 25%;
    box-sizing: border-box;
  }
  ul._4 li:before, ol._4 li:before {
    top: 12px !important;
  }
  .pc_none {
    display: none !important;
  }
  header .head {
    display: flex;
    justify-content: space-between;
    margin: 20px auto;
    max-width: 1200px;
  }
  header .head .image {
    height: 70px;
    margin-left: 0px;
  }
  header .head .image img {
    max-height: 50px;
    height: 100%;
  }
  header .head ul {
    list-style: none;
    display: flex;
    margin: 3px 2rem 0 0;
    font-size: 12px;
  }
  header .head ul li {
    margin: 0 15px;
  }
  header .head ul a {
    color: #00a08c;
  }
  header .head .right_area {
    position: relative;
    width: 100%;
    max-width: 920px;
  }
  header .head .right_area .right {
    display: flex;
    justify-content: end;
    margin-right: 25px;
  }
  header .head .tanerin_image_ara {
    position: relative;
  }
  header .head .tanerin_image_ara ._image {
    pointer-events: none;
    position: absolute;
    bottom: -85px;
    right: 50px;
    height: 80px;
  }
  header .head .tanerin_image_ara ._image img {
    height: 100px;
  }
  header .head .tanerin_image_ara ._image .tanerin_image {
    height: 80px;
  }
  header .body {
    height: 45px;
    background-color: #00a08c;
  }
  header .body_nav {
    display: flex;
    max-width: 1200px;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    list-style: none;
    height: 100%;
  }
  header .body_nav li {
    position: relative;
  }
  header .body_nav li a {
    color: #fff;
    padding: 5px 45px;
    box-sizing: border-box;
    position: relative;
  }
  header .body_nav li a:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 0%;
    height: 1px;
    background-color: #fff;
    transform-origin: 50% 50%;
    transition: all 0.2s;
  }
  header .body_nav li:not(:last-child):after {
    color: #fff;
    content: "|";
  }
  header .body_nav li.active a:after, header .body_nav li:hover a:after {
    width: 70%;
  }
  .shadowed_img img {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
  }
  .searchBox {
    border: none;
    background-color: transparent;
  }
  .header_search_form > div {
    border: 1px solid #63c5b9;
    border-radius: 5px;
    height: 20px;
    padding: 0 5px;
  }
  .header_search_form > div input {
    padding: 0;
  }
  .header_search_form input[type=image i] {
    width: 18px;
  }
  .header_search_form .searchBox {
    transform: translateY(-3px);
  }
  .title_are {
    margin: 0 auto;
    width: 100%;
    height: 575px;
    position: relative;
  }
}
@media print {
  .title_are {
    color: #fff;
  }
  .title_are img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    pointer-events: none;
  }
  .title_are h1 {
    position: absolute;
    color: #fff;
    text-shadow: 1px 1px 5px rgba(0, 0, 0, 0.8);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    text-align: center;
  }
  .title_are.none {
    height: auto;
    margin: 1rem auto;
  }
  .title_are.none img {
    display: none;
  }
  .title_are.none h1 {
    color: #000;
    position: inherit;
    text-shadow: none;
    box-sizing: border-box;
    text-align: center;
    padding: 20px;
    font-size: 36px;
    top: auto;
    margin: 1rem auto;
    left: auto;
    transform: none;
  }
  .breadcrumbs_area {
    background-color: #d25532;
    min-height: 20px;
  }
  .breadcrumbs_area .breadcrumbs {
    width: 1200px;
    margin: 0 auto;
    padding: 0.25em 10px;
    box-sizing: border-box;
    list-style-type: none;
    display: flex;
    flex-wrap: wrap;
  }
  .breadcrumbs_area .breadcrumbs a {
    color: #fff;
    text-decoration: underline;
  }
  .breadcrumbs_area .breadcrumbs li {
    margin: 0;
    padding: 0;
    display: inline-block;
    vertical-align: middle;
    color: #fff;
  }
  .breadcrumbs_area .breadcrumbs li:before {
    content: none !important;
  }
  .breadcrumbs_area .breadcrumbs li:after {
    content: "";
    position: inherit;
    top: auto;
    left: auto;
    width: auto;
    height: auto;
    border-radius: 0%;
    background-color: transparent;
  }
  .breadcrumbs_area .breadcrumbs li:not(:last-child)::after {
    content: "/" !important;
    margin: 0 1ex;
    font-size: 90%;
    color: #b8b8b8;
    display: inline-block;
  }
  .gnav.scroll_down > div {
    display: block !important;
    position: fixed;
    background-color: #a0cd37;
    top: -100px;
    transition: all 0.2s;
    z-index: 10000;
  }
  .gnav.scroll_down > div ul.nav_list {
    max-width: inherit;
  }
  .gnav.scroll_down > div ul.nav_list li img, .gnav.scroll_down > div ul.nav_list li .hover_text {
    display: none;
  }
  .gnav.scroll_down > div ul.nav_list li.logo_img {
    display: block;
  }
  .gnav.scroll_down > div ul.nav_list li.logo_img a {
    padding: 0;
  }
  .gnav.scroll_down > div ul.nav_list li.logo_img a:after {
    width: 100%;
    height: 100%;
  }
  .gnav.scroll_down > div ul.nav_list li.logo_img img {
    display: block;
    height: 55px;
    position: relative;
    z-index: 11;
  }
  .subnav {
    display: none;
  }
  .sitemap .subnav {
    display: block;
  }
  .sitemap ul {
    padding-left: 0;
  }
  .sitemap ul li.li_sub {
    padding-left: 17px !important;
  }
  .sitemap ul li.li_sub:before {
    content: none !important;
  }
  .sitemap ul li > ul li {
    padding-left: 17px !important;
  }
  .nav_list {
    display: flex;
    justify-content: center;
    list-style: none;
    max-width: 1200px;
    height: 100%;
    margin: 0 auto;
    padding: 10px 0;
  }
  .nav_list li {
    position: relative;
  }
  .nav_list li a {
    color: #fff;
    padding: 5px 15px;
    box-sizing: border-box;
    font-size: 120%;
    position: relative;
  }
  .nav_list li a:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 0%;
    height: 3px;
    background-color: #fff;
    transform-origin: 50% 50%;
    transition: all 0.2s;
  }
  .nav_list li:not(:last-child):after {
    font-size: 130%;
    color: #fff;
    content: "|";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  .nav_list li.active a:after, .nav_list li:hover a:after {
    width: 70%;
  }
  .pagelink_area {
    padding-top: 40px;
  }
  .pagelinkList {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0 0 70px;
  }
  .pagelinkList li a {
    padding-left: 20px;
  }
  .pagelinkList li a:before {
    top: 5px;
    left: 0px;
    content: "";
    display: block;
    position: absolute;
    width: 16px;
    height: 16px;
    mask-image: url(../img/icon/pagelink_icon.webp);
    -webkit-mask-image: url(../img/icon/pagelink_icon.webp);
    -webkit-mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    background-size: contain;
    background-color: #00a08c;
    background-size: contain;
  }
  .main_content {
    max-width: 1200px;
    min-height: 300px;
    margin: 0 auto 20px;
    padding: 0 10px;
    box-sizing: border-box;
  }
  .main_content.main_content_fixed {
    padding-top: 55px;
  }
  .main_content ul {
    list-style: none;
    margin-top: 1em 0;
  }
  .main_content ul li {
    position: relative;
  }
  .main_content ul li:before {
    content: "";
    width: 12px;
    height: 12px;
    background-color: #00a08c;
    display: inline-block;
    margin-right: 10px;
  }
  .main_content ul.link_list li {
    position: relative;
  }
  .main_content ul.link_list li:before {
    content: "";
    width: 9px;
    height: 13px;
    background-color: transparent;
    background-image: url(../img/icon/breadcrumbs.webp);
    background-size: contain;
  }
  .main_content ol {
    list-style: none;
    margin-top: 1em 0;
  }
  .main_content ol li {
    position: relative;
    counter-increment: number;
    padding-left: 20px;
  }
  .main_content ol li:after {
    content: counter(number);
    background-color: #d25532;
    border-radius: 50%;
    color: #fff;
    font-weight: bold;
    display: block;
    position: absolute;
    width: 18px;
    height: 18px;
    font-size: 70%;
    top: 3px;
    left: -6px;
    white-space: nowrap;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    letter-spacing: normal;
  }
  .main_content ol._2 li, .main_content ol._3 li {
    box-sizing: border-box;
  }
  .main_content ol._2 li:after, .main_content ol._3 li:after {
    top: 10px;
  }
  ul._2 li, ul._3 li {
    box-sizing: border-box;
  }
  ul._2 li:after, ul._3 li:after {
    top: 10px;
  }
  h1, h2, h3, h4, h5 {
    font-weight: 600;
  }
  h3:first-child, h4:first-child, h5:first-child {
    margin-top: 2rem;
  }
  h1 {
    font-size: 40px;
  }
  h2 {
    position: relative;
    box-sizing: border-box;
    text-align: center;
    padding: 20px;
    font-size: 25px;
    margin-bottom: 10px;
    color: #fff;
    z-index: 10;
  }
  h2:not(:first-child) {
    margin-top: 5rem;
  }
  h2:first-child {
    margin-top: 0;
  }
  h2:before {
    content: "";
    width: 200vw;
    height: 100%;
    display: block;
    position: absolute;
    left: -50vw;
    top: 0;
    background-color: #00a08c;
    z-index: -1;
  }
  h2.green:before {
    background-color: #00a08c;
  }
  h2.red:before {
    background-color: #d25532;
  }
  h2.yellowgreen:before {
    background-color: #a0cd37;
  }
  .clearfix:after {
    content: "";
    display: block;
    clear: both;
  }
  h3 {
    color: #00a08c;
    border-bottom: 2px solid #01a08c;
    padding-bottom: 10px;
    font-size: 20px;
    clear: both;
    margin-top: 2rem;
    margin-bottom: 1rem;
  }
  h2 + ul {
    margin-top: 2rem;
  }
  h2 + p {
    margin-top: 2rem;
  }
  h2 + h3 {
    margin-top: 2rem;
  }
  p + h3 {
    margin-top: 2rem;
  }
  h4, h5, h6 {
    margin-top: 0;
  }
  h4 {
    color: #00a08c;
    margin-top: 1rem;
    margin-bottom: 0.75rem;
    font-size: 100%;
  }
  h5 {
    margin-bottom: 0.75rem;
    margin-top: 1rem;
    color: #00a08c;
    font-size: 90%;
  }
  h6 {
    color: #00a08c;
    margin-bottom: 0.75rem;
    font-size: 80%;
  }
  .btn {
    margin: 1rem auto;
    font-weight: 500;
  }
  .btn a {
    border-radius: 30px;
    margin: 1rem auto;
    text-align: center;
    transition: all 0.2s;
    transform-origin: 50% 50%;
    position: relative;
    padding: 8px 40px;
    display: inline-block;
    width: 100%;
    width: auto;
    letter-spacing: 0.3ex;
  }
  .btn a span {
    position: relative;
    z-index: 10;
  }
  .btn a:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 30px;
    transform-origin: 50% 50%;
    transition: all 0.2s;
    transform: scale(0);
  }
  .btn a:hover span {
    color: #fff;
  }
  .btn a:hover:after {
    transform: scale(1.03);
  }
  .btn a.green {
    border: solid 2px #01a08c;
    color: #00a08c;
  }
  .btn a.green:hover:after {
    background-color: #01a08c;
  }
  .btn a.yellowgreen {
    border: solid 2px #a0cd37;
    color: #a0cd37;
  }
  .btn a.yellowgreen:hover:after {
    background-color: #a0cd37;
  }
  .btn a.red {
    border: solid 2px #d25532;
    color: #d25532;
  }
  .btn a.red:hover:after {
    background-color: #d25532;
  }
  .btn a.pdf:before, .btn a.ext:before {
    content: "";
    display: inline-block;
    width: 16px;
    height: 21px;
    background-size: cover;
    background-repeat: no-repeat;
    margin: 0px 5px 0 0;
    transform: translateY(4px);
    position: relative;
    z-index: 10;
  }
  .btn a.pdf:before {
    background-image: url(../img/icon/icon_pdf.webp);
  }
  .btn a.ext:before {
    background-image: url(../img/icon/icon_ext.webp);
  }
  .btn a:hover.pdf:before {
    background-image: url(../img/icon/icon_pdf_white.webp);
  }
  .btn a:hover.ext:before {
    background-image: url(../img/icon/icon_ext_white.webp);
  }
  .pc_column1,
  .pc_column2,
  .pc_column3,
  .pc_column4,
  .pc_column5,
  .pc_column6 {
    display: flex;
    flex-wrap: wrap;
  }
  .pc_column1 > div,
  .pc_column2 > div,
  .pc_column3 > div,
  .pc_column4 > div,
  .pc_column5 > div,
  .pc_column6 > div {
    padding: 0 10px;
    box-sizing: border-box;
    margin-bottom: 1rem;
  }
  .pc_column2 > * {
    width: 50%;
  }
  .pc_column3 > * {
    width: 33.33%;
  }
  .pc_column4 > * {
    width: 25%;
  }
  .pc_column5 > * {
    width: 20%;
  }
  .pc_column6 > * {
    width: 16.66%;
  }
  .topics_list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    max-width: 1000px;
    margin: 1rem auto 0;
  }
  .topics_list li {
    display: inline-block;
    padding: 5px 10px !important;
    margin-bottom: 20px;
  }
  .topics_list li:before {
    content: none !important;
  }
  .topics_list li a {
    border: 2px solid #00a08c;
    padding: 5px 10px;
    box-sizing: border-box;
    transition: all 0.2s;
  }
  .topics_list li a:hover, .topics_list li a.selected {
    background: #00a08c;
    color: #fff;
  }
  .img_max figure {
    width: 100%;
  }
  .img_max figure img {
    width: 100%;
  }
  .color_box {
    background-color: #ecf5d7;
    padding: 10px 20px 20px;
    box-sizing: border-box;
    margin: 0;
  }
  .color_box ul {
    padding-left: 0;
  }
  .midashi {
    background-color: #d9ebaf;
    color: #00a08c;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 30px;
    margin-bottom: 0;
    box-sizing: border-box;
  }
  img {
    max-width: 100%;
  }
  table {
    margin: 2rem 0 1rem;
    width: 100%;
    border: 2px solid #00a08c;
    border-collapse: collapse;
    table-layout: fixed;
  }
  table.auto {
    table-layout: auto;
  }
  table:first-child {
    margin-top: 0;
  }
  table td {
    border: none;
  }
  table th, table td {
    border: 2px solid #00a08c;
    padding: 5px 10px;
    box-sizing: border-box;
  }
  table thead th {
    background-color: #00a08c;
    color: #fff;
  }
  table thead th:not(:last-child) {
    border-right: 2.1px solid #fff;
  }
  table thead th a {
    color: #fff;
  }
  table.kinyu {
    border: 2px solid #d25532;
  }
  table.kinyu th, table.kinyu td {
    border: 2px solid #d25532;
  }
  table.kinyu thead th {
    background-color: #d25532;
  }
  table tbody th {
    background-color: #ecf5d7;
    color: #00a08c;
    width: 20% !important;
  }
  ._filter {
    display: none;
  }
  .wp-block-columns:first-child {
    margin-top: 3rem;
  }
  .pagelink_area + .wp-block-columns {
    margin-top: 2rem;
  }
  p + .wp-block-columns {
    margin-top: 2rem;
  }
  h2 + .wp-block-columns {
    margin-top: 3rem;
  }
  h3 + .wp-block-columns {
    margin-top: 2rem;
  }
  .wp-block-column h3:first-child, .wp-block-column h4:first-child, .wp-block-column p:first-child {
    margin-top: 0;
  }
  h4 + table {
    margin-top: 1rem;
  }
  .gray_border img {
    border: 1px solid #dddddd;
  }
  figcaption {
    text-align: center;
  }
  .content_red.content_red, .content_green.content_red, .content_yellowgreen.content_red {
    background-color: #d25532;
  }
  .content_red.content_green, .content_green.content_green, .content_yellowgreen.content_green {
    background-color: #00a08c;
  }
  .content_red.content_yellowgreen, .content_green.content_yellowgreen, .content_yellowgreen.content_yellowgreen {
    background-color: #a0cd37;
  }
  .content_red a, .content_green a, .content_yellowgreen a {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0 40px;
    min-height: 100px;
    box-sizing: border-box;
    font-weight: bold;
    font-size: 18px;
    color: #fff;
    max-width: 380px;
    margin: 0 auto;
  }
  .content_red a.pdf:before, .content_red a.ext:before, .content_green a.pdf:before, .content_green a.ext:before, .content_yellowgreen a.pdf:before, .content_yellowgreen a.ext:before {
    content: "";
    display: inline-block;
    width: 16px;
    height: 21px;
    background-size: cover;
    background-repeat: no-repeat;
    margin: 0px 5px 0 0;
    transform: translateY(2px);
    position: relative;
    z-index: 10;
  }
  .content_red a span, .content_green a span, .content_yellowgreen a span {
    position: relative;
  }
  .content_red a span:after, .content_green a span:after, .content_yellowgreen a span:after {
    content: "";
    position: absolute;
    bottom: -5px;
    left: 50%;
    transform: translateX(-50%);
    width: 0%;
    height: 2px;
    background-color: #fff;
    transform-origin: 50% 50%;
    transition: all 0.2s;
  }
  .content_red a.active span:after, .content_red a:hover span:after, .content_green a.active span:after, .content_green a:hover span:after, .content_yellowgreen a.active span:after, .content_yellowgreen a:hover span:after {
    width: 100%;
  }
  .content_red a.pdf:before, .content_green a.pdf:before, .content_yellowgreen a.pdf:before {
    background-image: url(../img/icon/icon_pdf_white.webp);
  }
  .content_red a.ext:before, .content_green a.ext:before, .content_yellowgreen a.ext:before {
    background-image: url(../img/icon/icon_ext_white.webp);
  }
  footer {
    background: url(../img/footer_bg.webp);
    background-repeat: no-repeat;
    background-position: top;
    margin-top: 60px;
    clear: both;
  }
  footer .link_area {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    padding: 110px 0 40px;
  }
  .footer_link {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    margin-left: 25px;
    margin: 0 0 10px 0px;
  }
  .footer_link li {
    margin-right: 25px;
    font-size: 12px;
    margin: 0px 25px 10px 0;
  }
  .footer_link a {
    color: #fff;
    position: relative;
  }
  .footer_link a:after {
    content: "";
    position: absolute;
    bottom: -3px;
    left: 50%;
    transform: translate(-50%) scale(0);
    transform-origin: center;
    transition: all 0.1s;
    display: block;
    width: 100%;
    height: 1px;
    background-color: #fff;
  }
  .footer_link a:hover:after {
    content: "";
    position: absolute;
    bottom: -3px;
    left: 50%;
    transform: translate(-50%) scale(1);
    transition: all 0.1s;
    display: block;
    width: 100%;
    height: 1px;
    background-color: #fff;
  }
  .coryright {
    color: #fff;
    margin-left: 20px;
    font-size: 80%;
    opacity: 0.7;
    padding-bottom: 10px;
  }
  .totop {
    z-index: 90;
    position: relative;
    padding: 0;
    margin: 0 auto;
    max-width: 1200px;
  }
}
@media print {
  .totop {
    display: none;
  }
  .totop a {
    margin: 0;
    padding: 0;
    background: none;
    text-decoration: none;
  }
}
@media print {
  .totop {
    display: none;
  }
  .totop > div {
    margin: 0 0 0 auto;
  }
  .totop a {
    display: block;
    position: absolute;
    bottom: -200px;
    bottom: -90px !important;
    right: 10px;
    transition: 0.25s all;
  }
  .totop a:hover img {
    opacity: 1;
  }
  .totop a.finished {
    position: absolute;
    bottom: -90px !important;
  }
  .totop a img {
    width: 100%;
    display: block;
    margin: auto;
  }
  .totop a img.hover {
    display: none;
  }
  .totop a.finished {
    position: absolute;
  }
  #fullcalendar {
    margin-top: 3rem;
  }
  #fullcalendar h2 {
    color: #000;
  }
  #fullcalendar h2:before {
    content: none;
  }
  .event_contents {
    margin-bottom: 3.5rem;
  }
  .event_column {
    padding: 20px;
    display: flex;
  }
  .event_column > * {
    padding: 30px;
  }
  .event_column .left {
    width: 50%;
    position: relative;
  }
  .event_column .left:after {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
    display: block;
    width: 2px;
    height: 80%;
    background-color: #dcdcdc;
  }
  .event_column .right {
    width: 50%;
  }
  .footer_banner {
    justify-content: space-between;
  }
  .footer_banner .footer_slide {
    transform: translateX(-50%);
  }
  ul.list_5_4 > li {
    width: 20%;
    padding: 0 10px;
  }
  .activity_blog_topic .icon_area span.label {
    width: 150px;
  }
  .activity_column a {
    display: flex !important;
  }
  .gnav_area {
    position: relative;
    width: 100%;
  }
  .gnav_area .gnav > div {
    position: relative !important;
    top: 0px;
  }
  .gnav_area .gnav.fixed {
    background: transparent !important;
  }
}
