@charset "UTF-8";
body {
  margin: 0;
  padding: 0;
  font-family: "BIZ UDPGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif" !important;
  font-size: 100%;
  letter-spacing: 0.05em;
  line-height: 1.6;
  color: #333333;
  background-color: #FFF;
  margin-bottom: 1px; /*scrollbar*/
  word-break: normal;
  word-wrap: break-word;
  position: relative;
}
@media print, screen and (max-width: 575px) {
  body {
    font-size: 80%;
  }
}
@media print, screen and (max-width: 767px) {
  body {
    font-size: 85%;
  }
}
@media print, screen and (max-width: 1199px) {
  body {
    font-size: 90%;
  }
}
body span, body p, body div {
  font-family: "BIZ UDPGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif" !important;
}

.fixed {
  position: fixed;
  width: 100%;
  height: 100%;
}

h1, h2, h3, h4, h5, h6, p, ul, ol, li, dl, dt, dd, form, input, blockquote, figure {
  margin: 0;
  padding: 0;
}

img {
  border: none;
}

a img {
  border: none;
}

ul li img {
  vertical-align: bottom;
}

li, dt, dd {
  line-height: 1.4;
}

a:link, a.skip {
  background-color: transparent;
}

a {
  color: #005379;
  text-decoration: underline;
}
a:hover, a:focus {
  color: #7c1801;
}
a:visited {
  color: #252c71;
}
a[href*="tel:"] {
  pointer-events: auto;
  cursor: pointer;
  text-decoration: underline;
  color: #005379 !important;
}
@media print, screen and (min-width: 768px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
    color: #333333 !important;
  }
}

.anchor {
  cursor: pointer;
}

.pcnone {
  display: none;
}

p.voice_navi {
  position: absolute;
  overflow: hidden;
  width: 1px;
  height: 1px;
  top: 0;
  left: 0;
  margin: 0;
  padding: 0;
}

.bold {
  font-weight: bold;
}

.mt10 {
  margin-top: 10px;
}

.mb20 {
  margin-bottom: 20px;
}

iframe {
  border: 0px;
  max-width: 100%;
}

video {
  max-width: 100%;
  height: auto;
}

@font-face {
  font-family: "icomoon";
  src: url("fonts/icomoon.eot?r62d7n");
  src: url("fonts/icomoon.eot?r62d7n#iefix") format("embedded-opentype"), url("fonts/icomoon.ttf?r62d7n") format("truetype"), url("fonts/icomoon.woff?r62d7n") format("woff"), url("fonts/icomoon.svg?r62d7n#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
[class^=icon-], [class*=" icon-"],
.slick-prev::before,
.slick-next::before,
.swiper-button-prev::before,
.swiper-button-next::before {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "icomoon" !important;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-arw:before {
  content: "\e904";
}

/* search */
form.gsc-search-box,
.gsc-refinementsArea {
  display: none !important;
}

/*!
 * ress.css • v2.0.4
 * MIT License
 * github.com/filipelinhares/ress
 */
/* # =================================================================
   # Global selectors
   # ================================================================= */
html {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-text-size-adjust: 100%; /* Prevent adjustments of font size after orientation changes in iOS */
  word-break: normal;
  -moz-tab-size: 4;
  -o-tab-size: 4;
     tab-size: 4;
}

*,
::before,
::after {
  background-repeat: no-repeat; /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
  -webkit-box-sizing: inherit;
          box-sizing: inherit;
}

::before,
::after {
  text-decoration: inherit; /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
}

* {
  padding: 0; /* Reset `padding` and `margin` of all elements */
  margin: 0;
}

/* # =================================================================
   # General elements
   # ================================================================= */
hr {
  overflow: visible; /* Show the overflow in Edge and IE */
  height: 0; /* Add the correct box sizing in Firefox */
}

details,
main {
  display: block; /* Render the `main` element consistently in IE. */
}

summary {
  display: list-item; /* Add the correct display in all browsers */
}

small {
  font-size: 80%; /* Set font-size to 80% in `small` elements */
}

[hidden] {
  display: none; /* Add the correct display in IE */
}

abbr[title] {
  border-bottom: none; /* Remove the bottom border in Chrome 57 */
  /* Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari */
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

a {
  background-color: transparent; /* Remove the gray background on active links in IE 10 */
}

a:active,
a:hover {
  outline-width: 0; /* Remove the outline when hovering in all browsers */
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace; /* Specify the font family of code elements */
}

pre {
  font-size: 1em; /* Correct the odd `em` font sizing in all browsers */
}

b,
strong {
  font-weight: bolder; /* Add the correct font weight in Chrome, Edge, and Safari */
}

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* # =================================================================
   # Forms
   # ================================================================= */
input {
  border-radius: 0;
}

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto; /* Correct the cursor style of increment and decrement buttons in Chrome */
}

[type=search] {
  -webkit-appearance: textfield; /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px; /* Correct the outline style in Safari */
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none; /* Remove the inner padding in Chrome and Safari on macOS */
}

textarea {
  overflow: auto; /* Internet Explorer 11+ */
  resize: vertical; /* Specify textarea resizability */
}

button,
input,
optgroup,
select,
textarea {
  /*font: inherit;  Specify font inheritance of form elements */
}

optgroup {
  font-weight: bold; /* Restore the font weight unset by the previous rule */
}

button {
  overflow: visible; /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

button,
select {
  text-transform: none; /* Firefox 40+, Internet Explorer 11- */
}

/* Apply cursor pointer to button elements */
button,
[type=button],
[type=reset],
[type=submit],
[role=button] {
  cursor: pointer;
  color: inherit;
}

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  outline: 1px dotted ButtonText;
}

button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button; /* Correct the inability to style clickable types in iOS */
}

/* Remove the default button styling in all browsers */
button,
input,
textarea {
  background-color: transparent;
  border-style: none;
}

/* Style select like a standard input */
select {
  -moz-appearance: none; /* Firefox 36+ */
  -webkit-appearance: none; /* Chrome 41+ */
}

select::-ms-expand {
  display: none; /* Internet Explorer 11+ */
}

select::-ms-value {
  color: currentColor; /* Internet Explorer 11+ */
}

legend {
  border: 0; /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit; /* Correct the color inheritance from `fieldset` elements in IE */
  display: table; /* Correct the text wrapping in Edge and IE */
  max-width: 100%; /* Correct the text wrapping in Edge and IE */
  white-space: normal; /* Correct the text wrapping in Edge and IE */
  max-width: 100%; /* Correct the text wrapping in Edge 18- and IE */
}

::-webkit-file-upload-button {
  /* Correct the inability to style clickable types in iOS and Safari */
  -webkit-appearance: button;
  color: inherit;
  font: inherit; /* Change font properties to `inherit` in Chrome and Safari */
}

/* # =================================================================
   # Specify media element style
   # ================================================================= */
img {
  border-style: none; /* Remove border when inside `a` element in IE 8/9/10 */
  vertical-align: middle;
}

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline;
}

svg:not([fill]) {
  fill: currentColor;
}

/* # =================================================================
   # Accessibility
   # ================================================================= */
/* Hide content from screens but not screenreaders */
@media screen {
  [hidden~=screen] {
    display: inherit;
  }
  [hidden~=screen]:not(:active):not(:focus):not(:target) {
    position: absolute !important;
    clip: rect(0 0 0 0) !important;
  }
}
/* Specify the progress cursor of updating elements */
[aria-busy=true] {
  cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled] {
  cursor: default;
}

#wrapper {
  width: 100%;
  position: relative;
  overflow: hidden;
}

#main {
  margin: 0 auto;
  clear: both;
}

.container {
  position: relative;
}
.container.z1 {
  z-index: 1;
}

#page_main {
  width: auto;
  margin-top: 20px;
  margin-left: 20px;
  margin-right: 20px;
  margin-bottom: 40px;
}
@media print, screen and (min-width: 992px) {
  #page_main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 30px;
  }
}
@media print, screen and (min-width: 1200px) {
  #page_main {
    width: auto;
    margin-top: 20px;
    margin-bottom: 40px;
    margin-left: 15px;
    margin-right: 15px;
  }
}
@media print, screen and (min-width: 1200px) and (min-width: 992px) {
  #page_main {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) and (min-width: 1200px) {
  #page_main {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}

#page_maincontents {
  margin-bottom: 30px;
}
@media print, screen and (min-width: 576px) {
  #page_maincontents {
    border-radius: 0px;
  }
}
@media print, screen and (min-width: 768px) {
  #page_maincontents {
    margin-bottom: 20px;
  }
}
@media print, screen and (min-width: 992px) {
  #page_maincontents {
    margin-bottom: 0px;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page_maincontents-onecol {
  width: 100%;
}

#page_sidemenu {
  width: 100%;
  position: relative;
}
@media print, screen and (min-width: 992px) {
  #page_sidemenu {
    width: 220px;
  }
}

.skip {
  position: absolute;
  overflow: hidden;
  width: 0;
  margin: 0;
  padding: 0;
}

a.skip {
  text-align: center;
  padding: 2px 0;
  top: 0;
}
a.skip:active, a.skip:focus {
  display: block;
  font-size: 100%;
  line-height: 1.6;
  top: 0;
  left: 0;
  z-index: 3000;
  height: auto;
}
a.skip:active {
  width: 100%;
}
a.skip:focus {
  width: 99.99%;
}

#header {
  width: 100%;
  background: #1B4D42;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#header #header_logo {
  width: 140px;
  margin: 14px 10px 10px 10px;
}
@media print, screen and (min-width: 992px) {
  #header #header_logo {
    width: 200px;
  }
}
@media print, screen and (min-width: 1200px) {
  #header #header_logo {
    width: 240px;
    margin: 20px 30px;
  }
}
#header #header_logo h1,
#header #header_logo div {
  font-size: inherit;
}
#header #header_logo h1 a,
#header #header_logo div a {
  display: block;
}
#header #header_logo h1 a img,
#header #header_logo div a img {
  width: 100%;
  height: auto;
  vertical-align: inherit;
  image-rendering: -webkit-optimize-contrast;
}
#header #header_logo.page {
  background: none;
  height: auto;
  width: 220px;
  padding: 20px;
}
@media print, screen and (min-width: 576px) {
  #header #header_logo.page {
    width: 260px;
  }
}
@media print, screen and (min-width: 768px) {
  #header #header_logo.page {
    width: 300px;
    padding: 32px 20px;
  }
}
@media print, screen and (min-width: 992px) {
  #header #header_logo.page {
    width: 320px;
    padding: 30px 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  #header #header_logo.page {
    width: 340px;
    padding: 30px;
  }
}

.menu-trigger {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  position: fixed;
  right: 0;
  top: 0;
  width: 64px;
  height: 64px;
  padding: 0 5px;
  display: inline-block;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  right: 0px;
  z-index: 200;
  background: #1B4D42 !important;
}
@media print, screen and (min-width: 768px) {
  .menu-trigger {
    display: none;
  }
}
.menu-trigger span {
  position: absolute;
  left: 16px;
  width: 36px;
  height: 4px;
  background-color: #FFF;
  border-radius: 4px;
  display: inline-block;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  z-index: 200;
}
.menu-trigger span:nth-of-type(1) {
  top: 16px;
}
.menu-trigger span:nth-of-type(2) {
  top: 26px;
}
.menu-trigger span:nth-of-type(3) {
  top: 36px;
}
.menu-trigger::after {
  position: absolute;
  bottom: 3px;
  content: "MENU";
  display: block;
  width: 100%;
  color: #FFF;
  font-size: 70%;
  text-decoration: none;
  left: 2px;
  text-align: center;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.menu-trigger.active::after {
  content: "CLOSE";
  bottom: 3px;
  font-size: 70%;
}
.menu-trigger.active span:nth-of-type(1) {
  -webkit-transform: translateY(10px) rotate(-45deg);
          transform: translateY(10px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}
.menu-trigger.active span:nth-of-type(3) {
  -webkit-transform: translateY(-10px) rotate(45deg);
          transform: translateY(-10px) rotate(45deg);
}

#menu {
  display: none;
  position: absolute;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  right: 100%;
  width: 100%;
  top: 0px;
  height: 100vh;
  z-index: 100;
  padding-top: 65px;
  background: #1B4D42;
}
@media print, screen and (min-width: 768px) {
  #menu {
    position: static;
    display: block;
    right: 15px;
    height: inherit;
    padding-top: 0px;
    background: none;
  }
}
@media print, screen and (min-width: 1200px) {
  #menu {
    width: auto;
  }
}
#menu.active {
  display: block;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
}
#menu .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
}
@media print, screen and (min-width: 768px) {
  #menu .inner {
    gap: 0px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
#menu .inner #gnavi {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  width: 100%;
  text-align: right;
}
#menu .inner #gnavi ul {
  list-style-type: none;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 100%;
  padding: 0px 10px 0px 0px;
}
@media print, screen and (min-width: 768px) {
  #menu .inner #gnavi ul {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}
@media print, screen and (min-width: 992px) {
  #menu .inner #gnavi ul {
    width: auto;
    padding: 0px 30px 0px 0px;
  }
}
@media print, screen and (min-width: 1200px) {
  #menu .inner #gnavi ul {
    width: auto;
    gap: 0;
  }
}
#menu .inner #gnavi ul li {
  width: calc(50% - 3px);
  text-align: center;
}
@media print, screen and (min-width: 576px) {
  #menu .inner #gnavi ul li {
    width: auto;
    border: 0;
    border-radius: 0;
  }
}
@media print, screen and (min-width: 768px) {
  #menu .inner #gnavi ul li {
    width: 100%;
  }
}
@media print, screen and (min-width: 992px) {
  #menu .inner #gnavi ul li {
    width: auto;
  }
}
#menu .inner #gnavi ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-decoration: none;
  color: #1B4D42;
  font-weight: bold;
  position: relative;
  color: #FFF;
}
@media print, screen and (min-width: 768px) {
  #menu .inner #gnavi ul li a {
    display: block;
  }
}
#menu .inner #gnavi ul li a:after {
  content: "";
  width: 0px;
  height: 3px;
  position: absolute;
  left: 0;
  bottom: 3px;
  visibility: hidden;
  -webkit-transition: width 0.2s, visibility 0.2s;
  transition: width 0.2s, visibility 0.2s;
}
#menu .inner #gnavi ul li a:hover:after, #menu .inner #gnavi ul li a.selected:after, #menu .inner #gnavi ul li a:focus:after {
  visibility: visible;
  width: 100%;
  -webkit-transition: width 0.2s 0.1s;
  transition: width 0.2s 0.1s;
}
@media print, screen and (max-width: 767px) {
  #menu .inner #gnavi ul li a:hover:after, #menu .inner #gnavi ul li a.selected:after, #menu .inner #gnavi ul li a:focus:after {
    display: none;
  }
}
#menu .inner #gnavi ul li a > div {
  -ms-flex-preferred-size: 10%;
      flex-basis: 10%;
}
#menu .inner #gnavi ul li a > div img {
  width: 100%;
  height: auto;
}
@media print, screen and (min-width: 1200px) {
  #menu .inner #gnavi ul li a > div img {
    max-width: 150px;
    height: auto;
  }
}
#menu .inner #gnavi ul li a span {
  text-align: center;
  display: block;
  padding: 0.5rem;
  font-size: 1rem;
  width: 100%;
  position: relative;
}
@media print, screen and (min-width: 768px) {
  #menu .inner #gnavi ul li a span {
    font-size: 0.7rem;
    padding: 1.4rem 5px;
  }
  #menu .inner #gnavi ul li a span::before {
    position: absolute;
    content: "";
    width: 1px;
    height: 30px;
    background: #41806E;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
