@charset "UTF-8";
/* reset ------------------------------------- */
body, input, textarea, button, select, label {
  font-family: "Hiragino Kaku Gothic ProN", "Helvetica Neue", "san francisco", "Segoe UI", "Hiragino Sans", Meiryo, sans-serif;
}

body {
  background-color: #fff;
  color: #000;
  font-size: 1rem;
  margin: 0;
  min-width: 320px;
  padding: 0;
  position: relative;
  -webkit-text-size-adjust: 100%;
}

header, footer, main, article, aside, section, nav, figure, figcaption {
  display: block;
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-feature-settings: "palt";
  line-height: 1.4;
  margin: 0;
  max-height: 100%;
  padding: 0;
}

p, th, td, li, dt, dd {
  font-feature-settings: "palt";
  line-height: 1.4;
  margin: 0;
  max-height: 100%;
  padding: 0;
}

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

dl, form {
  margin: 0;
  padding: 0;
}

fieldset, iframe {
  border-style: none;
  margin: 0;
  max-width: 100%;
  padding: 0;
}

input[type=text], textarea, button {
  -webkit-appearance: none;
  border: none;
  border-radius: 0;
  font-size: 1rem;
  font-feature-settings: "palt";
}
input[type=text]:focus, textarea:focus, button:focus {
  outline: none;
}

input[type=button],
input[type=submit],
input[type=reset],
button {
  cursor: pointer;
}
input[type=button]:focus,
input[type=submit]:focus,
input[type=reset]:focus,
button:focus {
  outline: none;
}
input[type=text]::-moz-placeholder {
  color: #ccc;
}
input[type=text]::placeholder {
  color: #ccc;
}

select {
  border: none;
  border-radius: 0;
  cursor: pointer;
  font-size: 1rem;
}
select:focus {
  outline: none;
}

label {
  cursor: pointer;
  font-size: 1rem;
}

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

th {
  text-align: left;
}

caption {
  text-align: left;
  width: 100%;
}

address {
  font-style: normal;
  font-weight: normal;
}

i {
  font-style: oblique;
}

b, em {
  font-style: normal;
  font-weight: 700;
}

strong {
  color: #f15c9b;
  font-weight: 700;
}

small {
  font-size: 1rem;
}

figure img {
  display: block;
  margin: 0 auto;
}

img {
  border-style: none;
  height: auto;
  -ms-interpolation-mode: bicubic;
  margin: 0 auto;
  max-width: 100%;
}

a {
  text-decoration: underline;
  transition: all 0.3s;
}
a:link {
  color: #00b8ce;
}
a:visited {
  color: #00b8ce;
}
a:active, a:hover {
  color: #00b8ce;
  text-decoration: none;
}
a:focus {
  color: #00b8ce;
}

hr {
  height: 0;
  margin: 0;
  padding: 0;
  border: 0;
}

* {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-touch-callout: none;
  box-sizing: border-box;
}

