@charset "UTF-8";
/*------------------------------------------------------------


  style.css


------------------------------------------------------------*/
@media (orientation: landscape), (min-width: 769px) and (orientation: portrait) {}
@media (max-width: 768px) and (orientation: portrait) {}
@media (-webkit-max-device-pixel-ratio: 1), (max-resolution: 1dppx) {}
@media (hover: hover) {}


/*============================================================
  #head
============================================================*/
#head {
  width: 100%;
  position: relative;
  z-index: 0;
}

#head > .div-body {
  width: var(--grid-164);
  margin-inline: auto;
  padding-block: var(--grid-4);
  position: relative;
}

#top #head > .div-body {
  padding-block: var(--grid-8);
}

#head .div-title + .div-nav {
  margin-block-start: var(--grid-2);
}

#head .div-heading {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
  width: var(--grid-68);
  margin-top: var(--grid-68);
  margin-left: var(--grid-88);
}

#head .div-heading .h-catchline {
  font-size: 4.8rem;
  letter-spacing: 0.064em;
  line-height: 1.44;
  margin-block: -0.22em;
}

#head .div-heading .p-catchline {
  font-size: 1.84rem;
  letter-spacing: 0.064em;
  line-height: 1.28;
  margin-block: -0.14em;
}

#head .div-heading .ul-points {
  display: flex;
  flex-direction: column;
  gap: var(--grid);
}

#head .div-guide {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
  width: var(--grid-68);
  margin-top: var(--grid-17);
}

#head .div-guide .div-timetable {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: 100%;
}

#head .div-guide .div-timetable .h-heading-small {
  padding-inline: calc(var(--grid) * 0.5);
}

#head .div-guide .ul-notes {
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 1.3);
  padding-inline: calc(var(--grid) * 0.5);
}

#head .div-image {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}

#head .div-image .figure-image {
  position: absolute;
}

#head .div-image .figure-image::after {
  content: "";
  aspect-ratio: 1 / 1;
  display: block;
  background-color: var(--color-yellowgreen);
  position: absolute;
  z-index: 1;
}

#head .div-image .figure-image .picture {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
  aspect-ratio: 1 / 1;
}

#head .div-image .figure-image .picture::after {
  opacity: 0.04;
}

#head .div-image .figure-image .picture img {
  grid-column: 1 / 2;
  grid-row: 1 / 2;
  opacity: 0;
}

#head .div-image .figure-image .picture img:nth-of-type(1) {
  opacity: 1;
}

#head .div-image .figure-image:nth-of-type(1) {
  left: 0;
  top: var(--grid-40);
}

#head .div-image .figure-image:nth-of-type(1)::after {
  width: var(--grid-44);
  border-radius: var(--grid-44);
  border-top-right-radius: var(--grid-3);
  opacity: 0.08;
  left: var(--grid-48);
  top: var(--grid-40);
}

#head .div-image .figure-image:nth-of-type(1) .picture {
  width: var(--grid-68);
  border-radius: var(--grid-68);
  border-top-right-radius: var(--grid-3);
}

#head .div-image .figure-image:nth-of-type(2) {
  right: 0;
  top: var(--grid-8);
}

#head .div-image .figure-image:nth-of-type(2)::after {
  width: var(--grid-32);
  border-radius: var(--grid-32);
  border-bottom-right-radius: var(--grid-2);
  opacity: 0.16;
  right: var(--grid-48);
  top: var(--grid-28);
}

#head .div-image .figure-image:nth-of-type(2) .picture {
  width: var(--grid-56);
  border-radius: var(--grid-56);
  border-bottom-left-radius: var(--grid-3);
}

#head .div-image .figure-image:nth-of-type(3) {
  right: var(--grid-24);
  top: calc(var(--grid) * 118);
}

#head .div-image .figure-image:nth-of-type(3)::after {
  width: var(--grid-24);
  border-radius: var(--grid-24);
  border-top-right-radius: calc(var(--grid) * 1.5);
  opacity: 0.12;
  left: var(--grid-32);
  bottom: var(--grid-32);
}

#head .div-image .figure-image:nth-of-type(3) .picture {
  width: var(--grid-44);
  border-radius: var(--grid-44);
  border-top-left-radius: var(--grid-2);
}