@media print, screen and (min-width: 992px) {
  #menu .inner #gnavi ul li a span {
    font-size: 1rem;
    padding: 1.4rem 15px;
  }
}
@media print, screen and (min-width: 1200px) {
  #menu .inner #gnavi ul li a span {
    font-size: 1rem;
    padding: 1.6rem 20px;
  }
}
#menu .inner #gnavi ul li .sub {
  display: none;
}
@media print, screen and (min-width: 768px) {
  #menu .inner #gnavi ul li .sub {
    display: block;
  }
}
#menu .inner #gnavi ul li .sub ul {
  height: auto;
  border-radius: 0px;
  position: absolute;
  left: 0;
  background-color: #F4F6F8;
  -webkit-box-shadow: 0px 5px 10px rgba(16, 106, 181, 0.05) inset, 0px 3px 2px rgba(0, 0, 0, 0.1);
          box-shadow: 0px 5px 10px rgba(16, 106, 181, 0.05) inset, 0px 3px 2px rgba(0, 0, 0, 0.1);
  padding: 20px;
  width: 100%;
  z-index: 100;
  display: none;
}
@media print, screen and (min-width: 768px) {
  #menu .inner #gnavi ul li .sub ul {
    top: 120px;
  }
}
@media print, screen and (min-width: 992px) {
  #menu .inner #gnavi ul li .sub ul {
    top: 135px;
  }
}
@media print, screen and (min-width: 1200px) {
  #menu .inner #gnavi ul li .sub ul {
    top: 145px;
  }
}
#menu .inner #gnavi ul li .sub ul li {
  width: calc(50% - 15px);
  text-align: left;
  float: left;
  display: block;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
  border-right: 0px;
  margin: 0px;
  padding: 10px 0px;
}
@media print, screen and (min-width: 1200px) {
  #menu .inner #gnavi ul li .sub ul li {
    width: calc(33.3333333333% - 15px);
  }
}
#menu .inner #gnavi ul li .sub ul li a {
  text-indent: 0;
  padding: 3px 5px 3px 30px;
  text-decoration: underline;
  display: block;
  position: relative;
  color: #1B4D42;
  width: auto;
}
#menu .inner #gnavi ul li .sub ul li a::before {
  content: "";
  position: absolute;
  top: 0.3rem;
  left: 0;
  width: 5px;
  height: 5px;
  margin: 0.3rem 0 0 0.5rem;
  border-top: 2px solid #41806E;
  border-right: 2px solid #41806E;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
#menu .inner #gnavi ul li .sub ul li:hover {
  background: #FFF;
  cursor: pointer;
}
#menu .inner #gnavi ul li .sub ul li a::after {
  background: none;
}
@media print, screen and (min-width: 768px) {
  #menu .inner #gnavi ul li:last-child span::after {
    position: absolute;
    content: "";
    width: 1px;
    height: 30px;
    background: #41806E;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
#menu .inner .setting {
  width: 100%;
  background: #41806E;
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting {
    width: inherit;
    background: none;
  }
}
#menu .inner .setting ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  font-size: 0.7rem;
  position: relative;
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul {
    font-size: 0.8rem;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    padding-left: 15px;
  }
}
@media print, screen and (min-width: 1200px) {
  #menu .inner .setting ul {
    font-size: inherit;
  }
}
#menu .inner .setting ul li {
  color: #FFF;
  font-weight: bold;
  list-style-type: none;
  background: #41806E;
  padding: 0px 10px;
  width: 25%;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li {
    width: auto;
  }
}
#menu .inner .setting ul li span[class^=icon-] {
  font-size: 1rem;
  text-align: center;
  line-height: inherit;
  display: block;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li span[class^=icon-] {
    font-size: 1.6rem;
  }
}
@media print, screen and (min-width: 1200px) {
  #menu .inner .setting ul li span[class^=icon-] {
    display: inline-block;
    padding-right: 5px;
    width: auto;
  }
}
#menu .inner .setting ul li span.icon-text::before {
  content: "\e904";
}
#menu .inner .setting ul li span.icon-yomi::before {
  content: "\e905";
}
#menu .inner .setting ul li span.icon-kana::before {
  content: "\e902";
}
#menu .inner .setting ul li span.icon-kana::before {
  content: "\e902";
}
#menu .inner .setting ul li span.icon-lang::before {
  content: "\e903";
}
#menu .inner .setting ul li span.icon-search::before {
  content: "\e908";
}
#menu .inner .setting ul li a {
  color: #FFF;
  text-decoration: none;
}
#menu .inner .setting ul li.text, #menu .inner .setting ul li.yomiage, #menu .inner .setting ul li.kana, #menu .inner .setting ul li.lang {
  padding-top: 5px;
}
@media print, screen and (min-width: 1200px) {
  #menu .inner .setting ul li.yomiage, #menu .inner .setting ul li.kana, #menu .inner .setting ul li.lang {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
#menu .inner .setting ul li.text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li.text {
    padding-left: 20px;
  }
}
#menu .inner .setting ul li.text .txtbtn {
  cursor: pointer;
}
@media print, screen and (min-width: 1200px) {
  #menu .inner .setting ul li.text .txtbtn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
#menu .inner .setting ul li.text .txtbtn span {
  display: block;
}
@media print, screen and (min-width: 1200px) {
  #menu .inner .setting ul li.text .txtbtn span {
    display: inline;
  }
}
#menu .inner .setting ul li.text .txt-inner {
  display: none;
}
#menu .inner .setting ul li.yomiage > span a,
#menu .inner .setting ul li.yomiage > span > span,
#menu .inner .setting ul li.yomiage > span a, #menu .inner .setting ul li.kana > span a,
#menu .inner .setting ul li.kana > span > span,
#menu .inner .setting ul li.kana > span a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media print, screen and (min-width: 1200px) {
  #menu .inner .setting ul li.yomiage > span a,
  #menu .inner .setting ul li.yomiage > span > span,
  #menu .inner .setting ul li.yomiage > span a, #menu .inner .setting ul li.kana > span a,
  #menu .inner .setting ul li.kana > span > span,
  #menu .inner .setting ul li.kana > span a {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li.lang {
    padding-right: 20px;
  }
}
#menu .inner .setting ul li.lang a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media print, screen and (min-width: 1200px) {
  #menu .inner .setting ul li.lang a {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
#menu .inner .setting ul li.search {
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li.search {
    background: #FFF;
    color: #1B4D42;
    padding: 5px 30px 10px 30px;
    cursor: pointer;
    width: auto;
  }
}
#menu .inner .setting ul li.search .searchbtn {
  display: none;
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li.search .searchbtn {
    display: block;
  }
}
#menu .inner .setting ul li.search .searchbtn span {
  display: block;
}
#menu .inner .setting ul li.search .searchbtn span.icon-search {
  padding-right: 0;
  text-align: center;
}
#menu .inner .setting ul li.search .searchbtn span.icon-search::before {
  font-size: 1.4rem;
}
#menu .inner .setting ul li.search .search-inner {
  display: block;
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li.search .search-inner {
    display: none;
  }
}
#menu .inner .setting ul li .txt-inner,
#menu .inner .setting ul li .search-inner {
  display: none;
  z-index: 4;
  width: 100%;
  /*&.none {
    transition-duration:1s;
    pointer-events: none;
    opacity:0;
  }*/
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li .txt-inner,
  #menu .inner .setting ul li .search-inner {
    bottom: inherit;
    background: rgba(255, 255, 255, 0.9);
    font-size: inherit;
    width: auto;
  }
}
#menu .inner .setting ul li .txt-inner .btn_close,
#menu .inner .setting ul li .search-inner .btn_close {
  text-align: right;
}
#menu .inner .setting ul li .txt-inner .btn_close div,
#menu .inner .setting ul li .search-inner .btn_close div {
  cursor: pointer;
  position: relative;
  color: #1B4D42;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 6px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 6px;
}
#menu .inner .setting ul li .txt-inner .btn_close div:hover,
#menu .inner .setting ul li .search-inner .btn_close div:hover {
  color: #FFF;
  background: #1B4D42;
}
#menu .inner .setting ul li .txt-inner .btn_close div span.icon-close,
#menu .inner .setting ul li .search-inner .btn_close div span.icon-close {
  font-size: 0.8rem;
  display: block;
}
#menu .inner .setting ul li .txt-inner .btn_close div span.icon-close::before,
#menu .inner .setting ul li .search-inner .btn_close div span.icon-close::before {
  content: "\e909";
}
#menu .inner .setting ul li .txt-inner {
  position: absolute;
  top: 80px;
  width: 100%;
  left: 0px;
  font-size: 0.65rem;
  padding: 20px 10px;
  border-radius: 30px;
  background: #EBFFF7;
  z-index: 100;
}
@media print, screen and (min-width: 1200px) {
  #menu .inner .setting ul li .txt-inner {
    font-size: 0.8rem;
  }
}
#menu .inner .setting ul li .txt-inner > div:first-child {
  margin-bottom: 10px;
  gap: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media print, screen and (min-width: 1200px) {
  #menu .inner .setting ul li .txt-inner > div:first-child {
    gap: 30px;
  }
}
#menu .inner .setting ul li .txt-inner > div:first-child dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 5px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: bold;
}
#menu .inner .setting ul li .txt-inner > div:first-child dl dt {
  color: #1B4D42;
  padding: 0.3rem;
}
#menu .inner .setting ul li .txt-inner > div:first-child dl dd {
  background: #FFF;
  color: #1B4D42;
  border: 1px solid #1B4D42;
  cursor: pointer;
}
#menu .inner .setting ul li .txt-inner > div:first-child dl dd span {
  padding: 5px;
  display: block;
}
#menu .inner .setting ul li .txt-inner > div:first-child dl dd.color_blue {
  color: #FFEE00;
  background: #2752FF;
}
#menu .inner .setting ul li .txt-inner > div:first-child dl dd.color_yellow {
  color: #000;
  background: #FFEE00;
}
#menu .inner .setting ul li .txt-inner > div:first-child dl dd.color_black {
  color: #FFEE00;
  background: #000;
}
#menu .inner .setting ul li .txt-inner > div:first-child dl dd:hover {
  opacity: 0.8;
}
#menu .inner .setting ul li .search-inner {
  width: 100%;
  right: 0;
  font-size: 0.8rem;
  padding: 10px 0px;
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li .search-inner {
    position: absolute;
    top: 80px;
    padding: 20px 10px;
    border-radius: 30px;
    background: #EBFFF7;
  }
}
#menu .inner .setting ul li .search-inner .btn_close {
  display: none;
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li .search-inner .btn_close {
    display: block;
  }
}
#menu .inner .setting ul li .search-inner form {
  margin-bottom: 5px;
}
#menu .inner .setting ul li .search-inner form fieldset {
  border: none;
  padding: 0px 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#menu .inner .setting ul li .search-inner form fieldset legend {
  display: contents;
  font-size: 0.7rem;
  color: #FFF;
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li .search-inner form fieldset legend {
    font-size: inherit;
    color: #1B4D42;
  }
}
#menu .inner .setting ul li .search-inner form fieldset legend span {
  display: block;
  padding: 0.5rem 0.5rem 0.5rem 0;
}
#menu .inner .setting ul li .search-inner form fieldset div:nth-child(2) {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#menu .inner .setting ul li .search-inner form fieldset div:nth-child(2) input[type=text] {
  border: 0px;
  padding: 10px 20px;
  width: 100%;
  border-radius: 0;
  background: #FFF;
  font-family: "BIZ UDPGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif";
}
#menu .inner .setting ul li .search-inner form fieldset div:nth-child(3) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#menu .inner .setting ul li .search-inner form fieldset div:nth-child(3) input[type=submit] {
  background: #1B4D42;
  color: #fff;
  padding: 10px;
  border: 0;
  width: 60px;
  letter-spacing: 0.2em;
  border-radius: 0;
  font-family: "BIZ UDPGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif";
}
@media print, screen and (min-width: 768px) {
  #menu .inner .setting ul li .search-inner form fieldset div:nth-child(3) input[type=submit] {
    width: 100px;
  }
}
#menu .inner .setting ul li .search-inner form fieldset div:nth-child(3) input[type=submit]:hover {
  opacity: 0.8;
}

.menu-trigger,
.menu-trigger:hover,
.menu-trigger:focus {
  cursor: pointer;
}

.close {
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .close {
    display: none;
  }
}
.close .menu-trigger2 {
  display: inline-block;
  font-size: 80%;
  padding: 10px 30px;
  color: #FFF !important;
  border: 1px solid #FFF;
  border-radius: 10px;
  margin-top: 1rem;
  text-align: center;
  text-decoration: none;
}

.header_search {
  margin: 0px;
  width: 100%;
  max-width: 100%;
}
.header_search input[type=text] {
  width: 100%;
  padding: 10px;
}
.header_search input::-webkit-input-placeholder {
  letter-spacing: 0.1em;
  font-size: 80%;
}
.header_search input::-moz-placeholder {
  letter-spacing: 0.1em;
  font-size: 80%;
}
.header_search input:-ms-input-placeholder {
  letter-spacing: 0.1em;
  font-size: 80%;
}
.header_search input::-ms-input-placeholder {
  letter-spacing: 0.1em;
  font-size: 80%;
}
.header_search input::placeholder {
  letter-spacing: 0.1em;
  font-size: 80%;
}