@media (max-width: 767px) {
  .header {
    display: flex;
    flex-flow: row wrap;
  }
  .header-layout {
    padding: 8px 0 0 20px;
    width: calc(100% - 60px);
  }
  .header-logo img {
    width: 195px;
  }
  .header-sub {
    display: none;
  }
  .header-nav {
    background-color: #fff;
    height: 100vh;
    left: -340px;
    overflow: auto;
    position: fixed;
    top: 0;
    transition: all 0.3s;
    width: 340px;
    z-index: 10;
  }
  .header-nav::before {
    background-color: rgba(0, 0, 0, 0.5);
    content: "";
    height: 100vh;
    left: 100%;
    position: fixed;
    top: 0;
    transition: all 0.3s;
    width: calc(100% - 340px);
    z-index: 10;
  }
  .header-nav > ul {
    align-items: center;
    display: flex;
    flex-flow: column wrap;
    margin: 0;
    position: relative;
  }
  .header-nav > ul::before {
    background: url(../img/logo.svg) center center no-repeat;
    background-size: 215px;
    content: "";
    display: block;
    height: 106px;
    width: 100%;
  }
  .header-nav > ul > li > a {
    text-decoration: none;
  }
  .header-nav > ul > li:nth-of-type(1) {
    margin: 0 0 40px;
  }
  .header-nav > ul > li:nth-of-type(1) > a {
    background-color: #00b8ce;
    border-radius: 16px/50%;
    color: #fff;
    display: block;
    font-size: 1.13rem;
    font-weight: 700;
    line-height: 41px;
    text-align: center;
    width: 154px;
  }
  .header-nav > ul > li:nth-of-type(1) > a:hover {
    opacity: 0.6;
  }
  .header-nav > ul > li:not(:nth-of-type(1)):not(:last-child) {
    margin: 0 0 24px;
  }
  .header-nav > ul > li:not(:nth-of-type(1)):not(:last-child) > a {
    color: #000;
    font-size: 0.94rem;
    font-weight: 700;
  }
  .header-nav > ul > li:not(:nth-of-type(1)):not(:last-child) > a:hover {
    color: #00b8ce;
  }
  .header-nav > ul > li:last-child {
    width: 100%;
  }
  .header-nav > ul > li:last-child > a {
    background-color: #00b8ce;
    color: #fff;
    display: block;
    font-size: 1.13rem;
    font-weight: 700;
    line-height: 60px;
    text-align: center;
    width: 100%;
  }
  .header-nav > ul > li:last-child > a:hover {
    opacity: 0.6;
  }
  .header-sp-menu {
    height: 60px;
    position: relative;
    width: 60px;
    z-index: 10;
  }
  .header-sp-menu > button {
    background-color: rgba(255, 255, 255, 0);
    height: 100%;
    outline: none;
    padding: 0;
    width: 100%;
  }
  .header-sp-menu > button > span {
    background-color: #00b8ce;
    border-radius: 2px;
    display: block;
    height: 3px;
    left: 20px;
    position: absolute;
    top: 26px;
    width: 20px;
  }
  .header-sp-menu > button > span::before, .header-sp-menu > button > span::after {
    background-color: #00b8ce;
    border-radius: 2px;
    content: "";
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    transition: all 0.3s;
    width: 100%;
  }
  .header-sp-menu > button > span::before {
    top: -5px;
  }
  .header-sp-menu > button > span::after {
    bottom: -5px;
  }
  .header-sp-donation {
    width: 100%;
  }
  .header-sp-donation > a {
    background-color: #00b8ce;
    color: #fff;
    display: block;
    font-size: 1rem;
    font-weight: 700;
    line-height: 37px;
    text-align: center;
    text-decoration: none;
    transition: all 0.3s;
  }
  .header-sp-donation > a:hover {
    opacity: 0.6;
  }
}
@media (min-width: 768px) {
  .header-layout {
    align-items: center;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    margin: 0 auto;
    max-width: 1280px;
  }
  .header-logo {
    padding: 0 0 0 50px;
  }
  .header-logo > h1,
.header-logo > a {
    margin: 0;
    padding: 0;
  }
  .header-logo > h1::before, .header-logo > h1::after,
.header-logo > a::before,
.header-logo > a::after {
    content: none;
  }
  .header-logo img {
    width: 300px;
  }
  .header-sub > ul {
    align-items: center;
    display: flex;
    flex-flow: row wrap;
    margin: 0;
  }
  .header-sub > ul > li > a {
    display: block;
    font-weight: 700;
    text-align: center;
    text-decoration: none;
    transition: all 0.3s;
  }
  .header-sub > ul > li:nth-child(1) > a {
    background-color: #00b8ce;
    border-radius: 18px/50%;
    color: #fff;
    font-size: 1.13rem;
    line-height: 40px;
    max-width: 150px;
    width: 13vw;
  }
  .header-sub > ul > li:nth-child(1) > a:hover {
    opacity: 0.6;
  }
  .header-sub > ul > li:nth-child(2) > a {
    color: #000;
    font-size: 0.94rem;
    line-height: 84px;
    max-width: 170px;
    width: 16vw;
  }
  .header-sub > ul > li:nth-child(2) > a:hover {
    color: #00b8ce;
  }
  .header-sub > ul > li:nth-child(3) > a {
    background-color: #00b8ce;
    color: #fff;
    font-size: 0.94rem;
    line-height: 84px;
    max-width: 170px;
    width: 16vw;
  }
  .header-sub > ul > li:nth-child(3) > a:hover {
    opacity: 0.6;
  }
  .header-nav > ul {
    align-items: center;
    background-color: #e3e3e3;
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    margin: 0;
  }
  .header-nav > ul > li:nth-of-type(1), .header-nav > ul > li:nth-last-of-type(2), .header-nav > ul > li:last-child {
    display: none;
  }
  .header-nav > ul > li > a {
    color: #000;
    font-size: 0.94rem;
    font-weight: 700;
    line-height: 48px;
    padding: 0 16px;
    text-align: center;
    text-decoration: none;
    transition: all 0.3s;
  }
  .header-nav > ul > li > a:hover {
    color: #00b8ce;
  }
  .header-sp-menu, .header-sp-donation {
    display: none;
  }
}

@media (max-width: 767px) {
  .sp-menu-open .header-nav {
    left: 0;
  }
  .sp-menu-open .header-nav::before {
    left: 340px;
  }
  .sp-menu-open .header-sp-menu > button > span {
    background-color: rgba(255, 255, 255, 0);
  }
  .sp-menu-open .header-sp-menu > button > span::before {
    top: 0;
    transform: rotate(45deg);
  }
  .sp-menu-open .header-sp-menu > button > span::after {
    bottom: 0;
    transform: rotate(-45deg);
  }
}

.to_page_top {
  left: 50%;
  margin: 36px 0 0;
  max-width: 1280px;
  padding: 0 24px 0 0;
  position: absolute;
  transform: translateX(-50%);
  width: 100%;
}
.to_page_top a {
  background-color: #e9e9e9;
  display: block;
  height: 40px;
  margin: 0 0 0 auto;
  overflow: hidden;
  position: relative;
  text-indent: 50px;
  text-decoration: none;
  width: 40px;
  white-space: nowrap;
}
.to_page_top a:after {
  content: "";
  display: block;
  height: 8px;
  left: 12px;
  position: absolute;
  top: 16px;
  width: 16px;
}
@media (min-width: 480px) {
  .to_page_top {
    padding: 0 40px 0 0;
  }
}

