.l-main:after {
  position: fixed;
  z-index: -1;
  left: 300px;
  bottom: 0;
  content: '';
  opacity: .1;
  width: 849px;
  height: 735px;
  background: url(../imgs/top/bg_main.png) left -150px bottom no-repeat; }

.p-mv {
  position: relative;
  background: #ffffff; }
  .p-mv__frame {
    position: relative;
    width: 100%;
    padding-top: 50.72917%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    background-color: #fff; }
    .p-mv__frame:after {
      content: '';
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      left: 0;
      margin: auto;
      width: 80px;
      height: 80px;
      border: 2px solid #E894B1;
      border-left-color: #0a7cff;
      border-radius: 50%;
      -webkit-animation: spin 1s 0s linear infinite;
      animation: spin 1s 0s linear infinite; }
      @media screen and (max-width: 767px) {
        .p-mv__frame:after {
          width: 40px;
          height: 40px; } }
    .p-mv__frame span {
      position: absolute;
      z-index: 3;
      display: block;
      top: 0;
      left: 0;
      right: 0;
      margin: 0 auto;
      width: 90%;
      height: 100%; }
    .p-mv__frame video {
      width: 100%;
      height: auto; }
  .p-mv__copy {
    position: absolute;
    z-index: 5;
    bottom: 0;
    left: 0;
    right: 0;
    margin-bottom: 2.16049%;
    text-align: center;
    font-size: 1.77083vw;
    line-height: 2; }
    .p-mv__copy span {
      display: inline-block; }
    html[lang="en"] .p-mv__copy {
      line-height: 1.5;
      margin-bottom: 1.85185%; }
  @media screen and (max-width: 767px) {
    .p-mv__copy {
      position: static;
      padding: 30px 10px 0;
      margin-bottom: 1.5625%;
      font-size: 4.6875vw; }
      html[lang="en"] .p-mv__copy span {
        display: inline; } }

@-webkit-keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }

@keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }

.m-section-subtitle {
  font-size: 1.25rem;
  font-weight: bold; }

/* information, thoughts
---------------------------------------------- */
.p-information,
.p-thoughts {
  padding: 75px 30px; }
  .p-information .m-container,
  .p-thoughts .m-container {
    overflow: hidden; }
  .p-information__head,
  .p-thoughts__head {
    margin-bottom: 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center; }
    .p-information__head .m-title,
    .p-thoughts__head .m-title {
      margin-bottom: 0; }
  .p-information__viewall,
  .p-thoughts__viewall {
    margin-left: 10px;
    font-size: 14px; }
    .p-information__viewall a,
    .p-thoughts__viewall a {
      position: relative;
      display: inline-block;
      color: #000;
      background: #E894B1;
      text-decoration: none;
      padding: .3em .5em; }
      .p-information__viewall a::after,
      .p-thoughts__viewall a::after {
        content: '';
        display: inline-block;
        position: absolute;
        z-index: -1;
        top: 0;
        right: -8px;
        bottom: 0;
        margin: auto 0;
        width: 1.25em;
        height: 1.25em;
        background-color: #E894B1;
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg); }
  .p-information__list,
  .p-thoughts__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    margin: 0 -15px; }
  .p-information__article,
  .p-thoughts__article {
    -ms-flex-preferred-size: 30%;
    flex-basis: 30%;
    margin: 0 15px; }
    .p-information__article a,
    .p-thoughts__article a {
      color: inherit; }
  @media screen and (max-width: 767px) {
    .p-information,
    .p-thoughts {
      padding: 35px 15px; }
      .p-information__head,
      .p-thoughts__head {
        margin-bottom: 15px; }
      .p-information__viewall,
      .p-thoughts__viewall {
        margin: 0 15px 0 auto; }
        .p-information__viewall a,
        .p-thoughts__viewall a {
          font-size: 12px; }
      .p-information__list,
      .p-thoughts__list {
        display: block;
        margin: 0; }
      .p-information__article,
      .p-thoughts__article {
        margin: 0 0 15px; }
      .p-information__more,
      .p-thoughts__more {
        color: #E894B1;
        text-align: right; } }

