@charset "UTF-8";
/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー 20210116 */
/* テスト用背景色 */
/* ------------------------
 default
------------------------- */
* {
  margin: 0;
  padding: 0;
  font-family: 'メイリオ','Meiryo','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック'; }

* {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

/* ------------------------
 webfont local
------------------------- */
@font-face {
  font-family: "UD Shin Go Heavy";
  src: url("../font/A-OTF-UDShinGoPro-Heavy.woff") format("woff"), url("../font/A-OTF-UDShinGoPro-Heavy.woff2") format("woff2"); }
@font-face {
  font-family: "UD Shin Go Medium";
  src: url("../font/A-OTF-UDShinGoPro-Medium.woff") format("woff"), url("../font/A-OTF-UDShinGoPro-Medium.woff2") format("woff2"); }
@font-face {
  font-family: "UD Shin Go Regular";
  src: url("../font/A-OTF-UDShinGoPro-Regular.woff") format("woff"), url("../font/A-OTF-UDShinGoPro-Regular.woff2") format("woff2"); }
.wf-shingo-h {
  font-family: "UD Shin Go Heavy";
  font-display: swap;
  font-weight: 400;
  font-display: swap; }

.wf-shingo-m {
  font-family: "UD Shin Go Medium";
  font-display: swap;
  font-weight: 500;
  font-display: swap; }

.wf-shingo-r {
  font-family: "UD Shin Go Regular";
  font-display: swap;
  font-weight: 500;
  font-display: swap; }

/* ------------------------
 body
------------------------- */
body {
  padding: 0;
  margin: 0;
  font-size: 17px;
  color: #000;
  line-height: 1.6;
  text-align: center;
  background: url(../image/common_bg2_page.jpg); }
  @media only screen and (max-width: 767px) {
    body {
      font-size: 14px;
      line-height: 1.6; } }
  @media only screen and (max-width: 767px) and (max-width: 375px) {
    body {
      font-size: 13px;
      line-height: 1.8; } }

/* ------------------------
 text
------------------------- */
.ruby {
  font-size: 75%; }

/* ------------------------
 link
------------------------- */
a {
  text-decoration: none; }

a:link {
  text-decoration: none; }

a:visited {
  text-decoration: none; }

a:hover,
a:active,
a:focus {
  text-decoration: underline; }

a img {
  border: none; }

a.hv:hover,
a:hover img {
  /* マウスオーバーで背景を透過 */
  opacity: 0.95;
  filter: alpha(opacity=95);
  -moz-opacity: 0.95;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=95)"; }

/* PCでは電話発信しない */
@media (max-width: 767px) {
  a[href^="tel:"] {
    color: blue;
    text-decoration: underline; } }
@media (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
    color: #000;
    text-decoration: none; } }