.footer-link {
  align-items: center;
  display: flex;
  flex-direction: column;
  padding: 50px 0 0;
  position: relative;
}
.footer-link::before {
  background-image: linear-gradient(180deg, rgb(219, 239, 249) 36%, rgba(255, 255, 255, 0));
  content: "";
  display: block;
  height: 140px;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1;
}
.footer-link > button {
  background-color: #00b8ce;
  border-radius: 18px/50%;
  color: #fff;
  display: block;
  font-size: 1.13rem;
  font-weight: 700;
  line-height: 40px;
  margin: 0 auto 36px;
  max-width: 280px;
  outline: none;
  padding: 0;
  transition: all 0.3s;
  width: 70%;
}
.footer-link > button:hover {
  opacity: 0.6;
}
.footer-link > img {
  margin: 0 auto 20px;
  width: 300px;
}
.footer-link > a {
  color: #00b8ce;
  font-size: 0.94rem;
  font-weight: 700;
  display: block;
  margin: 0 auto 60px;
  text-decoration: underline;
}
.footer-link > a:hover {
  text-decoration: none;
}
.footer-link .wm-button-fill a {
  padding: 8px 20px;
}
.footer-nav {
  background-color: #00b8ce;
  padding: 30px 0 10px;
}
.footer-nav > ul {
  align-items: center;
  display: flex;
}
.footer-nav > ul > li > a {
  color: #fff;
  display: block;
  font-size: 0.94rem;
  font-weight: 700;
  text-decoration: none;
}
.footer-contact {
  background-color: #00b8ce;
  display: flex;
}
.footer-contact > ul {
  margin: 0;
}
.footer > p {
  background-color: #00b8ce;
  line-height: 1.2;
  margin: 0 auto;
  padding: 70px 0 10px;
  text-align: center;
}
.footer > p > small {
  color: #fff;
}
@media (max-width: 767px) {
  .footer-nav > ul {
    flex-direction: column;
    gap: 30px;
  }
  .footer-contact {
    align-items: center;
    flex-direction: column;
  }
  .footer-contact > ul {
    margin: 20px 0 0;
  }
  .footer > p > small {
    font-size: 0.63rem;
  }
}
@media (min-width: 768px) {
  .footer-nav > ul {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 30px 60px;
    justify-content: center;
  }
  .footer-contact {
    flex-direction: row;
    justify-content: center;
    gap: 40px;
  }
  .footer-contact > img {
    width: 252px;
    margin: 0;
  }
  .footer-contact > ul {
    width: 320px;
  }
  .footer > p > small {
    font-size: 0.75rem;
  }
}

.breadcrumb {
  margin: 0 auto 48px;
  max-width: 1280px;
  padding: 20px 20px 0;
}
.breadcrumb ol {
  display: flex;
  flex-flow: row wrap;
  gap: 16px;
  margin: 0;
}
.breadcrumb ol li {
  line-height: 1;
}
.breadcrumb ol li + li {
  position: relative;
}
.breadcrumb ol li + li::before, .breadcrumb ol li + li::after {
  background-color: #000;
  content: "";
  display: block;
  height: 1px;
  left: -11px;
  position: absolute;
  top: 0.5em;
  transform-origin: 100%;
  width: 7px;
}
.breadcrumb ol li + li::before {
  transform: rotate(20deg);
}
.breadcrumb ol li + li::after {
  transform: rotate(-20deg);
}
.breadcrumb ol li:last-child a {
  color: #000;
  text-decoration: none;
}
.breadcrumb ol li a {
  font-size: 0.88rem;
  line-height: 1;
}
@media (min-width: 768px) {
  .breadcrumb {
    padding: 20px 50px 0;
  }
}

.localnavi {
  background-color: #f4f4f4;
  margin: 50px auto;
}
.localnavi > ul > li > a {
  text-align: center;
}
.localnavi ul {
  margin: 0;
}
.localnavi ul li a {
  color: #000;
  display: block;
  font-weight: 700;
  text-decoration: none;
}
.localnavi > ul > li > a {
  background-color: #00b8ce;
  color: #fff;
  padding: 14px;
}
.localnavi > ul > li > a:hover {
  opacity: 0.6;
}
.localnavi > ul > li > ul {
  padding: 20px 30px 0;
}
.localnavi > ul > li > ul > li > a {
  font-size: 1rem;
}
.localnavi > ul > li > ul > li a {
  display: flex;
  flex-direction: row;
}
.localnavi > ul > li > ul > li a span:first-child {
  height: 16px;
  position: relative;
  width: 16px;
}
.localnavi > ul > li > ul > li a span:first-child::before {
  border: 1px solid;
  border-width: 2px 2px 0 0;
  content: "";
  display: block;
  height: 8px;
  left: 0;
  position: absolute;
  top: 6px;
  transform: rotate(45deg) skew(-10deg, -10deg);
  width: 8px;
}
.localnavi > ul > li > ul > li a span:last-child {
  max-width: calc(100% - 16px);
}
.localnavi > ul > li > ul > li a.wm-open span:first-child::before {
  left: 2px;
  top: 2px;
  transform: rotate(135deg) skew(-10deg, -10deg);
}
.localnavi > ul > li > ul > li a:hover {
  text-decoration: underline;
}
.localnavi > ul > li ul {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  gap: 17px;
}
.localnavi > ul > li > ul > li > ul {
  padding: 17px 20px 0;
}
.localnavi > ul > li > ul > li > ul > li a {
  font-size: 0.94rem;
}
.localnavi > ul > li > ul > li > ul > li > ul {
  padding: 17px 10px 0;
}
.localnavi > ul > li > ul > li > ul > li > ul > li a {
  font-weight: 500;
}
.localnavi > ul > li > ul > li > ul > li > ul > li a span:first-child::before {
  border-width: 1px 1px 0 0;
}
.localnavi > ul > li > ul > li > ul > li > ul > li > ul {
  padding: 17px 0 0;
}
.localnavi > ul > li > ul > li > ul > li > ul > li > ul > li > a span:first-child::before {
  background-color: #000;
  height: 5px;
  transform: rotate(0deg);
  width: 5px;
}
.localnavi > ul > li > ul > li > ul > li > ul > li > ul > li > a span:first-child::after {
  content: none;
}
@media (max-width: 1279px) {
  .localnavi {
    max-width: 768px;
  }
}
@media (min-width: 1280px) {
  .localnavi {
    margin: 0;
  }
}