@media (max-width: 768px) and (orientation: portrait) {
  #head > .div-body {
    width: var(--grid-46);
    margin-inline: auto;
    padding-block: var(--grid-3);
  }

  #top #head > .div-body {
    padding-block: var(--grid-6);
  }

  #head .div-heading {
    gap: var(--grid-2);
    width: 100%;
    margin-top: var(--grid-46);
    margin-left: 0;
  }

  #head .div-heading .h-catchline {
    font-size: 3.2rem;
    line-height: 1.36;
    margin-block: -0.18em;
  }

  #head .div-heading .p-catchline {
    font-size: 1.6rem;
  }

  #head .div-heading .ul-points {
    gap: calc(var(--grid) * 0.8);
  }

  #head .div-heading .ul-points .p-point {
    font-size: 1.44rem;
  }

  #head .div-guide {
    width: 100%;
    gap: var(--grid-2);
    margin-top: var(--grid-6);
  }

  #head .div-guide .div-timetable {
    gap: calc(var(--grid) * 1.5);
  }

  #head .div-guide .div-timetable .h-heading-small {
    padding-inline: calc(var(--grid) * 0.5);
  }

  #head .div-guide .ul-notes {
    display: flex;
    flex-direction: column;
    gap: calc(var(--grid) * 1.3);
    padding-inline: calc(var(--grid) * 0.5);
  }

  #head .div-image .figure-image:nth-of-type(1) {
    left: calc(var(--grid) * -0.5);
    top: var(--grid-14);
  }

  #head .div-image .figure-image:nth-of-type(1)::after {
    width: var(--grid-16);
    border-radius: var(--grid-16);
    border-top-right-radius: var(--grid-2);
    left: var(--grid-12);
    top: var(--grid-14);
  }

  #head .div-image .figure-image:nth-of-type(1) .picture {
    width: var(--grid-26);
    border-radius: var(--grid-26);
    border-top-right-radius: var(--grid-3);
  }

  #head .div-image .figure-image:nth-of-type(2) {
    right: calc(var(--grid) * -0.5);
    top: var(--grid-2);
  }

  #head .div-image .figure-image:nth-of-type(2)::after {
    width: var(--grid-10);
    border-radius: var(--grid-10);
    border-bottom-right-radius: calc(var(--grid) * 1.5);
    right: var(--grid-4);
    top: var(--grid-16);
  }

  #head .div-image .figure-image:nth-of-type(2) .picture {
    width: var(--grid-18);
    border-radius: var(--grid-18);
    border-bottom-left-radius: var(--grid-2);
  }

  #head .div-image .figure-image:nth-of-type(3) {
    right: var(--grid-6);
    top: calc(var(--grid) * 35);
  }

  #head .div-image .figure-image:nth-of-type(3)::after {
    width: var(--grid-6);
    border-radius: var(--grid-6);
    border-top-right-radius: var(--grid);
    left: var(--grid-10);
    bottom: var(--grid-10);
  }

  #head .div-image .figure-image:nth-of-type(3) .picture {
    width: var(--grid-14);
    border-radius: var(--grid-14);
    border-top-left-radius: calc(var(--grid) * 1.5);
  }
}


/*============================================================
  #topics
============================================================*/
#topics {
  width: 100%;
  background-color: var(--color-lightgray);
  border-radius: var(--grid-2);
  position: relative;
  z-index: 0;
}

#head + #topics {
  margin-block-start: calc(var(--grid-2) * -1);
}

#topics > .div-body {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  gap: var(--grid-4);
  width: var(--grid-164);
  margin-inline: auto;
  padding-block: var(--grid-8);
  position: relative;
}

#topics > .div-body::before {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background-color: var(--color-black);
  margin: auto;
  opacity: 0.2;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
}

#topics > .div-body > .div-1,
#topics > .div-body > .div-2 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  width: var(--grid-76);
}

#topics .div-topics-column {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  width: 100%;
}

#topics .div-topics-column .div-description {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
  width: var(--grid-44);
}

#topics .div-topics-column .div-description .h-heading {
  font-size: 2.4rem;
  letter-spacing: 0.064em;
  line-height: 1.44;
  margin-block: -0.22em;
}

#topics .div-topics-column .div-description .p-text {
  font-size: 1.44rem;
}

#topics .div-topics-column .div-description .ul-cure {
  display: flex;
  flex-direction: column;
  gap: var(--grid);
}

#topics .div-topics-column .div-description .ul-cure > li {
  width: 100%;
}

#topics .div-topics-column .div-description .ul-cure > li .a-topic {
  width: 100%;
  height: var(--grid-7);
}

#topics .div-topics-column .div-image .figure-image .picture {
  aspect-ratio: 1 / 1;
  width: var(--grid-28);
  border-radius: var(--grid-28);
  border-top-left-radius: var(--grid-2);
}

#topics .div-topics-column .div-image .figure-image .picture::after {
  opacity: 0.04;
}

