@charset "UTF-8";
html {
  font-size: 62.5%; }

body {
  font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 2;
  background-color: #fff; }

p {
  margin: 0; }

a:not(.no_hover):hover {
  opacity: 0.8; }

.ker {
  font-feature-settings: "palt"; }

img {
  vertical-align: bottom; }

ul {
  list-style: none;
  padding: 0;
  margin: 0; }

ol {
  padding: 0;
  margin: 0; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

/* header */
.header-container {
  width: 1040px;
  margin: 0 auto;
  padding: 46px 0 52px 0;
  text-align: center;
  line-height: 0;
  overflow: hidden; }

.head_top {
  width: 100%;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  align-items: flex-end;
  flex-flow: row;
  justify-content: flex-end;
  margin-bottom: 65px; }

.logo_wrap {
  margin-left: 360px;
  margin-right: 186px; }

.head_logo {
  width: 264px;
  height: 70px;
  background: url(../img/bnr_logo.png) no-repeat;
  background-size: contain;
  text-indent: -3000px;
  margin: 0; }
  .head_logo a {
    display: block;
    width: 100%;
    height: 100%; }
  .head_logo a:hover {
    opacity: 1; }

.head_right {
  text-align: right;
  position: relative;
  margin-right: 60px; }

.head_search_box {
  margin-bottom: 8px; }

#keywords4 {
  width: 170px;
  height: 23px;
  box-sizing: border-box;
  border: 1px solid black;
  padding: 5px;
  border-radius: 12px; }

#keywords4:focus {
  box-shadow: none; }

#keywords4 input[type="text"] {
  outline: none; }

#searchBtn4 {
  position: absolute;
  width: 32px;
  height: 21px;
  right: -1px;
  top: 1px; }

.head_font {
  width: 100%;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  flex-flow: row;
  justify-content: flex-end;
  height: 26px; }

.head_font_ttl {
  width: 64px;
  height: 26px;
  margin-right: 2px; }
  .head_font_ttl img {
    width: 100%;
    height: auto; }

#font_Change {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  align-items: baseline;
  flex-flow: row;
  justify-content: flex-end;
  right: 4px;
  position: relative; }
  #font_Change li {
    margin-left: 7px; }
  #font_Change a {
    display: block;
    width: 100%;
    height: 100%; }

#fontS {
  width: 26px;
  height: 26px;
  background: url(../img/head_font_small.png) no-repeat;
  background-size: contain;
  text-indent: -3000px; }

#fontS.active {
  background: url(../img/head_font_small_on.png) no-repeat;
  background-size: contain; }

#fontM {
  width: 26px;
  height: 26px;
  background: url(../img/head_font_middle.png) no-repeat;
  background-size: contain;
  text-indent: -3000px; }

#fontM.active {
  background: url(../img/head_font_middle_on.png) no-repeat;
  background-size: contain; }

#fontL {
  width: 26px;
  height: 26px;
  background: url(../img/head_font_large.png) no-repeat;
  background-size: contain;
  text-indent: -3000px; }

#fontL.active {
  background: url(../img/head_font_large_on.png) no-repeat;
  background-size: contain; }

.head_nav {
  list-style: none;
  display: flex;
  justify-content: space-around;
  margin: 0 auto;
  width: 960px; }
  .head_nav li {
    display: block;
    width: 106px; }
  .head_nav a {
    display: block;
    position: relative;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%); }

.head_index {
  width: 90px;
  height: 20px;
  background: url(../img/head_menu_top.png) no-repeat;
  background-size: contain;
  text-indent: -3000px; }

.head_life {
  width: 106px;
  height: 20px;
  background: url(../img/head_menu_life.png) no-repeat;
  background-size: contain;
  text-indent: -3000px; }

.head_admin {
  width: 106px;
  height: 20px;
  background: url(../img/head_menu_admin.png) no-repeat;
  background-size: contain;
  text-indent: -3000px; }

.head_tourism {
  width: 74px;
  height: 20px;
  background: url(../img/head_menu_tourism.png) no-repeat;
  background-size: contain;
  text-indent: -3000px; }

.head_immig {
  width: 74px;
  height: 20px;
  background: url(../img/head_menu_immig.png) no-repeat;
  background-size: contain;
  text-indent: -3000px; }

/* ホバー時の動作 */
.head_a {
  position: relative;
  display: inline-block;
  transition: .3s 0s; }

.head_a::after {
  position: absolute;
  content: '';
  width: 0;
  height: 2px;
  background-color: black;
  transition: .3s 0s;
  bottom: -10px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%); }

.head_a:hover::after {
  width: 100%; }

.head_a.head_a_active::after {
  position: absolute;
  content: '';
  width: 100%;
  height: 2px;
  background-color: black;
  transition: .15s 0s;
  bottom: -10px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%); }