#page-top {
  width: 40px;
  height: 40px;
  position: fixed;
  right: 10px;
  bottom: -40px;
  border-radius: 50%;
  z-index: 100;
  display: inline-block;
}
@media print, screen and (min-width: 768px) {
  #page-top {
    width: 60px;
    height: 60px;
    right: 20px;
    bottom: -60px;
  }
}
#page-top:hover {
  opacity: 0.8;
}
#page-top a {
  position: relative;
  display: block;
  text-decoration: none;
  z-index: 100;
}
#page-top a img {
  width: 100%;
  height: auto;
}

#footer .bg {
  background: #1B4D42;
  color: #FFF;
  width: 100%;
  padding: 80px 0px 40px 0px;
}
@media print, screen and (min-width: 992px) {
  #footer .bg {
    padding: 180px 0px 40px 0px;
  }
}
#footer .bg > div:first-child {
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 50px;
}
@media print, screen and (min-width: 992px) {
  #footer .bg > div:first-child {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  #footer .bg > div:first-child {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 768px) {
  #footer .bg > div:first-child {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
#footer .bg > div:first-child > div.left .footer_logo img {
  width: 36px;
  height: auto;
  margin: 0px 0px 10px 10px;
}
@media print, screen and (min-width: 768px) {
  #footer .bg > div:first-child > div.left .footer_logo img {
    width: 72px;
  }
}
#footer .bg > div:first-child > div.left .footer_logo span {
  display: block;
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2rem;
}
@media print, screen and (min-width: 768px) {
  #footer .bg > div:first-child > div.left .footer_logo span {
    font-size: 2.3rem;
  }
}
#footer .bg > div:first-child > div.left .number {
  font-weight: bold;
  padding-bottom: 1.8rem;
  font-size: 0.8rem;
}
@media print, screen and (min-width: 768px) {
  #footer .bg > div:first-child > div.left .number {
    font-size: inherit;
  }
}
#footer .bg > div:first-child > div.left address {
  font-style: normal;
  font-size: 0.8rem;
  line-height: 2em;
}
@media print, screen and (min-width: 576px) {
  #footer .bg > div:first-child > div.left address {
    font-size: inherit;
  }
}
#footer .bg > div:first-child > div.right img {
  max-width: 100%;
  width: 400px;
  height: auto;
}
@media print, screen and (min-width: 992px) {
  #footer .bg > div:first-child > div.right img {
    width: 610px;
  }
}
#footer .bg div.population {
  width: auto;
  margin-top: 50px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
}
@media print, screen and (min-width: 992px) {
  #footer .bg div.population {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  #footer .bg div.population {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 768px) {
  #footer .bg div.population {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 20px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
#footer .bg div.population h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 5px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 5px;
}
@media print, screen and (min-width: 768px) {
  #footer .bg div.population h2 {
    margin-bottom: 0px;
  }
}
#footer .bg div.population h2 span {
  display: block;
  font-size: 1.2rem;
}
#footer .bg div.population h2 span.icon-population::before {
  color: #FFF;
  content: "\e916";
  font-size: 1.8rem;
  padding-right: 10px;
}
#footer .bg div.population h2 span:nth-of-type(3) {
  font-size: 0.8rem;
}
#footer .bg div.population ul {
  list-style-type: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#footer .bg div.population a {
  display: inline-block;
  background: #FFF;
  text-decoration: none;
  color: #1B4D42;
  padding: 3px 30px 3px 10px;
  font-weight: bold;
  position: relative;
  margin-top: 10px;
}
@media print, screen and (min-width: 768px) {
  #footer .bg div.population a {
    margin-top: 0;
  }
}
#footer .bg div.population a::after {
  position: absolute;
  content: "";
  top: 0.4rem;
  right: 5px;
  width: 6px;
  height: 6px;
  margin: 0.4rem 0.5rem 0 0.5rem;
  border-top: 2px solid #2BAA76;
  border-right: 2px solid #2BAA76;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
#footer .bg .footer_btn {
  width: auto;
  margin-top: 25px;
  margin-bottom: 30px;
  margin-left: 15px;
  margin-right: 15px;
}
@media print, screen and (min-width: 992px) {
  #footer .bg .footer_btn {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  #footer .bg .footer_btn {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 768px) {
  #footer .bg .footer_btn {
    width: auto;
    margin-top: 50px;
    margin-bottom: 60px;
    margin-left: 15px;
    margin-right: 15px;
  }
}
@media print, screen and (min-width: 768px) and (min-width: 992px) {
  #footer .bg .footer_btn {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 768px) and (min-width: 1200px) {
  #footer .bg .footer_btn {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
#footer .bg .footer_btn ul {
  list-style-type: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
  margin: 20px 0px;
}
@media print, screen and (min-width: 768px) {
  #footer .bg .footer_btn ul {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
#footer .bg .footer_btn ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  #footer .bg .footer_btn ul li {
    width: calc(33.3333333333% - 10px);
  }
}
#footer .bg .footer_btn ul li a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 10px 10px;
  text-decoration: none;
  color: #1B4D42;
  background: #FFF;
  content: "";
}
@media print, screen and (min-width: 768px) {
  #footer .bg .footer_btn ul li a {
    padding: 20px 30px 20px 10px;
  }
}
@media print, screen and (min-width: 992px) {
  #footer .bg .footer_btn ul li a {
    padding: 20px 10px;
  }
}
#footer .bg .footer_btn ul li a:hover {
  opacity: 0.8;
}
#footer .bg .footer_btn ul li a::after {
  position: absolute;
  content: "";
  top: 0.7rem;
  right: 15px;
  width: 6px;
  height: 6px;
  margin: 0.4rem 0.5rem 0 0.5rem;
  border-top: 2px solid #2BAA76;
  border-right: 2px solid #2BAA76;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media print, screen and (min-width: 768px) {
  #footer .bg .footer_btn ul li a::after {
    right: 10px;
    top: 1.5rem;
  }
}
@media print, screen and (min-width: 992px) {
  #footer .bg .footer_btn ul li a::after {
    right: 15px;
  }
}
#footer .bg .footer_btn ul li span.icon-car,
#footer .bg .footer_btn ul li span.icon-chosha,
#footer .bg .footer_btn ul li span.icon-mail {
  vertical-align: -15%;
  padding-right: 20px;
  font-size: 1.2rem;
}
@media print, screen and (min-width: 768px) {
  #footer .bg .footer_btn ul li span.icon-car,
  #footer .bg .footer_btn ul li span.icon-chosha,
  #footer .bg .footer_btn ul li span.icon-mail {
    font-size: 1.6rem;
  }
}
#footer .bg .footer_btn ul li span.icon-car:before {
  content: "\e912";
}
#footer .bg .footer_btn ul li span.icon-chosha:before {
  content: "\e911";
}
#footer .bg .footer_btn ul li span.icon-mail:before {
  content: "\e913";
}
#footer #footer_menu ul {
  list-style-type: none;
  font-size: 0.8rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 1.6rem 10px;
}
#footer #footer_menu ul li a {
  text-decoration: none;
  color: #333333;
  position: relative;
  padding: 3px 15px;
}
#footer #footer_menu ul li a:hover {
  color: #41806E;
}
#footer #footer_menu ul li a::before {
  position: absolute;
  content: "|";
  top: 1px;
  left: -4px;
  color: #D5D5D5;
}
#footer #footer_copy {
  padding: 0.5rem 0 1rem 0;
}
#footer #footer_copy p {
  text-align: center;
  font-size: 0.6rem;
}

#top_main {
  width: 100%;
  position: relative;
}

#top_header_image {
  position: relative;
  margin: 1rem 15px 2.5rem 15px;
}
@media print, screen and (min-width: 768px) {
  #top_header_image {
    margin: 1rem auto 2.5rem auto;
  }
}
@media print, screen and (min-width: 1200px) {
  #top_header_image {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 1rem;
    margin-bottom: 3rem;
  }
}
#top_header_image ul#slider {
  list-style-type: none;
  display: none;
}
#top_header_image ul#slider.slick-initialized {
  display: block;
}
#top_header_image ul#slider li img {
  width: 100%;
  height: auto;
}
#top_header_image ul#slider li a img:hover {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  -webkit-transition-duration: 0.5s;
          transition-duration: 0.5s;
}
#top_header_image ul#slider .slick-dots li button {
  background: #1B4D42;
}
#top_header_image ul#slider .slick-dots li button:hover, #top_header_image ul#slider .slick-dots li button:focus {
  background: #2BAA76;
}
#top_header_image ul#slider .slick-dots li button img {
  width: 100%;
  height: auto;
}
#top_header_image ul#slider .slick-dots li.slick-active button {
  background: #2BAA76;
}
#top_header_image ul#slider.slick-slider {
  margin-bottom: 0;
}
#top_header_image ul#slider.slick-initialized {
  height: auto;
  background-color: transparent;
}
#top_header_image ul#slider .slick-prev {
  width: 24px;
  height: 24px;
  left: 1%;
  bottom: 35%;
  z-index: 2;
  background-color: #1B4D42;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media print, screen and (min-width: 768px) {
  #top_header_image ul#slider .slick-prev {
    width: 44px;
    height: 44px;
    bottom: calc(50% - 44px);
  }
}
@media print, screen and (min-width: 1200px) {
  #top_header_image ul#slider .slick-prev {
    left: -5%;
  }
}
#top_header_image ul#slider .slick-prev::before {
  content: "\e907";
  vertical-align: -15%;
  font-size: 0.7rem;
  color: #FFF;
}
#top_header_image ul#slider .slick-next {
  width: 24px;
  height: 24px;
  right: 1%;
  bottom: 35%;
  z-index: 2;
  background-color: #1B4D42;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media print, screen and (min-width: 768px) {
  #top_header_image ul#slider .slick-next {
    width: 44px;
    height: 44px;
    bottom: calc(50% - 44px);
  }
}
@media print, screen and (min-width: 1200px) {
  #top_header_image ul#slider .slick-next {
    right: -5%;
  }
}
#top_header_image ul#slider .slick-next::before {
  content: "\e906";
  vertical-align: -15%;
  font-size: 0.7rem;
  color: #FFF;
}
#top_header_image ul#slider .slick-next:hover,
#top_header_image ul#slider .slick-next:focus,
#top_header_image ul#slider .slick-prev:hover,
#top_header_image ul#slider .slick-prev:focus {
  background-color: #2BAA76;
}
#top_header_image .btnPlay {
  position: absolute;
  width: 70px;
  height: 26px;
  background-image: url(../images/slide_btn_stop.png);
  background-repeat: no-repeat;
  background-color: transparent;
  background-size: cover;
  padding: 0;
  margin: 0;
  border: 0;
  font-size: 0%;
  line-height: 0;
  overflow: visible;
  cursor: pointer;
  right: 5px;
  bottom: -30px;
}
@media print, screen and (min-width: 992px) {
  #top_header_image .btnPlay {
    right: 20px;
  }
}