.extlink {
  display: block;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  padding: 10px;
  margin: 3px;
  background-color: #fff;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  -ms-border-radius: 5px;
  border-radius: 5px;
  border: 1px solid #ccc;
  text-align: center;
  font-weight: bold;
  color: #000; }
  .extlink:hover {
    text-decoration: none;
    background-color: #BDE75E;
    color: #fff; }
  @media only screen and (max-width: 1140px) {
    .extlink {
      padding: 0.8771929825vw;
      -js-display: flex;
      display: -webkit-box;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: flex;
      -webkit-align-items: center;
      -ms-align-items: center;
      align-items: center;
      -webkit-box-pack: center;
      -moz-box-pack: center;
      -ms-flex-pack: center;
      -webkit-justify-content: center;
      -ms-justify-content: center;
      justify-content: center; } }

.tolist {
  display: block;
  text-align: right;
  font-weight: 600;
  color: #000;
  text-decoration: underline;
  font-weight: 600; }
  .tolist:after {
    content: " \f0a9";
    font-family: "Font Awesome 5 Free";
    font-weight: 900; }

.todetail,
.topdf {
  display: inline-block;
  width: auto;
  padding: 0.8em;
  border: 1px solid #ccc;
  border-radius: 8px;
  text-decoration: underline;
  color: #000;
  font-weight: 600;
  background-color: #BDE75E; }

.todetail:hover,
.topdf:hover {
  background-color: #eee; }

.todetail:after {
  content: " \f0a9";
  font-family: "Font Awesome 5 Free";
  font-weight: 900; }

.topdf:after {
  content: " \f1c1";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: red; }

.newmark {
  display: inline-block;
  padding-left: 5px;
  color: red;
  font-weight: 600;
  font-size: 90%; }

/* ------------------------
 misc
------------------------- */
img {
  vertical-align: bottom; }

li {
  list-style-type: none; }

/* ------------------------
 ptop follow
------------------------- */
.ptop {
  position: fixed;
  right: 0;
  bottom: 0;
  z-index: 9999;
  display: none; }

.ptop a {
  display: block;
  color: #666;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 0.8rem;
  margin: 0;
  text-decoration: none;
  font-weight: bold;
  font-size: 4rem;
  z-index: 9999; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .ptop a {
    font-size: 2.5rem; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    .ptop a {
      font-size: 2rem; } }

.ptop a:hover {
  color: #005C33; }

/* ------------------------
 responsive
------------------------- */
.md {
  display: block; }
  @media only screen and (max-width: 767px) {
    .md {
      display: none; } }

.sp {
  display: none; }
  @media only screen and (max-width: 767px) {
    .sp {
      display: block; } }

/* ------------------------
jquery inview
------------------------- */
.fadeIn_up {
  opacity: 0;
  transform: translate(0, 50%);
  transition: 0.3s; }

.fadeIn_up.is-show {
  transform: translate(0, 0);
  opacity: 1; }

/* ------------------------
.imgBox
------------------------- */
.imgBox {
  text-align: center; }

.imgBox img {
  max-width: 100%;
  height: auto;
  vertical-align: top; }

/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー 20210116 */
/* テスト用背景色 */
/*-----------------------
 default structure
------------------------*/
#header,
#cover,
#bread,
.content,
#footer {
  width: 100%;
  text-align: center; }

#header .inner,
#cover .inner,
#bread .inner,
.content .inner,
#footer .inner {
  width: 1140px;
  margin: 0 auto; }
  @media only screen and (max-width: 1140px) {
    #header .inner,
    #cover .inner,
    #bread .inner,
    .content .inner,
    #footer .inner {
      width: 100%; } }

/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー 20210116 */
/* テスト用背景色 */
/* ======================
 header
========================= */
#header {
  position: relative;
  padding: 10px 0;
  opacity: 1;
  height: auto;
  z-index: 9999;
  transition: all 0.5s 0s ease;
  background-color: #fff; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #header {
    padding: 15px 0;
    text-align: left; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    #header {
      padding: 10px 0; } }

#header-logo {
  display: inline-block;
  width: 371px !important;
  margin: 2em auto; }
  @media only screen and (max-width: 1140px) {
    #header-logo {
      margin: 2em auto; } }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #header-logo {
    width: 70% !important;
    padding-left: 10px;
    margin: 1em 0;
    max-width: 371px; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    #header-logo {
      width: 60% !important; } }

#header-logo img {
  width: 100%;
  height: auto; }

#header-links {
  position: absolute;
  top: 0;
  right: 0;
  padding: 0.5em; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #header-links {
    display: none; } }

#header-links .list-root {
  margin-bottom: 0.1em; }

#header-links .list-item {
  display: inline-block; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) {
  #header-links .list-item {
    display: block; } }

#header-links .list-item a {
  display: block;
  width: 100%;
  padding: 0 2px;
  color: #000;
  font-size: 90%;
  text-align: right; }

#header-links .list-item a:after {
  content: " \f0a9";
  font-family: "Font Awesome 5 Free";
  font-weight: 900; }

#header-links .list-item a:hover {
  background-color: #eee;
  text-decoration: none;
  color: red;
  font-weight: 600; }

/* ----------------------
 header-banner
------------------------- */
#header-links .bn-bousai {
  width: 100%;
  margin: 0 0 0.5em;
  text-align: right; }
  @media only screen and (max-width: 1140px) {
    #header-links .bn-bousai {
      width: 17.5438596491vw; } }
  @media only screen and (max-width: 1140px) and (max-width: 1024px) {
    #header-links .bn-bousai {
      width: 17.578125vw; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
    #header-links .bn-bousai {
      width: 80%; } }

