@charset "UTF-8";
/**
 * Normalize
 */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
}

@media (max-width: 599.9px) {
  html {
    font-size: 3.84vw;
  }
}
body {
  margin: 0;
  background-color: #d8d8d8;
  color: #333;
  font-family: "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: 500;
  -webkit-text-size-adjust: 100%;
}

a {
  color: hsl(135, 60%, 60%);
}
a:hover {
  color: hsl(135, 40%, 40%);
}

img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}

figure {
  display: block;
  margin: 0;
}

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

th {
  text-align: left;
}

button, input, select, textarea {
  font: inherit;
}

/**
 * Site Header
 */
.siteHeader {
  width: min(100%, 54rem);
  margin: auto;
}

/**
 * Site Title
 */
.siteTitle {
  margin: 0;
  padding: 1.5rem 0.75rem;
  background: linear-gradient(#000, hsl(135, 60%, 60%));
  font-size: 2rem;
  text-align: center;
  line-height: 1.2;
}
.siteTitle a {
  color: #fff;
}
.siteTitle span {
  display: inline-block;
}

/**
 * G Nav
 */
.gNav {
  background-color: #fff;
}

.gNav__heading {
  margin: 0;
  padding: 0.375rem 0;
  background-color: #333;
  color: #fff;
  font-size: 1rem;
  text-align: center;
  text-transform: uppercase;
}

.gNav__menu {
  list-style: none;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  margin: 0;
  padding: 0.75rem 0;
  text-align: center;
}

.gNav__menuItem {
  flex: 1 0 50%;
  margin: 0.375rem 0;
}
.gNav__menuItem:nth-child(even) {
  border-left: 1px solid hsl(135, 60%, 60%);
}

@media (min-width: 600px) {
  .gNav__heading {
    display: none;
  }
  .gNav__menuItem {
    flex: 1 0 auto;
    border-left: 1px solid hsl(135, 60%, 60%);
  }
  .gNav__menuItem:first-child {
    border-left: none;
  }
}
/**
 * Main
 */
.main {
  width: min(100%, 54rem);
  margin: auto;
  background-color: #fff;
}

/**
 * Page Header
 */
.pageHeader {
  padding: 0 0.75rem 0.75rem;
  background-color: #333;
  color: #fff;
}

.pageHeader__mainVisual {
  margin: 0 -0.75rem;
}

@media (min-width: 600px) {
  .pageHeader {
    padding: 0 3rem 0.75rem;
  }
  .pageHeader__mainVisual {
    margin: 0 -3rem;
  }
}
/**
 * Local Nav
 */
.localNav__menu {
  list-style: none;
  display: flex;
  flex-flow: row wrap;
  padding: 0;
}

.localNav__menuItem:not(:last-child)::after {
  content: "/";
  margin: 0 0.75rem;
}

/**
 * Section
 */
.section {
  padding: 0.75rem;
}
.section p {
  margin: 0.75rem 0;
  text-align: justify;
}

@media (min-width: 600px) {
  .section {
    padding: 1.5rem 3rem;
  }
}
/**
 * Article
 */
.article {
  padding: 0.75rem 0;
}
.article p {
  margin: 0.75rem 0;
  text-align: justify;
}

/**
 * Heading
 */
.heading {
  margin: 1.5rem 0 0.75rem;
  line-height: 1.2;
}
.heading.--level_1 {
  margin-top: 1.5rem;
  font-size: 1.5rem;
}
.heading.--level_2 {
  border-bottom: 1px dashed #ccc;
  font-size: 1.5rem;
}
.heading.--level_3 {
  font-size: 1.17rem;
}

/**
 * Media Text
 */
@media (min-width: 600px) {
  .mediaText {
    display: flex;
    flex-flow: row wrap;
  }
  .mediaText__media {
    flex: 1 1 18rem;
    order: 1;
    padding: 0.75rem;
  }
  .mediaText__text {
    flex: 1 1 30rem;
    order: 0;
    padding: 0.75rem;
  }
}
/**
 * Gallery
 */
.gallery__media:not(:last-child) {
  margin-bottom: 0.75rem;
}

@media (min-width: 600px) {
  .gallery {
    display: flex;
    flex-flow: row wrap;
  }
  .gallery__media {
    flex: 1 1 24rem;
    margin: 0;
    padding: 0.75rem;
  }
}
/**
 * Table Wrap
 */
.tableWrap {
  width: 100%;
  overflow-x: auto;
}

/**
 * Table
 */
.table {
  width: 48rem;
  font-size: 0.875rem;
}
.table thead {
  border: 0;
}
.table tr {
  border-bottom: 1px solid #ccc;
}
.table tr:first-child {
  border-top: 1px solid #ccc;
}
.table th, .table td {
  padding: 0.625rem;
  border: 0;
}

/**
 * Footer
 */
.footer {
  padding: 6rem 0;
  background-color: #333;
  color: #fff;
  text-align: center;
}

/**
 * Component - Icon
 */
.icon {
  position: relative;
  display: inline-block;
  width: 1.5rem;
  height: 1.5rem;
  overflow: hidden;
  fill: currentColor;
}
.icon--md {
  width: 2.25rem;
  height: 2.25rem;
}
.icon--lg {
  width: 3rem;
  height: 3rem;
}
.icon__span {
  position: relative;
  display: block;
  border-width: 0;
  border-style: solid;
  border-color: #fff;
  transition: border-color 0.25s ease;
}
.icon--menu .icon__span {
  width: 60%;
  height: 20%;
  margin: 40% 20%;
  border-block-start-width: 2px;
  border-block-end-width: 2px;
}
.icon--close .icon__span::before, .icon--close .icon__span::after {
  content: "";
  position: absolute;
  display: block;
  width: 60%;
  height: 4%;
  margin: 48% 20%;
  border: 1px solid #fff;
  transform: rotate(-45deg);
}
.icon--close .icon__span::after {
  transform: rotate(45deg);
}
.icon--chevron-up .icon__span {
  width: 30%;
  height: 30%;
  margin: 35%;
  border-block-start-width: 2px;
  border-inline-start-width: 2px;
  transform: rotate(45deg) translate(10%, 10%);
}
.icon--chevron-down .icon__span {
  width: 30%;
  height: 30%;
  margin: 35%;
  border-inline-end-width: 2px;
  border-block-end-width: 2px;
  transform: rotate(45deg) translate(-10%, -10%);
}
.icon--chevron-left .icon__span {
  width: 30%;
  height: 30%;
  margin: 35%;
  border-inline-start-width: 2px;
  border-block-end-width: 2px;
  transform: rotate(45deg) translate(10%, -10%);
}
.icon--chevron-right .icon__span {
  width: 30%;
  height: 30%;
  margin: 35%;
  border-block-start-width: 2px;
  border-inline-end-width: 2px;
  transform: rotate(45deg) translate(-10%, 10%);
}

/**
 * Component - Back To Top
 */
.backToTop {
  position: fixed;
  right: 0.75rem;
  bottom: 0.75rem;
  z-index: 1000;
  display: block;
  width: 3rem;
  height: 3rem;
  padding: 0;
  opacity: 0;
  transform: translateY(1rem) rotateY(-180deg);
  transition: all 0.5s ease;
  text-align: center;
  outline: 0;
  cursor: default;
  pointer-events: none;
}
.backToTop--active {
  opacity: 1;
  transform: translateY(0) rotateY(0);
  cursor: pointer;
  pointer-events: auto;
}
.backToTop > .icon {
  border-radius: 50%;
  background-color: hsl(135, 40%, 40%);
  transition: background-color 0.25s ease;
}
.backToTop > .icon > .icon__span, .backToTop > .icon > .icon__span::before, .backToTop > .icon > .icon__span::after {
  border-color: #fff;
}
.backToTop:hover > .icon {
  background-color: hsl(135, 60%, 60%);
}
.backToTop:hover > .icon > .icon__span, .backToTop:hover > .icon > .icon__span::before, .backToTop:hover > .icon > .icon__span::after {
  border-color: #333;
}

/**
 * Component - Drawer Menu
 */
.drawer {
  position: fixed;
  top: 0.75rem;
  right: 0.75rem;
  z-index: 1110;
  display: block;
  width: 3rem;
  height: 3rem;
  padding: 0;
  border: 0;
  background-color: transparent;
  text-align: center;
  outline: 0;
  cursor: pointer;
}
.drawer__navicon {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1110;
  opacity: 0;
  transform: rotateY(-180deg);
  transition: all 0.5s ease;
}
.drawer__navicon > .icon {
  border-radius: 0;
  background-color: hsl(135, 40%, 40%);
  transition: background-color 0.25s ease;
}
.drawer__navicon > .icon > .icon__span, .drawer__navicon > .icon > .icon__span::before, .drawer__navicon > .icon > .icon__span::after {
  border-color: #fff;
}
.drawer__navicon:hover > .icon {
  background-color: hsl(135, 60%, 60%);
}
.drawer__navicon:hover > .icon > .icon__span, .drawer__navicon:hover > .icon > .icon__span::before, .drawer__navicon:hover > .icon > .icon__span::after {
  border-color: #333;
}
.drawer:not(.drawer--active):not(.drawer--ready) .drawer__navicon {
  opacity: 1;
  transform: rotateY(0);
}
.drawer__close {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1100;
  opacity: 1;
  transform: rotateY(0);
  transition: all 0.5s ease;
}
.drawer__close > .icon {
  border-radius: 0;
  background-color: hsl(135, 40%, 40%);
  transition: background-color 0.25s ease;
}
.drawer__close > .icon > .icon__span, .drawer__close > .icon > .icon__span::before, .drawer__close > .icon > .icon__span::after {
  border-color: #fff;
}
.drawer__close:hover > .icon {
  background-color: hsl(135, 40%, 40%);
}
.drawer__close:hover > .icon > .icon__span, .drawer__close:hover > .icon > .icon__span::before, .drawer__close:hover > .icon > .icon__span::after {
  border-color: #333;
}
.drawer:not(.drawer--active) .drawer__close {
  opacity: 0;
  transform: rotateY(180deg);
}

.drawerMenu {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 1100;
  width: clamp(18rem, 40%, 24rem);
  height: 100%;
  margin: auto;
  background-color: hsl(135, 40%, 40%);
  text-align: center;
  transition: width 0.5s ease;
}
.drawerMenu:not(.drawerMenu--show) {
  width: 0;
}
.drawerMenu__inner {
  display: flex;
  flex-wrap: wrap;
  align-content: center;
  height: 100%;
  margin: 0;
  padding-inline-start: 0;
  text-align: left;
  opacity: 1;
}
.drawerMenu__inner:not(.drawerMenu__inner--show) {
  opacity: 0;
}
.drawerMenu__inner--collapse {
  display: none;
}
.drawerMenu__primaryMenu, .drawerMenu__socialMenu {
  list-style: none;
  flex: 1 1 100%;
  padding-inline-start: 0;
}
.drawerMenu__socialMenu {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding-inline-start: 20%;
}
.drawerMenu__item {
  width: 100%;
  margin: 0;
  text-transform: capitalize;
}
.drawerMenu__item a {
  display: block;
  padding-block: 0.375rem;
  padding-inline-start: 20%;
  color: #fff;
  fill: #fff;
  text-decoration: none;
  transition: all 0.25s ease;
}
.drawerMenu__item a:hover {
  background-color: hsl(135, 60%, 60%);
  color: #333;
  fill: #333;
}
.drawerMenu__item--siteBrand {
  padding-block: 1rem;
  font-size: 1.5rem;
}
.drawerMenu__item--siteBrand a {
  padding: 0 0 0 20%;
}
.drawerMenu__item--siteBrand img {
  width: auto;
  height: 3rem;
}
.drawerMenu__item--social {
  width: -moz-fit-content;
  width: fit-content;
  padding-block: 1rem;
}
.drawerMenu__item--social a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 3rem;
  height: 3rem;
  padding: 0;
}
.drawerMenu__item--social img {
  width: 100%;
  height: auto;
}