.top_emg {
  background: #FFF5F6;
  padding: 1.5rem 0px;
}
@media print, screen and (min-width: 768px) {
  .top_emg {
    padding: 2.8rem 0px;
  }
}
.top_emg > div {
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media print, screen and (min-width: 992px) {
  .top_emg > div {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  .top_emg > div {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 768px) {
  .top_emg > div {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    gap: 70px;
  }
}
.top_emg > div h2 {
  color: #C1272D;
  padding: 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1.1rem;
  letter-spacing: 0.2rem;
  width: 100%;
}
@media print, screen and (min-width: 576px) {
  .top_emg > div h2 {
    font-size: 1.2rem;
  }
}
@media print, screen and (min-width: 768px) {
  .top_emg > div h2 {
    font-size: 1.4rem;
    padding: 0;
    width: auto;
  }
}
@media print, screen and (min-width: 992px) {
  .top_emg > div h2 {
    font-size: 2rem;
    letter-spacing: 0.5rem;
  }
}
.top_emg > div h2 span {
  font-size: 1.6rem;
  padding-right: 10px;
}
@media print, screen and (min-width: 768px) {
  .top_emg > div h2 span {
    font-size: 2.4rem;
    padding-right: 16px;
  }
}
@media print, screen and (min-width: 992px) {
  .top_emg > div h2 span {
    font-size: 2.8rem;
  }
}
.top_emg > div h2 span.icon-emg:before {
  content: "\e90c";
}
.top_emg > div ul {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  list-style-type: none;
}
.top_emg > div ul li {
  position: relative;
  padding-left: 30px;
  padding-top: 1rem;
}
@media print, screen and (min-width: 992px) {
  .top_emg > div ul li {
    /*display:flex;
    gap:20px;*/
    padding-left: 35px;
  }
}
.top_emg > div ul li::before {
  position: absolute;
  content: "";
  top: 1rem;
  left: 0px;
  width: 6px;
  height: 6px;
  margin: 0.4rem 0.5rem 0 0.5rem;
  border-top: 2px solid #C1272D;
  border-right: 2px solid #C1272D;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media print, screen and (min-width: 992px) {
  .top_emg > div ul li::before {
    top: 1.2rem;
  }
}
.top_emg > div ul li .kinkyu_title {
  color: #C1272D;
  font-weight: bold;
}
.top_emg > div ul li .kinkyu_text {
  font-weight: normal;
}
.top_emg > div ul li a {
  display: block;
  color: #C1272D;
  font-weight: bold;
  letter-spacing: 0.1em;
}

.top_search {
  background: #41806E;
  padding: 0.5rem 0px;
}
@media print, screen and (min-width: 576px) {
  .top_search {
    padding: 1.5rem 0px;
  }
}
@media print, screen and (min-width: 768px) {
  .top_search {
    padding: 2.8rem 0px;
  }
}
.top_search > div {
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
}
@media print, screen and (min-width: 992px) {
  .top_search > div {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  .top_search > div {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
.top_search > div form {
  width: 100%;
}
.top_search > div form fieldset {
  border: none;
  padding: 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media print, screen and (min-width: 768px) {
  .top_search > div form fieldset {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
.top_search > div form fieldset legend {
  display: contents;
  font-size: 0.7rem;
  color: #FFF;
  font-weight: bold;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .top_search > div form fieldset legend {
    font-size: inherit;
    letter-spacing: 0.2rem;
  }
}
.top_search > div form fieldset legend span {
  display: block;
  padding: 0.7rem 0.5rem 0.7rem 0;
}
@media print, screen and (min-width: 768px) {
  .top_search > div form fieldset legend span {
    padding: 0.7rem 1rem 0.7rem 0;
  }
}
.top_search > div form fieldset > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .top_search > div form fieldset > div {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
.top_search > div form fieldset > div div:nth-child(1) {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.top_search > div form fieldset > div div:nth-child(1) input[type=text] {
  border: 0px;
  padding: 10px 5px;
  width: 100%;
  border-radius: 0;
  background: #FFF;
  font-family: "BIZ UDPGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif";
  font-size: 0.8rem;
}
@media print, screen and (min-width: 768px) {
  .top_search > div form fieldset > div div:nth-child(1) input[type=text] {
    padding: 16px 20px;
    font-size: 1rem;
    letter-spacing: 0.1rem;
  }
}
.top_search > div form fieldset > div div:nth-child(2) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.top_search > div form fieldset > div div:nth-child(2) input[type=submit] {
  background: #1B4D42;
  color: #fff;
  padding: 10px;
  border: 0;
  width: 50px;
  border-radius: 0;
  font-family: "BIZ UDPGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif";
  font-weight: bold;
  font-size: 0.9rem;
  letter-spacing: 0.1em;
}
@media print, screen and (min-width: 768px) {
  .top_search > div form fieldset > div div:nth-child(2) input[type=submit] {
    width: 120px;
    font-size: 1.2rem;
    letter-spacing: 0.2em;
  }
}
.top_search > div form fieldset > div div:nth-child(2) input[type=submit]:hover {
  opacity: 0.8;
}
.top_search > div dl {
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .top_search > div dl {
    margin-top: 1.8rem;
    padding-top: 1.5rem;
  }
}
@media print, screen and (min-width: 992px) {
  .top_search > div dl {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    gap: 30px;
  }
}
.top_search > div dl dt, .top_search > div dl dd {
  width: 100%;
}
@media print, screen and (min-width: 992px) {
  .top_search > div dl dt, .top_search > div dl dd {
    width: auto;
  }
}
.top_search > div dl dt {
  color: #FFF;
  font-weight: bold;
  padding: 0 0 0.5rem 0px;
}
@media print, screen and (min-width: 992px) {
  .top_search > div dl dt {
    padding: 0 10px 0 0;
  }
}
.top_search > div dl dd a {
  color: #FFF;
  display: block;
  position: relative;
  padding: 0.4rem 0 0.4rem 30px;
}
@media print, screen and (min-width: 992px) {
  .top_search > div dl dd a {
    padding: 0 0 0 30px;
  }
}
.top_search > div dl dd a::before {
  position: absolute;
  content: "";
  top: 0.5rem;
  left: 0px;
  width: 6px;
  height: 6px;
  margin: 0.4rem 0.5rem 0 0.5rem;
  border-top: 2px solid #2BAA76;
  border-right: 2px solid #2BAA76;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media print, screen and (min-width: 992px) {
  .top_search > div dl dd a::before {
    top: 0.2rem;
  }
}

.top_news {
  background: #F4F6F8;
  padding-bottom: 3rem;
}
.top_news > h2 {
  color: #1B4D42;
  padding: 30px 0px 20px 0px;
  font-size: 1.2rem;
  letter-spacing: 0.2rem;
  text-align: center;
}
@media print, screen and (min-width: 576px) {
  .top_news > h2 {
    font-size: 1.4rem;
    letter-spacing: 0.3rem;
  }
}
@media print, screen and (min-width: 768px) {
  .top_news > h2 {
    font-size: 1.6rem;
  }
}
@media print, screen and (min-width: 992px) {
  .top_news > h2 {
    font-size: 2rem;
    letter-spacing: 0.5rem;
    padding: 3rem 0 2.5rem 0;
  }
}
.top_news > h2 span {
  position: relative;
  display: inline-block;
}
.top_news > h2 span::before, .top_news > h2 span::after {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  background: #2BAA76;
  border-radius: 50%;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media print, screen and (min-width: 768px) {
  .top_news > h2 span::before, .top_news > h2 span::after {
    width: 15px;
    height: 15px;
  }
}
.top_news > h2 span::before {
  left: -30px;
}
@media print, screen and (min-width: 768px) {
  .top_news > h2 span::before {
    left: -50px;
  }
}
.top_news > h2 span::after {
  right: -25px;
}
@media print, screen and (min-width: 768px) {
  .top_news > h2 span::after {
    right: -45px;
  }
}
.top_news > div {
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px;
}
@media print, screen and (min-width: 992px) {
  .top_news > div {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  .top_news > div {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 768px) {
  .top_news > div {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
@media print, screen and (min-width: 992px) {
  .top_news > div {
    gap: 30px;
  }
}
.top_news > div ul li {
  list-style-type: none;
}
.top_news > div > div {
  background: #FFF;
  width: 100%;
}
.top_news > div > div.topics {
  padding: 10px 20px 30px 20px;
}
@media print, screen and (min-width: 768px) {
  .top_news > div > div.topics {
    width: 30%;
  }
}
.top_news > div > div.topics h3 {
  color: #1B4D42;
  font-size: 1.1rem;
  padding: 0.5rem 0 1rem 0;
}
@media print, screen and (min-width: 768px) {
  .top_news > div > div.topics h3 {
    font-size: 1.3rem;
  }
}
@media print, screen and (min-width: 992px) {
  .top_news > div > div.topics h3 {
    font-size: 1.4rem;
  }
}
.top_news > div > div.topics ul li {
  list-style-type: none;
  padding: 0.4rem 0.6rem 0.4rem 1.3rem;
  position: relative;
}
@media print, screen and (min-width: 768px) {
  .top_news > div > div.topics ul li {
    padding: 0.6rem 0.6rem 0.6rem 2rem;
  }
}
.top_news > div > div.topics ul li:last-child {
  padding-bottom: 0px;
}
.top_news > div > div.topics ul li::before {
  position: absolute;
  content: "";
  top: 0.4rem;
  left: -10px;
  width: 6px;
  height: 6px;
  margin: 0.4rem 0.5rem 0 0.5rem;
  border-top: 2px solid #2BAA76;
  border-right: 2px solid #2BAA76;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media print, screen and (min-width: 768px) {
  .top_news > div > div.topics ul li::before {
    top: 0.7rem;
    left: 0;
  }
}
@media print, screen and (min-width: 768px) {
  .top_news > div > div.news {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
.top_news > div > div.news .tabs ul.horizontal {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.top_news > div > div.news .tabs ul.horizontal li {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-right: 1px solid #FFF;
}
.top_news > div > div.news .tabs ul.horizontal li a {
  width: 100%;
  display: block;
  padding: 1rem 5px;
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: #41806E;
  color: #FFF;
  font-weight: bold;
  font-size: 1rem;
}
@media print, screen and (min-width: 768px) {
  .top_news > div > div.news .tabs ul.horizontal li a {
    padding: 1rem 5px;
    font-size: 1.3rem;
  }
}
@media print, screen and (min-width: 992px) {
  .top_news > div > div.news .tabs ul.horizontal li a {
    padding: 1.5rem 5px;
    font-size: 1.3rem;
  }
}
.top_news > div > div.news .tabs ul.horizontal li a:hover {
  background: #1B4D42;
}
.top_news > div > div.news .tabs ul.horizontal li.active a {
  background: #FFF;
  color: #1B4D42;
}
.top_news > div > div.news .tabs ul.horizontal li:last-child {
  border-right: 0;
}
.top_news > div > div.news .tabs > div .link {
  padding: 20px;
}
@media print, screen and (min-width: 992px) {
  .top_news > div > div.news .tabs > div .link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 10px;
  }
}
.top_news > div > div.news .tabs > div .link .btn {
  margin-bottom: 10px;
  width: 100%;
}
@media print, screen and (min-width: 992px) {
  .top_news > div > div.news .tabs > div .link .btn {
    margin-bottom: 0px;
  }
}
.top_news > div > div.news .tabs > div .link .btn a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
  text-decoration: none;
  color: #1B4D42;
  border: 1px solid #1B4D42;
  padding: 0.6rem 2rem;
}
.top_news > div > div.news .tabs > div .link .btn a span.icon-ichiran {
  vertical-align: -15%;
  font-size: 1.4rem;
}
.top_news > div > div.news .tabs > div .link .btn a span.icon-ichiran::before {
  content: "\e901";
}
.top_news > div > div.news .tabs > div .link .btn a span.icon-calendar {
  vertical-align: -15%;
  font-size: 1.4rem;
}
.top_news > div > div.news .tabs > div .link .btn a span.icon-calendar::before {
  content: "\e914";
}
.top_news > div > div.news .tabs > div .link .btn a span.icon-rss {
  vertical-align: -15%;
  font-size: 1.4rem;
}
.top_news > div > div.news .tabs > div .link .btn a span.icon-rss::before {
  content: "\e900";
}
.top_news > div > div.news .tabs > div .link .btn a:hover {
  opacity: 0.8;
}
.top_news > div > div.news .tabs > div#top_news ul {
  padding: 0.8rem 1rem 1.4rem 1rem;
}
@media print, screen and (min-width: 768px) {
  .top_news > div > div.news .tabs > div#top_news ul {
    padding: 0.8rem 1rem 1.4rem 2rem;
  }
}
.top_news > div > div.news .tabs > div#top_news ul li {
  padding: 0.6rem 0.6rem 0.6rem 2rem;
  padding-left: 0;
}
@media print, screen and (min-width: 992px) {
  .top_news > div > div.news .tabs > div#top_news ul li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
.top_news > div > div.news .tabs > div#top_news ul li > div {
  -ms-flex-preferred-size: 35%;
      flex-basis: 35%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 14px;
  font-size: 0.8rem;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding-bottom: 0.3rem;
}
@media print, screen and (min-width: 1200px) {
  .top_news > div > div.news .tabs > div#top_news ul li > div {
    -ms-flex-preferred-size: 32%;
        flex-basis: 32%;
  }
}
.top_news > div > div.news .tabs > div#top_news ul li > div span {
  padding: 0.1rem;
}
.top_news > div > div.news .tabs > div#top_news ul li > div span[class^=news-] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 80px;
  font-weight: bold;
  color: #FFF;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.top_news > div > div.news .tabs > div#top_news ul li > div span.news- {
  background: #C00000;
}
.top_news > div > div.news .tabs > div#top_news ul li > div span.news-oshirase {
  background: #9C4F57;
}
.top_news > div > div.news .tabs > div#top_news ul li > div span.news-event {
  background: #685b8d;
}
.top_news > div > div.news .tabs > div#top_news ul li > div span.news-bosyu {
  background: #C44A0F;
}
.top_news > div > div.news .tabs > div#top_news ul li > div span.news-sonota {
  background: #35739C;
}
.top_news > div > div.news .tabs > div#top_news ul li a {
  display: block;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.top_news > div > div.news .tabs > div#top_news ul li::before {
  content: none;
}
.top_news > div > div.news .tabs > div#top_event > div {
  padding: 20px;
}
.top_news > div > div.news .tabs > div#top_event > div h3 {
  color: #1B4D42;
  font-size: 1rem;
  padding-bottom: 0.8em;
}
@media print, screen and (min-width: 992px) {
  .top_news > div > div.news .tabs > div#top_event > div h3 {
    font-size: 1.2rem;
  }
}
.top_news > div > div.news .tabs > div#top_event > div ul {
  margin-bottom: 1rem;
}
.top_news > div > div.news .tabs > div#top_event > div ul li {
  list-style-type: none;
  padding: 0.4rem 0.6rem 0.4rem 1.3rem;
  position: relative;
}
@media print, screen and (min-width: 768px) {
  .top_news > div > div.news .tabs > div#top_event > div ul li {
    padding: 0.6rem 0.6rem 0.6rem 2rem;
  }
}
.top_news > div > div.news .tabs > div#top_event > div ul li:last-child {
  padding-bottom: 0px;
}
.top_news > div > div.news .tabs > div#top_event > div ul li::before {
  position: absolute;
  content: "";
  top: 0.4rem;
  left: -10px;
  width: 6px;
  height: 6px;
  margin: 0.4rem 0.5rem 0 0.5rem;
  border-top: 2px solid #2BAA76;
  border-right: 2px solid #2BAA76;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media print, screen and (min-width: 768px) {
  .top_news > div > div.news .tabs > div#top_event > div ul li::before {
    top: 0.7rem;
    left: 0;
  }
}
.top_news > div > div.news .tabs > div#top_event > div p {
  text-align: center;
  padding: 1rem 0;
}
.top_news .top_sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 2rem 0;
  gap: 0;
  width: auto;
  margin-top: 2rem;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
}
@media print, screen and (min-width: 992px) {
  .top_news .top_sns {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  .top_news .top_sns {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 992px) {
  .top_news .top_sns {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
.top_news .top_sns h2 {
  background: #1B4D42;
  color: #FFF;
  font-size: 1rem;
  padding: 10px;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
@media print, screen and (min-width: 992px) {
  .top_news .top_sns h2 {
    -ms-flex-preferred-size: 20%;
        flex-basis: 20%;
    font-size: 1.2rem;
  }
}
.top_news .top_sns h2::after {
  position: absolute;
  content: "";
  bottom: -10px;
  right: calc(45% - 7px);
  -webkit-transform: translateX(calc(-45% + 7px));
          transform: translateX(calc(-45% + 7px));
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 15px 15px 0 15px;
  border-color: #1B4D42 transparent transparent transparent;
}
@media print, screen and (min-width: 992px) {
  .top_news .top_sns h2::after {
    position: absolute;
    content: "";
    right: -10px;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 15px 0 15px 15px;
    border-color: transparent transparent transparent #1B4D42;
  }
}
.top_news .top_sns h2 br {
  display: none;
}
@media print, screen and (min-width: 992px) {
  .top_news .top_sns h2 br {
    display: block;
  }
}
.top_news .top_sns > div {
  background: #FFF;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding: 20px;
}
.top_news .top_sns > div ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
  margin: 0;
}
@media print, screen and (min-width: 768px) {
  .top_news .top_sns > div ul {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    gap: 20px;
  }
}
.top_news .top_sns > div ul li {
  width: 100%;
}
.top_news .top_sns > div ul li a {
  color: #FFF;
  text-decoration: none;
  display: block;
  font-weight: bold;
  padding: 15px 20px 15px 50px;
  text-align: center;
  position: relative;
}
@media print, screen and (min-width: 768px) {
  .top_news .top_sns > div ul li a {
    padding: 20px 20px 20px 50px;
  }
}
.top_news .top_sns > div ul li a.line {
  background: #06C755;
}
.top_news .top_sns > div ul li a.fb {
  background: #3B5997;
}
.top_news .top_sns > div ul li a.tw {
  background: #000000;
}
.top_news .top_sns > div ul li a span {
  position: absolute;
  display: block;
  left: 15px;
  top: 0.8rem;
}
@media print, screen and (min-width: 992px) {
  .top_news .top_sns > div ul li a span {
    top: 1.1rem;
    left: 30px;
  }
}
.top_news .top_sns > div ul li a span::before {
  position: absolute;
  color: #FFF;
  font-size: 2rem;
}
.top_news .top_sns > div ul li a span.icon-line::before {
  content: "\e90f";
}
.top_news .top_sns > div ul li a span.icon-fb::before {
  content: "\e90d";
}
.top_news .top_sns > div ul li a span.icon-tw::before {
  content: "\e917";
  font-size: 1.6rem;
}

#top_ban,
#top_ban2 {
  overflow: hidden;
  padding: 0 0 2.5rem 0;
}
#top_ban > h2,
#top_ban2 > h2 {
  color: #1B4D42;
  padding: 30px 0px 20px 0px;
  font-size: 1.2rem;
  letter-spacing: 0.2rem;
  text-align: center;
}
@media print, screen and (min-width: 576px) {
  #top_ban > h2,
  #top_ban2 > h2 {
    font-size: 1.4rem;
    letter-spacing: 0.3rem;
  }
}
@media print, screen and (min-width: 768px) {
  #top_ban > h2,
  #top_ban2 > h2 {
    font-size: 1.6rem;
  }
}
@media print, screen and (min-width: 992px) {
  #top_ban > h2,
  #top_ban2 > h2 {
    font-size: 2rem;
    letter-spacing: 0.5rem;
    padding: 3rem 0 2.5rem 0;
  }
}
#top_ban > h2 span,
#top_ban2 > h2 span {
  position: relative;
  display: inline-block;
}
#top_ban > h2 span::before, #top_ban > h2 span::after,
#top_ban2 > h2 span::before,
#top_ban2 > h2 span::after {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  background: #2BAA76;
  border-radius: 50%;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media print, screen and (min-width: 768px) {
  #top_ban > h2 span::before, #top_ban > h2 span::after,
  #top_ban2 > h2 span::before,
  #top_ban2 > h2 span::after {
    width: 15px;
    height: 15px;
  }
}
#top_ban > h2 span::before,
#top_ban2 > h2 span::before {
  left: -30px;
}
@media print, screen and (min-width: 768px) {
  #top_ban > h2 span::before,
  #top_ban2 > h2 span::before {
    left: -50px;
  }
}
#top_ban > h2 span::after,
#top_ban2 > h2 span::after {
  right: -25px;
}
@media print, screen and (min-width: 768px) {
  #top_ban > h2 span::after,
  #top_ban2 > h2 span::after {
    right: -45px;
  }
}
#top_ban > div,
#top_ban2 > div {
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
  position: relative;
}
@media print, screen and (min-width: 992px) {
  #top_ban > div,
  #top_ban2 > div {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  #top_ban > div,
  #top_ban2 > div {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
#top_ban > div.slick-initialized,
#top_ban2 > div.slick-initialized {
  height: auto;
  background-color: transparent;
}
#top_ban > div ul,
#top_ban2 > div ul {
  /*width:100%;
  list-style:none;
  margin:0 0 40px;
  z-index:1;*/
}
#top_ban > div ul .slick-slide,
#top_ban2 > div ul .slick-slide {
  padding: 0px;
  margin: 0px 30px;
}
@media print, screen and (min-width: 768px) {
  #top_ban > div ul .slick-slide,
  #top_ban2 > div ul .slick-slide {
    margin: 0px 10px;
  }
}
#top_ban > div ul .slick-slide img,
#top_ban2 > div ul .slick-slide img {
  width: 100%;
  height: auto;
  margin-left: auto;
  margin-right: auto;
}
#top_ban > div ul .slick-slide a,
#top_ban2 > div ul .slick-slide a {
  text-decoration: none;
}
#top_ban > div ul .slick-slide p,
#top_ban2 > div ul .slick-slide p {
  padding: 8px;
}
#top_ban > div .slick-prev, #top_ban > div .slick-next,
#top_ban2 > div .slick-prev,
#top_ban2 > div .slick-next {
  width: 24px;
  height: 24px;
  bottom: calc(50% - 44px);
  z-index: 2;
  background-color: #1B4D42;
  border-radius: 30px;
}
@media print, screen and (min-width: 768px) {
  #top_ban > div .slick-prev, #top_ban > div .slick-next,
  #top_ban2 > div .slick-prev,
  #top_ban2 > div .slick-next {
    width: 44px;
    height: 44px;
  }
}
#top_ban > div .slick-prev::before, #top_ban > div .slick-next::before,
#top_ban2 > div .slick-prev::before,
#top_ban2 > div .slick-next::before {
  vertical-align: -15%;
  font-size: 0.6rem;
  color: #FFF;
}
#top_ban > div .slick-prev:hover, #top_ban > div .slick-next:hover,
#top_ban2 > div .slick-prev:hover,
#top_ban2 > div .slick-next:hover {
  background-color: #EBFFF7;
}
#top_ban > div .slick-prev,
#top_ban2 > div .slick-prev {
  left: -5px;
}
@media print, screen and (min-width: 768px) {
  #top_ban > div .slick-prev,
  #top_ban2 > div .slick-prev {
    left: -50px;
  }
}
#top_ban > div .slick-prev::before,
#top_ban2 > div .slick-prev::before {
  content: "\e907";
}
#top_ban > div .slick-next,
#top_ban2 > div .slick-next {
  right: -5px;
}
@media print, screen and (min-width: 768px) {
  #top_ban > div .slick-next,
  #top_ban2 > div .slick-next {
    right: -50px;
  }
}
#top_ban > div .slick-next::before,
#top_ban2 > div .slick-next::before {
  content: "\e906";
}
#top_ban > div .slick-next:hover,
#top_ban > div .slick-next:focus,
#top_ban > div .slick-prev:hover,
#top_ban > div .slick-prev:focus,
#top_ban2 > div .slick-next:hover,
#top_ban2 > div .slick-next:focus,
#top_ban2 > div .slick-prev:hover,
#top_ban2 > div .slick-prev:focus {
  background-color: #2BAA76;
}
#top_ban > div .slick-dots,
#top_ban2 > div .slick-dots {
  bottom: -40px;
}
#top_ban > div .slick-dots li button,
#top_ban2 > div .slick-dots li button {
  background: #1B4D42;
}
#top_ban > div .slick-dots li button:hover,
#top_ban > div .slick-dots li button:focus,
#top_ban > div .slick-dots li.slick-active button,
#top_ban2 > div .slick-dots li button:hover,
#top_ban2 > div .slick-dots li button:focus,
#top_ban2 > div .slick-dots li.slick-active button {
  background: #2BAA76;
}
#top_ban .btnPlay_ban,
#top_ban .btnPlay_ban2,
#top_ban2 .btnPlay_ban,
#top_ban2 .btnPlay_ban2 {
  position: absolute;
  width: 70px;
  height: 26px;
  background-image: url(../images/slide_btn_stop.png);
  background-repeat: no-repeat;
  background-color: transparent;
  background-size: 70px 26px;
  padding: 0;
  margin: 0;
  border: 0;
  font-size: 0%;
  line-height: 0;
  overflow: visible;
  cursor: pointer;
  right: 5px;
  bottom: -40px;
  z-index: 1;
}