.switch_box dt,
.switch_box .js_toggle_button {
  background-color: #00b8ce;
  color: #fff;
  cursor: pointer;
  font-size: 0.94rem;
  font-weight: 700;
  margin: 0;
  outline: none;
  padding: 12px 60px 12px 20px;
  position: relative;
  transition: all 0.3s;
}
.switch_box dt::before,
.switch_box .js_toggle_button::before {
  content: none;
}
.switch_box dt::after,
.switch_box .js_toggle_button::after {
  background-image: linear-gradient(rgba(255, 255, 255, 0) 6px, #fff 6px, #fff 10px, rgba(255, 255, 255, 0) 10px), linear-gradient(90deg, rgba(255, 255, 255, 0) 6px, #fff 6px, #fff 10px, rgba(255, 255, 255, 0) 10px);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 16px 16px;
  bottom: 0;
  content: "";
  height: 3px;
  margin: auto 0;
  position: absolute;
  right: 22px;
  top: 0;
  transition: all 0.3s;
  width: 16px;
}
.switch_box dt + *,
.switch_box .js_toggle_button + * {
  height: auto;
  margin: 0 0 20px;
  opacity: 1;
  padding: 20px 0 0 7px;
  transition: all 0.3s;
}
.switch_box dt.js_close,
.switch_box .js_toggle_button.js_close {
  background-color: #00b8ce;
  color: #fff;
}
.switch_box dt.js_close::after,
.switch_box .js_toggle_button.js_close::after {
  height: 16px;
}
.switch_box dt.js_close:hover,
.switch_box .js_toggle_button.js_close:hover {
  opacity: 0.6;
}
.switch_box dt.js_close + *,
.switch_box .js_toggle_button.js_close + * {
  -webkit-animation: act_open 0.3s 1 alternate forwards;
          animation: act_open 0.3s 1 alternate forwards;
  height: 0;
  opacity: 0;
  overflow: hidden;
  padding: 0 24px;
}

*:not(#notice) > .info-list > div {
  align-items: center;
  border-bottom: 1px solid #ccc;
  display: flex;
  flex-flow: row wrap;
  margin: 0 0 24px;
  padding: 0 0 24px;
}
*:not(#notice) > .info-list > div > dt {
  font-size: 0.88rem;
  width: 137px;
}
*:not(#notice) > .info-list > div > dd.label {
  border: 1px solid #ccc;
  font-size: 0.88rem;
  height: 24px;
  line-height: 22px;
  text-align: center;
  width: 96px;
}
*:not(#notice) > .info-list > div > dd.title {
  margin: 10px 0 0;
  width: 100%;
}
*:not(#notice) > .info-list > div > dd.title > a {
  color: #000;
}
@media (min-width: 480px) {
  *:not(#notice) > .info-list {
    margin: 0 auto;
    max-width: 960px;
  }
  *:not(#notice) > .info-list > div {
    align-items: baseline;
  }
  *:not(#notice) > .info-list > div > dd.title {
    margin: 0;
    width: calc(100% - 137px);
  }
  *:not(#notice) > .info-list > div > dd.label + dd.title {
    padding: 0 0 0 24px;
    width: calc(100% - 233px);
  }
}
@media (min-width: 1280px) {
  *:not(#notice) > .info-list {
    max-width: 1352px;
  }
}

.info-list + .wm-button-border a {
  margin: 0 auto 72px;
}
@media (min-width: 480px) {
  .info-list + .wm-button-border a {
    margin: 0 auto 104px;
  }
}

.info-list-with-thumbnail > div {
  align-items: flex-start;
  border-bottom: 1px solid #ccc;
  display: flex;
  flex-flow: row wrap;
  margin: 0 0 24px;
  padding: 0 0 24px;
}
.info-list-with-thumbnail > div > a,
.info-list-with-thumbnail > div > figure {
  margin: 0;
  padding: 0 24px 0 0;
  width: 30%;
}
.info-list-with-thumbnail > div > a > figure {
  margin: 0;
}
.info-list-with-thumbnail > div > div {
  display: flex;
  flex-flow: row wrap;
  width: 70%;
}
.info-list-with-thumbnail > div > div > dt {
  font-size: 0.88rem;
  width: 137px;
}
.info-list-with-thumbnail > div > div > dd.label {
  border: 1px solid #ccc;
  font-size: 0.88rem;
  height: 24px;
  line-height: 22px;
  text-align: center;
  width: 200px;
}
.info-list-with-thumbnail > div > div > dd.title {
  margin: 10px 0 0;
  width: 100%;
}
.info-list-with-thumbnail > div > div > dd.title > a {
  color: #000;
}
.info-list-with-thumbnail > div > div > dd.multi_label {
  align-items: center;
  display: flex;
  flex-flow: row wrap;
  gap: 8px;
}
.info-list-with-thumbnail > div > div > dd.multi_label > span {
  border: 1px solid #ccc;
  display: block;
  font-size: 0.88rem;
  height: 24px;
  line-height: 22px;
  text-align: center;
}
.info-list-with-thumbnail > div > div > dd.multi_label > span:nth-child(1) {
  width: 100px;
}
.info-list-with-thumbnail > div > div > dd.multi_label > span:nth-child(2) {
  min-width: 100px;
  padding: 0 10px;
}
@media (min-width: 480px) {
  .info-list-with-thumbnail > div {
    margin: 0 auto 24px;
    max-width: 960px;
  }
}
@media (min-width: 960px) {
  .info-list-with-thumbnail > div > a,
.info-list-with-thumbnail > div > figure {
    width: 264px;
  }
  .info-list-with-thumbnail > div > div {
    width: calc(100% - 264px);
  }
}
@media (min-width: 1280px) {
  .info-list-with-thumbnail > div {
    max-width: 1352px;
  }
}

/* modal window ------------------------------ */
html.js-active,
html.js-active body {
  min-height: 100%;
  min-width: 100%;
  overflow: hidden;
  position: relative;
}

.js_modal_window {
  background-color: #fff;
  border-radius: 4px;
  display: inline-flex;
  flex-direction: column;
  max-height: calc(100% - 32px);
  max-width: calc(100% - 32px);
  opacity: 0;
  padding-top: 24px;
  position: relative;
  transform: scale(0);
  transition: all 0.3s;
  z-index: 10002;
}
.js_modal_button {
  cursor: pointer;
  height: 18px;
  margin: 0;
  overflow: hidden;
  position: absolute;
  right: 0;
  text-indent: 20px;
  top: -32px;
  transition: all 0.3s;
  white-space: nowrap;
  width: 18px;
}
.js_modal_button::before, .js_modal_button::after {
  border-top: 2px solid #fff;
  content: "";
  display: block;
  bottom: -2px;
  height: 0;
  left: -2px;
  margin: auto;
  position: absolute;
  right: -2px;
  top: -2px;
  transform: rotate(45deg);
  width: 20px;
}
.js_modal_button::before {
  transform: rotate(45deg);
}
.js_modal_button::after {
  transform: rotate(-45deg);
}
.js_modal_button:hover::before, .js_modal_button:hover::after {
  border-color: #036eb8;
}
@media (min-width: 480px) {
  .js_modal_button {
    right: -32px;
    top: 0;
  }
}
.js_modal_scroll {
  box-sizing: border-box;
  max-height: calc(100% - 92px);
  max-width: 880px;
  overflow-y: auto;
  padding: 0 24px;
}
.js_modal_scroll > img:first-child:last-child {
  max-width: 500vw;
}
.js_modal_video {
  background-color: #000;
  border-radius: 0;
  display: block;
  padding: 0;
  width: 720px;
}
.js_modal_video .js_modal_scroll {
  max-height: calc(100vh - 192px);
  padding: 0;
}
.js_modal_video_inner {
  height: 0;
  padding-top: 56.25%;
  margin: 0;
  position: relative;
  width: 100%;
}
.js_modal_video_inner video,
.js_modal_video_inner iframe {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

#js_modal_screen,
#js_modal_area {
  height: 100%;
  left: 0;
  margin: 0;
  opacity: 0;
  position: fixed;
  top: 0;
  width: 100%;
}

#js_modal_screen {
  background-color: rgba(0, 0, 0, 0.8);
  cursor: pointer;
  transition: all 0.3s;
  z-index: 10001;
}
.js-active #js_modal_screen {
  opacity: 1;
}

