.content.town-content {
  margin: 0;
  color: #fff;
  min-height: 100vh;
  padding-bottom: 70vh;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
}
@media only screen and (max-width: 640px) {
  .content.town-content {
    padding-bottom: 30vh;
  }
}
.content_container {
  margin: 13.5416666667vw 0 0 auto;
  width: 74.21875vw;
}
@media only screen and (max-width: 1200px) {
  .content_container {
    width: 89.2rem;
  }
}
@media only screen and (max-width: 640px) {
  .content_container {
    width: 100%;
  }
}
.content .inner {
  z-index: 1;
  position: relative;
}
.content .inner.-widhSticky {
  margin-top: -80vh;
}
@media only screen and (max-width: 640px) {
  .content .inner.-widhSticky {
    margin-top: -90vh;
  }
}
.content_title_container {
  position: sticky;
  top: 13.2rem;
  left: 0;
  height: 100vh;
  z-index: 2;
}
@media only screen and (max-width: 640px) {
  .content_title_container {
    top: 12.5vw;
  }
}
.content_title-en {
  font-size: 8.3333333333vw;
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  line-height: 1;
}
@media only screen and (max-width: 640px) {
  .content_title-en {
    font-size: 14.0625vw;
  }
}
.content_title-large {
  margin-top: 5.2083333333vw;
  margin-left: 9.375vw;
  z-index: 1;
  font-size: 2.5vw;
  line-height: 1.3;
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-weight: 300;
  white-space: nowrap;
}
@media only screen and (max-width: 640px) {
  .content_title-large {
    margin-top: 15.625vw;
    margin-left: 4.6875vw;
    font-size: 5vw;
  }
}

.town .content {
  margin-top: 9.4791666667vw;
  padding-top: 0;
  padding-bottom: 120vh;
  text-align: center;
  position: relative !important;
}
@media only screen and (max-width: 640px) {
  .town .content {
    padding-bottom: 100vh;
  }
}
.town .content_bg {
  background-image: url(../img/town/bg_town.jpg);
}
.town_title-main {
  margin-bottom: 10.4166666667vw;
  font-size: 6.0416666667vw;
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-weight: 400;
  line-height: 1;
}
@media only screen and (max-width: 1200px) {
  .town_title-main {
    font-size: 7.2rem;
  }
}
@media only screen and (max-width: 640px) {
  .town_title-main {
    font-size: 11.875vw;
  }
}
.town_title-sub {
  margin-bottom: 6.25vw;
  font-size: 1.875vw;
}
@media only screen and (max-width: 1200px) {
  .town_title-sub {
    font-size: 2.2rem;
  }
}
@media only screen and (max-width: 640px) {
  .town_title-sub {
    font-size: 4.375vw;
  }
}
.town_lead {
  margin-bottom: 1.25em;
  font-size: 1.875vw;
}
@media only screen and (max-width: 1200px) {
  .town_lead {
    font-size: 2.2rem;
  }
}
@media only screen and (max-width: 640px) {
  .town_lead {
    font-size: 4.375vw;
  }
}
.town_text {
  font-size: 1.0416666667vw;
  line-height: 2.4;
}
@media only screen and (max-width: 1200px) {
  .town_text {
    font-size: 1.3rem;
  }
}
.town_image {
  position: absolute;
}
.town_image.-deco01 {
  width: 20.0520833333vw;
  top: 33.3333333333vw;
  left: 0;
}
@media only screen and (max-width: 640px) {
  .town_image.-deco01 {
    width: 34.375vw;
    top: 125vw;
  }
}
.town_image.-deco02 {
  width: 20.5729166667vw;
  top: 37.7083333333vw;
  right: 5vw;
}
@media only screen and (max-width: 640px) {
  .town_image.-deco02 {
    right: 5vw;
    width: 43.75vw;
    top: 131.875vw;
  }
}
.town_image.-deco03 {
  width: 20.5729166667vw;
  top: 56.25vw;
  right: 0;
}
@media only screen and (max-width: 640px) {
  .town_image.-deco03 {
    width: 39.0625vw;
    top: 171.875vw;
  }
}
.town_image.-deco04 {
  margin: 0 auto;
  width: 30.2083333333vw;
  top: 66.6666666667vw;
  left: 0;
  right: 0;
}
@media only screen and (max-width: 640px) {
  .town_image.-deco04 {
    right: auto;
    left: 7.8125vw;
    width: 43.75vw;
    top: 181.25vw;
  }
}

.smart .content_bg {
  background-image: url(../img/town/bg_smart.jpg);
}
.smart_item {
  margin: 0 auto 8.3333333333vw;
  padding-right: 9.5rem;
  width: 64.3229166667vw;
}
@media only screen and (max-width: 1200px) {
  .smart_item {
    width: 66rem;
  }
}
@media only screen and (max-width: 640px) {
  .smart_item {
    margin: 0 auto 15.625vw;
    padding-right: 0;
    padding-left: 20.3125vw;
    width: 100%;
  }
}
.smart_item:nth-child(even) {
  padding-right: 0;
  padding-left: 9.5rem;
}
@media only screen and (max-width: 640px) {
  .smart_item:nth-child(even) {
    padding-left: 0;
    padding-left: 20.3125vw;
  }
}
.smart_title {
  font-size: 2.5vw;
  line-height: 1.3;
  font-weight: 300;
}
@media only screen and (max-width: 640px) {
  .smart_title {
    font-size: 5.625vw;
  }
}
.smart_title_container {
  margin-bottom: 2em;
  display: flex;
  align-items: flex-start;
  gap: 2.0833333333vw;
}
@media only screen and (max-width: 640px) {
  .smart_title_container {
    flex-direction: column;
    gap: 3.125vw;
  }
}
.smart_title_container .num {
  margin-top: 1em;
}
@media only screen and (max-width: 640px) {
  .smart_title_container .num {
    margin-top: 0.25em;
  }
}
.smart_title_container .num img {
  height: 3.125vw;
}
@media only screen and (max-width: 640px) {
  .smart_title_container .num img {
    height: 6.25vw;
  }
}
.smart_image {
  margin-bottom: 2em;
}
.notes {
  margin-top: 2em;
}