/*
#top_ban-old {
  padding:1.5rem 0;
  > h2 {
    color:$main-color;
    padding:30px 0px 20px 0px;
    font-size:1.2rem;
    letter-spacing:0.2rem;
    text-align:center;
    @include media-breakpoint-up(sm){
      font-size:1.4rem;
      letter-spacing:0.3rem;
    }
    @include media-breakpoint-up(md){
      font-size:1.6rem;
    }
    @include media-breakpoint-up(lg){
      font-size:2.0rem;
      letter-spacing:0.5rem;
      padding:3.0rem 0 2.5rem 0;
    }
    span {
      position:relative;
      display:inline-block;
      &::before,
      &::after {
        position:absolute;
        content:"";
        width:10px;
        height:10px;
        background:$sub-color2;
        border-radius:50%;
        top:50%;
        transform: translateY(-50%);
        @include media-breakpoint-up(md){
          width:15px;
          height:15px;
        }
      }
      &::before {
        left:-30px;        
        @include media-breakpoint-up(md){
          left:-50px; 
        }
      }      
      &::after {
        right:-25px; 
        @include media-breakpoint-up(md){
          right:-45px;
        }
      }
    }
  }  
  > div {
    @include contentarea;
    position:relative;
    ul {
      &.slick-initialized {
        height:auto;
        background-color:transparent;
        list-style-type:none;
        display:flex;
        flex-wrap:wrap;
        gap:16px;
        li {
          &.slick-slide {
            padding:0px;
            margin:0px 10px;
            img {
              width:100%;
              height:auto;
              margin-left:auto;
              margin-right:auto;
            }
            a {
              text-decoration:none;
            }
            p {
              padding:8px;
            }
          }
          img {
            width:100%;
            height:auto;
          }
        }
      }
    }
    .slick-prev,.slick-next {
      width: 24px;
      height: 24px;
      bottom: calc(50% - 44px);
      z-index: 2;
      background-color: $main-color;
      border-radius:30px;
      @include media-breakpoint-up(md) {
        width: 44px;
        height: 44px;
      }
      &::before {
        vertical-align: -15%;
        font-size: 0.6rem;
        color: $white;      
      }
      &:hover {
        background-color: $main-light-color;
      }
    }
    .slick-prev {
      left:-5px;      
      @include media-breakpoint-up(md) {
        left:-50px;
      }
      &::before {
          content: "\e907";
      }
    } 
    .slick-next {
      right:-5px;
      @include media-breakpoint-up(md) {
        right:-50px;
      }
      &::before {
        content: "\e906";
    }
    }
    .slick-next:hover,
    .slick-next:focus,
    .slick-prev:hover,
    .slick-prev:focus{
      background-color:$sub-color2;
    }
   .slick-dots {
    bottom:-40px;
      li button {
        background:$main-color;
      }  
      li button:hover,
      li button:focus,
      li.slick-active button {
        background:$sub-color2;
      }
   }  
   .btnPlay_ban {
    position: absolute;
    width: 70px;
    height: 26px;
    background-image: url(../images/slide_btn_stop.png);
    background-repeat: no-repeat;
    background-color: transparent;
    background-size: 70px 26px;
    padding: 0;
    margin: 0;
    border: 0;
    font-size: 0%;
    line-height: 0;
    overflow: visible;
    cursor: pointer;
    right: 5px;
    bottom: -40px;
  }
  }
}*/
.top_life {
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
}
@media print, screen and (min-width: 992px) {
  .top_life {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  .top_life {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
.top_life > h2 {
  color: #1B4D42;
  padding: 30px 0px 20px 0px;
  font-size: 1.2rem;
  letter-spacing: 0.2rem;
  text-align: center;
}
@media print, screen and (min-width: 576px) {
  .top_life > h2 {
    font-size: 1.4rem;
    letter-spacing: 0.3rem;
  }
}
@media print, screen and (min-width: 768px) {
  .top_life > h2 {
    font-size: 1.6rem;
  }
}
@media print, screen and (min-width: 992px) {
  .top_life > h2 {
    font-size: 2rem;
    letter-spacing: 0.5rem;
    padding: 4rem 0 2.5rem 0;
  }
}
.top_life > h2 > span {
  display: block;
}
.top_life > h2 > span span {
  position: relative;
  display: inline-block;
}
.top_life > h2 > span span::before, .top_life > h2 > span span::after {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  background: #2BAA76;
  border-radius: 50%;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media print, screen and (min-width: 768px) {
  .top_life > h2 > span span::before, .top_life > h2 > span span::after {
    width: 15px;
    height: 15px;
  }
}
.top_life > h2 > span span::before {
  left: -30px;
}
@media print, screen and (min-width: 768px) {
  .top_life > h2 > span span::before {
    left: -50px;
  }
}
.top_life > h2 > span span::after {
  right: -25px;
}
@media print, screen and (min-width: 768px) {
  .top_life > h2 > span span::after {
    right: -45px;
  }
}
.top_life > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: 1.5rem;
}
@media print, screen and (min-width: 992px) {
  .top_life > div {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
.top_life > div h3 {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  color: #FFF;
  font-size: 1rem;
  padding: 0px;
}
@media print, screen and (min-width: 768px) {
  .top_life > div h3 {
    font-size: 1.2rem;
  }
}
@media print, screen and (min-width: 992px) {
  .top_life > div h3 {
    -ms-flex-preferred-size: 20%;
        flex-basis: 20%;
    padding: 95px 0px 0px 0px;
  }
}
.top_life > div h3::after {
  position: absolute;
  content: "";
  right: calc(45% - 7px);
  bottom: -10px;
  -webkit-transform: translateX(calc(-45% + 7px));
          transform: translateX(calc(-45% + 7px));
  width: 0;
  height: 0;
  border-style: solid;
}
@media print, screen and (min-width: 992px) {
  .top_life > div h3::after {
    right: -10px;
    top: calc(50% - 8px);
  }
}
.top_life > div h3 span.illust {
  display: block;
  position: relative;
  width: 100%;
}
.top_life > div h3 span.illust::before {
  position: absolute;
  width: 71px;
  height: 65px;
}
@media print, screen and (min-width: 992px) {
  .top_life > div h3 span.illust::before {
    width: 142px;
    height: 130px;
  }
}
.top_life > div h3 span.txt {
  display: block;
  padding: 20px 0;
}
.top_life > div div {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding: 20px 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media print, screen and (min-width: 992px) {
  .top_life > div div {
    padding: 20px;
  }
}
.top_life > div div ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
  width: 100%;
}
.top_life > div div ul li {
  list-style-type: none;
  width: calc(50% - 8px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media print, screen and (min-width: 768px) {
  .top_life > div div ul li {
    width: calc(25% - 8px);
  }
}
.top_life > div div ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: #FFF;
  color: #1B4D42;
  text-decoration: none;
  width: 100%;
  padding: 1rem 10px;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .top_life > div div ul li a {
    padding: 1.5rem 10px;
  }
}
.top_life > div.pickup h3 {
  background: #41806E;
}
.top_life > div.pickup h3::after {
  border-width: 15px 15px 0 15px;
  border-color: #41806E transparent transparent transparent;
}
@media print, screen and (min-width: 992px) {
  .top_life > div.pickup h3::after {
    border-width: 15px 0 15px 15px;
    border-color: transparent transparent transparent #41806E;
  }
}
.top_life > div.pickup h3 span.illust::before {
  content: "";
  background-image: url("../images/illust_pickup.png");
  background-size: cover;
  top: -10px;
  left: -80px;
}
@media print, screen and (min-width: 992px) {
  .top_life > div.pickup h3 span.illust::before {
    top: -120px;
    left: -16px;
  }
}
.top_life > div.pickup > div {
  background: #DFEEE9;
}
.top_life > div.dekigoto h3 {
  background: #3E669B;
}
.top_life > div.dekigoto h3::after {
  border-width: 15px 15px 0 15px;
  border-color: #3E669B transparent transparent transparent;
}
@media print, screen and (min-width: 992px) {
  .top_life > div.dekigoto h3::after {
    border-width: 15px 0 15px 15px;
    border-color: transparent transparent transparent #3E669B;
  }
}
.top_life > div.dekigoto h3 span.illust::before {
  content: "";
  background-image: url("../images/illust_dekigoto.png");
  background-size: cover;
  top: 0px;
  left: -80px;
}
@media print, screen and (min-width: 992px) {
  .top_life > div.dekigoto h3 span.illust::before {
    top: -105px;
    left: 0px;
  }
}
.top_life > div.dekigoto > div {
  background: #D1DFF1;
}
.top_life > div.moshimo h3 {
  background: #874E44;
}
.top_life > div.moshimo h3::after {
  border-width: 15px 15px 0 15px;
  border-color: #874E44 transparent transparent transparent;
}
@media print, screen and (min-width: 992px) {
  .top_life > div.moshimo h3::after {
    border-width: 15px 0 15px 15px;
    border-color: transparent transparent transparent #874E44;
  }
}
.top_life > div.moshimo h3 span.illust::before {
  content: "";
  background-image: url("../images/illust_moshimo.png");
  background-size: cover;
  top: 0px;
  left: -80px;
}
@media print, screen and (min-width: 992px) {
  .top_life > div.moshimo h3 span.illust::before {
    top: -100px;
    left: 0px;
  }
}
.top_life > div.moshimo > div {
  background: #E2D9D8;
}

/*
#top_ban2 {
  padding:0 0 1.5rem 0;
  > h2 {
    color:$main-color;
    padding:30px 0px 20px 0px;
    font-size:1.2rem;
    letter-spacing:0.2rem;
    text-align:center;
    @include media-breakpoint-up(sm){     
      font-size:1.4rem;
      letter-spacing:0.3rem;
    }
    @include media-breakpoint-up(md){
      font-size:1.6rem;
    }
    @include media-breakpoint-up(lg){
      font-size:2.0rem;
      letter-spacing:0.5rem;
      padding:3.0rem 0 2.5rem 0;
    }
    span {
      position:relative;
      display:inline-block;
      &::before,
      &::after {
        position:absolute;
        content:"";
        width:10px;
        height:10px;
        background:$sub-color2;
        border-radius:50%;
        top:50%;
        transform: translateY(-50%);
        @include media-breakpoint-up(md){
          width:15px;
          height:15px;
        }
      }
      &::before {
        left:-30px;        
        @include media-breakpoint-up(md){
          left:-50px; 
        }
      }      
      &::after {
        right:-25px; 
        @include media-breakpoint-up(md){
          right:-45px;
        }
      }
    }
  }  
  > div {
    @include contentarea;
    position:relative;
    ul {
      &.slick-initialized {
        height:auto;
        background-color:transparent;
        list-style-type:none;
        display:flex;
        flex-wrap:wrap;
        gap:16px;
        li {
          &.slick-slide {
            padding:0px;
            margin:0px 10px;
            img {
              width:100%;
              height:auto;
              margin-left:auto;
              margin-right:auto;
            }
            a {
              text-decoration:none;
            }
            p {
              padding:8px;
            }
          }
          img {
            width:100%;
            height:auto;
          }
        }
      }
    }
    .slick-prev,.slick-next {
      width: 24px;
      height: 24px;
      bottom: calc(50% - 44px);
      z-index: 2;
      background-color: $main-color;
      border-radius:30px;
      @include media-breakpoint-up(md) {
        width: 44px;
        height: 44px;
      }
      &::before {
        vertical-align: -15%;
        font-size: 0.6rem;
        color: $white;      
      }
      &:hover {
        background-color: $main-light-color;
      }
    }
    .slick-prev {
      left:-5px;
      @include media-breakpoint-up(md) {
        left:-50px;
      }
      &::before {
          content: "\e907";
      }
    } 
    .slick-next {
      right:-5px;
      @include media-breakpoint-up(md) {
        right:-50px;
      }
      &::before {
        content: "\e906";
      }
    }
    .slick-next:hover,
    .slick-next:focus,
    .slick-prev:hover,
    .slick-prev:focus{
      background-color:$sub-color2;
    }
   .slick-dots {
    bottom:-40px;
      li button {
        background:$main-color;
      }  
      li button:hover,
      li button:focus,
      li.slick-active button {
        background:$sub-color2;
      }
   }

   .btnPlay_ban2 {
    position: absolute;
    width: 70px;
    height: 26px;
    background-image: url(../images/slide_btn_stop.png);
    background-repeat: no-repeat;
    background-color: transparent;
    background-size: 70px 26px;
    padding: 0;
    margin: 0;
    border: 0;
    font-size: 0%;
    line-height: 0;
    overflow: visible;
    cursor: pointer;
    right: 5px;
    bottom: -40px;
  }
  }
}*/
.top_profile {
  background: #41806E;
  margin-top: 3rem;
  padding-bottom: 3rem;
}
.top_profile > h2 {
  color: #FFF;
  padding: 30px 0px 20px 0px;
  font-size: 1.2rem;
  letter-spacing: 0.2rem;
  text-align: center;
}
@media print, screen and (min-width: 576px) {
  .top_profile > h2 {
    font-size: 1.4rem;
    letter-spacing: 0.3rem;
  }
}
@media print, screen and (min-width: 768px) {
  .top_profile > h2 {
    font-size: 1.6rem;
  }
}
@media print, screen and (min-width: 992px) {
  .top_profile > h2 {
    font-size: 2rem;
    letter-spacing: 0.5rem;
    padding: 3rem 0 2.5rem 0;
  }
}
.top_profile > h2 span {
  position: relative;
  display: inline-block;
}
.top_profile > h2 span::before, .top_profile > h2 span::after {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  background: #2BAA76;
  border-radius: 50%;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media print, screen and (min-width: 768px) {
  .top_profile > h2 span::before, .top_profile > h2 span::after {
    width: 15px;
    height: 15px;
  }
}
.top_profile > h2 span::before {
  left: -30px;
}
@media print, screen and (min-width: 768px) {
  .top_profile > h2 span::before {
    left: -50px;
  }
}
.top_profile > h2 span::after {
  right: -25px;
}
@media print, screen and (min-width: 768px) {
  .top_profile > h2 span::after {
    right: -45px;
  }
}
.top_profile > div {
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px;
  width: auto;
}
@media print, screen and (min-width: 992px) {
  .top_profile > div {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  .top_profile > div {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 992px) {
  .top_profile > div {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    gap: 30px;
  }
}
.top_profile > div ul li a:hover {
  opacity: 0.8;
}
@media print, screen and (min-width: 992px) {
  .top_profile > div > div:first-child {
    -ms-flex-preferred-size: 70%;
        flex-basis: 70%;
  }
}
.top_profile > div > div:first-child ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
}
@media print, screen and (min-width: 992px) {
  .top_profile > div > div:first-child ul {
    gap: 20px;
  }
}
.top_profile > div > div:first-child ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style-type: none;
  width: calc(50% - 5px);
}
@media print, screen and (min-width: 768px) {
  .top_profile > div > div:first-child ul li {
    width: calc(33.3333333333% - 7px);
  }
}
@media print, screen and (min-width: 992px) {
  .top_profile > div > div:first-child ul li {
    width: calc(33.3333333333% - 14px);
  }
}
.top_profile > div > div:first-child ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  background: #FFF;
  text-decoration: none;
  color: #1B4D42;
  font-weight: bold;
  width: 100%;
}
.top_profile > div > div:first-child ul li a div {
  display: block;
}
.top_profile > div > div:first-child ul li a div img {
  width: 100%;
  height: auto;
}
.top_profile > div > div:first-child ul li a div:last-child {
  padding: 10px;
  font-size: 0.8rem;
}
@media print, screen and (min-width: 768px) {
  .top_profile > div > div:first-child ul li a div:last-child {
    padding: 20px;
    font-size: inherit;
  }
}
.top_profile > div > div:last-child {
  width: 100%;
}
@media print, screen and (min-width: 992px) {
  .top_profile > div > div:last-child {
    -ms-flex-preferred-size: 30%;
        flex-basis: 30%;
    width: auto;
  }
}
.top_profile > div > div:last-child ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
}
@media print, screen and (min-width: 768px) {
  .top_profile > div > div:last-child ul {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
@media print, screen and (min-width: 992px) {
  .top_profile > div > div:last-child ul {
    gap: 20px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
.top_profile > div > div:last-child ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style-type: none;
  width: 100%;
}
.top_profile > div > div:last-child ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 10px 20px 10px 45px;
  background: #FFF;
  text-decoration: none;
  color: #1B4D42;
  font-weight: bold;
  width: 100%;
  position: relative;
}
@media print, screen and (min-width: 768px) {
  .top_profile > div > div:last-child ul li a {
    padding: 20px 20px 20px 45px;
  }
}
.top_profile > div > div:last-child ul li a::before {
  position: absolute;
  content: "";
  top: 0.6rem;
  left: 10px;
  width: 6px;
  height: 6px;
  margin: 0.4rem 0.5rem 0 0.5rem;
  border-top: 2px solid #2BAA76;
  border-right: 2px solid #2BAA76;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media print, screen and (min-width: 768px) {
  .top_profile > div > div:last-child ul li a::before {
    top: 1.4rem;
  }
}

.top_koho {
  background: url(../images/top_koho_bg.jpg) no-repeat;
  background-size: cover;
  background-position: top center;
  padding-bottom: 3rem;
}
.top_koho > h2 {
  color: #1B4D42;
  padding: 30px 0px 20px 0px;
  font-size: 1.2rem;
  letter-spacing: 0.2rem;
  text-align: center;
}
@media print, screen and (min-width: 576px) {
  .top_koho > h2 {
    font-size: 1.4rem;
    letter-spacing: 0.3rem;
  }
}
@media print, screen and (min-width: 768px) {
  .top_koho > h2 {
    font-size: 1.6rem;
  }
}
@media print, screen and (min-width: 992px) {
  .top_koho > h2 {
    font-size: 2rem;
    letter-spacing: 0.5rem;
    padding: 3rem 0 2.5rem 0;
  }
}
.top_koho > h2 span {
  position: relative;
  display: inline-block;
}
.top_koho > h2 span::before, .top_koho > h2 span::after {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  background: #2BAA76;
  border-radius: 50%;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media print, screen and (min-width: 768px) {
  .top_koho > h2 span::before, .top_koho > h2 span::after {
    width: 15px;
    height: 15px;
  }
}
.top_koho > h2 span::before {
  left: -30px;
}
@media print, screen and (min-width: 768px) {
  .top_koho > h2 span::before {
    left: -50px;
  }
}
.top_koho > h2 span::after {
  right: -25px;
}
@media print, screen and (min-width: 768px) {
  .top_koho > h2 span::after {
    right: -45px;
  }
}
.top_koho > div {
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px;
}
@media print, screen and (min-width: 992px) {
  .top_koho > div {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  .top_koho > div {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 768px) {
  .top_koho > div {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
@media print, screen and (min-width: 992px) {
  .top_koho > div {
    gap: 50px;
  }
}
.top_koho > div > div.photo {
  background: #FFF;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .top_koho > div > div.photo {
    -ms-flex-preferred-size: 35%;
        flex-basis: 35%;
    width: auto;
  }
}
.top_koho > div > div.photo h3 {
  background: #1B4D42;
  color: #FFF;
  text-align: center;
  position: relative;
  padding: 10px;
  font-size: 1rem;
  letter-spacing: 0.2rem;
}
@media print, screen and (min-width: 768px) {
  .top_koho > div > div.photo h3 {
    padding: 15px;
    font-size: 1.2rem;
  }
}
.top_koho > div > div.photo h3::after {
  position: absolute;
  content: "";
  right: calc(45% - 7px);
  -webkit-transform: translateX(calc(-45% + 7px));
          transform: translateX(calc(-45% + 7px));
  bottom: -10px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 15px 15px 0 15px;
  border-color: #1B4D42 transparent transparent transparent;
}
.top_koho > div > div.photo div {
  padding: 20px;
}
.top_koho > div > div.photo div img {
  margin-bottom: 1rem;
  width: 100%;
  height: auto;
}
.top_koho > div > div.photo div p.date {
  font-size: 0.8rem;
  padding: 0.5rem 0 0 0;
}
@media print, screen and (min-width: 768px) {
  .top_koho > div > div.photo div p.date {
    font-size: 1rem;
  }
}
.top_koho > div > div.photo div p.ttl {
  font-size: 1rem;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .top_koho > div > div.photo div p.ttl {
    font-size: 1.2rem;
  }
}
.top_koho > div > div:last-child {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}
@media print, screen and (min-width: 576px) {
  .top_koho > div > div:last-child {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    gap: 20px;
  }
}
.top_koho > div > div:last-child > div {
  width: 100%;
}
.top_koho > div > div:last-child > div h3 {
  color: #1B4D42;
  padding: 10px 0px 10px 30px;
  font-size: 1rem;
  letter-spacing: 0.1rem;
}
@media print, screen and (min-width: 992px) {
  .top_koho > div > div:last-child > div h3 {
    font-size: 1.2rem;
  }
}
.top_koho > div > div:last-child > div h3 span {
  position: relative;
  display: inline-block;
}
.top_koho > div > div:last-child > div h3 span::before {
  position: absolute;
  content: "";
  width: 7px;
  height: 7px;
  background: #2BAA76;
  border-radius: 50%;
  top: 50%;
  left: -20px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media print, screen and (min-width: 768px) {
  .top_koho > div > div:last-child > div h3 span::before {
    width: 10px;
    height: 10px;
    left: -30px;
  }
}
.top_koho > div > div:last-child > div ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
}
.top_koho > div > div:last-child > div ul li {
  list-style-type: none;
  width: 100%;
}
.top_koho > div > div:last-child > div ul li a {
  display: block;
  width: 100%;
  background: #FFF;
  padding: 10px 20px 10px 45px;
  text-decoration: none;
  color: #1B4D42;
  font-weight: bold;
  position: relative;
}
@media print, screen and (min-width: 576px) {
  .top_koho > div > div:last-child > div ul li a {
    padding: 20px 20px 20px 45px;
  }
}
.top_koho > div > div:last-child > div ul li a::before {
  position: absolute;
  content: "";
  top: 0.7rem;
  left: 10px;
  width: 6px;
  height: 6px;
  margin: 0.4rem 0.5rem 0 0.5rem;
  border-top: 2px solid #2BAA76;
  border-right: 2px solid #2BAA76;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media print, screen and (min-width: 576px) {
  .top_koho > div > div:last-child > div ul li a::before {
    top: 1.4rem;
  }
}

.top_ad {
  background: #F4F6F8;
  padding: 2rem 0;
}
.top_ad h2 {
  color: #1B4D42;
  font-size: 1rem;
  padding-bottom: 1rem;
}
@media print, screen and (min-width: 768px) {
  .top_ad h2 {
    font-size: 1.2rem;
  }
}
.top_ad p {
  font-size: 0.8rem;
}
.top_ad > div {
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
}
@media print, screen and (min-width: 992px) {
  .top_ad > div {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  .top_ad > div {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
.top_ad > div ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px;
  padding: 1rem 0;
}
.top_ad > div ul li {
  list-style-type: none;
  width: calc(50% - 10px);
}
@media print, screen and (min-width: 768px) {
  .top_ad > div ul li {
    width: calc(25% - 15px);
  }
}
.top_ad > div ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.top_ad > div ul li a img {
  width: 100%;
  height: auto;
}
.top_ad > div .link {
  text-align: right;
}
.top_ad > div .link a {
  position: relative;
  display: inline-block;
  padding: 0px 40px 0px 0px;
}
.top_ad > div .link a::after {
  position: absolute;
  content: "";
  top: 0.1rem;
  right: 10px;
  width: 6px;
  height: 6px;
  margin: 0.4rem 0.5rem 0 0.5rem;
  border-top: 2px solid #2BAA76;
  border-right: 2px solid #2BAA76;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media print, screen and (min-width: 768px) {
  .top_ad > div .link a::after {
    top: 0.3rem;
  }
}

#header_ttl {
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
  color: #1B4D42;
  letter-spacing: 0.2em;
  padding: 1rem 0 1rem 110px;
  position: relative;
  font-size: 1.3rem;
  margin-top: 1.5rem;
}
@media print, screen and (min-width: 992px) {
  #header_ttl {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  #header_ttl {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 576px) {
  #header_ttl {
    font-size: 1.6rem;
    padding: 2rem 0 2rem 170px;
    margin-top: 0;
  }
}
@media print, screen and (min-width: 768px) {
  #header_ttl {
    font-size: 2rem;
    padding: 3rem 0 3rem 230px;
  }
}
@media print, screen and (min-width: 992px) {
  #header_ttl {
    font-size: 2.4rem;
  }
}
#header_ttl span {
  position: absolute;
  content: "";
  width: 80px;
  height: 57px;
  left: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media print, screen and (min-width: 576px) {
  #header_ttl span {
    width: 120px;
    height: 85px;
    left: 20px;
  }
}
@media print, screen and (min-width: 768px) {
  #header_ttl span {
    width: 180px;
    height: 128px;
    left: 20px;
  }
}
#header_ttl span.cate_2 {
  background: url("../images/cate_ttl_kurashi.png");
  background-size: cover;
}
#header_ttl span.cate_3 {
  background: url("../images/cate_ttl_kanko.png");
  background-size: cover;
}
#header_ttl span.cate_4 {
  background: url("../images/cate_ttl_sangyo.png");
  background-size: cover;
}
#header_ttl span.cate_5 {
  background: url("../images/cate_ttl_shisei.png");
  background-size: cover;
}
#header_ttl span.cate_7 {
  background: url("../images/cate_ttl_kyukyu.png");
  background-size: cover;
}
#header_ttl span.cate_8 {
  background: url("../images/cate_ttl_kosodate.png");
  background-size: cover;
}
#header_ttl span.cate_9 {
  background: url("../images/cate_ttl_kenko.png");
  background-size: cover;
}