#js_modal_area {
  align-items: center;
  justify-content: center;
  display: flex;
  opacity: 0;
  transition: all 0s 0.3s;
  visibility: hidden;
  z-index: 10000;
}
#js_modal_area.js-active {
  opacity: 1;
  transition: all 0s;
  visibility: visible;
}
#js_modal_area.js-active .js_modal_window {
  opacity: 1;
  transform: scale(1);
}

main:not(.top):not(.category):not(.contact) {
  display: flex;
  flex-direction: column;
  margin: 0 auto;
  padding: 0 20px;
}
@media (min-width: 768px) {
  main:not(.top):not(.category):not(.contact) {
    max-width: 1280px;
    padding: 0 50px;
  }
}
@media (min-width: 1280px) {
  main:not(.top):not(.category):not(.contact) {
    flex-direction: row;
    padding: 0 0 0 50px;
  }
  main:not(.top):not(.category):not(.contact) > article {
    padding: 0 80px 80px 0;
    width: calc(100% - 294px);
  }
  main:not(.top):not(.category):not(.contact) > .localnavi {
    width: 294px;
  }
}

h1,
h2,
h3,
h4,
h5,
.wm-h1,
.wm-h2,
.wm-h3,
.wm-h4,
.wm-h5 {
  position: relative;
}
h1::before,
h2::before,
h3::before,
h4::before,
h5::before,
.wm-h1::before,
.wm-h2::before,
.wm-h3::before,
.wm-h4::before,
.wm-h5::before {
  content: "";
  display: block;
  position: absolute;
}

h1,
.wm-h1 {
  font-size: 2.5rem;
  font-weight: 700;
  margin: 0 0 33px;
  padding: 0 0 0 64px;
}
h1::before, h1::after,
.wm-h1::before,
.wm-h1::after {
  height: 20px;
  width: 20px;
}
h1::before,
.wm-h1::before {
  background-color: #6eb795;
  left: 0;
  top: 12px;
}
h1::after,
.wm-h1::after {
  background-color: #84a7c6;
  bottom: 0;
  content: "";
  display: block;
  left: 20px;
  position: absolute;
  top: 32px;
}
@media (min-width: 768px) {
  h1,
.wm-h1 {
    margin: 0 0 33px 0;
  }
}

h2,
.wm-h2 {
  font-size: 1.56rem;
  font-weight: 700;
  margin: 40px 0 14px;
}

h3,
.wm-h3 {
  font-size: 1.25rem;
  font-weight: 700;
  margin: 40px 0 16px;
  padding: 0 0 0 30px;
}
h3::before,
.wm-h3::before {
  background-color: #00b8ce;
  border-radius: 100%;
  height: 20px;
  left: 0;
  top: 4px;
  width: 20px;
}

h4,
.wm-h4 {
  font-size: 1.13rem;
  font-weight: 700;
  margin: 40px 0 17px;
  padding: 0 0 0 30px;
}
h4::before,
.wm-h4::before {
  background-color: #4b4b4b;
  border-radius: 100%;
  height: 20px;
  left: 0;
  top: 3px;
  width: 20px;
}

h5,
.wm-h5 {
  font-size: 1rem;
  font-weight: 700;
  margin: 40px 0 18px;
}
h5::before,
.wm-h5::before {
  content: none;
}

h6,
.wm-h6 {
  font-size: 0.94rem;
  font-weight: 700;
  margin: 40px 0 19px;
}

p {
  font-size: 0.94rem;
  margin: 0 0 24px;
}

.lead-sentence {
  font-size: 1.13rem;
  font-weight: 700;
}
@media (min-width: 768px) {
  .lead-sentence {
    margin: 0 0 40px 0;
  }
}

.release_date {
  font-size: 1.13rem;
  margin: 0 0 17px;
}
@media (min-width: 768px) {
  .release_date {
    margin: 0 0 17px 0;
  }
}

.wm-left {
  text-align: left;
}

.wm-center {
  text-align: center;
}