#topics .div-topics-info .ul-info {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
  width: 100%;
}

#topics .div-topics-info .ul-info > li {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: 100%;
}

@media (max-width: 768px) and (orientation: portrait) {
  #head + #topics {
    margin-block-start: calc(var(--grid-2) * -1);
  }

  #topics > .div-body {
    display: flex;
    flex-direction: column;
    justify-content: normal;
    gap: var(--grid-4);
    width: var(--grid-46);
    padding-block: var(--grid-4);
  }

  #topics > .div-body::before {
    display: none;
  }

  #topics > .div-body > .div-1,
  #topics > .div-body > .div-2 {
    gap: var(--grid-4);
    width: 100%;
  }

  #topics > .div-body > .div-2::before {
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: var(--color-black);
    margin: auto;
    opacity: 0.2;
  }

  #topics .div-topics-column {
    flex-direction: column-reverse;
    align-items: flex-end;
    justify-content: normal;
    gap: 0;
    width: 100%;
  }

  #topics .div-topics-column .div-description {
    gap: calc(var(--grid) * 2.5);
    width: 100%;
    margin-block-start: calc(var(--grid-12) * -1);
  }

  #topics .div-topics-column .div-description .h-heading {
    width: calc(100% - var(--grid-13));
    font-size: 2.24rem;
    line-height: 1.28;
    margin-block: -0.14em;
  }

  #topics .div-topics-column .div-description .h-heading br {
    display: none;
  }

  #topics .div-topics-column .div-description .ul-cure {
    display: flex;
    flex-direction: column;
    gap: var(--grid);
  }

  #topics .div-topics-column .div-description .ul-cure > li {
    width: 100%;
  }

  #topics .div-topics-column .div-image .figure-image .picture {
    width: var(--grid-12);
    border-radius: var(--grid-12);
    border-top-left-radius: calc(var(--grid) * 1.5);
  }

  #topics .div-topics-info .ul-info > li {
    gap: calc(var(--grid) * 1.5);
  }
}


/*============================================================
  #features
============================================================*/
#features {
  width: 100%;
  position: relative;
  z-index: 0;
}

#features > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-8);
  width: var(--grid-164);
  margin-inline: auto;
  padding-block: var(--grid-8);
  position: relative;
}

#features .ul-features {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-end;
  column-gap: var(--grid-4);
  row-gap: var(--grid-8);
  width: 100%;
  counter-reset: item;
}

#features .ul-features > li {
  width: var(--grid-44);
}

#features .ul-features > li:nth-of-type(1) {
  width: var(--grid-68);
}

#features .ul-features .div-features-column {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
  width: 100%;
}

#features .ul-features .div-features-column .div-image .figure-image .picture {
  aspect-ratio: 4 / 3;
  border-radius: var(--grid-8);
}

#features .ul-features > li:nth-of-type(-n+3) .div-features-column .div-image .figure-image .picture {
  aspect-ratio: 1 / 1;
}

#features .ul-features .div-features-column .div-image .figure-image .picture::after {
  opacity: 0.04;
}

#features .ul-features .div-features-column .div-heading {
  width: 100%;
  padding-inline: var(--grid-9) var(--grid-2);
  position: relative;
}

#features .ul-features .div-features-column .div-heading::before {
  content: counter(item);
  counter-increment: item;
  display: block;
  width: var(--grid-5);
  height: 1em;
  color: var(--color-deepgreen);
  font-family: var(--font-Aboreto);
  font-size: 4.8rem;
  letter-spacing: 0;
  margin: auto 0;
  position: absolute;
  left: var(--grid-2);
  top: 0;
  bottom: 0;
}

#features .ul-features .div-features-column .div-heading .p-heading {
  color: #484848;
  font-family: var(--font-sans-serif);
  font-size: 1.2rem;
  letter-spacing: 0.064em;
  line-height: 1.6;
  margin-block: -0.3em;
}

#features .ul-features .div-features-column .div-heading .h-heading {
  display: inline-flex;
  align-items: center;
  gap: var(--grid);
  font-size: 2.4em;
  letter-spacing: 0.064em;
  line-height: 1.04;
  margin-block: -0.02em;
  position: relative;
}

#features .ul-features .div-features-column .div-heading .p-heading + .h-heading {
  margin-block-start: var(--grid-2);
}

#features .ul-features .div-features-column .div-heading .h-heading::before {
  content: "";
  display: block;
  width: calc(var(--grid-2) * 0.2);
  height: calc(var(--grid-2) * 0.2);
  border-right: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  margin: auto 0;
  transform: rotate(-45deg);
  opacity: 0.24;
  position: absolute;
  right: calc(var(--grid) * 0.96);
  top: 0;
  bottom: 0;
}