.article_date {
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
  font-size: 0.7rem;
  padding-bottom: 0.5rem;
  color: #1B4D42;
}
@media print, screen and (min-width: 992px) {
  .article_date {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  .article_date {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 768px) {
  .article_date {
    font-size: 0.8rem;
    padding-bottom: 1rem;
  }
}

/* pankuzu */
.pankuzu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-left: 15px;
  margin-right: 15px;
  padding: 1rem 0;
  font-weight: bold;
  color: #1B4D42;
}
@media print, screen and (min-width: 992px) {
  .pankuzu {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media print, screen and (min-width: 1200px) {
  .pankuzu {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
  }
}
.pankuzu > div:first-child {
  font-size: 0.8rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media print, screen and (max-width: 767px) {
  .pankuzu > div:last-child {
    display: none;
  }
}
.pankuzu > div:last-child a {
  display: block;
  background: #FFF;
  border: 1px solid #1B4D42;
  color: #1B4D42;
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: bold;
  padding: 6px 20px 6px 15px;
}
.pankuzu > div:last-child a span.icon-print {
  vertical-align: -15%;
  font-size: 1rem;
  color: #1B4D42;
  padding-right: 10px;
}
.pankuzu > div:last-child a span.icon-print::before {
  content: "\e90a";
}
.pankuzu > div:last-child a:hover {
  opacity: 0.8;
}
.pankuzu ul {
  list-style-type: none;
  font-size: 90%;
}
.pankuzu ul li {
  display: inline-block;
}
.pankuzu ul li:first-child {
  position: relative;
}
.pankuzu ul li:first-child span.icon-location {
  vertical-align: -15%;
  font-size: 1rem;
}
.pankuzu ul li:first-child span.icon-location::before {
  content: "\e90b";
}
.pankuzu ul li + li:before {
  content: ">";
}
.pankuzu ul li a, .pankuzu ul li span {
  padding: 0px 10px;
  display: inline-block;
  color: #1B4D42;
}
.pankuzu ul li:first-child a {
  padding: 0px 10px 0px 0px;
}

/* news */
#article #page_maincontents-onecol .news {
  position: relative;
  margin: 20px 0px 40px 0px;
  padding: 1rem;
  border: 5px solid #F4F6F8;
}
#article #page_maincontents-onecol .news.backnumber {
  padding: 0;
  border: 0;
}
@media print, screen and (min-width: 992px) {
  #article #page_maincontents-onecol .news {
    padding: 1.5rem;
  }
}
#article #page_maincontents-onecol .news h2 {
  color: #1B4D42;
  font-size: 1.2rem;
  letter-spacing: 0.2rem;
  padding: 0.5rem 0 1rem 0;
}
@media print, screen and (min-width: 768px) {
  #article #page_maincontents-onecol .news h2 {
    font-size: 1.4rem;
  }
}
@media print, screen and (min-width: 992px) {
  #article #page_maincontents-onecol .news h2 {
    font-size: 1.6rem;
  }
}
#article #page_maincontents-onecol .news ul {
  padding: 0;
  margin: 0;
}
#article #page_maincontents-onecol .news ul li {
  padding: 0.4rem 0.4rem 0.4rem 2rem;
  padding-left: 0;
}
@media print, screen and (min-width: 768px) {
  #article #page_maincontents-onecol .news ul li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
#article #page_maincontents-onecol .news ul li > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 14px;
  font-size: 0.8rem;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding-bottom: 0.3rem;
}
@media print, screen and (min-width: 768px) {
  #article #page_maincontents-onecol .news ul li > div {
    padding-bottom: 0;
    -ms-flex-preferred-size: 35%;
        flex-basis: 35%;
  }
}
@media print, screen and (min-width: 992px) {
  #article #page_maincontents-onecol .news ul li > div {
    -ms-flex-preferred-size: 25%;
        flex-basis: 25%;
  }
}
#article #page_maincontents-onecol .news ul li > div span {
  padding: 0.1rem;
}
#article #page_maincontents-onecol .news ul li > div span[class^=news-] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 80px;
  font-weight: bold;
  color: #FFF;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#article #page_maincontents-onecol .news ul li > div span.news- {
  background: #C00000;
}
#article #page_maincontents-onecol .news ul li > div span.news-oshirase {
  background: #9C4F57;
}
#article #page_maincontents-onecol .news ul li > div span.news-event {
  background: #685b8d;
}
#article #page_maincontents-onecol .news ul li > div span.news-bosyu {
  background: #C44A0F;
}
#article #page_maincontents-onecol .news ul li > div span.news-sonota {
  background: #35739C;
}
#article #page_maincontents-onecol .news ul li a {
  display: block;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