.wm-right {
  text-align: right;
}

sup {
  font-size: 0.6em;
  vertical-align: text-top;
}

sub {
  font-size: 0.6em;
  vertical-align: text-bottom;
}

.wm-link-path {
  word-break: break-all;
}

figure {
  margin: 0 0 24px;
}
figure img {
  vertical-align: bottom;
}
figure figcaption {
  font-size: 0.81rem;
  margin: 12px 0 0;
  text-align: center;
}

hr {
  border-top: 1px solid #ccc;
  height: 0;
  margin: 24px 0;
}

ul, ol {
  margin: 0 0 24px;
}
ul ul, ul ol, ol ul, ol ol {
  margin: 0;
}

.wm-ul-def > li:not(.wm-icon),
.wm-ul-circle > li:not(.wm-icon),
.wm-ul-disc > li:not(.wm-icon),
.wm-ul-square > li:not(.wm-icon) {
  font-size: 0.94rem;
  padding: 0 0 0 20px;
  position: relative;
  margin: 0 0 7px;
}
.wm-ul-def > li:not(.wm-icon)::before,
.wm-ul-circle > li:not(.wm-icon)::before,
.wm-ul-disc > li:not(.wm-icon)::before,
.wm-ul-square > li:not(.wm-icon)::before {
  content: "";
  display: block;
  position: absolute;
}

.wm-ul-def > li:not(.wm-icon)::before,
.wm-ul-circle > li:not(.wm-icon)::before {
  background-color: #4b4b4b;
  border-radius: 100%;
  height: 5px;
  left: 0;
  top: 8px;
  width: 5px;
}

.wm-ul-disc > li:not(.wm-icon)::before {
  background-color: #4b4b4b;
  border-radius: 100%;
  height: 3px;
  left: 0;
  top: 10px;
  width: 3px;
}

.wm-ul-square > li:not(.wm-icon)::before {
  background-color: #4b4b4b;
  height: 5px;
  left: 0;
  top: 8px;
  width: 5px;
}

.wm-ol-decimal,
.wm-ol-lower-greek,
.wm-ol-lower-alpha,
.wm-ol-lower-roman,
.wm-ol-upper-alpha,
.wm-ol-upper-roman {
  list-style-position: outside;
}
.wm-ol-decimal > li:not(.wm-icon),
.wm-ol-lower-greek > li:not(.wm-icon),
.wm-ol-lower-alpha > li:not(.wm-icon),
.wm-ol-lower-roman > li:not(.wm-icon),
.wm-ol-upper-alpha > li:not(.wm-icon),
.wm-ol-upper-roman > li:not(.wm-icon) {
  font-size: 0.94rem;
  margin: 0 0 7px 24px;
  padding: 0 0 0 10px;
}

.wm-ol-decimal {
  list-style-type: decimal;
}

.wm-ol-lower-greek {
  list-style-type: lower-greek;
}

.wm-ol-lower-alpha {
  list-style-type: lower-alpha;
}

.wm-ol-upper-alpha {
  list-style-type: upper-alpha;
}

.wm-ol-lower-roman {
  list-style-type: lower-roman;
}

.wm-ol-upper-roman {
  list-style-type: upper-roman;
}

p,
.wm-icon {
  /*@at-root {
  	ulp, .wm-icon {
  		> li > a {
  			display: inline-block;
  			padding-left: 16px;
  			&::before {
  				margin-left: -16px;
  			}
  		}
  	}
  	h2p, .wm-icon {
  		line-height: 1.8;
  	}
  }*/
}
p a,
.wm-icon a {
  display: inline-block;
  font-size: 0.94rem;
  position: relative;
}
p a:not([target=_blank]):not([href*=".pdf"]):not([href$=".doc"]):not([href$=".docx"]):not([href$=".xls"]):not([href$=".xlsx"]):not([href$=".zip"])::before,
.wm-icon a:not([target=_blank]):not([href*=".pdf"]):not([href$=".doc"]):not([href$=".docx"]):not([href$=".xls"]):not([href$=".xlsx"]):not([href$=".zip"])::before {
  content: ">";
  display: inline;
}
p a[target=_blank], p a[href*=".pdf"], p a[href$=".doc"], p a[href$=".docx"], p a[href$=".xls"], p a[href$=".xlsx"], p a[href$=".zip"],
.wm-icon a[target=_blank],
.wm-icon a[href*=".pdf"],
.wm-icon a[href$=".doc"],
.wm-icon a[href$=".docx"],
.wm-icon a[href$=".xls"],
.wm-icon a[href$=".xlsx"],
.wm-icon a[href$=".zip"] {
  color: #000;
  padding-left: 30px;
  text-decoration: none;
}
p a[target=_blank]::before, p a[href*=".pdf"]::before, p a[href$=".doc"]::before, p a[href$=".docx"]::before, p a[href$=".xls"]::before, p a[href$=".xlsx"]::before, p a[href$=".zip"]::before,
.wm-icon a[target=_blank]::before,
.wm-icon a[href*=".pdf"]::before,
.wm-icon a[href$=".doc"]::before,
.wm-icon a[href$=".docx"]::before,
.wm-icon a[href$=".xls"]::before,
.wm-icon a[href$=".xlsx"]::before,
.wm-icon a[href$=".zip"]::before {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 20px;
  left: 0;
  position: absolute;
  top: 0;
  width: 20px;
}
p a[target=_blank]:hover, p a[href*=".pdf"]:hover, p a[href$=".doc"]:hover, p a[href$=".docx"]:hover, p a[href$=".xls"]:hover, p a[href$=".xlsx"]:hover, p a[href$=".zip"]:hover,
.wm-icon a[target=_blank]:hover,
.wm-icon a[href*=".pdf"]:hover,
.wm-icon a[href$=".doc"]:hover,
.wm-icon a[href$=".docx"]:hover,
.wm-icon a[href$=".xls"]:hover,
.wm-icon a[href$=".xlsx"]:hover,
.wm-icon a[href$=".zip"]:hover {
  text-decoration: underline;
}
p a[target=_blank]::before,
.wm-icon a[target=_blank]::before {
  background-image: url(../img/icon/blank.png);
}
p a[href*=".pdf"]::before,
.wm-icon a[href*=".pdf"]::before {
  background-image: url(../img/icon/pdf.png);
}
p a[href$=".doc"]::before, p a[href$=".docx"]::before,
.wm-icon a[href$=".doc"]::before,
.wm-icon a[href$=".docx"]::before {
  background-image: url(../img/icon/doc.png);
}
p a[href$=".xls"]::before, p a[href$=".xlsx"]::before,
.wm-icon a[href$=".xls"]::before,
.wm-icon a[href$=".xlsx"]::before {
  background-image: url(../img/icon/xls.png);
}
p a[href$=".zip"]::before,
.wm-icon a[href$=".zip"]::before {
  background-image: url(../img/icon/zip.png);
}

