@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,500,700,900&display=swap&subset=japanese");
@import url("https://fonts.googleapis.com/css?family=Lato:400&display=swap");
@import url("https://fonts.googleapis.com/css?family=Roboto:400,700&display=swap");
@import url("https://fonts.googleapis.com/css?family=Noto+Serif+JP:700&display=swap");
@import url(base.css);
.head-image {
  background-image: url("../img/base/head-img3.jpg"); }
  .head-image .text-box {
    margin-top: 21px; }
    .head-image .text-box .head-image-text {
      font-size: 35px;
      font-weight: 700; }
    .head-image .text-box .head-image-text-sub {
      font-size: 20px;
      margin-top: 12px;
      letter-spacing: 1px; }

.top-area {
  margin: 73px 0 90px;
  padding: 0 20px; }
  .top-area .mission {
    color: #31547b;
    font-family: "Roboto", sans-serif;
    font-size: 22px;
    margin-bottom: 10px;
    text-align: center;
    letter-spacing: 1px; }
    .top-area .mission .num {
      font-size: 52px;
      margin-left: 10px;
      vertical-align: -10px;
      letter-spacing: 1.5px; }
  .top-area .top-catch {
    color: #31547b;
    font-size: 32px;
    letter-spacing: 4.5px;
    margin-bottom: 21px;
    line-height: 1.7;
    text-align: center; }
  .top-area .top-read {
    font-size: 26px;
    font-family: "Noto Serif JP", serif;
    font-weight: 700;
    line-height: 43px;
    margin-bottom: 48px;
    text-align: center;
    letter-spacing: 4px; }
  .top-area .top-text {
    line-height: 32px;
    max-width: 890px;
    margin: 0 auto;
    text-align: justify;
    letter-spacing: .5px; }

.infra .inner {
  width: 100%;
  max-width: 1140px;
  padding: 0 20px;
  display: flex;
  flex-wrap: wrap; }
  .infra .inner .infra-ttl {
    font-size: 25px;
    color: #31547b;
    letter-spacing: 1px;
    margin-bottom: 34px;
    width: 100%; }
  .infra .inner .infra-item {
    width: 49%;
    height: 109px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    font-size: 26px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 1.5px;
    color: #31547b;
    border: solid 2px #31547b;
    margin-bottom: 19px; }
    .infra .inner .infra-item .infra-item-inner {
      text-align: center; }
    .infra .inner .infra-item .small {
      font-size: 21px;
      font-weight: inherit;
      letter-spacing: .3px; }
    .infra .inner .infra-item:nth-child(odd) {
      margin: 0 0 0 auto; }

.match {
  margin-top: 66px; }
  .match .match-box {
    max-width: 1140px;
    width: 100%;
    padding: 0 50px 30px 20px;
    position: relative; }
    .match .match-box .match-ttl {
      background: #31547b;
      padding: 20px 11px 20px 17px;
      font-size: 24px;
      font-weight: 700;
      color: white;
      letter-spacing: .5px;
      display: inline-block;
      position: relative; }
      .match .match-box .match-ttl:after {
        content: "";
        position: absolute;
        top: 0;
        right: -40px;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 68px 0 0 40px;
        border-color: transparent transparent transparent #31547b; }
    .match .match-box .match-text {
      border: solid 5px #31547b;
      color: #31547b;
      font-size: 20px;
      line-height: 37px;
      letter-spacing: .5px;
      padding: 15px 29px; }
      .match .match-box .match-text li {
        display: flex;
        align-items: flex-start; }
        .match .match-box .match-text li:before {
          content: "□";
          margin-right: .2em; }
    .match .match-box .match-iamge {
      position: absolute;
      width: 301px;
      bottom: 0;
      right: -5px;
      z-index: 1; }

.detail-area {
  background: #fafafa;
  padding: 80px 0 47px; }
  .detail-area .inner {
    max-width: 1140px;
    width: 100%;
    padding: 0 20px; }
    .detail-area .inner .detail-box {
      *zoom: 1;
      margin-bottom: 56px; }
      .detail-area .inner .detail-box:before, .detail-area .inner .detail-box:after {
        display: table;
        content: "";
        line-height: 0; }
      .detail-area .inner .detail-box:after {
        clear: both; }
      .detail-area .inner .detail-box .detail-image {
        width: 50%;
        height: 300px;
        overflow: hidden;
        float: left;
        position: relative; }
        .detail-area .inner .detail-box .detail-image .image {
          position: absolute;
          height: 100%;
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%); }
      .detail-area .inner .detail-box .detail-ttl, .detail-area .inner .detail-box .detail-text {
        width: 46.1%;
        float: right; }
      .detail-area .inner .detail-box .detail-ttl {
        color: #31547b;
        font-size: 26px;
        letter-spacing: 1.5px;
        margin-bottom: 26px;
        line-height: 1.4; }
      .detail-area .inner .detail-box .detail-text {
        line-height: 32px;
        text-align: justify;
        letter-spacing: .5px; }
      .detail-area .inner .detail-box:nth-child(even) .detail-image {
        float: right; }
      .detail-area .inner .detail-box:nth-child(even) .detail-ttl, .detail-area .inner .detail-box:nth-child(even) .detail-text {
        float: left; }
      .detail-area .inner .detail-box:last-child {
        margin-bottom: 0; }