#article #page_maincontents-onecol .news ul li::before, #article #page_maincontents-onecol .news ul li::after {
  content: none;
}
#article #page_maincontents-onecol .news .pagenation {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  font-size: 70%;
  line-height: 1rem;
}
@media print, screen and (min-width: 768px) {
  #article #page_maincontents-onecol .news .pagenation {
    font-size: inherit;
    line-height: inherit;
  }
}
#article #page_maincontents-onecol .news .pagenation a, #article #page_maincontents-onecol .news .pagenation span {
  border: 1px solid #1B4D42;
  border-radius: 5px;
  padding: 5px;
  margin-right: 3px;
  font-weight: bold;
  text-decoration: none;
  display: block;
}
@media print, screen and (min-width: 768px) {
  #article #page_maincontents-onecol .news .pagenation a, #article #page_maincontents-onecol .news .pagenation span {
    padding: 5px 8px;
  }
}
#article #page_maincontents-onecol .news .pagenation a:last-child {
  margin-right: 0px;
}
#article #page_maincontents-onecol .news .pagenation span:last-child {
  margin-right: 0px;
}
#article #page_maincontents-onecol .news .pagenation span.selected {
  background: #1B4D42;
  color: #FFF;
}
#article #page_maincontents-onecol .news .pagenation a {
  color: #1B4D42;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
#article #page_maincontents-onecol .news .pagenation a:hover {
  background: #1B4D42;
  color: #FFF;
}

/* category_list */
#article #page_maincontents ul.category_page_list,
#article #page_maincontents-onecol ul.category_page_list {
  padding: 0;
  overflow: hidden;
  margin: 0px 0px 0px 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  list-style: none;
}
@media print, screen and (min-width: 576px) {
  #article #page_maincontents ul.category_page_list,
  #article #page_maincontents-onecol ul.category_page_list {
    gap: 10px 20px;
  }
}
@media print, screen and (min-width: 768px) {
  #article #page_maincontents ul.category_page_list,
  #article #page_maincontents-onecol ul.category_page_list {
    gap: 15px 20px;
  }
}
#article #page_maincontents ul.category_page_list li,
#article #page_maincontents-onecol ul.category_page_list li {
  width: 100%;
  padding: 0px;
  border: 2px solid #F4F6F8;
  background: #F4F6F8;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  /*
  @include media-breakpoint-up(sm) {
    width:calc((100% / 2) - 10px);
    flex-wrap:nowrap;
  }
  @include media-breakpoint-up(lg) {
    width:calc((100% / 3) - 14px);
  }*/
}
#article #page_maincontents ul.category_page_list li:hover,
#article #page_maincontents-onecol ul.category_page_list li:hover {
  background: #FFF;
  cursor: pointer;
  border: 2px solid #41806E;
  background: #F4F6F8;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
#article #page_maincontents ul.category_page_list li::after,
#article #page_maincontents-onecol ul.category_page_list li::after {
  content: none;
}
#article #page_maincontents ul.category_page_list li::before,
#article #page_maincontents-onecol ul.category_page_list li::before {
  content: none;
}
#article #page_maincontents ul.category_page_list li .cate_list,
#article #page_maincontents-onecol ul.category_page_list li .cate_list {
  cursor: pointer;
  padding: 10px;
}
@media print, screen and (min-width: 576px) {
  #article #page_maincontents ul.category_page_list li .cate_list,
  #article #page_maincontents-onecol ul.category_page_list li .cate_list {
    padding: 20px;
  }
}
#article #page_maincontents ul.category_page_list li .cate_list p.ttl,
#article #page_maincontents-onecol ul.category_page_list li .cate_list p.ttl {
  font-size: 0.9rem;
  position: relative;
  display: inline-block;
  padding: 2px 0 0 30px;
  vertical-align: middle;
  margin-bottom: 0;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  #article #page_maincontents ul.category_page_list li .cate_list p.ttl,
  #article #page_maincontents-onecol ul.category_page_list li .cate_list p.ttl {
    font-size: 1.2rem;
  }
}
#article #page_maincontents ul.category_page_list li .cate_list p.ttl.pageicon::before, #article #page_maincontents ul.category_page_list li .cate_list p.ttl.cateicon::before,
#article #page_maincontents-onecol ul.category_page_list li .cate_list p.ttl.pageicon::before,
#article #page_maincontents-onecol ul.category_page_list li .cate_list p.ttl.cateicon::before {
  position: absolute;
  content: "";
  top: 0.2em;
  left: 0px;
  width: 18px;
  height: 23px;
}
#article #page_maincontents ul.category_page_list li .cate_list p.ttl.pageicon::before,
#article #page_maincontents-onecol ul.category_page_list li .cate_list p.ttl.pageicon::before {
  background: url("../images/icon_file_s.png") no-repeat;
  background-size: cover;
}
#article #page_maincontents ul.category_page_list li .cate_list p.ttl.cateicon::before,
#article #page_maincontents-onecol ul.category_page_list li .cate_list p.ttl.cateicon::before {
  background: url("../images/icon_folder_s.png") no-repeat;
  background-size: contain;
}
#article #page_maincontents ul.category_page_list li .cate_list p.ttl::after,
#article #page_maincontents-onecol ul.category_page_list li .cate_list p.ttl::after {
  background: none;
}
#article #page_maincontents ul.category_page_list li .cate_list p.txt,
#article #page_maincontents-onecol ul.category_page_list li .cate_list p.txt {
  font-size: 0.8rem;
  margin: 0.8rem 0 0 0;
  line-height: 1.5rem;
}

@media print, screen and (min-width: 576px) {
  #article #page_maincontents-onecol ul.category_page_list li {
    width: calc(50% - 10px);
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
@media print, screen and (min-width: 992px) {
  #article #page_maincontents-onecol ul.category_page_list li {
    width: calc(33.3333333333% - 14px);
  }
}

@media print, screen and (min-width: 768px) {
  #article #page_maincontents ul.category_page_list li {
    width: calc(50% - 10px);
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}