#header-links .bn-bousai {
  display: block;
  width: 100%;
  text-align: right; }

#header-links .bn-bousai img {
  width: auto;
  max-width: 310px;
  height: auto; }
  @media only screen and (max-width: 1140px) {
    #header-links .bn-bousai img {
      max-width: 26.3157894737vw; } }
  @media only screen and (max-width: 1140px) and (max-width: 1024px) {
    #header-links .bn-bousai img {
      max-width: 29.296875vw; } }

/* ----------------------
 header-banner sp
------------------------- */
#nav-contact-sp .bn-bousai {
  display: block;
  width: 80%;
  margin: 1em 0;
  text-align: center; }

#nav-contact-sp .bn-bousai img {
  width: 100% !important;
  max-width: 100% !important;
  height: auto; }

/* ----------------------
 header-contact
------------------------- */
@media only screen and (max-width: 1140px) and (max-width: 1024px) {
  #header-links #header-contact {
    display: none; } }

#header-links #header-contact .wrap {
  text-align: right;
  line-height: 1.2; }

#header-links #header-contact .wrap p {
  display: inline;
  font-siZe: 70%; }

#header-links #header-contact .wrap .tel {
  color: #005C33;
  font-size: 115%;
  font-weight: 600; }

#header-links #header-contact .txt,
#nav-main #nav-contact-sp .txt {
  margin-top: 0.1em;
  font-size: 75%;
  text-align: right; }

/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー 20210116 */
/* テスト用背景色 */
/* ------------------------
 cover
------------------------- */
#cover {
  background-color: #BDE75E; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #cover {
    margin-bottom: 2em; } }

/* draft */
#cover .inner img {
  width: 100%;
  height: auto; }

#cover .inner {
  position: relative; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #cover .inner {
    padding: 1em 0; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    #cover .inner {
      padding: 2em 0; } }

#pagettl {
  width: auto;
  max-width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  line-height: 1.2;
  -webkit-transform: translate(-50%, -50%);
  /* Safari用 */
  transform: translate(-50%, -50%);
  text-shadow: 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) {
  #pagettl {
    font-size: 175%; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
    #pagettl {
      width: 90%;
      font-size: 150%; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    #pagettl {
      font-size: 120%; } }

#pagettl .cat {
  display: block;
  margin-bottom: 0.5em;
  font-size: 55%;
  text-shadow: 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff; }

#pagettl .cat:before {
  content: "- "; }

#pagettl .cat:after {
  content: " -"; }

/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー 20210116 */
/* テスト用背景色 */
/* ------------------------
 nav overwrite
 レスポンシブメニュー
 (ドロップダウン＆ドロワー)
------------------------- */
* {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

.nav-wrap #nav-main {
  margin: 0 auto; }

#nav-main #mn02 .list-child {
  min-width: 200% !important; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #nav-main #mn02 .list-child {
    width: 100%; } }

#nav-main #nav-contact-sp {
  padding: 0.5em;
  margin-top: 1em;
  border: 1px solid #ccc; }

#nav-main #nav-contact-sp .txt,
#nav-main #nav-contact-sp .txt a {
  padding: 0.5em 1em;
  text-align: left;
  color: #fff; }

/* ------------------------
 bread
------------------------- */
#bread {
  margin-bottom: 2em; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #bread {
    display: none; } }

#bread .inner {
  padding: 0.5em;
  text-align: right;
  font-size: 0.8rem; }

#bread .inner span {
  display: inline-block;
  margin-right: 5px; }

#bread .inner span a {
  color: #000; }

#bread .inner span a:after {
  content: " \f0a9";
  font-family: "Font Awesome 5 Free";
  font-weight: 900; }

/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー 20210116 */
/* テスト用背景色 */
/* ======================
 content
========================= */
/* ----------------------
 content common
------------------------- */
.page-wrap {
  text-align: center; }

main {
  margin: 0 auto; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  main {
    width: 100%; } }