.p-thoughts {
  background-color: #fdf3f8; }
  .p-thoughts__viewall {
    -ms-flex-negative: 0;
    flex-shrink: 0; }

/* about
---------------------------------------------- */
.p-about {
  background-color: #fdf3f8;
  padding: 50px 30px; }
  .p-about .m-container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
  .p-about .p-about__image {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    width: 59.52381%; }
  .p-about .p-about__body {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    margin-right: 4.7619%;
    width: 43.65079%; }
  .p-about .p-about__unit-title {
    margin-bottom: 15px; }
  .p-about .p-about__movie {
    margin: 20px auto; }
    .p-about .p-about__movie-inner {
      position: relative;
      width: 100%;
      padding-top: 56.25%; }
    .p-about .p-about__movie iframe {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
  .p-about__subtitle {
    text-align: center;
    padding: 20px 0;
    margin-bottom: 10px;
    font-size: 1.25rem; }
  .p-about .p-about__unit {
    font-size: 0.875rem; }
  .p-about .p-about__unit-title {
    font-size: 1.25rem;
    line-height: 1.5;
    color: #005BAC;
    padding: 0 0 0 15px;
    background: url(../imgs/top/icon_dallow-right.svg) left top 0.25em no-repeat;
    background-size: 10px 20px; }
  .p-about .p-about__unit--01 {
    margin-bottom: 50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between; }
    .p-about .p-about__unit--01 .p-about__unit-head {
      width: 37.5%;
      margin-right: 10px; }
    .p-about .p-about__unit--01 .p-about__unit-pic {
      width: 62.5%; }
  .p-about .p-about__unit--02 .p-about__unit-head {
    margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    .p-about {
      padding: 25px 15px; }
      .p-about .m-container {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column; }
      .p-about .p-about__image {
        width: 100%; }
      .p-about .p-about__body {
        margin: 0 auto;
        width: 100%; }
      .p-about__subtitle {
        font-size: 1.125rem;
        margin-bottom: 0; }
      .p-about .p-about__unit {
        font-size: 0.8125rem; }
      .p-about .p-about__unit-title {
        font-size: 1rem;
        line-height: 1.5;
        color: #005BAC;
        padding: 0 0 0 15px;
        margin-bottom: 10px;
        background: url(../imgs/top/icon_dallow-right.svg) left top 0.2em no-repeat;
        background-size: 8px 16px; }
      .p-about .p-about__unit--01 {
        margin-bottom: 35px;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column; }
        .p-about .p-about__unit--01 .p-about__unit-head,
        .p-about .p-about__unit--01 .p-about__unit-pic {
          width: 100%; }
        .p-about .p-about__unit--01 .p-about__unit-head {
          margin-bottom: 10px; }
      .p-about .p-about__unit--02 .p-about__unit-head {
        margin-bottom: 10px; } }

.p-about-button {
  font-weight: bold;
  text-align: center;
  padding: 40px 60px 40px 30px;
  color: #fff;
  display: block;
  font-size: 24px;
  background-image: url(../imgs/top/icon_arrow_right_01.png);
  background-position: right 20px center;
  background-repeat: no-repeat;
  background-color: #e894b1;
  text-decoration: none;
  cursor: pointer; }
  .p-about-button:hover {
    opacity: .65; }
  @media screen and (max-width: 640px) {
    .p-about-button {
      padding: 20px 30px 20px 15px;
      background-size: 18px;
      font-size: 18px; } }

/* concept
---------------------------------------------- */
.p-concept {
  padding: 50px 30px; }
  .p-concept__inner-top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
  .p-concept .p-concept__body {
    width: 55.55556%;
    margin-left: 4.7619%; }
  .p-concept .p-concept__image {
    width: 39.68254%;
    -ms-flex-item-align: center;
    -ms-grid-row-align: center;
    align-self: center; }
  .p-concept .p-concept__copy {
    margin-bottom: 15px; }
  .p-concept .p-concept__lead {
    margin-bottom: 15px;
    color: #005BAC;
    font-weight: bold;
    font-size: 1.5rem; }
  .p-concept .p-concept__desc {
    line-height: 1.77778; }
  .p-concept .p-concept-subtitle {
    margin-bottom: 30px;
    text-align: center;
    color: #005BAC;
    line-height: 1.5; }
    .p-concept .p-concept-subtitle > span {
      display: block;
      min-width: 300px;
      padding: 10px;
      text-align: center;
      border-top: 2px solid;
      border-bottom: 2px solid; }
    .p-concept .p-concept-subtitle > span span {
      font-size: 1rem; }
  .p-concept .p-concept__detail {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }
    .p-concept .p-concept__detail > div {
      width: 30%;
      margin: 50px 1%; }
  .p-concept .p-concept__value {
    margin: 50px 0; }
  .p-concept .p-concept__social p {
    text-align: center;
    line-height: 1.36364; }
  .p-concept .p-concept__theme {
    margin: 50px 0; }
    .p-concept .p-concept__theme ul {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center; }
      .p-concept .p-concept__theme ul li {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        background-color: #005BAC;
        height: 100px;
        margin: 0 5px;
        width: 100px;
        font-size: 1.125rem;
        line-height: 1.3;
        color: #fff;
        font-weight: bold;
        text-align: center;
        letter-spacing: .05em;
        border-radius: 50%; }
      html[lang="en"] .p-concept .p-concept__theme ul {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap; }
        html[lang="en"] .p-concept .p-concept__theme ul li {
          display: -webkit-inline-box;
          display: -ms-inline-flexbox;
          display: inline-flex;
          -webkit-box-align: center;
          -ms-flex-align: center;
          align-items: center;
          -webkit-box-pack: center;
          -ms-flex-pack: center;
          justify-content: center;
          line-height: 1.3;
          padding: 1.5em 0;
          width: 130px;
          font-size: 0.75rem; }
      html[lang="zh-cn"] .p-concept .p-concept__theme ul li {
        display: -webkit-inline-box;
        display: -ms-inline-flexbox;
        display: inline-flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        line-height: 1.3;
        padding: 1.5em 0;
        min-height: 2em; }
  @media screen and (max-width: 1260px) {
    .p-concept .p-concept__detail > div {
      width: 44%; }
    .p-concept .p-concept__theme ul li {
      font-size: 0.9375rem;
      margin: 0 5px; } }
  @media screen and (max-width: 767px) {
    .p-concept {
      padding: 25px 15px; }
      .p-concept__inner-top {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse; }
      .p-concept .p-concept__body {
        width: 100%;
        margin: 0 auto 15px; }
      .p-concept .p-concept__image {
        width: 100%; }
      .p-concept .p-concept-subtitle {
        margin-bottom: 15px; }
        .p-concept .p-concept-subtitle > span {
          width: 100%;
          min-width: auto; }
        .p-concept .p-concept-subtitle > span span {
          font-size: 0.875rem; }
      .p-concept .p-concept__copy {
        margin-bottom: 10px;
        font-size: 0; }
      .p-concept .p-concept__lead {
        margin-bottom: 5px;
        font-size: 0.9375rem; }
      .p-concept .p-concept__detail {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column; }
        .p-concept .p-concept__detail > div {
          width: 100%;
          margin: 15px 0 0; }
        .p-concept .p-concept__detail .p-concept__value {
          margin: 15px 0 25px; }
        .p-concept .p-concept__detail .p-concept__theme ul {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-pack: center;
          -ms-flex-pack: center;
          justify-content: center;
          -ms-flex-wrap: wrap;
          flex-wrap: wrap; }
          .p-concept .p-concept__detail .p-concept__theme ul li {
            width: 75px;
            height: 75px;
            font-size: 13px;
            margin: 0 3px 3px; }
          html[lang="en"] .p-concept .p-concept__detail .p-concept__theme ul {
            -ms-flex-wrap: wrap;
            flex-wrap: wrap; }
            html[lang="en"] .p-concept .p-concept__detail .p-concept__theme ul li {
              padding: 1em 0;
              width: 90px;
              font-size: 0.75rem; }
          html[lang="zh-cn"] .p-concept .p-concept__detail .p-concept__theme ul {
            -ms-flex-wrap: wrap;
            flex-wrap: wrap; }
            html[lang="zh-cn"] .p-concept .p-concept__detail .p-concept__theme ul li {
              padding: 1em 0;
              width: 90px; } }

/* service
---------------------------------------------- */
.p-service {
  background-color: #fdf3f8;
  padding: 50px 30px; }
  .p-service .m-section__subtitle {
    margin-bottom: 30px;
    font-size: 2.25rem; }
    html[lang="en"] .p-service .m-section__subtitle {
      line-height: 1.5; }
    html[lang="ja"] .m-section__subtitle br:nth-child(2) {
      display: none; }
    @media screen and (max-width: 640px) {
      .p-service .m-section__subtitle {
        font-size: 1.25rem; } }

.p-service-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }
  .p-service-nav li {
    width: 20%;
    opacity: .3;
    background: #fff; }
    .p-service-nav li a {
      display: block;
      padding: 20px 0 20px 10px; }
    .p-service-nav li.is-active {
      opacity: 1; }
  @media screen and (max-width: 640px) {
    .p-service-nav li {
      font-size: 0; }
      .p-service-nav li a {
        display: block;
        padding: 10px 0 10px 10px; } }

.p-service-items {
  padding: 40px 20px;
  background: #fff; }
  .p-service-items .p-service-item__lead {
    color: #005bac;
    font-weight: bold;
    font-size: 24px;
    line-height: 1.33333;
    margin-bottom: 40px; }
  @media screen and (max-width: 640px) {
    .p-service-items {
      padding: 20px 10px; }
      .p-service-items .p-service-item__lead {
        font-size: 1.125rem;
        margin-bottom: 20px; } }

.p-service-box-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  @media screen and (max-width: 640px) {
    .p-service-box-wrap {
      display: block; } }

.p-service-box-column {
  width: calc(50% - 30px); }
  @media screen and (max-width: 640px) {
    .p-service-box-column {
      width: 100%; } }

.p-service-box {
  margin-bottom: 40px;
  font-size: 1.375rem;
  line-height: 1.45455; }
  .p-service-box + .p-service-box {
    margin-top: 20px; }
  @media screen and (max-width: 640px) {
    .p-service-box {
      margin-bottom: 30px;
      font-size: 1.125rem; } }
  .p-service-box p + p {
    margin-top: .5em; }
  .p-service-box sup {
    top: -0.3em; }

.p-service-box__head {
  font-weight: bold;
  line-height: 1.41667;
  margin-bottom: .3em;
  text-indent: -1em;
  padding-left: 1em; }
  .p-service-box__head i {
    font-style: normal; }

.p-service-box__note {
  font-size: 0.9375rem; }
  @media screen and (max-width: 640px) {
    .p-service-box__note {
      font-size: 0.75rem; } }

.p-energy .p-service-box__head i {
  color: #f8b62d; }

.p-security .p-service-box__head i {
  color: #036eb8; }

.p-mobility .p-service-box__head i {
  color: #82c1ea; }

.p-wellness .p-service-box__head i {
  color: #f19dbb; }

.p-community .p-service-box__head i {
  color: #b077b0; }

/* plan
---------------------------------------------- */
.p-plan {
  background-color: #fdf3f8;
  padding: 50px 30px; }
  .p-plan__inner-top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
  .p-plan__image {
    width: 55.55556%; }
  .p-plan__body {
    width: 39.68254%;
    margin-left: 4.7619%; }
  .p-plan-list {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 15px;
    margin: -30px 15px 0;
    background-color: #fff;
    -webkit-box-shadow: 0 1px 3px 3px rgba(0, 0, 0, 0.1);
    box-shadow: 0 1px 3px 3px rgba(0, 0, 0, 0.1); }
    .p-plan-list__item {
      position: relative;
      max-width: 250px;
      margin: 0 10px; }
      .p-plan-list__item:not(:first-child)::after {
        content: '';
        position: absolute;
        top: 0;
        bottom: 0;
        left: -10px;
        margin: auto;
        height: 100%;
        width: 0;
        border-right: 1px solid #eee; }
      .p-plan-list__item p, .p-plan-list__item dl {
        line-height: 1.5;
        font-size: 0.8125rem; }
      .p-plan-list__item p {
        margin-bottom: 1em; }
      .p-plan-list__item dl {
        overflow: hidden; }
        .p-plan-list__item dl dt {
          float: left; }
        .p-plan-list__item dl dd {
          overflow: hidden; }
    .p-plan-list__item-head {
      text-indent: -1.4em;
      padding-left: 1.4em;
      line-height: 1.4;
      margin-bottom: 0.5em; }
    .p-plan-list__num {
      background: #E95290;
      display: inline-block;
      color: #fff;
      width: 1.4em;
      height: 1.4em;
      text-align: center;
      border-radius: 50%;
      text-indent: 0; }
    .p-plan-list__title {
      font-weight: bold;
      font-size: 1rem; }
  .p-plan__notes {
    text-align: right;
    margin: 10px 15px 0;
    font-size: 0.625rem; }
  @media screen and (min-width: 751px) and (max-width: 1620px) {
    .p-plan-list {
      -ms-flex-wrap: wrap;
      flex-wrap: wrap; }
      .p-plan-list__item {
        max-width: 100%;
        width: calc(33.1% - 20px); }
        .p-plan-list__item:nth-child(-n+3) {
          margin-bottom: 20px; }
        .p-plan-list__item:nth-child(4) br {
          display: inline; }
        .p-plan-list__item:nth-child(4):after {
          display: none; } }
  @media screen and (max-width: 767px) {
    .p-plan {
      padding: 25px 15px; }
      .p-plan__inner-top {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse; }
      .p-plan__image, .p-plan__body {
        width: 100%;
        margin: 0 auto 25px; }
      .p-plan-list {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        margin: -30px 10px 0; }
        .p-plan-list__item {
          max-width: 100%;
          margin: 0 0 10px;
          padding: 10px 0; }
          .p-plan-list__item:not(:first-child)::after {
            top: -6px;
            left: 0;
            margin: 0 auto;
            height: 1px;
            width: 100%;
            border-bottom: 1px solid #eee;
            border-right: none; } }

.p-plan-logoarea {
  margin-top: 40px;
  padding: 0 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start; }
  @media screen and (max-width: 640px) {
    .p-plan-logoarea {
      margin-top: 30px; } }

.p-plan-logoarea__item {
  margin: 0 10px 20px; }
  @media screen and (max-width: 640px) {
    .p-plan-logoarea__item {
      margin: 0 5px 10px;
      max-width: calc(50% - 10px); } }

/* p town
---------------------------------------------- */
.p-town {
  padding: 50px 30px; }
  .p-town .m-section__subtitle {
    margin-bottom: 30px;
    font-size: 2.25rem; }
    html[lang="en"] .p-town .m-section__subtitle {
      line-height: 1.5; }
    html[lang="ja"] .m-section__subtitle br:nth-child(2) {
      display: none; }
  .p-town .p-town__goal h4,
  .p-town .p-town__potal h4 {
    color: #005bac;
    font-weight: bold;
    font-size: 1.5rem;
    text-align: center;
    border: solid 1px #005bac;
    padding: 10px;
    margin: 35px auto; }
  .p-town .p-town__goal h4 {
    margin-bottom: 25px; }
  .p-town .p-town__goal p {
    font-size: 1.125rem;
    line-height: 1.77778;
    margin-bottom: 30px; }
  @media screen and (max-width: 640px) {
    .p-town {
      padding: 25px 15px; }
      .p-town .m-section__subtitle {
        font-size: 1.125rem;
        margin-bottom: 10px; }
      .p-town .p-town__goal h4,
      .p-town .p-town__potal h4 {
        margin-bottom: 15px;
        font-size: 18px; } }

.p-town__cats {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  @media screen and (max-width: 640px) {
    .p-town__cats {
      display: block; } }

.p-town__catitem {
  width: calc(33% - 10px); }
  @media screen and (min-width: 641px) {
    .p-town__catitem .p-town__catitem + .p-town__catitem {
      margin-left: 20px; } }
  @media screen and (max-width: 640px) {
    .p-town__catitem {
      width: auto; } }

.p-town__catitem-head {
  font-size: 24px;
  line-height: 1.25;
  min-height: 3.75em;
  text-align: center;
  margin-bottom: 5px; }
  @media screen and (max-width: 640px) {
    .p-town__catitem-head {
      min-height: 2em;
      font-size: 18px;
      padding: 10px 0; } }

.p-town__catitem--env .p-town__catitem-head {
  color: #6fba2c; }

.p-town__catitem--resilience .p-town__catitem-head {
  color: #796baf; }

.p-town__catitem--attempt .p-town__catitem-head {
  color: #eb6e9e; }

.p-town .m-section__desc {
  font-size: 1.125rem;
  line-height: 2;
  margin-bottom: 30px; }

.p-town__potal ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 40px; }

.p-town__potal li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: calc(33% - 10px);
  background-color: #dee4f3;
  border-radius: 30px;
  color: #005bac;
  font-weight: bold;
  padding: 5px;
  text-align: center;
  font-size: 1.5rem;
  line-height: 1.25; }

@media screen and (min-width: 641px) {
  .p-town__potal li + li {
    margin-left: 20px; } }

@media screen and (max-width: 640px) {
  .p-town__potal ul {
    display: block; }
  .p-town__potal li {
    border-radius: 5px;
    width: 100%;
    font-size: 18px;
    margin-bottom: 10px; } }

.p-town__potalsite h4 {
  margin-bottom: 30px;
  background: #005bac;
  color: #fff;
  font-size: 1.5rem;
  font-weight: bold;
  padding: 8px;
  text-align: center; }

.p-town__potalsite p {
  text-align: center; }

@media screen and (max-width: 640px) {
  .p-town__potalsite h4 {
    font-size: 1.125rem; } }

/* promotions and overview
---------------------------------------------- */
.p-section-columns {
  background-color: #fdf3f8;
  padding: 50px 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  .p-section-columns > .m-section {
    width: 48%; }
  .p-section-columns > .m-container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between; }
    .p-section-columns > .m-container > .m-section {
      width: 48%; }
  @media screen and (max-width: 767px) {
    .p-section-columns {
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -ms-flex-direction: column;
      flex-direction: column;
      padding: 25px 15px; }
      .p-section-columns > .m-section {
        width: 100%; }
      .p-section-columns > .m-container {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column; }
        .p-section-columns > .m-container > .m-section {
          width: 100%; } }

.p-partner {
  background-color: #ffffff;
  padding: 50px 30px; }
  .p-partner .m-section-subtitle {
    font-size: 1.25rem;
    margin-bottom: 20px; }
  .p-partner__lead {
    margin-bottom: 30px; }
  .p-partner__desc dl:not(:last-child) {
    padding-bottom: 15px; }
  .p-partner__desc dt {
    position: relative;
    z-index: 3;
    text-align: left;
    font-size: 1.125rem;
    font-weight: bold; }
    .p-partner__desc dt:after {
      content: '';
      position: absolute;
      z-index: -1;
      left: 0;
      top: 0;
      bottom: 0;
      margin: auto;
      height: 1px;
      width: 100%;
      background: #ccc; }
    .p-partner__desc dt span {
      display: inline-block;
      background: #fff;
      padding-right: .5em; }
  .p-partner__desc dd {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; }
    .p-partner__desc dd span {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      padding: 25px; }
      .p-partner__desc dd span img {
        width: 100%; }
    .p-partner__desc dd .logo-kowa {
      max-width: 160px; }
    .p-partner__desc dd .logo-plt {
      max-width: 270px; }
    .p-partner__desc dd .logo-osakagas {
        max-width: 160px; }
    .p-partner__desc dd .logo-asahi {
        max-width: 150px; }


  @media screen and (max-width: 767px) {
    .p-partner {
      padding: 25px 15px;
      margin-bottom: 50px; }
      .p-partner .m-section-subtitle {
        text-align: center;
        font-size: 1.125rem; }
      .p-partner__desc dd span {
        padding: 15px 10px; }
      .p-partner__desc dd span img {
        width: auto;
        max-height: 26px; }
      .p-partner__desc dd .logo-kanden img {
        max-height: 35px; }
      .p-partner__desc dd .logo-takenaka img,
      .p-partner__desc dd .logo-mitsuisumitomo img,
      .p-partner__desc dd .logo-jr-nishi-develop img {
        max-height: 35px; }
      .p-partner__desc dd .logo-suita {
        max-height: 35px; }
      .p-partner__desc dd .logo-kowa {
        max-width: 160px; }
      .p-partner__desc dd .logo-kowa img {
          min-height: 32px; }
      .p-partner__desc dd .logo-plt img {
        min-height: 40px; } 
      .p-partner__desc dd .logo-osakagas img {
        min-height: 45px;}
      .p-partner__desc dd .logo-asahi img {
        min-height: 45px;}}

.p-overview {
  padding: 50px 30px; }
  .p-overview .m-section-subtitle {
    font-size: 1.25rem;
    margin-bottom: 20px; }
  .p-overview p {
    margin-bottom: 15px; }
  .p-overview .p-overview__desc {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
  .p-overview .p-overview-about {
    width: 43%;
    margin-right: 2%; }
    .p-overview .p-overview-about h4 {
      margin: 15px 0 5px;
      line-height: 1.3;
      font-weight: bold;
      font-size: 1.125rem; }
    .p-overview .p-overview-about dl {
      overflow: hidden;
      font-size: 1rem; }
      .p-overview .p-overview-about dl dt {
        position: relative;
        float: left;
        min-width: 6em; }
        .p-overview .p-overview-about dl dt:after {
          content: ':';
          position: absolute;
          top: 0;
          right: .5em; }
        html[lang="en"] .p-overview .p-overview-about dl dt {
          min-width: 7em; }
      .p-overview .p-overview-about dl dd {
        overflow: hidden; }
  .p-overview .p-overview-photo {
    width: 55%; }
    .p-overview .p-overview-photo img {
      width: 100%; }
  .p-overview .overview__contact {
    margin-top: 30px; }
    .p-overview .overview__contact h5 {
      font-weight: normal;
      margin-bottom: 15px; }
    .p-overview .overview__contact p {
      font-size: 0.875rem;
      line-height: 1.15; }
    .p-overview .overview__contact a {
      color: #005BAC; }
  @media screen and (max-width: 767px) {
    .p-overview {
      padding: 25px 15px; }
      .p-overview .m-section-subtitle {
        font-size: 1.125rem;
        margin-bottom: 10px; }
      .p-overview p {
        margin-bottom: 15px; }
      .p-overview .p-overview__desc {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column; }
      .p-overview .p-overview-about,
      .p-overview .p-overview-photo {
        width: 100%;
        margin: 0 auto 20px; }
      .p-overview .p-overview-photo {
        margin-bottom: 0; } }

.p-schedule {
  background-color: #fdf3f8;
  padding: 50px 30px; }
  .p-schedule__fig {
    text-align: center; }
  .p-schedule__fig-scroll {
    position: relative;
    width: 100px;
    margin: 5px 0 0 auto;
    padding: 0 20px 0;
    border-bottom: 1px solid #999;
    text-align: center;
    font-size: 0.8125rem;
    color: #999; }
    .p-schedule__fig-scroll:before, .p-schedule__fig-scroll:after {
      position: absolute;
      content: '';
      bottom: 0; }
    .p-schedule__fig-scroll:after {
      right: 0;
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 7px 0 0 7px;
      border-color: transparent transparent transparent #999; }
  @media screen and (max-width: 767px) {
    .p-schedule {
      padding: 25px 15px; }
      .p-schedule__fig {
        overflow: auto;
        height: 320px;
        padding: 10px;
        border: 2px solid #000; }
        .p-schedule__fig img {
          display: block;
          height: 290px;
          width: auto;
          max-width: none; } }

.p-supporter {
  padding: 50px 30px;
  text-align: center; }
  .p-supporter h2 {
    font-size: 1.5rem;
    max-width: 600px;
    margin: 0 auto 10px; }
    .p-supporter h2 span {
      display: inline-block;
      padding-bottom: 5px;
      border-bottom: 3px solid #E894B1; }
  .p-supporter p {
    margin: 30px;
    line-height: 1.5; }
  .p-supporter ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }
    .p-supporter ul li {
      margin: 0 15px;
      width: 260px; }
  @media screen and (max-width: 767px) {
    .p-supporter {
      padding: 25px 15px; }
      .p-supporter h2 {
        font-size: 1.25rem; }
      .p-supporter p {
        font-size: 0.875rem;
        text-align: left;
        line-height: 1.5;
        margin: 15px 0; }
      .p-supporter ul {
        margin: 0 -5px; }
        .p-supporter ul li {
          margin: 0 5px; } }

.p-tour {
  max-width: 700px;
  margin: 30px auto 50px;
  border: 3px solid #005bac; }
  .p-tour h2 {
    background: #005bac;
    color: #fff;
    font-size: 1.5rem;
    padding: 10px;
    text-align: center; }
  .p-tour .p-tour-box__body {
    padding: 15px 20px;
    font-size: 1.125rem;
    line-height: 1.55556; }
  .p-tour .p-tour-box__link {
    text-align: center;
    font-size: 1.5rem;
    margin-top: 10px;
    font-weight: bold; }
    .p-tour .p-tour-box__link a {
      color: #005bac;
      text-decoration: none; }
      .p-tour .p-tour-box__link a:hover {
        text-decoration: underline; }
  @media screen and (max-width: 640px) {
    .p-tour {
      max-width: calc(100% - 30px);
      margin: 15px auto 25px; }
      .p-tour h2 {
        font-size: 20px; }
      .p-tour .p-tour-box__body {
        font-size: 14px; }
      .p-tour .p-tour-box__link {
        font-size: 1.25rem; } 
.p-mv__frame span {
    width: 100%;
}
		}