#features .ul-features .div-features-column .div-heading .h-heading::after {
  content: "";
  display: block;
  width: var(--grid-2);
  height: var(--grid-2);
  border: 1px solid var(--color-black);
  border-radius: var(--grid-2);
  opacity: 0.24;
}

@media (max-width: 768px) and (orientation: portrait) {
  #features > .div-body {
    gap: var(--grid-4);
    width: var(--grid-46);
    padding-block: var(--grid-6);
  }

  #features .ul-features {
    flex-direction: column;
    align-items: normal;
    gap: var(--grid-3);
  }

  #features .ul-features > li {
    width: 100%;
  }

  #features .ul-features > li:nth-of-type(1) {
    width: 100%;
  }

  #features .ul-features .div-features-column {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: var(--grid-2);
    width: 100%;
  }

  #features .ul-features .div-features-column .div-image .figure-image .picture {
    aspect-ratio: 1 / 1;
    width: var(--grid-14);
    border-radius: var(--grid-2);
  }

  #features .ul-features .div-features-column .div-heading {
    flex: 1;
    width: auto;
    padding-inline: 0;
  }

  #features .ul-features .div-features-column .div-heading::before {
    width: auto;
    height: auto;
    font-size: 2.8rem;
    line-height: 0.96;
    margin-block: -0.012em var(--grid);
    position: static;
  }

  #features .ul-features .div-features-column .div-heading .p-heading {
    font-size: 1.2rem;
    line-height: 1.44;
    margin-block: -0.22em;
  }

  #features .ul-features .div-features-column .div-heading .h-heading {
    font-size: 2.24em;
  }

  #features .ul-features .div-features-column .div-heading .p-heading + .h-heading {
    margin-block-start: calc(var(--grid) * 1.5);
  }
}


/*============================================================
  #notice
============================================================*/
#notice {
  width: 100%;
  position: relative;
  z-index: 0;
}

#notice > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: var(--grid-164);
  margin-inline: auto;
}

#notice .div-notice-column {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--grid-4);
  width: 100%;
  background-color: var(--color-lightgray);
  border-radius: var(--grid-4);
  padding: var(--grid-4);
}

#notice .div-notice-column .div-heading {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--grid-3);
  width: var(--grid-40);
}

#notice .div-notice-column .div-heading .figure-image .picture {
  aspect-ratio: 1 / 1;
  width: var(--grid-8);
  border-radius: var(--grid-8);
  border-bottom-right-radius: var(--grid);
}

#notice .div-notice-column .div-heading .figure-image .picture::after {
  opacity: 0.04;
}

#notice .div-notice-column .div-heading .h-heading {
  font-size: 2em;
  letter-spacing: 0.064em;
  line-height: 1.52;
  margin-block: -0.26em;
}

#notice .div-notice-column .div-content {
  flex: 1;
}

#notice .div-notice-column .ul-chart {
  display: flex;
  flex-direction: row;
  width: 100%;
  border-left: 1px solid rgba(40, 40, 40, 0.16);
  border-right: 1px solid rgba(40, 40, 40, 0.16);
}

#notice .div-notice-column .ul-chart > li {
  flex: 1;
}

#notice .div-notice-column .ul-chart > li + li {
  border-left: 1px solid rgba(40, 40, 40, 0.16);
}

#notice .div-notice-column  .ul-chart .dl-chart {
  display: flex;
  flex-direction: column;
  gap: var(--grid);
  width: 100%;
}

#notice .div-notice-column  .ul-chart .dl-chart > dt,
#notice .div-notice-column  .ul-chart .dl-chart > dd {
  width: 100%;
  font-family: var(--font-sans-serif);
  font-size: 1.28rem;
  letter-spacing: 0.064em;
  text-align: center;
}

#notice .div-notice-column  .ul-chart .dl-chart > dd .number {
  font-family: var(--font-Aboreto);
  font-size: 3.2rem;
  letter-spacing: 0.008em;
}

#notice .div-notice-column .div-content .p-text {
  font-size: 1.44rem;
}