/* sidemenu */
#page_sidemenu ul {
  list-style-type: none;
}

#page_sidemenu h2.page_cate,
#page_sidemenu h2 {
  font-size: 120%;
}
#page_sidemenu h2.page_cate a, #page_sidemenu h2.page_cate span,
#page_sidemenu h2 a,
#page_sidemenu h2 span {
  color: #FFF;
  background: #1B4D42;
  padding: 20px 15px;
  display: block;
}

#article .page_menu_cate_link {
  padding: 0;
  font-size: 100%;
  margin-bottom: 15px;
}
#article .page_menu_cate_link ul {
  margin: 0px 0px 10px 0px;
}
#article .page_menu_cate_link ul li {
  position: relative;
  text-align: left;
  list-style: none;
  padding: 0px;
  margin: 0;
  font-weight: bold;
  border-bottom: 1px solid #E5E5E5;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
#article .page_menu_cate_link ul li:last-child {
  border: none;
}
#article .page_menu_cate_link ul li:hover {
  cursor: pointer;
  background: #F4F6F8;
}
#article .page_menu_cate_link ul li a,
#article .page_menu_cate_link ul li > span {
  position: relative;
  padding: 10px 10px 10px 35px;
  display: block;
}
#article .page_menu_cate_link ul li a {
  font-weight: normal;
}
#article .page_menu_cate_link ul li::before {
  position: absolute;
  top: 0.8em;
  width: 6px;
  height: 6px;
  margin: 0.4rem 0 0 0.8rem;
  border-top: 2px solid #2BAA76;
  border-right: 2px solid #2BAA76;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  content: "";
}
#article .page_menu_cate_link ul li::after {
  background: none;
}

#article #page_menu_life {
  padding: 10px 15px 15px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-color: #786239;
  border-radius: 20px;
}
#article #page_menu_life h2 {
  margin: 0 0 10px;
  padding: 0px;
  color: #FFF;
  background: none;
}
#article #page_menu_life h2 span {
  position: relative;
  display: block;
  padding-left: 30px;
}
#article #page_menu_life h2 span::before {
  position: absolute;
  top: 0.8rem;
  left: 0;
  width: 15px;
  height: 4px;
  background: #FFF;
  content: "";
}
#article #page_menu_life ul {
  margin: 0 auto;
  background: none;
}
#article #page_menu_life ul li {
  list-style: none;
  margin: 0 0 10px;
  padding: 15px 10px 15px 60px;
  cursor: pointer;
  background: #FFF;
  border-radius: 15px;
}
#article #page_menu_life ul li::after {
  background: none;
}
#article #page_menu_life ul li:last-child {
  margin-bottom: 0;
}
#article #page_menu_life ul li[class^=life0] {
  position: relative;
}
#article #page_menu_life ul li[class^=life0]::before {
  position: absolute;
  content: "";
  display: inline-block;
  width: 50px;
  height: 50px;
  top: 0;
  left: 0;
  margin-right: 0.2em;
}
#article #page_menu_life ul li[class^=life0] a:after {
  position: absolute;
  top: 1.5em;
  right: 0.5em;
  width: 6px;
  height: 6px;
  border-top: 2px solid #786239;
  border-right: 2px solid #786239;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  content: "";
}
#article #page_menu_life ul li.life01:before {
  background: url(../images/top_life_01.svg) no-repeat;
  background-size: contain;
}
#article #page_menu_life ul li.life02:before {
  background: url(../images/top_life_02.svg) no-repeat;
  background-size: contain;
}
#article #page_menu_life ul li.life03:before {
  background: url(../images/top_life_03.svg) no-repeat;
  background-size: contain;
}
#article #page_menu_life ul li.life04:before {
  background: url(../images/top_life_04.svg) no-repeat;
  background-size: contain;
}
#article #page_menu_life ul li.life05:before {
  background: url(../images/top_life_05.svg) no-repeat;
  background-size: contain;
}
#article #page_menu_life ul li.life06:before {
  background: url(../images/top_life_06.svg) no-repeat;
  background-size: contain;
}
#article #page_menu_life ul li.life07:before {
  background: url(../images/top_life_07.svg) no-repeat;
  background-size: contain;
}
#article #page_menu_life ul li.life08:before {
  background: url(../images/top_life_08.svg) no-repeat;
  background-size: contain;
}
#article #page_menu_life ul li a {
  text-decoration: none;
  color: #786239;
  font-weight: bold;
}

/* language */
.lang_btn {
  margin: 20px;
}
.lang_btn a {
  display: inline-block;
  padding: 20px 20px 20px 60px;
  text-decoration: none;
  font-weight: bold;
  color: #333;
  font-size: 140%;
  border: 1px solid #1B4D42;
  position: relative;
}
.lang_btn a:hover {
  background: #F4F6F8;
}
.lang_btn a::before {
  position: absolute;
  content: "";
  top: 1.4rem;
  left: 10px;
  width: 6px;
  height: 6px;
  margin: 0.4rem 0.5rem 0 0.9rem;
  border-top: 2px solid #FFF;
  border-right: 2px solid #FFF;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  z-index: 1;
}
.lang_btn a::after {
  position: absolute;
  content: "";
  top: 0.7rem;
  left: 0px;
  width: 30px;
  height: 30px;
  margin: 0.4rem 0.5rem 0 0.9rem;
  background: #1B4D42;
  border-radius: 50%;
}

/* sitemap */
#article #page_maincontents-onecol ul.sitemap {
  list-style: none;
  padding: 0 10px;
  margin: 0px 0px 20px 0px;
}
#article #page_maincontents-onecol ul.sitemap li {
  padding: 0px;
  display: inline;
}
#article #page_maincontents-onecol ul.sitemap li::after {
  background: none;
}
#article #page_maincontents-onecol ul.sitemap li a::after {
  content: "|";
  margin: 15px;
  color: #E6E6E6;
  right: 0;
  top: 0;
}
#article #page_maincontents-onecol dl.sitemap {
  padding: 0 10px;
}
#article #page_maincontents-onecol .sitemap dt {
  line-height: 1.6;
  font-weight: bold;
}
#article #page_maincontents-onecol .sitemap dt a {
  background: url(../images/icon_folder_s.png) no-repeat left 0.3em;
  padding: 0 25px;
  margin: 0;
  font-size: 110%;
  display: inline-block;
}
#article #page_maincontents-onecol .sitemap dt span {
  margin-left: 1.5em;
  padding-left: 1.5em;
  display: block;
}
#article #page_maincontents-onecol .sitemap dt + dt {
  margin-top: 5px;
}
#article #page_maincontents-onecol .sitemap dd {
  line-height: 1.6;
  margin: 5px 0 20px;
}
#article #page_maincontents-onecol .sitemap dd span {
  margin-left: 1.3em;
  padding-left: 1.3em;
  display: inline-block;
}
#article #page_maincontents-onecol .sitemap dd span.link {
  margin: 0px;
  padding: 0px;
}
#article #page_maincontents-onecol .sitemap dd span:after {
  content: "|";
  margin: 15px;
  color: #E6E6E6;
}
#article #page_maincontents-onecol .sitemap dd span span:after {
  content: "|";
  margin: 15px;
  color: #E6E6E6;
}
#article #page_maincontents-onecol .sitemap dd span:last-child::after {
  content: none;
}

/*-- lifeevent --*/
dl.life {
  margin-left: auto;
  margin-right: auto;
  padding: 0 10px;
}
dl.life dt {
  text-align: left;
  padding: 6px;
  font-weight: bold;
  margin-top: 2px;
  line-height: 1.6;
}
dl.life dt a {
  background: url(../images/icon_folder_s.png) no-repeat left 0.3em !important;
  padding: 0 25px;
  margin: 0;
  display: inline-block;
}
dl.life dt span {
  margin-left: 0.5em;
  padding-left: 1em;
  display: block;
}
dl.life dt + dt {
  margin-top: 5px;
}
dl.life dd {
  line-height: 1.6;
  margin: 5px 0 15px;
  text-align: left;
  padding: 2px 2px 2px 30px;
  color: #4e7b20;
}
dl.life dd span {
  padding-left: 1.25em;
  display: block;
}
dl.life dd a {
  background: url(../images/icon_file_s.png) no-repeat left 0.1em !important;
  padding: 0 25px;
  margin: 0;
  display: inline-block;
}

/*--soshiki--*/
#article #page_maincontents table.group {
  width: 100%;
}
#article #page_maincontents table.group th {
  width: 30%;
}
#article #page_maincontents table.group td {
  width: 70%;
}
#article #page_maincontents table.group td p {
  margin-bottom: 0px;
  padding-left: 20px;
}
#article #page_maincontents table.group td .group_name {
  padding: 0px;
  font-weight: bold;
}
#article #page_maincontents table.group td h3 {
  margin-top: 10px;
  font-size: 1.1rem;
}

#article #page_maincontents .soshiki h2 {
  font-size: 170%;
  margin: 0px auto;
  padding: 0px 0px 15px 0px;
  font-weight: bold;
  color: #1B4D42;
}
#article #page_maincontents .soshiki h2 span {
  position: relative;
  line-height: 1.5em;
  padding-left: 2em;
}
#article #page_maincontents .soshiki h2 span::before {
  position: absolute;
  left: 0;
  content: "";
  display: inline-block;
  width: 42px;
  height: 42px;
  top: -7px;
  background: url(../images/shisho.png) no-repeat;
  background-size: contain;
}
#article #page_maincontents .soshiki p {
  margin-bottom: 0px;
}

/* facility_map */
#article #building {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media print, screen and (min-width: 992px) {
  #article #building {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    gap: 30px;
  }
}
#article #building h2.pagetitle_a2 {
  margin: 0 0 10px 0;
  padding: 0.5rem 1rem;
  font-size: 1.2rem;
}
#article #building > div:first-child {
  width: 100%;
}
@media print, screen and (min-width: 992px) {
  #article #building > div:first-child {
    -ms-flex-preferred-size: 40%;
        flex-basis: 40%;
  }
}
#article #building > div:first-child #building_search {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 1rem;
}
#article #building > div:first-child #building_search input[type=text] {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding: 5px !important;
  font-family: "BIZ UDPGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif";
  font-size: 1.2rem;
}
#article #building > div:first-child #building_search input[type=button] {
  -ms-flex-preferred-size: 60px;
      flex-basis: 60px;
  background: #1B4D42;
  color: #FFF;
  font-weight: bold;
  font-family: "BIZ UDPGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif";
}
#article #building > div:first-child ul.akichiakiya_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 5px;
  margin: 0 0 1rem 0;
}
#article #building > div:first-child ul.akichiakiya_list li {
  padding: 0;
  width: calc(50% - 10px);
}
#article #building > div:first-child ul.akichiakiya_list li::after {
  content: none;
}
#article #building > div:first-child ul.akichiakiya_list li a {
  display: block;
}
#article #building > div:first-child ul.akichiakiya_list li img {
  width: 100%;
  height: auto;
}
#article #building > div:first-child ul.building_ichiran {
  height: 300px;
  overflow-y: scroll;
  border: 1px solid #CCCCCC;
  padding: 10px 20px;
  list-style: none;
}
#article #building > div:first-child .genzaichi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 5px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media print, screen and (min-width: 768px) {
  #article #building > div:first-child .genzaichi {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
}
#article #building > div:first-child .genzaichi input[type=button] {
  -ms-flex-preferred-size: 60px;
      flex-basis: 60px;
  background: #1B4D42;
  color: #FFF;
  font-weight: bold;
  font-family: "BIZ UDPGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif";
  font-size: 0.9rem;
  padding: 5px 10px;
}
#article #building > div:first-child input[type=button].clear {
  background: #F5F5F5;
  color: #666666;
  border: 1px solid #CCCCCC;
  font-weight: bold;
  font-family: "BIZ UDPGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif";
  font-size: 0.9rem;
  padding: 5px 10px;
  margin: 0.5rem 0;
}
#article #building > div:last-child {
  width: 100%;
}
@media print, screen and (min-width: 992px) {
  #article #building > div:last-child {
    -ms-flex-preferred-size: 60%;
        flex-basis: 60%;
  }
}
#article #building > div:last-child #gMap {
  width: 100%;
  height: 300px;
}
@media print, screen and (min-width: 992px) {
  #article #building > div:last-child #gMap {
    width: 700px;
    height: 500px;
  }
}

/*pdficon*/
.article_fileicon {
  font-size: 0.8rem;
  line-height: 1.5em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
  margin-top: 2rem;
}
@media print, screen and (min-width: 576px) {
  .article_fileicon {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    gap: 20px;
  }
}
.article_fileicon_img {
  width: 100%;
}
@media print, screen and (min-width: 576px) {
  .article_fileicon_img {
    width: 158px;
  }
}
.article_fileicon_txt {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

#article [class^=icon_] {
  padding: 0 5px;
  margin: 5px 10px;
  color: #FFFFFF;
  display: inline-block;
  font-size: 0.8rem;
  line-height: 1.8em;
}

.icon_pdf {
  background: #9E0000;
}

.icon_xls {
  background: #217547;
}

.icon_xlsx {
  background: #217547;
}

.icon_csv {
  background: #848484;
}

.icon_doc {
  background: #153B86;
}

.icon_rtf {
  background: #153B86;
}

.icon_docx {
  background: #153B86;
}

.icon_jtd {
  background: #DB1718;
}

.icon_gif {
  background: #76720F;
}

.icon_jpeg {
  background: #76720F;
}

.icon_jpg {
  background: #76720F;
}

.icon_bmp {
  background: #76720F;
}

.icon_mp3 {
  background: #509C15;
}

.icon_mp4 {
  background: #412184;
}

.icon_png {
  background: #76720F;
}

.icon_ppt {
  background: #C05203;
}

.icon_pptx {
  background: #C05203;
}

.icon_sxc {
  background: #076A00;
}

.icon_sxw {
  background: #163A86;
}

.icon_wav {
  background: #4F9C12;
}

.icon_wmv {
  background: #A02F07;
}

.icon_xdw {
  background: #006A54;
}

.icon_xls {
  background: #0B6606;
}

.icon_xlsx {
  background: #0B6606;
}

.icon_zip {
  background: #646464;
}

.icon_link {
  background: #385B99;
}

.icon_docment {
  background: #C00000;
}

/*#header::after,
#footer_menu::after,
#oshirase > div #top_moshimo::after,
#main::after,
#article::after,
#page_main::after {
	content:".";
	display:block;
	height:0;
	font-size:0.1%;
	line-height:0.1;
	clear:both;
	visibility:hidden;
}
*/