.explanation {
  margin: 35px 0 81px; }
  .explanation .inner {
    width: 100%;
    max-width: 1140px;
    padding: 0 20px;
    display: flex;
    flex-wrap: wrap; }
    .explanation .inner .exp-item {
      width: 50%;
      padding-right: 37px;
      border-right: dashed 1px #808080; }
      .explanation .inner .exp-item:nth-child(even) {
        padding: 0 0 0 37px;
        border-right: none; }
      .explanation .inner .exp-item dt {
        font-size: 24px;
        letter-spacing: 1px;
        margin-bottom: 10px;
        line-height: 1.5;
        font-weight: 500; }
        .explanation .inner .exp-item dt .small {
          font-size: 18px;
          letter-spacing: .2px;
          margin-left: .5em; }
      .explanation .inner .exp-item dd {
        font-size: 14px;
        line-height: 27px;
        letter-spacing: .3px;
        text-align: justify; }

@media screen and (max-width: 768px) {
  .head-image {
    height: 220px; }
    .head-image .text-box {
      margin-top: 8px; }
      .head-image .text-box .head-image-text {
        font-size: 30px;
        line-height: 1.2; }
      .head-image .text-box .head-image-text-sub {
        font-size: 17px;
        margin-top: 15px; }

  .top-area {
    margin: 50px 0 50px;
    padding: 0 20px; }
    .top-area .mission {
      font-size: 18px;
      margin-bottom: 8px; }
      .top-area .mission .num {
        font-size: 35px;
        margin-left: 7px;
        vertical-align: -7px;
        letter-spacing: 1px; }
    .top-area .top-catch {
      font-size: 23px;
      letter-spacing: 2.5px;
      margin-bottom: 14px;
      line-height: 1.7; }
    .top-area .top-read {
      font-size: 18px;
      line-height: 32px;
      margin-bottom: 30px;
      letter-spacing: 2px; }
    .top-area .top-text {
      line-height: 26px; }

  .infra .inner .infra-item {
    width: 100%;
    height: 60px;
    font-size: 16px;
    letter-spacing: 1px;
    margin-bottom: 15px;
    border: none;
    border-bottom: dotted 1px #31547b;
    justify-content: left;
    font-weight: 400; }
    .infra .inner .infra-item .infra-item-inner {
      text-align: left; }
    .infra .inner .infra-item .small {
      font-size: 14px;
      letter-spacing: -.3px;
      margin-left: -.5em; }
    .infra .inner .infra-item:nth-child(n) {
      margin: 0; }
  .infra .inner .infra-ttl {
    font-size: 22px;
    letter-spacing: .5px;
    margin-bottom: 10px; }

  .match {
    margin-top: 40px; }
    .match .match-box {
      padding: 0 20px 30px; }
      .match .match-box .match-ttl {
        padding: 12px 30px 12px 15px;
        font-size: 20px;
        line-height: 1.5; }
        .match .match-box .match-ttl:after {
          border-width: 84px 0 0 40px; }
      .match .match-box .match-text {
        font-size: 17px;
        line-height: 30px;
        padding: 15px 20px; }
      .match .match-box .match-iamge {
        display: none; }

  .detail-area {
    padding: 30px 0 35px; }
    .detail-area .inner .detail-box {
      margin-bottom: 35px; }
      .detail-area .inner .detail-box .detail-image {
        width: 100%;
        height: 200px;
        float: none;
        margin-bottom: 15px; }
        .detail-area .inner .detail-box .detail-image .image {
          width: 100%;
          min-width: 348px;
          height: auto;
          min-height: auto;
          max-height: none; }
      .detail-area .inner .detail-box .detail-ttl, .detail-area .inner .detail-box .detail-text {
        width: 100%;
        float: none; }
      .detail-area .inner .detail-box .detail-ttl {
        color: white;
        background: #31547b;
        padding: 14px 20px;
        font-size: 20px;
        margin: 0 -20px 15px;
        line-height: 1.5;
        width: 100vw; }
      .detail-area .inner .detail-box .detail-text {
        line-height: 26px; }
      .detail-area .inner .detail-box:nth-child(even) .detail-image {
        float: none; }
      .detail-area .inner .detail-box:nth-child(even) .detail-ttl, .detail-area .inner .detail-box:nth-child(even) .detail-text {
        float: none; }

  .explanation {
    margin: 10px 0 30px; }
    .explanation .inner .exp-item {
      width: 100%;
      padding: 15px 0;
      border-right: none;
      border-bottom: dashed 1px #808080; }
      .explanation .inner .exp-item:nth-child(even) {
        padding: 15px 0; }
      .explanation .inner .exp-item:last-child {
        border-bottom: none; }
      .explanation .inner .exp-item dt {
        font-size: 18px;
        margin-bottom: 10px;
        line-height: 1.5; }
        .explanation .inner .exp-item dt .small {
          font-size: 14px; } }

/*# sourceMappingURL=infra.css.map */