.right_bnr {
  width: 110px;
  height: 110px;
  background: url(../img/right_bnr_nozei.png) no-repeat;
  background-size: contain;
  text-indent: -3000px;
  position: fixed;
  top: 290px;
  right: 0;
  z-index: 20;
  overflow: hidden; }
  .right_bnr a {
    display: block;
    width: 100%;
    height: 100%; }

.breadcrumbs {
  width: 960px;
  text-align: left;
  margin: 0 auto 40px auto; }
  .breadcrumbs p {
    line-height: 1; }

/* main */
.main-container {
  width: 1040px;
  margin: 0 auto;
  text-align: center; }

.main-inner {
  width: 960px;
  margin: 0 auto;
  padding: 0;
  text-align: left; }

.template_h3 {
  font-size: 18px;
  font-size: 1.8rem;
  border-top: solid 1px black;
  position: relative;
  z-index: 1; }
  .template_h3 h3 {
    display: inline-block;
    border-top: solid 3px #008E22;
    top: -2px;
    position: relative;
    padding-right: 0.5em;
    padding-left: 0.3em;
    margin: 0;
    line-height: 1.4;
    padding-top: 0.3em; }

.template_h3.template_h3_22 {
  font-size: 22px;
  font-size: 2.2rem; }
  .template_h3.template_h3_22 h3 {
    padding-left: 0; }

.bold {
  font-weight: bold; }

.link_pdf::after {
  display: inline-block;
  width: 20px;
  height: 18px;
  background: url(../img/icon_pdf.png) no-repeat;
  background-size: 14px 18px;
  content: "";
  position: relative;
  top: 3px;
  left: 3px; }

.link_word::after {
  display: inline-block;
  width: 20px;
  height: 18px;
  background: url(../img/icon_word.png) no-repeat;
  background-size: 14px 18px;
  content: "";
  position: relative;
  top: 3px;
  left: 3px; }

.link_excel::after {
  display: inline-block;
  width: 20px;
  height: 18px;
  background: url(../img/icon_excel.png) no-repeat;
  background-size: 14px 18px;
  content: "";
  position: relative;
  top: 3px;
  left: 3px; }

.link_blank::after {
  display: inline-block;
  width: 20px;
  height: 16px;
  background: url(../img/icon_blank.png) no-repeat;
  background-size: 14px 16px;
  content: "";
  position: relative;
  top: 2px;
  left: 3px; }

/* footer */
.footer-container {
  width: 100%;
  min-width: 1040px;
  border-top: 1px solid black;
  margin: 80px auto 0 auto;
  text-align: left;
  position: relative; }

.footer_inner {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  flex-flow: row;
  text-align: left;
  width: 960px;
  margin: 0 auto;
  overflow: hidden; }

.footer_left {
  border-right: 1px solid black;
  padding: 30px 30px 30px 0; }
  .footer_left p {
    margin: 40px 0 50px 0;
    line-height: 1.8; }

.footer_logo {
  width: 264px;
  height: 70px;
  background: url(../img/bnr_logo.png) no-repeat;
  background-size: contain;
  text-indent: -3000px; }
  .footer_logo a {
    display: block;
    width: 100%;
    height: 100%; }
  .footer_logo a:hover {
    opacity: 1; }

.footer_bnr_wrap {
  margin-bottom: 35px; }
  .footer_bnr_wrap a {
    display: block;
    width: 100%;
    height: 100%;
    line-height: 0; }
  .footer_bnr_wrap img {
    width: 276px;
    height: auto; }

.footer_bnr_wrap2 img {
  width: 276px;
  height: 100px; }

.footer_center {
  padding: 30px 0 10px 45px;
  width: 264px; }

.footer_right {
  padding: 30px 0 10px 79px;
  width: 264px; }

.footer_ul {
  font-weight: bold;
  line-height: 1.2; }
  .footer_ul ul {
    font-weight: normal;
    padding-left: 3px;
    margin-bottom: 25px; }
    .footer_ul ul li {
      margin-left: 9px;
      margin-top: 0.6em;
      position: relative;
      text-indent: -14px; }
    .footer_ul ul li::before {
      content: "●";
      color: #008E22;
      font-size: 7px;
      font-size: 0.7rem;
      position: relative;
      left: 14px;
      display: inline-block;
      width: 14px;
      bottom: 2px; }
  .footer_ul a {
    color: black;
    text-decoration: none; }

.footer_top {
  width: 52px;
  height: 52px;
  background: url(../img/icon_top.png) no-repeat;
  background-size: contain;
  text-indent: -3000px;
  position: fixed;
  bottom: 40px;
  right: 45px;
  z-index: 20;
  overflow: hidden; }
  .footer_top a {
    display: block;
    width: 100%;
    height: 100%; }

.footer_top.scroll_bottom {
  position: absolute;
  bottom: 110px; }

.footer_copy {
  background: black;
  color: white;
  text-align: center;
  font-size: 15px;
  font-size: 1.5rem;
  padding: 20px; }

.search_h2 {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
  margin: 0; }
