footer {
  margin-top: 13.75rem;
}
@media screen and (max-width: 750px) {
  footer {
    margin-top: 10rem;
  }
}


.container {
  opacity: 0;
  transition: opacity .5s ease-in;
  transition-delay: .5s;
}
.container.loaded {
  opacity: 1;
}
@media screen and (min-width: 751px) {
  .container {
    max-width: 55.625rem;
    padding: 0 2rem;
    margin: 0 auto;
  }
}
@media screen and (max-width: 750px) {
  .container {
    padding: 0 1.875rem;
    margin: 0 auto;
  }
}


.page__title {
  color: var(--main);
  text-align: center;
}
.page__title:after {
  content: '';
  display: block;
  height: .0625rem;
  background: var(--main);
}
@media screen and (min-width: 751px) {
  .page__title {
    margin-top: 12.5rem;
    font-size: 2rem;
    line-height: 1.3125;
    letter-spacing: 2.4px;
  }
  .page__title:after {
    width: .9375rem;
    margin: .875rem auto 0;
  }
}
@media screen and (max-width: 750px) {
  .page__title {
    margin-top: 6.25rem;
    font-size: 1.5rem;
    line-height: 1.25;
    letter-spacing: 1.8px;
  }
  .page__title:after {
    width: .625rem;
    margin: .625rem auto 0;
  }
}


.content {
  margin-top: 4rem;
  color: var(--page-content-text);
  font-size: .8125rem;
  font-family: var(--font-sans-serif);
  font-weight: 400;
  letter-spacing: .97px;
  line-height: 1.75rem;
}
.content h1,
.content h2,
.content h3,
.content h4,
.content h5,
.content h6 {
  color: var(--page-content-title);
  font-family: var(--font-serif-ja);
  font-weight: 400;
  letter-spacing: .9px;
}
.content h1,
.content h2 {
  line-height: 1.625rem;
}
.content h3,
.content h4 {
  line-height: 1.5rem;
}
.content h5,
.content h6 {
  line-height: 1.375rem;
}
.content img {
  display: block;
  max-width: 100%;
}
@media screen and (min-width: 751px) {
  .content h1,
  .content h2 {
    margin: 5rem auto 2.1875rem;
    font-size: 1.125rem;
  }
  .content h3,
  .content h4 {
    margin: 4rem auto 2rem;
    font-size: 1rem;
  }
  .content h5,
  .content h6 {
    margin: 3rem auto 1.5rem;
    font-size: .875rem;
  }
  .content p + p {
    margin-top: 1.875rem;
  }
}
@media screen and (max-width: 750px) {
  .content h1,
  .content h2 {
    margin: 2.8125rem auto 1.25rem;
    font-size: .9375rem;
  }
  .content h3,
  .content h4 {
    margin: 2.5rem auto 1rem;
    font-size: .875rem;
  }
  .content h5,
  .content h6 {
    margin: 2rem auto 1rem;
    font-size: .8125rem;
  }
  .content p + p {
    margin-top: 1.25rem;
  }
}

.content__history {
  border-left: 1px solid var(--border);
}
.content__history h2 {
  margin-top: 0;
  color: var(--text);
}
.content__history h2 span {
  display: block;
  color: var(--page-content-title);
  font-size: .625rem;
  letter-spacing: .75px;
  line-height: 1.3;
  position: relative;
}
.content__history h2 span:before {
  content: '';
  display: block;
  height: .0625rem;
  background: var(--border);
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.content__history h2 span:after {
  content: '';
  display: block;
  background: var(--page-content-title);
  border-radius: 50%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 751px) {
  .content__history {
    padding: 2.1875rem 0 3.75rem 6.5625rem;
  }
  .content__history__item:nth-of-type(n + 2) {
    margin-top: 5.625rem;
  }
  .content__history h2 span {
    margin-bottom: .625rem;
  }
  .content__history h2 span:before {
    width: 5.0625rem;
    right: calc(100% + 1.5rem);
  }
  .content__history h2 span:after {
    width: .5rem;
    height: .5rem;
    right: calc(100% + 1rem);
  }
}
@media screen and (max-width: 750px) {
  .content__history {
    padding: 1.25rem 0 2.5rem 1.8125rem;
  }
  .content__history__item:nth-of-type(n + 2) {
    margin-top: 2.8125rem;
  }
  .content__history h2 {
    font-size: .9375rem;
    letter-spacing: .75px;
  }
  .content__history h2 span {
    margin-bottom: .25rem;
  }
  .content__history h2 span:before {
    width: .9375rem;
    right: calc(100% + .875rem);
  }
  .content__history h2 span:after {
    width: .25rem;
    height: .25rem;
    right: calc(100% + .625rem);
  }
}

.content__overview__item {
  border-top: 1px solid var(--border);
}
.content__overview__item:last-of-type {
  border-bottom: 1px solid var(--border);
}
.content__overview__item dt {
  display: flex;
  align-items: center;
}
.content__overview__item dt:before {
  content: '';
  display: block;
  width: .375rem;
  height: .0625rem;
  background: var(--main);
}
@media screen and (min-width: 751px) {
  .content__overview__item {
    display: flex;
    align-items: flex-start;
    padding: 1.875rem 0;
  }
  .content__overview__item dt {
    gap: .5rem;
    width: 12.5rem;
  }
  .content__overview__item dd {
    flex: 1;
  }
}
@media screen and (max-width: 750px) {
  .content__overview__item {
    padding: 1.25rem 0;
  }
  .content__overview__item dt {
    gap: .375rem;
    line-height: 1.0625rem;
  }
  .content__overview__item dd {
    margin-top: .625rem;
    padding-left: .75rem;
    line-height: 1.375rem;
  }
}
@media screen and (max-width: 480px) {
  .content__overview__item-postcode {
    display: block;
  }
}