.drawerMenuOverlay {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 1090;
  display: block;
  width: 100%;
  height: 100%;
  background-color: transparent;
}
.drawerMenuOverlay--collapse {
  display: none;
}

/**
 * Component - Modal
 */
.modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  width: 100%;
  height: 100vh;
  transition: opacity 0.5s ease;
}
.modal--hide {
  opacity: 0;
}
.modal[aria-hidden=true] {
  visibility: hidden;
}
.modal__main {
  position: absolute;
  inset: 0;
  z-index: 2000;
  width: -moz-fit-content;
  width: fit-content;
  height: min(100%, 36rem);
  margin: auto;
}
.modal__main img {
  width: auto;
  height: 100%;
}
.modal__image {
  opacity: 0;
  transition: opacity 0.25s ease;
}
.modal__image.is-loaded {
  opacity: 1;
}
.modal__overlay {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1990;
  width: 100%;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.7);
}
.modal__close, .modal__prev, .modal__next {
  position: absolute;
  z-index: 2010;
  width: 3rem;
  height: 3rem;
  margin: auto;
  border-radius: 50%;
  overflow: hidden;
}
.modal__close > .icon, .modal__prev > .icon, .modal__next > .icon {
  border-radius: 0;
  background-color: hsl(135, 40%, 40%);
  transition: background-color 0.25s ease;
}
.modal__close > .icon > .icon__span, .modal__close > .icon > .icon__span::before, .modal__close > .icon > .icon__span::after, .modal__prev > .icon > .icon__span, .modal__prev > .icon > .icon__span::before, .modal__prev > .icon > .icon__span::after, .modal__next > .icon > .icon__span, .modal__next > .icon > .icon__span::before, .modal__next > .icon > .icon__span::after {
  border-color: #fff;
}
.modal__close:hover > .icon, .modal__prev:hover > .icon, .modal__next:hover > .icon {
  background-color: hsl(135, 60%, 60%);
}
.modal__close:hover > .icon > .icon__span, .modal__close:hover > .icon > .icon__span::before, .modal__close:hover > .icon > .icon__span::after, .modal__prev:hover > .icon > .icon__span, .modal__prev:hover > .icon > .icon__span::before, .modal__prev:hover > .icon > .icon__span::after, .modal__next:hover > .icon > .icon__span, .modal__next:hover > .icon > .icon__span::before, .modal__next:hover > .icon > .icon__span::after {
  border-color: #333;
}
.modal__close {
  top: 0.75rem;
  right: 0.75rem;
}
.modal__prev {
  top: 0;
  left: 0.75rem;
  bottom: 0;
}
.modal__next {
  top: 0;
  right: 0.75rem;
  bottom: 0;
}

[data-gallery-item] {
  cursor: pointer;
}