@media (max-width: 768px) and (orientation: portrait) {
  #notice > .div-body {
    gap: var(--grid);
    width: var(--grid-46);
  }

  #notice .div-notice-column {
    flex-direction: column;
    align-items: normal;
    gap: var(--grid-2);
    border-radius: var(--grid-2);
    padding: var(--grid-2);
  }

  #notice .div-notice-column .div-heading {
    gap: var(--grid-2);
    width: 100%;
  }

  #notice .div-notice-column .div-heading .h-heading {
    line-height: 1.36;
    margin-block: -0.18em;
  }

  #notice .div-notice-column .div-content {
    flex: 1;
  }

  #notice .div-notice-column .ul-chart {
    flex-direction: column;
    flex-wrap: wrap;
    border: none;
  }

  #notice .div-notice-column .ul-chart > li {
    flex: initial;
    width: 100%;
  }

  #notice .div-notice-column .ul-chart > li + li {
    border-left: none;
    border-top: 1px solid rgba(40, 40, 40, 0.16);
    margin-block-start: calc(var(--grid) * 0.75);
    padding-block-start: calc(var(--grid) * 0.75);
  }

  #notice .div-notice-column  .ul-chart .dl-chart {
    flex-direction: row;
    align-items: center;
  }

  #notice .div-notice-column  .ul-chart .dl-chart > dt,
  #notice .div-notice-column  .ul-chart .dl-chart > dd {
    font-size: 1.44rem;
  }

  #notice .div-notice-column  .ul-chart .dl-chart > dt {
    text-align: left;
  }

  #notice .div-notice-column  .ul-chart .dl-chart > dd {
    text-align: right;
  }

  #notice .div-notice-column  .ul-chart .dl-chart > dd .number {
    font-size: 2.4rem;
  }
}

/*============================================================
  #information
============================================================*/
#information {
  width: 100%;
  position: relative;
  z-index: 0;
}

#information > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-8);
  width: var(--grid-164);
  margin-inline: auto;
  padding-block: var(--grid-8);
  position: relative;
}

#information .div-content {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
  width: var(--grid-164);
  margin-inline: auto;
  position: relative;
}

#information .div-information-list {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
  width: var(--grid-76);
}

#information .div-information-list .ul-information {
  display: flex;
  flex-direction: column;
}

#information .div-information-list .ul-information > li + li::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--color-black);
  opacity: 0.16;
  margin-block: var(--grid-4);
}

#information .div-information-list .dl-information {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
}

#information .div-information-list .dl-information .time-post {
  color: var(--color-deepgreen);
  font-family: var(--font-Aboreto);
  font-size: 1.68rem;
  margin-block: -0.012em;
}

#information .div-information-list .dl-information .a-text {
  color: var(--color-red);
}

#information .div-information-list .dl-information .h-heading {
  font-size: 1.84em;
  letter-spacing: 0.064em;
  line-height: 1.44;
  margin-block: -0.22em;
}

#information .div-information-list .dl-information .p-text + .h-heading {
  margin-block-start: var(--grid-3);
}

#information .div-information-list .dl-information .p-text + .p-text {
  margin-block-start: var(--grid-2);
}

#information .div-information-list .dl-information .p-text {
  font-size: 1.44rem;
}

#information .div-information-list .dl-information .h-heading + .p-text {
  margin-block-start: var(--grid-2);
}

#information .div-information-topic {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
  width: var(--grid-76);
  border: 1px solid rgba(40, 40, 40, 0.4);
  border-radius: var(--grid-3);
  padding: var(--grid-4);
}

#information .div-information-topic > .div-1 {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: var(--grid-2);
  width: 100%;
}

#information .div-information-topic .h-heading {
  font-size: 2.4em;
  letter-spacing: 0.064em;
  line-height: 1.44;
  margin-block: -0.22em;
}

#information .div-information-topic .p-point {
  font-size: 1.2rem;
}

#information .div-information-topic .h-heading + .p-point {
  margin-block-start: var(--grid-3);
}

#information .div-information-topic .figure-image .picture {
  aspect-ratio: 1 / 1;
  width: var(--grid-16);
  border-radius: var(--grid-16);
  border-top-left-radius: calc(var(--grid) * 1.5);
}

#information .div-information-topic .figure-image .picture::after {
  opacity: 0.04;
}

#information .div-information-topic .p-text {
  font-size: 1.44rem;
}