.content {
  margin-top: 0;
  margin-bottom: 97px; }
  @media only screen and (max-width: 1140px) {
    .content {
      padding: 0 15px;
      margin-bottom: 5.1vw;
      margin-bottom: 8.5087719298vw; } }
  @media only screen and (max-width: 1140px) and (max-width: 1024px) {
    .content {
      margin-bottom: 9.47265625vw; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
    .content {
      padding: 0 10px;
      margin-bottom: 50px; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    .content {
      margin-bottom: 40px; } }

.content .img img {
  width: 100%;
  height: auto; }

.content .img.org {
  text-align: center; }
  .content .img.org img {
    width: auto;
    max-width: 100%;
    height: auto; }

.content#maindesc {
  margin-bottom: 50px; }
  @media only screen and (max-width: 1140px) {
    .content#maindesc {
      padding: 0 15px;
      margin-bottom: 5.1vw;
      margin-bottom: 4.3859649123vw; } }
  @media only screen and (max-width: 1140px) and (max-width: 1024px) {
    .content#maindesc {
      margin-bottom: 4.8828125vw; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
    .content#maindesc {
      padding: 0 10px;
      margin-bottom: 25px; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    .content#maindesc {
      margin-bottom: 20px; } }

.content:not(#menu, #submenu, #topics) .inner {
  -moz-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.2);
  -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.2);
  box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.2);
  filter: progid:DXImageTransform.Microsoft.Shadow(color="#d9d9d9", Direction=145, Strength=5); }

/* ----------------------
 content .wrap
------------------------- */
.content .wrap + .wrap,
.content .txt + .wrap {
  margin-top: 2em !important; }
  @media only screen and (max-width: 1140px) {
    .content .wrap + .wrap,
    .content .txt + .wrap {
      margin-top: 2.9824561404vw; } }
  @media only screen and (max-width: 1140px) and (max-width: 1024px) {
    .content .wrap + .wrap,
    .content .txt + .wrap {
      margin-top: 2.9824561404vw; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
    .content .wrap + .wrap,
    .content .txt + .wrap {
      margin-top: 15px; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    .content .wrap + .wrap,
    .content .txt + .wrap {
      margin-top: 10px; } }

.content .wrap.info {
  padding: 1em 1.5em;
  border: 3px dashed #27AD37;
  border-radius: 8px;
  background-color: #FFFCF2; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .content .wrap.info {
    padding: 1em; } }

.content .wrap.common-2col {
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -moz-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -ms-justify-content: space-between;
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }

/* ----------------------
 content #menu
------------------------- */
.content#menu {
  text-align: center; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .content#menu {
    display: none; } }

.content#menu .inner {
  width: 767px; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .content#menu .inner {
    width: 100%; } }

.content#menu .subj {
  display: inline-block;
  margin: 1.5em auto 0.5em;
  text-align: center;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  font-size: 120%; }
  @media only screen and (max-width: 1140px) {
    .content#menu .subj {
      margin: 1.5em auto; } }

.content#menu .list-root {
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: auto;
  max-width: 100%;
  height: auto; }

.content#menu .list-item {
  position: relative;
  margin: 0 3px 0.5em;
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: auto !important;
  max-width: 100% !important; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .content#menu .list-item {
    width: 100% !important;
    max-width: 47%;
    margin: 0 3px 8px; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    .content#menu .list-item {
      width: 100%;
      margin: 0 0 8px; }
      .content#menu .list-item:last-of-type {
        margin-bottom: 0; } }

.content#menu .list-item a {
  display: block;
  width: 100%;
  text-decoration: none;
  color: #000; }

.content#menu .list-item a h3,
.content#menu .list-item a p {
  width: 100%;
  color: #000;
  line-height: 1.3; }

.content#menu .list-item a h3 {
  padding: 0.5em;
  font-size: 90%;
  border: 2px solid #BDE75E;
  border-radius: 8px;
  background-color: #fff; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .content#menu .list-item a h3 br {
    display: none; } }

@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
  .content#menu .list-item a h3 {
    text-align: left;
    line-height: 1.4; } }

.content#menu .list-item a h3:hover {
  background-color: #eee !important; }

