@charset "UTF-8";
/* functions
 * ----------------------------- */
body {
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-size: 16px;
  line-height: 1.8;
}

a {
  color: inherit;
  text-decoration: none;
}
a:link, a:active, a:visited {
  color: inherit;
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: bold;
  line-height: 1.3;
}

/* スキップリンク */
.skip-link {
  background: #fff;
  display: inline-block;
  position: absolute;
  top: -30px;
  left: 50%;
  width: 1px;
  height: 1px;
  overflow: hidden;
  padding: 2px 10px;
  text-decoration: none !important;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  white-space: nowrap;
}
.skip-link:focus {
  width: auto;
  height: auto;
  top: 0;
  overflow: visible;
  z-index: 10000;
}

@media screen and (max-width: 640px) {
  .skip-link {
    font-size: 12px;
  }
}
@media (min-width: 641px) {
  .sponly {
    display: none !important;
  }
}
@media (max-width: 640px) {
  .pconly {
    display: none !important;
  }
}
.u-ta_c {
  text-align: center;
}

a.u-line {
  text-decoration: underline;
}
a.u-line:hover {
  text-decoration: none;
}

/* Header
 * ----------------------------- */
.header-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  height: 80px;
  margin: 0 auto;
  max-width: 1200px !important;
}
.header-logo_livable {
  min-width: 256px;
  width: 21.25%;
}
.header-logo_aruhi {
  min-width: 115px;
  margin-left: 2%;
  width: 12.75%;
}

@media (max-width: 1199px) {
  .header-inner {
    padding-right: 25px;
    padding-left: 25px;
  }
}
@media (max-width: 800px) {
  .header-inner {
    gap: 0 4%;
    height: 60px;
    margin: 0 !important;
    padding: 16px 15px;
  }
  .header-logo_livable {
    margin-right: 0;
    max-width: 256px;
    min-width: 186px;
    width: 43.5%;
  }
  .header-logo_aruhi {
    margin-left: auto;
    max-width: 115px;
    min-width: 68px;
    width: 19.5%;
  }
}
@media (max-width: 480px) {
  .header-inner {
    height: 50px;
  }
}
.p-townranking_contact .header {
  position: relative;
}

/* Global Navigation
 * ----------------------------- */
.nav-global {
  width: auto;
}
.nav-global_list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav-global_list li {
  margin: 0;
}