@media (max-width: 768px) and (orientation: portrait) {
  #information > .div-body {
    gap: var(--grid-4);
    width: var(--grid-46);
    padding-block: var(--grid-6);
  }

  #information .div-content {
    flex-direction: column;
    justify-content: normal;
    gap: var(--grid-3);
    width: var(--grid-46);
  }

  #information .div-information-list {
    gap: var(--grid-2);
    width: 100%;
  }

  #information .div-information-list .ul-information > li + li::before {
    margin-block: var(--grid-2);
  }

  #information .div-information-list .dl-information {
    gap: var(--grid-2);
  }

  #information .div-information-list .dl-information .h-heading {
    line-height: 1.28;
    margin-block: -0.14em;
  }

  #information .div-information-list .dl-information .p-text {
    font-size: 1.44rem;
  }

  #information .div-information-list .p-button {
    text-align: center;
  }

  #information .div-information-topic {
    gap: var(--grid-2);
    width: 100%;
    border-radius: var(--grid-2);
    padding: var(--grid-2);
  }

  #information .div-information-topic .h-heading {
    font-size: 2.24em;
    line-height: 1.28;
    margin-block: -0.14em;
  }

  #information .div-information-topic .h-heading br {
    display: none;
  }

  #information .div-information-topic .h-heading + .p-point {
    margin-block-start: calc(var(--grid) * 1.5);
  }

  #information .div-information-topic .figure-image .picture {
    width: var(--grid-12);
    border-radius: var(--grid-12);
    border-top-left-radius: calc(var(--grid) * 1.5);
  }
}


/*============================================================
  #gallery
============================================================*/
#gallery {
  width: 100%;
  position: relative;
  z-index: 0;
}

#features + #gallery {
  margin-block-start: calc(var(--grid-2) * -1);
}

#gallery .figure-image {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(1, 1fr);
  gap: var(--grid-2);
  padding: var(--grid-2);
}

#gallery .figure-image .picture {
  aspect-ratio: 4 / 3;
  border-radius: var(--grid-2);
}

@media (max-width: 768px) and (orientation: portrait) {
  #gallery .figure-image {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 1fr);
  }

  #gallery .figure-image .picture {
    border-radius: var(--grid);
  }
}


/*============================================================
  #guide
============================================================*/
#guide {
  width: 100%;
  background-color: rgba(128, 184, 36, 0.08);
  border-top-left-radius: var(--grid-2);
  border-top-right-radius: var(--grid-2);
  position: relative;
  z-index: 0;
}

#information + #guide {
  margin-block-start: calc(var(--grid-2) * -1);
}

#guide > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  width: var(--grid-164);
  margin-inline: auto;
  padding-block: var(--grid-8);
  position: relative;
}

#guide .div-content {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
  width: var(--grid-164);
  margin-inline: auto;
  position: relative;
}

#guide .div-content > .div-1 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
  width: var(--grid-92);
}

#guide .div-content > .div-2 {
  width: var(--grid-56);
}

#guide .div-content .ul-point {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  align-items: center;
  gap: var(--grid);
}

#guide .div-content .ul-point .p-point {
  font-size: 1.2rem;
}

#guide .div-content .ul-address {
  display: flex;
  flex-direction: column;
}

#guide .div-content .ul-address > li {
  width: 100%;
}

#guide .div-content .ul-address > li + li::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--color-black);
  opacity: 0.16;
  margin-block: var(--grid-3);
}

#guide .div-content .div-address-column {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

#guide .div-content .div-address-column .p-call .a-call {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--grid);
  font-family: var(--font-Aboreto);
  font-size: 4.8rem;
  margin-block: -0.02em;
  white-space: nowrap;
}

#guide .div-content .div-address-column .p-call .a-call .icon {
  width: var(--grid-6);
  height: auto;
}

#guide .div-content .div-address-column .p-text {
  font-size: 1.2rem;
}

#guide .div-content .div-address-column .p-access {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--grid);
  font-family: var(--font-sans-serif);
  font-size: 1.44rem;
  letter-spacing: 0.064em;
  line-height: 1.6;
  margin-block: -0.3em;
  white-space: nowrap;
}

#guide .div-content .div-address-column .p-access strong {
  font-size: 2.8rem;
  letter-spacing: 0.08em;
}

#guide .div-content .div-address-column .p-access .icon {
  width: calc(var(--grid) * 2.5);
  height: auto;
  margin-inline: calc(var(--grid) * 1.5);
}

#guide .div-content .div-address-column .p-link {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--grid);
}

#guide .div-content .div-consultation {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
  width: 100%;
}

#guide .div-content .div-consultation .dl-timetable {
  border: none;
}

#guide .div-content .div-consultation .ul-notes {
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 1.3);
  padding-inline: calc(var(--grid) * 0.5);
}

#guide .div-content .div-consultation .ul-info {
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 1.3);
  width: 100%;
}

#guide .div-content .figure-image .map {
  aspect-ratio: 1 / 1;
  background-color: var(--color-white);
  border-radius: var(--grid);
}