.content#menu .list-item a h3:after {
  content: " \f0a9";
  font-family: "Font Awesome 5 Free";
  font-weight: 900; }

.content#menu .list-item a .txt {
  padding: 0.5em;
  font-size: 75%; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .content#menu .list-item a .txt {
    display: none; } }

.content#menu .list-item a .txt:first-of-type {
  border-top: 1px solid #ccc; }

/* ----------------------
 content #content-menu (コーナートップ)
------------------------- */
.content#content-menu {
  text-align: center; }

.content#content-menu .list-root {
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: auto;
  max-width: 100%;
  height: auto; }

.content#content-menu .list-item {
  position: relative;
  margin: 0 3px 0.5em;
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: auto !important;
  max-width: 100% !important; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .content#content-menu .list-item {
    width: 100% !important;
    max-width: 47%;
    margin: 0 3px 8px; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    .content#content-menu .list-item {
      width: 100%;
      margin: 0 0 8px; }
      .content#content-menu .list-item:last-of-type {
        margin-bottom: 0; } }

.content#content-menu .list-item a {
  display: block;
  width: 100%;
  text-decoration: none;
  color: #000; }

.content#content-menu .list-item a h3,
.content#content-menu .list-item a p {
  width: 100%;
  color: #000;
  line-height: 1.3; }

.content#content-menu .list-item a h3 {
  padding: 0.5em;
  font-size: 90%;
  border: 2px solid #BDE75E;
  border-radius: 8px;
  background-color: #fff; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .content#content-menu .list-item a h3 br {
    display: none; } }

@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
  .content#content-menu .list-item a h3 {
    text-align: left;
    line-height: 1.4; } }

.content#content-menu .list-item a h3:hover {
  background-color: #eee !important; }

.content#content-menu .list-item a h3:after {
  content: " \f0a9";
  font-family: "Font Awesome 5 Free";
  font-weight: 900; }

.content#content-menu .list-item a .txt {
  padding: 0.5em;
  font-size: 75%; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .content#content-menu .list-item a .txt {
    display: none; } }

.content#content-menu .list-item a .txt:first-of-type {
  border-top: 1px solid #ccc; }

/* ----------------------
 content #submenu
------------------------- */
#submenu .list-root {
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }

#submenu .list-item {
  display: inline-block;
  border: 2px solid transparent;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

#submenu .list-item a {
  display: block;
  width: 100%;
  max-height: 3em;
  padding: 0.8em;
  font-size: 90%;
  color: #fff;
  background-color: #005C33;
  text-decoration: none; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
  #submenu .list-item a {
    max-height: 5em;
    padding: 1em;
    font-size: 80%; } }

#submenu .list-item a:after {
  content: " \f078";
  font-family: "Font Awesome 5 Free";
  font-weight: 900; }

#submenu .list-item a:hover {
  background-color: #27AD37; }

/* ----------------------
 section common
------------------------- */
.sect-ttl {
  width: 100%;
  margin-bottom: 0;
  text-align: center; }

.sect-ttl {
  position: relative;
  padding: 0.8em 0.8em 0.8em 4.8em;
  background-color: #005C33;
  color: #fff;
  text-align: left;
  font-size: 120%;
  font-weight: 600; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .sect-ttl {
    font-size: 100%; } }

.sect-ttl:before {
  position: absolute;
  top: -10px;
  left: 10px;
  content: "";
  display: block;
  width: 65px;
  height: 59px;
  background: url(../image/common/pref_clover.png) top left no-repeat;
  background-size: cover;
  z-index: 99; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .sect-ttl:before {
    width: 45px;
    height: 40px; } }

.ttl {
  padding: 0.5em;
  margin-bottom: 1em;
  text-align: left;
  background-color: #fff;
  border-bottom: 2px solid #BDE75E;
  border-left: 5px solid #BDE75E;
  color: #000;
  font-weight: 600;
  font-size: 100%; }