li.wm-icon {
  margin: 0 0 14px;
}
li.wm-icon ul {
  padding: 14px 0 0 20px;
}

/*
h2.wm-icon {
	font-size: b.$font-18px;
	+ ul.wm-icon {
		margin-left: 16px;
	}
}
.wm-list-indent1,
.wm-list-indent2 {
	* + & {
		margin-top: 20px;
	}
	 > li*:not([class*='list-indent']) > li {
		text-indent: 0;
	}
}
.wm-list-indent1 > li {
	padding-left: 1em;
	text-indent: -1em;
}
.wm-list-indent2 > li {
	padding-left: 2em;
	text-indent: -2em;
}
*/
.wm-index {
  display: flex;
  flex-flow: column wrap;
  gap: 14px 18px;
}
.wm-index > li {
  width: 100%;
}
.wm-index > li > a {
  border: 2px solid #00b8ce;
  color: #000;
  display: block;
  font-size: 0.94rem;
  padding: 14px 8px 14px 44px;
  position: relative;
  text-decoration: none;
}
.wm-index > li > a::before, .wm-index > li > a::after {
  content: "";
  display: block;
  position: absolute;
  transition: all 0.3s;
}
.wm-index > li > a::before {
  border: 2px solid #00b8ce;
  height: 21px;
  left: 9px;
  top: 11px;
  width: 21px;
}
.wm-index > li > a::after {
  border: 1px solid #00b8ce;
  border-width: 3px 3px 0 0;
  height: 5px;
  left: 17px;
  top: 20px;
  transform: rotate(45deg);
  width: 5px;
}
.wm-index > li > a:hover {
  text-decoration: underline;
}
.wm-index > li > a:hover::before {
  background-color: #00b8ce;
}
.wm-index > li > a:hover::after {
  border-color: #fff;
}
@media (min-width: 480px) {
  .wm-index {
    flex-flow: row wrap;
  }
  .wm-index > li {
    width: calc(50% - 9px);
  }
}

.wm-link-column {
  display: flex;
  flex-flow: row wrap;
  gap: 0 24px;
}

/*.wm-link-column {
	border: 1px solid b.$color-border;
	padding: 0 0 24px;
	* + & {
		margin-top: 24px;
	}
	li {
		box-sizing: border-box;
		display: flex;
		margin-top: 24px !important;
		width: 100%;
	}
	a {
		align-items: center;
		background-color: b.$color-g3;
		box-sizing: border-box;
		color: #fff;
		display: flex;
		justify-content: center;
		margin: 0 auto;
		max-width: 240px;
		padding: 8px;
		text-decoration: none;
		width: 100%;
		&:hover,
		&:active {
			background-color: b.$color-main;
		}
	}
	@include b.mqMin(b.$screen-xs) {
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
		padding: 0 12px 24px;
		li {
			padding: 0 12px;
			width: 50%;
		}
	}
	@include b.mqMin(600px) {
		&:not(.wm-column3) {
			padding: 0 6.625% 24px;
		}
		&.wm-column3 {
			padding: 0 12px 24px;
			li {
				width: 33.333%;
			}
		}
	}
}
*/
.wm-link-column2,
.wm-link-column3 {
  display: flex;
  flex-flow: column wrap;
  gap: 7px 18px;
}
.wm-link-column2 > li,
.wm-link-column3 > li {
  margin: 0 !important;
  width: 100%;
}
@media (min-width: 480px) {
  .wm-link-column2,
.wm-link-column3 {
    flex-flow: row wrap;
  }
  .wm-link-column2 > li,
.wm-link-column3 > li {
    width: calc(50% - 9px);
  }
}

@media (min-width: 768px) {
  .wm-link-column3 > li {
    width: calc(33.33% - 12px);
  }
}

table {
  margin: 0 0 24px;
  width: 100%;
}

caption {
  font-weight: 700;
  padding-bottom: 0.5em;
}

th,
td {
  border: 1px solid #4b4b4b;
  padding: 5px 20px;
}
th *:last-child,
td *:last-child {
  margin: 0;
}

th {
  background-color: #e1e1e1;
  font-weight: 700;
}
.th_wid4 tbody th:first-child:last-of-type {
  box-sizing: content-box;
  max-width: 50%;
  width: 4em;
}
.th_wid6 tbody th:first-child:last-of-type {
  box-sizing: content-box;
  max-width: 50%;
  width: 6em;
}
.th_wid8 tbody th:first-child:last-of-type {
  box-sizing: content-box;
  max-width: 50%;
  width: 8em;
}

td {
  background-color: #fff;
}

.wm-table-above-and-left thead th {
  background-color: #8f8f8f;
}

input[placeholder]::-webkit-input-placeholder {
  color: #ccc;
}

input[placeholder]::-moz-placeholder {
  color: #ccc;
}