@media (max-width: 768px) and (orientation: portrait) {
  #guide > .div-body {
    gap: var(--grid-3);
    width: var(--grid-46);
    padding-block: var(--grid-4);
  }

  #guide .div-content {
    flex-direction: column;
    justify-content: normal;
    gap: var(--grid-4);
    width: var(--grid-46);
  }

  #guide .div-content > .div-1 {
    display: flex;
    flex-direction: column;
    gap: var(--grid-3);
    width: 100%;
  }

  #guide .div-content > .div-2 {
    width: 100%;
  }

  #guide .div-content .ul-point {
    gap: calc(var(--grid) * 0.6);
  }

  #guide .div-content .ul-address > li + li::before {
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: var(--color-black);
    opacity: 0.16;
    margin-block: var(--grid-3);
  }

  #guide .div-content .div-address-column {
    flex-direction: column;
    align-items: normal;
    justify-content: normal;
    gap: var(--grid);
  }

  #guide .div-content .div-address-column .p-call .a-call {
    font-size: 4rem;
  }

  #guide .div-content .div-address-column .p-call .a-call .icon {
    width: var(--grid-5);
  }

  #guide .div-content .div-address-column .p-access {
    line-height: 1.44;
    margin-block: -0.22em;
  }

  #guide .div-content .div-address-column .p-access strong {
    font-size: 2.4rem;
  }

  #guide .div-content .div-address-column .p-access .icon {
    width: calc(var(--grid) * 2.5);
    margin-inline: var(--grid);
  }

  #guide .div-content .div-address-column .p-link {
    justify-content: center;
    width: 100%;
  }

  #guide .div-content .div-consultation .ul-notes {
    display: flex;
    flex-direction: column;
    gap: calc(var(--grid) * 1.3);
    padding-inline: calc(var(--grid) * 0.5);
  }

  #guide .div-content .div-consultation .ul-info {
    display: flex;
    flex-direction: column;
    gap: calc(var(--grid) * 1.3);
    width: 100%;
  }
}


/*============================================================
  #content
============================================================*/
#content {
  width: 100%;
  position: relative;
  z-index: 0;
}

#head + #content {
  margin-block-start: var(--grid-2);
}

#content > .div-body {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  width: var(--grid-164);
  margin-inline: auto;
  position: relative;
}

#content .section-content {
  display: flex;
  flex-direction: column;
  gap: var(--grid-4);
}

#content .section-subcontent {
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 3.5);
  border-top: 1px solid rgba(40, 40, 40, 0.16);
  padding-top: var(--grid-3);
}

#content .div-content {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
  font-size: 1.52rem;
  letter-spacing: 0.064em;
  line-height: 1.68;
  padding-inline: calc(var(--grid) * 0.5);
}

#content .div-content-column {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  gap: var(--grid-16);
  width: 100%;
}

#content .div-content-column > .div-1,
#content .div-content-column > .div-2 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
}

#content .div-content-column > .div-1 {
  flex: 1;
}

#content .div-content-column > .div-2 {
  max-width: calc(var(--grid-56) - (var(--grid) * 0.5));
}

#content .div-content-column .div-column {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  column-gap: calc(var(--grid-9) - (var(--grid) * 0.5));
  row-gap: var(--grid-4);
  width: 100%;
}

#content .div-content-column .div-column > * {
  flex: 1;
}

#content .div-content .div-paragraph {
  display: flex;
  flex-direction: column;
  gap: 1.12em;
}

#content .div-content figcaption {
  font-family: var(--font-sans-serif);
  font-size: 1.36rem;
  letter-spacing: 0.064em;
  line-height: 1.36;
  margin-block: -0.18em;
}

#content .div-content figcaption .dl-caption {
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 1.2);
}

#content .div-content figcaption .dl-caption > dd {
  font-size: 1.2rem;
  line-height: 1.6;
  margin-block: -0.3em;
}

#content .div-content .figure-image {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
}

#content .div-content .figure-image .picture:not(.map):not(.map) {
  width: calc(var(--grid-24) - (var(--grid) * 0.5));
  border-radius: calc(var(--grid) * 0.5);
}

#content .div-content .figure-image .map {
  aspect-ratio: 1 / 1;
  border: 1px solid #e8e8e8;
  border-radius: var(--grid);
}

#content .div-content .figure-image .gmap {
  aspect-ratio: 4 / 3;
  width: 100%;
  height: auto;
  border-radius: var(--grid);
}

#content .div-content .figure-chart {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: 100%;
}

#content .div-sitemap .nav-sitemap {
  display: flex;
  flex-direction: row;
  gap: var(--grid-16);
}