.resilience .content_bg {
  background-image: url(../img/town/bg_resilience.jpg);
}
.resilience_container {
  display: flex;
  flex-wrap: wrap;
  gap: 3.90625vw 6.0728744939%;
  width: 64.3229166667vw;
}
@media only screen and (max-width: 640px) {
  .resilience_container {
    padding-left: 20.3125vw;
    flex-direction: column;
    width: 100%;
    gap: 15.625vw;
  }
}
.resilience_item {
  width: 46.963562753%;
}
@media only screen and (max-width: 1580px) {
  .resilience_item {
    width: 46.963562753%;
  }
}
@media only screen and (max-width: 640px) {
  .resilience_item {
    width: 100%;
  }
}
.resilience_title {
  font-size: 2.5vw;
  line-height: 1.3;
  font-weight: 400;
}
@media only screen and (max-width: 640px) {
  .resilience_title {
    font-size: 5.625vw;
  }
}
.resilience_title_container {
  margin-bottom: 2em;
  display: flex;
  align-items: flex-start;
  gap: 2.0833333333vw;
}
@media only screen and (max-width: 640px) {
  .resilience_title_container {
    flex-direction: column;
    gap: 3.125vw;
  }
}
.resilience_title_container .num {
  margin-top: 1em;
}
@media only screen and (max-width: 640px) {
  .resilience_title_container .num {
    margin-top: 0.25em;
  }
}
.resilience_title_container .num img {
  height: 2.0833333333vw;
}
@media only screen and (max-width: 640px) {
  .resilience_title_container .num img {
    height: 6.25vw;
  }
}
.resilience_image {
  margin-bottom: 2em;
}

.feature .content {
  padding: 8.3333333333vw 0 27.9166666667vw;
  background: #fff url(../img/town/bg_heimism.jpg) no-repeat center bottom;
  background-size: 100% auto;
  color: #000;
  text-align: center;
}
@media only screen and (max-width: 640px) {
  .feature .content {
    padding: 15.625vw 0 96.875vw;
    background: #fff url(../img/town/bg_heimism_sp.jpg) no-repeat center bottom -15.625vw;
    background-size: 125% auto;
  }
}
.feature_title_jp {
  margin-bottom: 1em;
  font-size: 5.6rem;
  font-weight: 400;
}
@media only screen and (max-width: 640px) {
  .feature_title_jp {
    font-size: 7.5vw;
  }
}
.feature_title_en {
  margin-bottom: 0.25em;
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 4.4rem;
}
@media only screen and (max-width: 640px) {
  .feature_title_en {
    font-size: 5.625vw;
  }
}
.feature_lead {
  font-size: 2.4rem;
}
@media only screen and (max-width: 640px) {
  .feature_lead {
    font-size: 3.75vw;
  }
}
.feature .heimism_container {
  margin-top: 6rem;
  padding: 6rem 13rem 11rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.2) 5%, rgba(255, 255, 255, 0.65) 100%);
}
@media only screen and (max-width: 640px) {
  .feature .heimism_container {
    margin-top: 9.375vw;
    padding: 6.25vw 6.25vw 9.375vw;
  }
}
.feature .heimism_lead {
  margin-bottom: 1em;
  font-size: 2.4rem;
}
@media only screen and (max-width: 640px) {
  .feature .heimism_lead {
    font-size: 4.375vw;
  }
}
.feature .heimism_title {
  margin-bottom: 0.75em;
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-weight: 400;
  font-size: 9.6rem;
}
@media only screen and (max-width: 640px) {
  .feature .heimism_title {
    font-size: 12.5vw;
  }
}
.feature_list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4.1rem;
}
@media only screen and (max-width: 640px) {
  .feature_list {
    gap: 7.5vw;
    justify-content: center;
  }
}
.feature_item a {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  border-radius: 9rem;
  border: solid 1px rgba(0, 0, 0, 0.5);
  width: 18rem;
  height: 18rem;
  background: rgba(255, 255, 255, 0.5) url(../img/common/arrow_black.svg) no-repeat center bottom 1.5em;
  background-size: 1.5rem auto;
}
@media only screen and (max-width: 640px) {
  .feature_item a {
    font-size: 3.4375vw;
    border-radius: 16.40625vw;
    width: 32.8125vw;
    height: 32.8125vw;
    background-size: 2.34375vw auto;
  }
}

.content_bg {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  display: block;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  opacity: 0;
  transition: all 0.5s ease 0s;
  z-index: -1;
}

.-show .content_bg {
  opacity: 1;
}/*# sourceMappingURL=town.css.map */

.note-font {
  font-size: 1.2rem;
}