@media (min-width: 801px) {
  .nav-global {
    font-size: 16px;
    line-height: 1 !important;
    margin-right: -13%;
  }
  .nav-global a {
    text-decoration: none;
  }
  .nav-global_inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    position: relative;
  }
  .nav-global_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .nav-global_item {
    border-right: none;
    line-height: 1;
  }
  .nav-global_item:first-child {
    border-left: 0;
  }
  .nav-global_item + .nav-global_item {
    border-left: 1px solid #DDD;
    margin-left: 24px;
    padding-left: 24px;
  }
  .nav-global_item a {
    color: #A28340 !important;
    display: block;
    font-weight: bold;
    padding-left: 36px;
    position: relative;
    white-space: nowrap;
  }
  .nav-global_item a::before {
    background-repeat: no-repeat;
    background-position: 0 0;
    background-size: contain;
    content: "";
    display: inline-block;
    width: 32px;
    height: 32px;
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .nav-global_item a:hover {
    text-decoration: underline;
  }
  .nav-global_item.--ranking a::before {
    background-image: url(../images/icon-ranking_gld.svg);
  }
  .nav-global_item.--towndata a::before {
    background-image: url(../images/icon-town_gld.svg);
  }
  .nav-global_item.--station a::before {
    background-image: url(../images/icon-station_gld.svg);
  }
  .nav-global_btn {
    margin-left: 13%;
    padding: 0;
  }
  .nav-global_btn .c-btn {
    background: #F7F7F7;
    border-radius: 20px;
    font-size: 13px;
    padding: 0.69em 2.08em;
    white-space: nowrap;
  }
  .nav-global_btn .c-btn:hover {
    opacity: 0.6;
  }
  .nav-global_btn::after {
    display: none;
  }
  .nav-global_close {
    display: none;
  }
  .nav-menu_btn {
    display: none;
  }
}
@media (max-width: 1199px) {
  .nav-global {
    margin-right: 0;
  }
  .nav-global_btn {
    margin-left: 10%;
  }
}
@media (min-width: 801px) and (max-width: 1000px) {
  .nav-global {
    font-size: 15px;
  }
  .nav-global_item + .nav-global_item {
    border-left: none;
    margin-left: 12px;
    padding-left: 12px;
  }
  .nav-global_item a {
    padding-left: 0;
  }
  .nav-global_item a::before {
    display: none;
  }
  .nav-global_btn {
    margin-left: 10%;
  }
  .nav-global_btn .c-btn {
    padding-right: 1em;
    padding-left: 1em;
  }
}
@media (max-width: 800px) {
  .nav-global {
    display: none;
  }
  .nav-menu_btn {
    background: url(../images/icon-menu.svg) no-repeat 50% 50%/contain;
    display: block;
    margin: 0;
    min-width: 20px;
    width: 4.9%;
    overflow: hidden;
  }
  .nav-menu_btn .label {
    display: block;
    height: 26px;
    padding-top: 100%;
    overflow: hidden;
  }
  .nav-menu_btn.is-active {
    background-image: url(../images/icon-menu_close.svg);
  }
  .nav-global {
    border-top: 1px solid #CCC;
    position: absolute;
    top: 50px;
    right: 0;
    left: 0;
    width: 100%;
    display: none;
    z-index: 1000;
  }
  .nav-global_inner {
    display: block;
  }
  .nav-global_list a, .nav-global_btn a {
    background: #F8F5F0 !important;
    color: #10357B;
    display: block;
    font-size: 16px;
    font-weight: normal;
    line-height: 1;
    padding: 20px;
    position: relative;
    text-align: left;
  }
  .nav-global_list {
    display: block;
    width: 100%;
  }
  .nav-global_list a::after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='5.811' height='10.121'%3E%3Cpath fill='none' stroke='%2310357b' stroke-linecap='round' stroke-linejoin='round' stroke-miterlimit='10' stroke-width='1.5' d='m1.061 1.061 4 4-4 4'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: 0 0;
    background-size: contain;
    content: "";
    position: absolute;
    top: 50%;
    width: 6px;
    height: 11px;
    right: 20px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .nav-global_list li + li {
    border-width: 1px 0 0 !important;
    border-top: 1px solid #CCC;
    margin-left: 0 !important;
    padding-left: 0 !important;
  }
  .nav-global_item {
    border-bottom: none;
    position: relative;
  }
  .nav-global_item a {
    padding-left: 69px;
  }
  .nav-global_item a::before {
    background-repeat: no-repeat;
    background-position: 50% 0;
    background-size: contain;
    content: "";
    display: inline-block;
    width: 29px;
    height: 29px;
    position: absolute;
    top: 50%;
    left: 20px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .nav-global_item.--ranking a::before {
    background-image: url(../images/icon-ranking_bl.svg);
  }
  .nav-global_item.--towndata a::before {
    background-image: url(../images/icon-town_bl.svg);
  }
  .nav-global_item.--station a::before {
    background-image: url(../images/icon-station_bl.svg);
    height: 26px;
  }
  .nav-global_btn {
    border-top: 1px solid #CCC;
    margin-left: 0;
    padding: 0;
  }
  .nav-global_btn::after {
    display: none;
  }
  .nav-global_btn .c-btn {
    border-radius: 0;
    display: block;
    font-size: 14px;
    padding: 16px 20px;
    text-align: left;
  }
  .nav-global_btn .c-btn .c-btn-label::after {
    display: none;
  }
  .nav-global_close {
    background: #333;
    color: #FFF;
    cursor: pointer;
    display: block;
    font-size: 14px;
    line-height: 1;
    padding: 1.29em 0;
    text-align: center;
  }
  .nav-global_close .label {
    display: inline-block;
    padding-left: 27px;
    position: relative;
  }
  .nav-global_close .label::before {
    background: url(../images/icon-close.svg) no-repeat 0 0/contain;
    content: "";
    display: block;
    width: 15px;
    height: 15px;
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
@media (max-width: 640px) {
  .nav-menu_btn {
    width: 5.33vw;
    height: 5.07vw;
  }
}
/* Bread Crumbs
 * ----------------------------- */
.nav-breadcrumbs {
  background: #10357B;
  color: #FFF;
  font-size: 14px;
  padding: 0.71em 0;
}
.nav-breadcrumbs a {
  color: inherit;
  text-decoration: none;
}
.nav-breadcrumbs a:hover {
  text-decoration: underline;
}
.nav-breadcrumbs_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style: none;
}
.nav-breadcrumbs_list li {
  position: relative;
}
.nav-breadcrumbs_list li + li {
  margin-left: 12px;
  padding-left: 16px;
}
.nav-breadcrumbs_list li + li::before {
  border-top: 1px solid #FFF;
  border-right: 1px solid #FFF;
  content: "";
  width: 6px;
  height: 6px;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}

@media (max-width: 640px) {
  .nav-breadcrumbs {
    font-size: 12px;
    padding: 0.67em 0;
  }
  .nav-breadcrumbs_list li + li {
    margin-left: 8px;
    padding-left: 12px;
  }
}
/* Main
 * ----------------------------- */
.section {
  margin-top: 60px;
  margin-bottom: 80px;
  text-align: left;
}
.section-title {
  font-size: 32px;
  font-weight: bold;
  letter-spacing: 0.05em;
  padding-bottom: 20px;
  position: relative;
}
.section-title::after {
  background: #E51F19;
  content: "";
  display: block;
  width: 100px;
  height: 6px;
  position: absolute;
  left: 50%;
  bottom: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.section-town.--blue {
  background: #10357B url(../images/texture_blue.png) no-repeat 0 0/cover;
  padding-top: 80px;
  padding-bottom: 80px;
}
.section-town.--blue .section-title,
.section-town.--blue .section-catch {
  color: #FFF;
}

@media (max-width: 640px) {
  .section {
    margin-top: 40px;
    margin-bottom: 60px;
  }
  .section-title {
    font-size: 26px;
    padding-bottom: 13px;
  }
  .section-title::after {
    width: 80px;
    height: 4px;
  }
  .section-lead {
    font-size: 14px;
  }
  .section-town.--blue {
    padding-top: 40px;
    padding-bottom: 60px;
  }
}
/* Footer
 * ----------------------------- */
.footer {
  background: #111;
  color: #FFF;
  font-size: 12px;
  padding: 1.9em 0;
  text-align: center;
}

/* link to page top */
.nav-top {
  position: fixed;
  right: 10px;
  bottom: 10px;
  z-index: 1000;
}
.nav-top a {
  background: rgba(0, 0, 0, 0.5);
  border-radius: 50px;
  display: block;
  width: 40px;
  height: 40px;
  overflow: hidden;
  padding-top: 40px;
}
.nav-top a::before {
  background-position: 50%;
  background-repeat: no-repeat;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='9'%3E%3Cpath fill='%23fff' d='M0 7.5a1.5 1.5 0 0 1 .439-1.061l6-6A1.5 1.5 0 0 1 7.5 0a1.5 1.5 0 0 1 1.061.439l6 6a1.5 1.5 0 0 1 0 2.121 1.5 1.5 0 0 1-2.121 0L7.5 3.621 2.561 8.56A1.5 1.5 0 0 1 0 7.5Z' data-name='path'/%3E%3C/svg%3E");
  background-size: contain;
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 15px;
  height: 15px;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

@media (max-width: 640px) {
  .footer {
    font-size: 11px;
    padding: 1.55em 0;
  }
  /* link to page top */
  .nav-top a::before {
    width: 15px;
    height: 15px;
  }
}
/* Common
 * ----------------------------- */
.l-inner {
  max-width: 1000px;
  margin-right: auto;
  margin-left: auto;
}

@media (max-width: 1000px) {
  .l-inner {
    max-width: 90%;
  }
}
@media (max-width: 640px) {
  .l-inner {
    margin-right: 4vw;
    margin-left: 4vw;
    max-width: 100%;
  }
}
/* Button
 * ----------------------------- */
.c-btn {
  border: 1px solid transparent;
  border-radius: 999px;
  display: inline-block;
  line-height: 1;
  padding: 1.19em 4em;
  text-decoration: none;
  text-align: center;
}
.c-btn-label {
  display: inline-block;
  padding-right: 1em;
  position: relative;
}
.c-btn-label::after {
  background-color: #333;
  content: "";
  display: block;
  -webkit-clip-path: path("M1.091 0a1.14 1.14 0 0 1 .771.293l3.818 3.5a.942.942 0 0 1 0 1.414l-3.818 3.5a1.162 1.162 0 0 1-1.543 0 .942.942 0 0 1 0-1.414L3.366 4.5.32 1.707a.942.942 0 0 1 0-1.414A1.14 1.14 0 0 1 1.091 0Z");
          clip-path: path("M1.091 0a1.14 1.14 0 0 1 .771.293l3.818 3.5a.942.942 0 0 1 0 1.414l-3.818 3.5a1.162 1.162 0 0 1-1.543 0 .942.942 0 0 1 0-1.414L3.366 4.5.32 1.707a.942.942 0 0 1 0-1.414A1.14 1.14 0 0 1 1.091 0Z");
  width: 6px;
  height: 9px;
  aspect-ratio: 1;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.c-btn:hover {
  opacity: 1;
  text-decoration: none;
}
.c-btn.--gray {
  background: #F7F7F7;
  -webkit-box-shadow: 0 3px 0 #D8D8D8;
          box-shadow: 0 3px 0 #D8D8D8;
  font-size: 22px;
  padding: 0.91em 1em 1.09em;
  width: 100%;
}
.c-btn.--gray:hover {
  background: #F0F0F0;
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-transform: translate(3px);
          transform: translate(3px);
}
.c-btn.--gray .c-btn-label::after {
  -webkit-clip-path: path("M1.5 0a1.5 1.5 0 0 1 1.061.439l6 6a1.5 1.5 0 0 1 0 2.121l-6 6a1.5 1.5 0 0 1-2.122-2.121L5.379 7.5.44 2.561A1.5 1.5 0 0 1 1.5 0Z");
          clip-path: path("M1.5 0a1.5 1.5 0 0 1 1.061.439l6 6a1.5 1.5 0 0 1 0 2.121l-6 6a1.5 1.5 0 0 1-2.122-2.121L5.379 7.5.44 2.561A1.5 1.5 0 0 1 1.5 0Z");
  width: 9px;
  height: 15px;
  margin-top: 2px;
}
.c-btn.--red {
  background: #E51F19;
  -webkit-box-shadow: 0 2px 0 #A30500;
          box-shadow: 0 2px 0 #A30500;
  color: #FFF;
  font-size: 14px;
  font-weight: bold;
  padding: 0.93em 4em;
}
.c-btn.--red:hover {
  background-color: #C41E19;
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-transform: translate(2px);
          transform: translate(2px);
}
.c-btn.--white {
  background: #FFF;
  border-color: #707070;
}
.c-btn.--white:hover {
  background-color: #F0F0F0;
}
.c-btn.--blue {
  background: #10357B;
  border-color: #FFF;
  color: #FFF;
}
.c-btn.--blue:hover {
  background-color: #05235D;
}
.c-btn.--brown {
  background: #F8F5F0;
  border-color: #707070;
}
.c-btn.--brown:hover {
  background: #EAE2D5;
}
.c-btn.--red .c-btn-label::after, .c-btn.--blue .c-btn-label::after {
  background-color: #FFF;
  /*
  border-top-color: #FFF;
  border-right-color: #FFF;
  */
}
.c-btn.--lightblue {
  background: #F0F3F8;
  -webkit-box-shadow: 0 3px 0 #CDDBEB;
          box-shadow: 0 3px 0 #CDDBEB;
  color: #10357B;
  font-size: 22px;
  min-width: 488px;
  padding: 0.91em 4em 1.09em;
}
.c-btn.--lightblue:hover {
  background: #CDDBEB;
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-transform: translate(3px);
          transform: translate(3px);
}
.c-btn.--lightblue .c-btn-label::after {
  background-color: #10357B;
  -webkit-clip-path: path("M1.5 0a1.5 1.5 0 0 1 1.061.439l6 6a1.5 1.5 0 0 1 0 2.121l-6 6a1.5 1.5 0 0 1-2.122-2.121L5.379 7.5.44 2.561A1.5 1.5 0 0 1 1.5 0Z");
          clip-path: path("M1.5 0a1.5 1.5 0 0 1 1.061.439l6 6a1.5 1.5 0 0 1 0 2.121l-6 6a1.5 1.5 0 0 1-2.122-2.121L5.379 7.5.44 2.561A1.5 1.5 0 0 1 1.5 0Z");
  width: 9px;
  height: 15px;
  margin-top: 2px;
}

.link-btn_town.btn {
  background: #10357B url(../images/texture_blue.png) no-repeat 0 0/cover;
  border-radius: 10px;
  color: #FFF;
  display: block;
  font-size: 24px;
  font-weight: bold;
  margin-top: 80px;
  padding: 32px 70px 32px 32px;
  position: relative;
  text-align: center;
}
.link-btn_town.btn::after {
  background: #FFF;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='7.8' height='12.6'%3E%3Cpath fill='%2310357b' d='M1.5 0a1.5 1.5 0 0 1 1.061.439l4.8 4.8a1.5 1.5 0 0 1 0 2.121l-4.8 4.8a1.5 1.5 0 0 1-2.121 0 1.5 1.5 0 0 1 0-2.121L4.179 6.3.439 2.561A1.5 1.5 0 0 1 1.5 0Z' data-name='path'/%3E%3C/svg%3E");
  background-position: 60% 50%;
  background-repeat: no-repeat;
  background-size: 7.8px auto;
  border-radius: 100px;
  content: "";
  width: 32px;
  height: 32px;
  position: absolute;
  top: 50%;
  right: 38px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.link-btn_town.btn .btn-label {
  display: inline-block;
  line-height: 1.2;
  padding-left: 76px;
  position: relative;
  text-align: left;
}
.link-btn_town.btn .btn-label::before {
  background: url(../images/icon-town_wh.svg) no-repeat 0 0/cover;
  content: "";
  display: block;
  width: 56px;
  height: 48px;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.link-btn_town.btn:hover {
  background-color: rgba(0, 20, 83, 0.8);
  text-decoration: none;
}
.link-btn_more {
  margin-top: 50px;
  text-align: center;
}

@media (max-width: 640px) {
  .c-btn {
    font-size: 14px;
    padding: 1em 3em;
  }
  .c-btn.--gray {
    font-size: 18px;
    padding: 0.94em 1em 1.06em;
  }
  .c-btn.--gray .c-btn-label::after {
    -webkit-clip-path: path("M1 0a1 1 0 0 1 .707.293l4 4a1 1 0 0 1 0 1.414l-4 4A1 1 0 0 1 .293 8.293L3.586 5 .293 1.707A1 1 0 0 1 1 0Z");
            clip-path: path("M1 0a1 1 0 0 1 .707.293l4 4a1 1 0 0 1 0 1.414l-4 4A1 1 0 0 1 .293 8.293L3.586 5 .293 1.707A1 1 0 0 1 1 0Z");
    width: 6px;
    height: 10px;
  }
  .c-btn.--lightblue {
    font-size: 18px;
    min-width: 0;
    padding: 0.83em 3em;
  }
  .c-btn.--lightblue .c-btn-label::after {
    -webkit-clip-path: path("M1 0a1 1 0 0 1 .707.293l4 4a1 1 0 0 1 0 1.414l-4 4A1 1 0 0 1 .293 8.293L3.586 5 .293 1.707A1 1 0 0 1 1 0Z");
            clip-path: path("M1 0a1 1 0 0 1 .707.293l4 4a1 1 0 0 1 0 1.414l-4 4A1 1 0 0 1 .293 8.293L3.586 5 .293 1.707A1 1 0 0 1 1 0Z");
    width: 6px;
    height: 10px;
    margin-top: 0;
  }
  .link-btn_town.btn {
    font-size: 18px;
    line-height: 1.39;
    margin-top: 50px;
    padding: 20px;
    text-align: left;
  }
  .link-btn_town.btn::after {
    background-size: 6px auto;
    width: 24px;
    height: 24px;
    right: 20px;
  }
  .link-btn_town.btn .btn-label {
    padding: 0;
  }
  .link-btn_town.btn .btn-label::before {
    display: none;
  }
  .link-btn_more {
    margin-top: 30px;
  }
}
/* item list */
.list-btn_station {
  display: grid;
  gap: 30px 24px;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 60px;
}

.list-link_title {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 35px;
  text-align: center;
}
.list-link_title .label {
  display: inline-block;
  position: relative;
}
.list-link_title .label::before, .list-link_title .label::after {
  background: #333;
  content: "";
  display: block;
  width: 50px;
  height: 1px;
  position: absolute;
  top: 50%;
}
.list-link_title .label::before {
  left: -65px;
}
.list-link_title .label::after {
  right: -65px;
}
.list-link_towns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.list-link_towns li {
  border-left: 1px solid #DDD;
  text-align: center;
  width: 20%;
}
@media (min-width: 641px) {
  .list-link_towns li:nth-child(5n+1) {
    border-left: none;
  }
  .list-link_towns li:nth-child(n+6) {
    margin-top: 1.56em;
  }
}

@media (max-width: 640px) {
  .list-btn_station {
    display: grid;
    gap: 16px 13px;
    grid-template-columns: repeat(2, 1fr);
    margin-top: 30px;
  }
  .list-link_title {
    font-size: 20px;
    margin-bottom: 14px;
  }
  .list-link_title .label::before, .list-link_title .label::after {
    width: 30px;
  }
  .list-link_title .label::before {
    left: -43px;
  }
  .list-link_title .label::after {
    right: -43px;
  }
  .list-link_towns {
    gap: 14px 0;
  }
  .list-link_towns li {
    font-size: 14px;
    width: 33.33%;
  }
  .list-link_towns li:nth-child(3n+1) {
    border-left: none;
  }
  .list-link_towns li:nth-child(n+3) {
    margin-top: 0;
  }
}
/* town links */
.block-link_towns {
  background: #F7F7F7;
  border-radius: 6px;
  margin-top: 60px;
  padding: 40px 50px;
}

@media (max-width: 640px) {
  .block-link_towns {
    margin-top: 30px;
    padding: 25px 20px;
  }
}
.contents-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 200px;
  text-align: center;
}
.contents-head_title {
  font-size: 40px;
  font-weight: bold;
  letter-spacing: 0.05em;
}
.contents-head.--town {
  background: #EFF8FD url(../images/texture_lightblue.png) no-repeat 50% 50%/cover;
}
.contents-head.--station {
  background: #EBF6F0 url(../images/texture_lightgreen.png) no-repeat 50% 50%/cover;
}

.contents-main {
  margin-bottom: 80px;
  padding: 60px 0 0;
}
.contents-main.contents-town_top {
  margin-bottom: 0;
}

@media (max-width: 640px) {
  .contents-head {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    height: 142px;
  }
  .contents-head_title {
    font-size: 32px;
  }
  .contents-main {
    margin-bottom: 30px;
    padding: 30px 0 0;
  }
}
/* town blue block  */
.section-town {
  margin-bottom: 0;
}
.section-town .section-catch {
  font-size: 24px;
  font-weight: bold;
  margin: 45px 0 30px;
  text-align: center;
}
.section-town .section-catch_line {
  margin-top: 0;
  margin-bottom: 1.33em;
  position: relative;
}
.section-town .section-catch_line:after, .section-town .section-catch_line:before {
  border: solid transparent;
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  height: 0;
  width: 0;
  pointer-events: none;
  margin-top: -2px;
  z-index: 5;
}
.section-town .section-catch_line:after {
  border-color: rgba(136, 183, 213, 0);
  border-top-color: #10357B;
  border-width: 12px;
  margin-left: -12px;
}
.section-town .section-catch_line:before {
  border-color: rgba(255, 255, 255, 0);
  border-top-color: #ffffff;
  border-width: 15px;
  margin-left: -15px;
}
.section-town .section-catch_line .label {
  border-bottom: 2px solid #FFF;
  display: inline-block;
  padding-bottom: 3px;
}

@media (max-width: 640px) {
  .section-town .section-catch {
    font-size: 20px;
    margin: 30px 0 24px;
  }
  .section-town .section-catch_line {
    margin-bottom: 1.25em;
  }
  .section-town .section-catch_line:after {
    border-width: 8px;
    margin-left: -8px;
  }
  .section-town .section-catch_line:before {
    border-width: 11px;
    margin-left: -11px;
  }
  .section-town .section-catch_line .label {
    line-height: 1.4;
    padding-bottom: 13px;
  }
}
.media-contact {
  background: #F2F1E9;
  padding: 48px 0;
  text-align: center;
}
.media-contact_inner {
  background: #FFF;
  border-radius: 6px;
  max-width: 738px;
  padding: 36px 0 40px;
}
.media-contact_title {
  font-size: 20px;
  font-weight: bold;
}
.media-contact_desc {
  font-size: 14px;
  margin-top: 0.36em;
}
.media-contact_btn {
  margin-top: 1.13em;
}
.media-contact_btn .c-btn {
  width: 300px;
}

@media (max-width: 1000px) {
  .media-contact_inner {
    max-width: 90%;
  }
}
@media (max-width: 640px) {
  .media-contact {
    padding: 30px;
  }
  .media-contact_inner {
    margin: 0;
    max-width: 100%;
    padding: 30px 20px;
  }
  .media-contact_title {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 18px;
    line-height: 1.28;
    text-align: left;
  }
  .media-contact_desc {
    margin-top: 1.43em;
    text-align: left;
  }
  .media-contact_btn {
    margin-top: 1.13em;
  }
  .media-contact_btn .c-btn {
    width: auto;
  }
}
/*
 * page styles
 * ------------------------------ */
.contents-head_index {
  background: url(../images/img_main.jpg) no-repeat 50% 50%/cover;
  height: 461px;
}

.contents-index {
  padding-top: 0;
}
.contents-index .section {
  margin-top: 0;
  padding-top: 90px;
  position: relative;
}
.contents-index .section::before {
  background: #FFF;
  content: "";
  -webkit-clip-path: path("M112.272 23H.001A80.093 80.093 0 0 1 25.283 6.165a79.9 79.9 0 0 1 75.2 7.24A80.653 80.653 0 0 1 112.271 23Z");
          clip-path: path("M112.272 23H.001A80.093 80.093 0 0 1 25.283 6.165a79.9 79.9 0 0 1 75.2 7.24A80.653 80.653 0 0 1 112.271 23Z");
  aspect-ratio: 1;
  display: block;
  width: 113px;
  height: 23px;
  position: absolute;
  bottom: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  margin-bottom: -1px;
  z-index: 1;
}
.contents-index .section-town::before {
  background-color: #001272;
}
.contents-index .section-title {
  color: #10357B;
  position: relative;
}
.contents-index .section-title::before {
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  width: 56px;
  height: 48px;
  position: absolute;
  top: -66px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.contents-index .section-title.icon-ranking::before {
  background-image: url(../images/icon-ranking_bl.svg);
}
.contents-index .section-title.icon-town::before {
  background-image: url(../images/icon-town_wh.svg);
}
.contents-index .section-title.icon-station::before {
  background-image: url(../images/icon-station_bl.svg);
}

.block-ranking {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 60px;
}
.block-ranking .item-ranking {
  background: #F3FBFF;
  border-radius: 6px;
  -webkit-box-flex: 0;
      -ms-flex: 0 1 calc(50% - 20px);
          flex: 0 1 calc(50% - 20px);
}
.block-ranking .item-ranking_title {
  background: #DBF3FF;
  border-radius: 6px 6px 0 0;
  font-size: 24px;
  font-weight: bold;
  padding: 18px 20px;
  position: relative;
}
.block-ranking .item-ranking_title::before {
  background: #93C5EA url(../images/icon-ranking_wh.svg) no-repeat 50% 50%/28px auto;
  border-radius: 50px;
  content: "";
  display: block;
  width: 42px;
  height: 42px;
  position: absolute;
  top: 50%;
  left: 20px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.block-ranking .item-ranking_main {
  padding: 35px 40px 40px;
}
.block-ranking .item-ranking .list-link_archive {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 30px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.block-ranking .item-ranking .list-link_archive .label-pref {
  color: #10357B;
  font-size: 16px;
  font-weight: bold;
}
.block-ranking .item-ranking .list-link_ranking {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.5em 1em;
}
.block-ranking .item-ranking .list-link_ranking li {
  display: inline-block;
  font-size: 18px;
}
.block-ranking .item-ranking .list-link_ranking a {
  text-decoration: underline;
}

@media (max-width: 640px) {
  .contents-head_index {
    background-image: url(../images/img_main_sp.jpg);
    height: 390px;
    padding-top: 40px;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
  }
  .contents-head_index .contents-head_title {
    width: 89.9%;
    margin: 0 auto;
  }
  .contents-index {
    margin-bottom: 0;
  }
  .contents-index .section {
    padding-top: 70px;
  }
  .contents-index .section::before {
    -webkit-clip-path: path("M89.445 20H.001A60.158 60.158 0 0 1 19.822 5.4a59.668 59.668 0 0 1 11.965-4 60.541 60.541 0 0 1 25.879 0 59.74 59.74 0 0 1 22.656 10.3 60.543 60.543 0 0 1 9.123 8.3Z");
            clip-path: path("M89.445 20H.001A60.158 60.158 0 0 1 19.822 5.4a59.668 59.668 0 0 1 11.965-4 60.541 60.541 0 0 1 25.879 0 59.74 59.74 0 0 1 22.656 10.3 60.543 60.543 0 0 1 9.123 8.3Z");
    width: 90px;
    height: 21px;
  }
  .contents-index .section-title {
    color: #10357B;
    position: relative;
  }
  .contents-index .section-title::before {
    width: 42px;
    height: 36px;
    top: -54px;
  }
  .block-ranking {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
    margin-top: 30px;
  }
  .block-ranking .item-ranking {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 48%;
            flex: 0 1 48%;
  }
  .block-ranking .item-ranking_title {
    font-size: 20px;
    padding: 14px 20px;
  }
  .block-ranking .item-ranking_title::before {
    background-size: 24px auto;
    width: 36px;
    height: 36px;
  }
  .block-ranking .item-ranking_main {
    padding: 20px;
  }
  .block-ranking .item-ranking .list-link_archive .label-pref {
    font-size: 18px;
  }
  .block-ranking .item-ranking .list-link_ranking {
    gap: 1em;
  }
  .block-ranking .item-ranking .list-link_ranking li {
    font-size: 16px;
  }
}
.nav-anchor {
  border: 2px solid #333;
  border-radius: 6px;
  margin: 60px 0 80px;
  padding: 24px 40px;
}
.nav-anchor .list-anchor {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5em 30px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.nav-anchor .list-anchor a {
  display: inline-block;
  padding-right: 20px;
  position: relative;
}
.nav-anchor .list-anchor a::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='9' height='5.5'%3E%3Cpath fill='%23333' d='M9 1a1 1 0 0 1-.293.707l-3.5 3.5a1 1 0 0 1-1.414 0l-3.5-3.5A1 1 0 0 1 1.707.293L4.5 3.086 7.293.293A1 1 0 0 1 9 1Z'/%3E%3C/svg%3E");
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  width: 9px;
  height: 6px;
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-40%);
          transform: translateY(-40%);
}

.section-data {
  margin-top: 60px;
}
.section-data_title {
  background: #F8F5F0;
  border-radius: 6px 6px 0 0;
  display: inline-block;
  font-size: 30px;
  font-weight: 500;
  padding: 32px 45px 0 86px;
  position: relative;
  text-align: left;
  z-index: 5;
}
.section-data_title::before {
  background: #E6CEA6 url(../images/icon-station_wh.svg) no-repeat 50% 50%/18px auto;
  border-radius: 50px;
  content: "";
  display: block;
  width: 42px;
  height: 42px;
  position: absolute;
  left: 29px;
}
.section-data .block-data {
  background: #F8F5F0;
  margin-top: -24px;
  padding: 70px 50px 40px;
  position: relative;
}
.section-data .block-data_label {
  border-bottom: 4px solid #E51F19;
  display: inline-block;
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 24px;
  padding-bottom: 10px;
  text-align: left;
}
.section-data .block-data_label ~ .block-data_label {
  margin-top: 40px;
}
.section-data .block-data_supplementary_info {
  font-size: 12px;
  line-height: 1;
  margin-top: -40px;
  margin-bottom: calc(40px - 1em);
  text-align: right;
}
.section-data .list-feature {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(213px, 1fr));
}
.section-data .list-feature li {
  background: #FFF;
  font-size: 15px;
  padding: 24px;
  position: relative;
}
.section-data .list-feature li::after {
  content: "";
  display: block;
  border-bottom: 15px solid transparent;
  border-right: 15px solid #F8F5F0;
  position: absolute;
  top: 0;
  right: 0;
}

@media (max-width: 640px) {
  .nav-anchor {
    margin: 30px 0;
    padding: 16px 15px;
  }
  .nav-anchor .list-anchor {
    gap: 14px 0;
  }
  .nav-anchor .list-anchor li {
    width: 50%;
  }
  .nav-anchor .list-anchor li:nth-child(odd) {
    padding-right: 1em;
  }
  .nav-anchor .list-anchor li:nth-child(even) {
    border-left: 1px solid #CCC;
    margin-left: 0;
    padding-left: 1em;
  }
  .nav-anchor .list-anchor a {
    display: block;
    font-size: 14px;
    padding-right: 20px;
  }
  .section-data {
    margin-top: 30px;
  }
  .section-data_title {
    font-size: 26px;
    padding: 17px 35px 2px 71px;
  }
  .section-data_title::before {
    background-size: 16px auto;
    width: 36px;
    height: 36px;
    left: 20px;
  }
  .section-data .block-data {
    font-size: 14px;
    margin: -2px 0 0;
    padding: 30px 20px;
  }
  .section-data .block-data_label {
    font-size: 18px;
    margin-bottom: 20px;
    padding-bottom: 4px;
  }
  .section-data .block-data_label ~ .block-data_label {
    margin-top: 30px;
  }
  .section-data .block-data_supplementary_info {
    font-size: 12px;
    margin-top: -10px;
    text-align: left;
  }
  .section-data .list-feature {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  .section-data .list-feature li {
    font-size: 14px;
    line-height: 1.5;
    padding: 15px 13px;
    width: auto;
  }
}/*# sourceMappingURL=styles.css.map */