#content .div-sitemap .nav-sitemap .div-column {
  flex: 1;
}

#content .div-sitemap .nav-sitemap .h-heading {
  display: flex;
  align-items: center;
  min-height: var(--grid-6);
  color: var(--color-deepgreen);
  font-family: var(--font-sans-serif);
  font-size: 1.28rem;
  letter-spacing: 0.064em;
  line-height: 1.44;
  border-bottom: 1px solid rgba(40, 40, 40, 0.16);
}

#content .div-sitemap .nav-sitemap .ul-content > li + li {
  border-top: 1px solid rgba(40, 40, 40, 0.16);
}

#content .div-sitemap .nav-sitemap .ul-content .a-content {
  min-height: var(--grid-6);
}

#content .div-policy {
  display: flex;
  flex-direction: column;
  gap: var(--grid-6);
  font-size: 1.52rem;
  letter-spacing: 0.064em;
  line-height: 1.68;
}

#content .div-policy .h-heading-policy {
  font-size: 2rem;
  letter-spacing: 0.064em;
  line-height: 1.44;
  margin-block: -0.22em;
}

#content .div-policy .ul-policy {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
}

#content .div-policy .ul-policy > li {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
}

#content .div-policy .ul-policy > li::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--color-black);
  opacity: 0.16;
}

#content .div-policy .p-policy {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  gap: 0.24em;
  font-size: 1.68rem;
  letter-spacing: 0.064em;
  line-height: 1.44;
  margin-block: -0.22em;
}

#content .div-policy .p-policy::before {
  content: "●";
  font-family: var(--font-sans-serif-jp);
  font-size: 0.56em;
  transform: translateY(-12%);
}

#content .div-policy .dl-policy {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
}

#content .div-policy .dl-policy > dt {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  gap: 0.24em;
  font-size: 1.68rem;
  letter-spacing: 0.064em;
  line-height: 1.44;
  margin-block: -0.22em;
}

#content .div-policy .dl-policy > dt::before {
  content: "●";
  font-family: var(--font-sans-serif-jp);
  font-size: 0.56em;
  transform: translateY(-12%);
}

#content .div-policy .dl-policy > dd {
  padding-inline-start: 1em;
}

#content .div-policy .div-terms {
  display: flex;
  flex-direction: column;
  gap: var(--grid-3);
}

#content .div-policy .p-signature {
  font-family: var(--font-sans-serif);
  font-size: 1.44rem;
  letter-spacing: 0.064em;
  line-height: 1.68;
  text-align: right;
  margin-block: -0.34em;
}

@media (max-width: 768px) and (orientation: portrait) {
  #head + #content {
    margin-block-start: 0;
  }

  #content > .div-body {
    gap: var(--grid-4);
    width: var(--grid-46);
  }

  #content .section-content {
    gap: var(--grid-3);
  }

  #content .section-content > .div-content {
    padding-inline: calc(var(--grid) * 0.2);
  }

  #content .div-content-column {
    flex-direction: column;
    justify-content: normal;
    gap: var(--grid-4);
  }

  #content .div-content-column .p-text {
    font-size: 1.6rem;
  }

  #content .div-content-column > .div-1,
  #content .div-content-column > .div-2 {
    width: 100%;
    max-width: initial;
  }

  #content .div-content-column .div-column {
    column-gap: var(--grid-2);
    row-gap: var(--grid-3);
  }

  #content .div-content .div-paragraph {
    gap: 1.12em;
  }

  #content .div-content .figure-image .picture:not(.map) {
    width: calc(var(--grid-22) - (var(--grid) * 0.2));
  }

  #content .div-content .figure-image .gmap {
    aspect-ratio: 1 / 1;
  }

  #content .div-sitemap .nav-sitemap {
    flex-direction: column;
    gap: var(--grid-2);
  }

  #content .div-sitemap .nav-sitemap .div-column {
    width: 100%;
  }

  #content .div-sitemap .nav-sitemap .ul-content .a-content {
    min-height: var(--grid-6);
  }

  #content .div-policy {
    gap: var(--grid-4);
  }

  #content .div-policy .h-heading-policy {
    font-size: 1.84rem;
  }

  #content .div-policy .ul-policy {
    gap: calc(var(--grid) * 2.5);
  }

  #content .div-policy .ul-policy > li {
    gap: calc(var(--grid) * 2.5);
  }

  #content .div-policy .dl-policy {
    display: flex;
    flex-direction: column;
    gap: calc(var(--grid) * 2.5);
  }

  #content .div-policy .div-terms {
    gap: calc(var(--grid) * 2.5);
  }
}