.sect-body {
  padding: 30px 65px;
  background-color: #fff;
  text-align: left; }
  @media only screen and (max-width: 1140px) {
    .sect-body {
      padding: 2.6315789474vw 5.701754386vw; } }
  @media only screen and (max-width: 1140px) and (max-width: 1024px) {
    .sect-body {
      padding: 2.9296875vw 6.34765625vw; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
    .sect-body {
      padding: 20px; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    .sect-body {
      padding: 10px; } }

.sect-ttl > .sect-body .wrap {
  margin-top: 2.5em; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) {
  .sect-ttl > .sect-body .wrap {
    margin-top: 1.5em; } }

/* ----------------------
 content cat accordion

 ※※要・スクリプト追記
------------------------- */
.cat-ttl {
  display: block;
  text-decoration: none;
  cursor: pointer; }

.cat-ttl:after {
  content: "　　\f078";
  font-family: "Font Awesome 5 Free";
  font-weight: 900; }

.cat-box {
  display: none; }

/* ======================
 content list
========================= */
/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー 20210116 */
/* テスト用背景色 */
/* ------------------------
 content list
------------------------- */
/* ----------------------
 list-common
------------------------- */
.list-common {
  list-style-position: outside;
  padding-left: 4em;
  margin-left: -2em; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .list-common {
    padding-left: 2em;
    margin-left: 0;
    line-height: 1.4; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    .list-common {
      margin-left: 2em; } }

.list-common .list-item {
  list-style-type: disc;
  border-bottom: 1px solid #ccc; }
  .list-common .list-item:last-of-type {
    border-bottom: 0; }

.list-common .list-item a {
  display: block;
  padding: 1em 0;
  color: #000; }

.list-common .list-item a p:after {
  content: " \f0a9";
  font-family: "Font Awesome 5 Free";
  font-weight: 900; }

/* ----------------------
 list-topics
------------------------- */
.list-topics {
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -moz-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  -ms-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }

.list-topics .list-topics-item {
  position: relative;
  width: 100%;
  margin: 0.5em;
  margin-bottom: 0.5em;
  border-bottom: 1px solid #ccc; }
  .list-topics .list-topics-item:last-of-type {
    border-bottom: 0; }

.list-topics .list-topics-item a {
  display: block;
  padding: 0;
  color: #000;
  font-size: 95%; }

.list-topics .list-topics-item:after {
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
  /* Safari用 */
  transform: translateY(-50%);
  content: " \f054";
  font-family: "Font Awesome 5 Free";
  font-weight: 900; }

.list-topics .list-topics-item a:hover {
  background-color: #eee; }

.list-topics .list-topics-item .col2-1 {
  padding: 0 5px;
  text-align: left; }

.list-topics .list-topics-item .col2-2 {
  padding: 0 5px;
  text-align: left; }

/* ------------------------
 list-contact
------------------------- */
.list-contact {
  padding: 0;
  margin: 1em 0;
  border: 1px solid #ccc; }

.list-contact .list-item {
  padding: 0;
  margin: 0;
  border-bottom: 1px solid #ccc;
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: start;
  -moz-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  -ms-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap; }
  .list-contact .list-item:last-of-type {
    border-bottom: 0; }

.list-contact .list-item .col {
  display: table-cell;
  padding: 0.5em; }

.list-contact .list-item .col2-1 {
  width: 20%;
  background-color: #eee;
  font-weight: 600;
  text-align: center; }

.list-contact .list-item .col2-2 {
  width: 80%; }

.list-contact .num {
  font-size: 130%;
  font-weight: 600; }

/* ----------------------
 list-pdf
------------------------- */
.list-pdf {
  padding-left: 1em; }

.list-pdf .list-item {
  width: 100%;
  padding-left: 0.5em;
  margin-left: 0.5em;
  list-style-type: disc;
  list-style-position: outside;
  margin-bottom: 0.5em;
  border-bottom: 1px solid #ccc; }
  .list-pdf .list-item:last-of-type {
    margin-bottom: 0;
    border-bottom: 0; }

.list-pdf .list-item a {
  display: inline-block;
  width: auto;
  padding: 0.5em 0;
  color: #000;
  text-decoration: none; }

.list-pdf .list-item a:hover {
  background-color: #eee; }

.list-pdf .list-item a:after {
  content: " \f1c1";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: red; }

/* ----------------------
 list-gallery
(福祉用品貸し出し一覧)
------------------------- */
.list-gallery {
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -moz-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  -ms-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }

.list-gallery .list-item {
  width: 24.5%;
  padding: 0.5em;
  border-bottom: 0 !important; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .list-gallery .list-item {
    width: 49.5%; } }

.list-gallery .list-item .img img {
  width: auto;
  height: auto;
  max-width: 100%; }

.list-gallery .list-item .img .cap {
  width: 100% !important;
  padding: 0.4em 0.6em;
  font-size: 75%;
  text-align: center; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
  .list-gallery .list-item .img .cap {
    text-align: left; } }

/* ------------------------
 pager block
------------------------- */
#pager {
  width: 100%;
  padding: 30px 0 1em;
  text-align: center; }
  @media only screen and (max-width: 1140px) {
    #pager {
      padding: 2.6315789474vw 15px 1.4912280702vw; } }
  @media only screen and (max-width: 1140px) and (max-width: 1024px) {
    #pager {
      padding: 2.9296875vw 15px 1.66015625vw; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
    #pager {
      padding: 20px 0 2.2164276402vw; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    #pager {
      padding: 15px 0 4.5333333333vw; } }

#pager .page-numbers {
  display: inline-block;
  width: auto;
  padding: 0.4em 0.8em;
  text-decoration: none;
  border: 1px solid #000 !important;
  color: #000;
  font-size: 90%; }

#pager .page-numbers.prev,
#pager .page-numbers.next {
  border: 0 !important; }

#pager .page-numbers:hover {
  background-color: #000;
  color: #fff; }

/* ======================
 youtube動画埋め込み
(地域包括・介護予防関連)
========================= */
iframe {
  display: block;
  margin: 1em auto; }

/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー 20210116 */
/* テスト用背景色 */
/* ------------------------
 content list
------------------------- */
/* ----------------------
 list-common
------------------------- */
.list-common {
  list-style-position: outside;
  padding-left: 4em;
  margin-left: -2em; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .list-common {
    padding-left: 2em;
    margin-left: 0;
    line-height: 1.4; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    .list-common {
      margin-left: 2em; } }

.list-common .list-item {
  list-style-type: disc;
  border-bottom: 1px solid #ccc; }
  .list-common .list-item:last-of-type {
    border-bottom: 0; }

.list-common .list-item a {
  display: block;
  padding: 1em 0;
  color: #000; }

.list-common .list-item a p:after {
  content: " \f0a9";
  font-family: "Font Awesome 5 Free";
  font-weight: 900; }

/* ----------------------
 list-topics
------------------------- */
.list-topics {
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -moz-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  -ms-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }

.list-topics .list-topics-item {
  position: relative;
  width: 100%;
  margin: 0.5em;
  margin-bottom: 0.5em;
  border-bottom: 1px solid #ccc; }
  .list-topics .list-topics-item:last-of-type {
    border-bottom: 0; }

.list-topics .list-topics-item a {
  display: block;
  padding: 0;
  color: #000;
  font-size: 95%; }

.list-topics .list-topics-item:after {
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
  /* Safari用 */
  transform: translateY(-50%);
  content: " \f054";
  font-family: "Font Awesome 5 Free";
  font-weight: 900; }

.list-topics .list-topics-item a:hover {
  background-color: #eee; }

.list-topics .list-topics-item .col2-1 {
  padding: 0 5px;
  text-align: left; }

.list-topics .list-topics-item .col2-2 {
  padding: 0 5px;
  text-align: left; }

/* ------------------------
 list-contact
------------------------- */
.list-contact {
  padding: 0;
  margin: 1em 0;
  border: 1px solid #ccc; }

.list-contact .list-item {
  padding: 0;
  margin: 0;
  border-bottom: 1px solid #ccc;
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: start;
  -moz-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  -ms-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap; }
  .list-contact .list-item:last-of-type {
    border-bottom: 0; }

.list-contact .list-item .col {
  display: table-cell;
  padding: 0.5em; }

.list-contact .list-item .col2-1 {
  width: 20%;
  background-color: #eee;
  font-weight: 600;
  text-align: center; }

.list-contact .list-item .col2-2 {
  width: 80%; }

.list-contact .num {
  font-size: 130%;
  font-weight: 600; }

/* ----------------------
 list-pdf
------------------------- */
.list-pdf {
  padding-left: 1em; }

.list-pdf .list-item {
  width: 100%;
  padding-left: 0.5em;
  margin-left: 0.5em;
  list-style-type: disc;
  list-style-position: outside;
  margin-bottom: 0.5em;
  border-bottom: 1px solid #ccc; }
  .list-pdf .list-item:last-of-type {
    margin-bottom: 0;
    border-bottom: 0; }

.list-pdf .list-item a {
  display: inline-block;
  width: auto;
  padding: 0.5em 0;
  color: #000;
  text-decoration: none; }

.list-pdf .list-item a:hover {
  background-color: #eee; }

.list-pdf .list-item a:after {
  content: " \f1c1";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: red; }

/* ----------------------
 list-gallery
(福祉用品貸し出し一覧)
------------------------- */
.list-gallery {
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -moz-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  -ms-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }

.list-gallery .list-item {
  width: 24.5%;
  padding: 0.5em;
  border-bottom: 0 !important; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .list-gallery .list-item {
    width: 49.5%; } }

.list-gallery .list-item .img img {
  width: auto;
  height: auto;
  max-width: 100%; }

.list-gallery .list-item .img .cap {
  width: 100% !important;
  padding: 0.4em 0.6em;
  font-size: 75%;
  text-align: center; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
  .list-gallery .list-item .img .cap {
    text-align: left; } }

/* ------------------------
 pager block
------------------------- */
#pager {
  width: 100%;
  padding: 30px 0 1em;
  text-align: center; }
  @media only screen and (max-width: 1140px) {
    #pager {
      padding: 2.6315789474vw 15px 1.4912280702vw; } }
  @media only screen and (max-width: 1140px) and (max-width: 1024px) {
    #pager {
      padding: 2.9296875vw 15px 1.66015625vw; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
    #pager {
      padding: 20px 0 2.2164276402vw; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    #pager {
      padding: 15px 0 4.5333333333vw; } }

#pager .page-numbers {
  display: inline-block;
  width: auto;
  padding: 0.4em 0.8em;
  text-decoration: none;
  border: 1px solid #000 !important;
  color: #000;
  font-size: 90%; }

#pager .page-numbers.prev,
#pager .page-numbers.next {
  border: 0 !important; }

#pager .page-numbers:hover {
  background-color: #000;
  color: #fff; }

/* ------------------------
 aside
------------------------- */
/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー 20210116 */
/* テスト用背景色 */
/* ------------------------
 footer
------------------------- */
#footer {
  margin: 0;
  text-align: center;
  background-color: #BDE75E; }

#footer .inner {
  padding: 1em 0;
  text-align: center;
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #footer .inner {
    padding: 15px; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    #footer .inner {
      padding: 10px; } }

#footer .footer-name {
  width: 33%;
  padding: 0 1.5em;
  text-align: left;
  border-right: 1px solid #999; }
  #footer .footer-name:last-of-type {
    border-right: 0; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #footer .footer-name {
    width: 100%;
    padding: 15px;
    border-right: 0;
    border-bottom: 1px solid #999; }
    #footer .footer-name:last-of-type {
      border-bottom: 0; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 375px) {
    #footer .footer-name {
      padding: 10px; } }

#footer .footer-name a {
  display: block; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #footer .footer-name a {
    font-size: 125%;
    font-weight: 600; } }

#footer .footer-name .name h2 {
  padding: 0;
  margin: 0 0 0.5em;
  color: #005C33;
  font-weight: 600;
  font-size: 100%; }

#footer .footer-name .name h2:before {
  display: inline;
  content: "●"; }

#footer .footer-name address {
  padding-left: 1em;
  font-size: 85%; }

#footer .footer-name .zip {
  display: block; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #footer .footer-name .zip {
    display: inline-block; } }

@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #footer .footer-name .addr {
    display: inline-block; } }

#footer #copyright {
  width: 100%;
  padding: 2em 0;
  text-align: center;
  font-size: 90%; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  #footer #copyright {
    padding: 1em; } }