input[placeholder]:-ms-input-placeholder {
  color: #ccc;
}

input[placeholder]:focus::-webkit-input-placeholder {
  color: #ccc;
}

input[placeholder]:focus::-moz-placeholder {
  color: #ccc;
}

input[placeholder]:focus:-ms-input-placeholder {
  color: #ccc;
}

.wm-border,
.wm-background,
.wm-border-background {
  margin: 0 0 24px;
  padding: 17px 20px;
}
.wm-border *:last-child,
.wm-background *:last-child,
.wm-border-background *:last-child {
  margin: 0;
}

.wm-border {
  border: 2px solid #4b4b4b;
}

.wm-background {
  border: 2px solid #00b8ce;
}

.wm-border-background {
  border: 2px solid #f15c9b;
}

.wm-button-fill {
  margin: 0;
}
.wm-button-fill a, .wm-button-fill button {
  border-radius: 20px/50%;
  color: #fff;
  display: block;
  font-size: 1.13rem;
  font-weight: 700;
  margin: 0 auto 24px;
  max-width: 430px;
  outline: none;
  padding: 12px 20px;
  text-align: center;
  text-decoration: none;
  transition: all 0.3s;
  width: 100%;
}
.wm-button-fill a:hover, .wm-button-fill button:hover {
  opacity: 0.6;
}

.wm-button-fill.green a, .wm-button-fill.green button {
  background-color: #00b8ce;
}

.wm-button-fill.gray a, .wm-button-fill.gray button {
  background-color: #8f8f8f;
}

@media (min-width: 480px) {
  ul.wm-column2.button,
ul.wm-column2.tab {
    gap: 0 50px;
    justify-content: center;
    margin: 0;
  }
  ul.wm-column2.button > li,
ul.wm-column2.tab > li {
    width: calc(50% - 25px);
  }
}

@media (min-width: 480px) {
  .wm-column2,
.wm-column3,
.wm-column4 {
    display: flex;
    flex-flow: row wrap;
    gap: 0 50px;
  }
  .wm-column2 > .wm-column-item,
.wm-column3 > .wm-column-item,
.wm-column4 > .wm-column-item {
    width: calc(50% - 25px);
  }
}
@media (min-width: 768px) {
  .wm-column3 > .wm-column-item {
    width: calc(33.33% - 33.33px);
  }
}
@media (min-width: 768px) {
  .wm-column4 > .wm-column-item {
    width: calc(25% - 37.5px);
  }
}
.wm-parallelL-large, .wm-parallelL-medium, .wm-parallelL-small,
.wm-parallelR-large,
.wm-parallelR-medium,
.wm-parallelR-small {
  align-items: flex-start;
  display: flex;
  flex-flow: row wrap;
  gap: 0 20px;
  justify-content: space-between;
}
.wm-parallelL-large-txt,
.wm-parallelR-large-txt {
  width: 100%;
}
.wm-parallelL-medium-txt,
.wm-parallelR-medium-txt {
  width: 100%;
}
.wm-parallelL-small-txt,
.wm-parallelR-small-txt {
  width: 100%;
}

.wm-roundL-large, .wm-roundL-medium, .wm-roundL-small,
.wm-roundR-large,
.wm-roundR-medium,
.wm-roundR-small {
  clear: both;
}
.wm-roundL-large:after, .wm-roundL-medium:after, .wm-roundL-small:after,
.wm-roundR-large:after,
.wm-roundR-medium:after,
.wm-roundR-small:after {
  content: "";
  display: block;
  clear: both;
}

.wm-roundL-large-img, .wm-roundL-medium-img, .wm-roundL-small-img {
  margin: 0;
}

.wm-roundR-large-img, .wm-roundR-medium-img, .wm-roundR-small-img {
  margin: 0;
}

@media (min-width: 600px) {
  .wm-parallelL-large-img,
.wm-parallelR-large-img,
.wm-roundL-large-img,
.wm-roundR-large-img {
    max-width: 350px;
  }
  .wm-parallelL-medium-img,
.wm-parallelR-medium-img,
.wm-roundL-medium-img,
.wm-roundR-medium-img {
    max-width: 280px;
  }
  .wm-parallelL-small-img,
.wm-parallelR-small-img,
.wm-roundL-small-img,
.wm-roundR-small-img {
    max-width: 200px;
  }
  .wm-parallelL-large-txt,
.wm-parallelR-large-txt {
    max-width: calc(100% - 370px);
  }
  .wm-parallelL-medium-txt,
.wm-parallelR-medium-txt {
    max-width: calc(100% - 300px);
  }
  .wm-parallelL-small-txt,
.wm-parallelR-small-txt {
    max-width: calc(100% - 220px);
  }
  .wm-roundL-large, .wm-roundL-medium, .wm-roundL-small,
.wm-roundR-large,
.wm-roundR-medium,
.wm-roundR-small {
    clear: both;
  }
  .wm-roundL-large:after, .wm-roundL-medium:after, .wm-roundL-small:after,
.wm-roundR-large:after,
.wm-roundR-medium:after,
.wm-roundR-small:after {
    content: "";
    display: block;
    clear: both;
  }
  .wm-roundL-large-img, .wm-roundL-medium-img, .wm-roundL-small-img {
    float: left;
    margin: 0 20px 0 0;
  }
  .wm-roundR-large-img, .wm-roundR-medium-img, .wm-roundR-small-img {
    float: right;
    margin: 0 0 0 20px;
  }
}
a img {
  transition: all 0.3s;
}
a:hover img {
  opacity: 0.6;
}

/* お問い合わせボタン */
/* packege */
/* margin */
.mt0 {
  margin-top: 0px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mt60 {
  margin-top: 60px !important;
}

.mt70 {
  margin-top: 70px !important;
}

.mt80 {
  margin-top: 80px !important;
}

/* google map */
/* youtube */