@charset "UTF-8";
/**************************************************************
foundation
**************************************************************/
/* reset
------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline; }

html {
  line-height: 1; }

ol,
ul {
  list-style: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption,
th,
td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle; }

q,
blockquote {
  quotes: none; }

q:before,
q:after,
blockquote:before,
blockquote:after {
  content: "";
  content: none; }

a img {
  border: none; }

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary {
  display: block; }

img {
  vertical-align: bottom;
  border: none; }

button,
input,
select,
textarea {
  vertical-align: middle; }

input {
  outline: 0; }

button,
input {
  *overflow: visible;
  line-height: normal; }

button::-moz-focus-inner,
input::-moz-focus-inner {
  padding: 0;
  border: 0; }

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  cursor: pointer;
  -webkit-appearance: button; }

label,
select,
button,
input[type="button"],
input[type="reset"],
input[type="submit"],
input[type="radio"],
input[type="checkbox"] {
  cursor: pointer; }

textarea {
  overflow: auto;
  vertical-align: top;
  font-family: sans-serif; }

/* color
------------------------------------------------*/
/* mixin
------------------------------------------------*/
/* base
------------------------------------------------*/
html {
  font-size: 62.5%; }

body {
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  background-color: #EEF2F5; }
  body.fixed {
    position: fixed;
    width: 100%;
    height: 100%; }

body,
input,
textarea {
  font-size: 14px;
  font-size: 1.4rem;
  color: #333;
  font-family: "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Verdana, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1.8;
  -webkit-text-size-adjust: 100%; }

main {
  letter-spacing: 0.02em; }

a {
  color: #005491;
  text-decoration: none;
  -webkit-transition: all .2s;
  -o-transition: all .2s;
  transition: all .2s; }
  a:hover {
    -webkit-transition: all .2s;
    -o-transition: all .2s;
    transition: all .2s; }

@media screen and (max-width: 599px) {
  body,
  input,
  textarea {
    line-height: 1.8; }
  a:hover {
    -ms-filter: "alpha(opacity=100)";
    opacity: 1; }

	}

/**************************************************************
layout
**************************************************************/
/* header
------------------------------------------------*/
#top .l-header {
  background: rgba(253, 253, 253, 0.97); }

.l-header {
  -webkit-box-shadow: 0 6px 6px -6px rgba(0, 0, 0, 0.15);
  -moz-box-shadow: 0 6px 6px -6px rgba(0, 0, 0, 0.15);
  box-shadow: 0 6px 6px -6px rgba(0, 0, 0, 0.15);
  background: #FFF;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 4;
  width: 100%;
  height: 115px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden; }
  .l-header .c-layout-contents {
    position: relative; }
    .l-header .c-layout-contents:after {
      content: "";
      display: block;
      clear: both; }
  .l-header__logo {
    float: left;
    width: 15.18519%; }
    .l-header__logo img {
      padding: 28px 0 28px 10px;
      width: 100%;
      height: auto; }
  .l-header__menubtn {
    display: none; }
  .l-header .l-nav {
    float: right;
    width: 84.81481%; }
    .l-header .l-nav:after {
      content: "";
      width: 100%;
      height: 100%;
      position: fixed;
      padding: 0 500%;
      margin: 0 -500%;
      visibility: hidden;
      -webkit-transition: .4s;
      -o-transition: .4s;
      transition: .4s; }
    .l-header .l-nav.menuover:after {
      background-color: rgba(0, 0, 0, 0.7);
      visibility: visible;
      -webkit-transition: .4s;
      -o-transition: .4s;
      transition: .4s; }
    .l-header .l-nav__global {
      font-size: 17px;
      font-size: 1.7rem;
      margin: 62px -13px 0 0;
      text-align: right; }
      .l-header .l-nav__global:after {
        content: "";
        display: block;
        clear: both; }
      .l-header .l-nav__global-item {
        display: inline-block;
        margin-right: 3.5%;
        text-align: left; }
        .l-header .l-nav__global-item:first-child {
          display: none; }
        .l-header .l-nav__global-item a {
          display: block;
          color: #005491;
          font-weight: bold;
          padding-bottom: 17px; }
          .l-header .l-nav__global-item a img {
            display: none; }
          .l-header .l-nav__global-item a:hover {
            opacity: 1; }
        .l-header .l-nav__global-item:after {
          content: "";
          display: block;
          width: 100%;
          height: 6px;
          -moz-transform: scaleX(0);
          -o-transform: scaleX(0);
          -ms-transform: scaleX(0);
          -webkit-transform: scaleX(0);
          transform: scaleX(0);
          -webkit-transition: all .4s;
          -o-transition: all .4s;
          transition: all .4s; }
        .l-header .l-nav__global-item.is-current:after, .l-header .l-nav__global-item.is-hovered:after, .l-header .l-nav__global-item:hover:after {
          content: "";
          display: block;
          height: 6px;
          background: #005491;
          -moz-transform: scaleX(1);
          -o-transform: scaleX(1);
          -ms-transform: scaleX(1);
          -webkit-transform: scaleX(1);
          transform: scaleX(1); }
      .l-header .l-nav__global__sub {
        display: none;
        position: absolute;
        top: 115px;
        left: 0;
        z-index: 1;
        width: 100%;
        background: #005491;
        padding: 0 500%;
        margin: 0 -500%; }
        .l-header .l-nav__global__sub__title, .l-header .l-nav__global__sub__list {
          -ms-filter: "alpha(opacity=0)";
          opacity: 0;
          -webkit-transition: .3s;
          -o-transition: .3s;
          transition: .3s; }
          .l-header .l-nav__global__sub__title.menuon, .l-header .l-nav__global__sub__list.menuon {
            -ms-filter: "alpha(opacity=100)";
            opacity: 1;
            -webkit-transition: .3s;
            -o-transition: .3s;
            transition: .3s; }
        .l-header .l-nav__global__sub__title {
          color: #fff;
          float: left;
          width: 33%;
          min-height: 1%;
          padding: 40px 0;
          font-size: 12px;
          font-size: 1.2rem;
          letter-spacing: 0.2rem; }
          .l-header .l-nav__global__sub__title img {
            display: block;
            margin-bottom: 10px; }
        .l-header .l-nav__global__sub__list {
          padding: 33px 0;
          float: left;
          width: 67%; }
          .l-header .l-nav__global__sub__list:after {
            content: "";
            display: block;
            clear: both; }
          .l-header .l-nav__global__sub__list-item {
            float: left;
            width: 50%; }
            .l-header .l-nav__global__sub__list-item:first-child {
              display: none; }
            .l-header .l-nav__global__sub__list-item a {
              font-size: 13px;
              font-size: 1.3rem;
              font-weight: normal;
              color: #fff;
              padding: 2px; }
              .l-header .l-nav__global__sub__list-item a:hover {
                opacity: 0.7; }
    .l-header .l-nav__etc {
      position: absolute;
      top: 0;
      right: 0; }
      .l-header .l-nav__etc:after {
        content: "";
        display: block;
        clear: both; }
      .l-header .l-nav__etc-item {
        float: left;
        line-height: 39px;
        font-size: 12px;
        font-size: 1.2rem;
        color: #fff; }
        .l-header .l-nav__etc-item a {
          display: block;
          line-height: 39px;
          color: #fff;
          text-align: center;
          background: #005491;
          padding-bottom: 0; }
        .l-header .l-nav__etc-item.fontsize {
          background: #005491; }
          .l-header .l-nav__etc-item.fontsize .fontsize-title {
            font-size: 12px;
            font-size: 1.2rem;
            color: #fff;
            padding: 0 0 0 24px;
            float: left; }
            .l-header .l-nav__etc-item.fontsize .fontsize-title:after {
              content: "";
              display: inline-block;
              width: 1px;
              height: 11px;
              background: #4D87B5;
              margin-left: 16px; }
          .l-header .l-nav__etc-item.fontsize .fontsize-box {
            position: relative;
            float: left; }
            .l-header .l-nav__etc-item.fontsize .fontsize-box__select {
              -webkit-appearance: none;
              -moz-appearance: none;
              appearance: none;
              border: none;
              background: #005491;
              font-size: 12px;
              font-size: 1.2rem;
              color: #fff;
              padding: 0 12px;
              width: 53px;
              height: 39px;
              line-height: 39px; }
              .l-header .l-nav__etc-item.fontsize .fontsize-box__select:after {
                content: none; }
              .l-header .l-nav__etc-item.fontsize .fontsize-box__select::-ms-expand {
                display: none; }
              .l-header .l-nav__etc-item.fontsize .fontsize-box__select .list {
                width: 100%;
                margin-top: 0;
                border-radius: 0;
                -webkit-box-shadow: none;
                box-shadow: none;
                background-color: #005491;
                color: #FFF;
                -webkit-transform: none;
                -ms-transform: none;
                transform: none; }
                .l-header .l-nav__etc-item.fontsize .fontsize-box__select .list .option {
                  min-height: 0;
                  padding: 3px;
                  text-align: center;
                  line-height: 1.8; }
                  .l-header .l-nav__etc-item.fontsize .fontsize-box__select .list .option:hover, .l-header .l-nav__etc-item.fontsize .fontsize-box__select .list .option.focus {
                    background-color: #0A5E9E; }
            .l-header .l-nav__etc-item.fontsize .fontsize-box:after {
              content: "";
              display: inline-block;
              width: 0;
              height: 0;
              border-style: solid;
              border-width: 5px 3.5px 0 3.5px;
              border-color: #ffffff transparent transparent transparent;
              position: absolute;
              top: 50%;
              right: 15px;
              margin-top: -3px; }


.l-header .l-nav__etc-item.language {
          background: #005491;
          border-left: 1px solid #4D87B5;}
          .l-header .l-nav__etc-item.language .language-box {
            position: relative;
            float: left; }
            .l-header .l-nav__etc-item.language .language-box__select {
              -webkit-appearance: none;
              -moz-appearance: none;
              appearance: none;
              border: none;
              background: #005491;
              font-size: 12px;
              font-size: 1.2rem;
              color: #fff;
              padding: 0 12px;
              width: 53px;
              height: 39px;
              line-height: 39px; }
              .l-header .l-nav__etc-item.language .language-box__select:after {
                content: none; }
              .l-header .l-nav__etc-item.language .language-box__select::-ms-expand {
                display: none; }
              .l-header .l-nav__etc-item.language .language-box__select .list {
                width: 100%;
                margin-top: 0;
                border-radius: 0;
                -webkit-box-shadow: none;
                box-shadow: none;
                background-color: #005491;
                color: #FFF;
                -webkit-transform: none;
                -ms-transform: none;
                transform: none; }
                .l-header .l-nav__etc-item.language .language-box__select .list .option {
                  min-height: 0;
                  padding: 3px;
                  text-align: center;
                  line-height: 1.8; }
                  .l-header .l-nav__etc-item.language .language-box__select .list .option:hover, .l-header .l-nav__etc-item.language .language-box__select .list .option.focus {
                    background-color: #0A5E9E; }
            .l-header .l-nav__etc-item.language .language-box:after {
              content: "";
              display: inline-block;
              width: 0;
              height: 0;
              border-style: solid;
              border-width: 5px 3.5px 0 3.5px;
              border-color: #ffffff transparent transparent transparent;
              position: absolute;
              top: 50%;
              right: 15px;
              margin-top: -3px; }




        .l-header .l-nav__etc-item.search {
          position: relative;
          min-width: 48px;
          height: 39px;
          border-left: 1px solid #4D87B5; }
          .l-header .l-nav__etc-item.search.click .search-box {
            padding: 0 9px; }
            .l-header .l-nav__etc-item.search.click .search-box__text {
              margin-left: 40px; }
              .l-header .l-nav__etc-item.search.click .search-box__text input {
                position: relative;
                width: 102px;
                margin-right: 40px; }
            .l-header .l-nav__etc-item.search.click .search-box:after {
              left: 0;
              right: auto; }
            .l-header .l-nav__etc-item.search.click .search-box__btn {
              background-image: url(../images/common/search_close.png); }
              .l-header .l-nav__etc-item.search.click .search-box__btn:hover {
                background-color: #005491; }
          .l-header .l-nav__etc-item.search .search-box {
            background: #005491; }
            .l-header .l-nav__etc-item.search .search-box__text input {
              width: 48px;
              height: 100%;
              padding: 0;
              font-size: 12px;
              font-size: 1.2rem;
              color: #fff;
              background: #005491;
              border: none;
              z-index: 0;
              -webkit-transition: all .4s;
              -o-transition: all .4s;
              transition: all .4s; }
              .l-header .l-nav__etc-item.search .search-box__text input::-webkit-input-placeholder {
                color: #fff;
                -ms-filter: "alpha(opacity=40)";
                opacity: 0.4; }
            .l-header .l-nav__etc-item.search .search-box:after, .l-header .l-nav__etc-item.search .search-box__btn {
              content: "";
              display: inline-block;
              width: 48px;
              height: 39px;
              position: absolute;
              top: 0;
              right: 0;
              background: 50% 50% no-repeat #005491;
              background-image: url(../images/common/search.png);
              background-size: 16px auto; }
            .l-header .l-nav__etc-item.search .search-box__btn {
              padding: 0;
              border: none;
              z-index: 1;
              cursor: pointer;
              -webkit-transition: all .2s;
              -o-transition: all .2s;
              transition: all .2s; }
              .l-header .l-nav__etc-item.search .search-box__btn:hover {
                background-color: #0A5E9E; }
        .l-header .l-nav__etc-item.print {
          width: 135px;
          border-left: 1px solid #4D87B5; }
          .l-header .l-nav__etc-item.print a:hover {
            background: #0A5E9E; }
        .l-header .l-nav__etc-item.contact {
          width: 113px; }
          .l-header .l-nav__etc-item.contact a {
            background: #0499CC;
            font-weight: bold; }
            .l-header .l-nav__etc-item.contact a:hover {
              background: #23A9DA; }





@media only screen and (max-width: 999px) {
  .l-header {
    height: 60px; }
    .l-header.menuon {
      background: #fff; }
      .l-header.menuon .l-header__menubtn__line-top {
        -moz-transform: translateY(7px) rotate(-45deg);
        -o-transform: translateY(7px) rotate(-45deg);
        -ms-transform: translateY(7px) rotate(-45deg);
        -webkit-transform: translateY(7px) rotate(-45deg);
        transform: translateY(7px) rotate(-45deg); }
      .l-header.menuon .l-header__menubtn__line-middle {
        -ms-filter: "alpha(opacity=0)";
        opacity: 0; }
      .l-header.menuon .l-header__menubtn__line-bottom {
        -moz-transform: translateY(-7px) rotate(45deg);
        -o-transform: translateY(-7px) rotate(45deg);
        -ms-transform: translateY(-7px) rotate(45deg);
        -webkit-transform: translateY(-7px) rotate(45deg);
        transform: translateY(-7px) rotate(45deg); }
    .l-header .c-layout-contents {
      margin: 0; }
    .l-header__logo {
      position: absolute;
      top: 13px;
      left: 20px;
      z-index: 2;
      padding: 0;
      width: 90px; }
      .l-header__logo img {
        padding: 0; }
    .l-header__menubtn {
      display: block;
      position: absolute;
      top: 22px;
      right: 20px;
      z-index: 2;
      text-align: center;
      cursor: pointer;
      display: inline-block;
      -webkit-transition: all .4s;
      -o-transition: all .4s;
      transition: all .4s; }
      .l-header__menubtn__line {
        position: relative;
        width: 20px;
        height: 16px; }
        .l-header__menubtn__line span {
          position: absolute;
          left: 0;
          width: 100%;
          height: 2px;
          background-color: #005491; }
        .l-header__menubtn__line-top {
          top: 0; }
        .l-header__menubtn__line-middle {
          top: 50%;
          margin-top: -1px; }
        .l-header__menubtn__line-bottom {
          bottom: 0; }
    .l-header .l-nav {
      display: none;
      overflow-y: auto;
      position: fixed;
      top: 60px;
      left: 0;
      width: 100%;
      height: 100%;
      background: #005491;
      z-index: 1; }
      .l-header .l-nav__container {
        padding-bottom: 160px; }
      .l-header .l-nav__global {
        width: 100%;
        margin-top: 0;
        padding-top: 105px;
        font-size: 14px;
        font-size: 1.4rem; }
        .l-header .l-nav__global-item {
          width: 100%;
          margin-right: 0;
          border-bottom: 1px solid #085C9B; }
          .l-header .l-nav__global-item:first-child {
            display: block;
            border-top: 1px solid #085C9B; }
          .l-header .l-nav__global-item:last-child {
            border-bottom: none; }
          .l-header .l-nav__global-item a {
            color: #fff;
            padding: 12px 18px;
            font-weight: normal;
            position: relative; }
            .l-header .l-nav__global-item a img {
              position: absolute;
              top: 50%;
              -webkit-transform: translateY(-50%);
              -ms-transform: translateY(-50%);
              transform: translateY(-50%);
              right: 21px;
              display: inline-block;
              width: auto;
              height: 8px; }
          .l-header .l-nav__global-item:after {
            display: none; }
          .l-header .l-nav__global-item.is-current:after, .l-header .l-nav__global-item.is-hovered:after, .l-header .l-nav__global-item:hover:after {
            display: none; }
        .l-header .l-nav__global__sub {
          position: relative;
          top: auto;
          background: #074E82;
          padding: 11px 0;
          margin: 0; }
          .l-header .l-nav__global__sub__title {
            display: none; }
          .l-header .l-nav__global__sub__list {
            -ms-filter: "alpha(opacity=100)";
            opacity: 1;
            display: block;
            float: none;
            width: 100%;
            padding: 10px 0; }
            .l-header .l-nav__global__sub__list-item {
              width: 100%; }
              .l-header .l-nav__global__sub__list-item:first-child {
                display: block; }
              .l-header .l-nav__global__sub__list-item a {
                padding: 10px 38px 9px;
                text-align: left;
                font-size: 12px;
                font-size: 1.2rem; }
                .l-header .l-nav__global__sub__list-item a:hover {
                  opacity: 1; }
      .l-header .l-nav__etc {
        font-size: 14px;
        font-size: 1.4rem;
        position: inherit;
        top: auto;
        right: auto; }
        .l-header .l-nav__etc-item a {
          text-align: center;
          padding: 15px; }
        .l-header .l-nav__etc-item.fontsize, .l-header .l-nav__etc-item.print {
          display: none; }
        .l-header .l-nav__etc-item.search {
          position: absolute;
          top: 40px;
          left: 0;
          min-width: inherit;
          width: 100%;
          border: none; }
          .l-header .l-nav__etc-item.search.click .search-box {
            padding: 0 10px 0 20px; }
            .l-header .l-nav__etc-item.search.click .search-box__text {
              overflow: hidden;
              display: block;
              width: auto;
              height: 39px;
              margin-left: 0; }
              .l-header .l-nav__etc-item.search.click .search-box__text input {
                width: 111%;
                -webkit-transition: .4s;
                -o-transition: .4s;
                transition: .4s;
                margin-right: 0; }
              .l-header .l-nav__etc-item.search.click .search-box__text:before {
                content: "";
                display: none; }
            .l-header .l-nav__etc-item.search.click .search-box__btn {
              position: relative;
              left: auto;
              float: right;
              width: 40px;
              background-position: 50% 50%;
              -webkit-transition: all 0s;
              -o-transition: all 0s;
              transition: all 0s;
              background-size: 20px auto; }
          .l-header .l-nav__etc-item.search .search-box {
            margin: 0 auto;
            text-align: center; }
            .l-header .l-nav__etc-item.search .search-box__text {
              display: inline-block; }
              .l-header .l-nav__etc-item.search .search-box__text input {
                display: inline-block;
                vertical-align: middle;
                right: auto;
                padding: 5px;
                width: 8em;
                height: 39px;
                font-size: 16px;
                font-size: 1.6rem;
                -moz-transform: scale(0.9);
                -o-transform: scale(0.9);
                -ms-transform: scale(0.9);
                -webkit-transform: scale(0.9);
                transform: scale(0.9);
                moz-transform-origin: 0% 50%;
                -o-transform-origin: 0% 50%;
                -ms-transform-origin: 0% 50%;
                -webkit-transform-origin: 0% 50%;
                transform-origin: 0% 50%;
                padding: 0; }
              .l-header .l-nav__etc-item.search .search-box__text:before {
                content: "";
                display: inline-block;
                vertical-align: middle;
                width: 16px;
                height: 39px;
                margin: 0 10px 0 15px;
                background: 50% 50% no-repeat #005491;
                background-image: url(../images/common/search.png);
                background-size: 100% auto; }
            .l-header .l-nav__etc-item.search .search-box:after {
              display: none; }
            .l-header .l-nav__etc-item.search .search-box__btn {
              width: 100%;
              right: auto;
              left: 0;
              background-image: none;
              background-color: rgba(255, 255, 255, 0);
              -webkit-transition: all 0s;
              -o-transition: all 0s;
              transition: all 0s; }
              .l-header .l-nav__etc-item.search .search-box__btn:hover {
                background-color: rgba(255, 255, 255, 0);
                -webkit-transition: all 0s;
                -o-transition: all 0s;
                transition: all 0s; }
        .l-header .l-nav__etc-item.contact {
          position: fixed;
          top: auto;
          bottom: 0;
          width: 100%;
          font-size: 14px;
          font-size: 1.4rem;
          z-index: 2; }
          .l-header .l-nav__etc-item.contact a {
            padding: 0; }
	.l-header .l-nav__etc-item.language {
          position: fixed;
          top: auto;
		border-left: none;
          width: 100%;
          font-size: 14px;
          font-size: 1.4rem;
          z-index: 2; }
	.l-header .l-nav__etc-item.language, .l-header .l-nav__etc-item.print {
          display: none; }

}

/* footer
------------------------------------------------*/
.l-footer {
  position: relative;
  z-index: 3;
  background-color: #FFF; }
  .l-footer .pagetop {
    position: fixed;
    bottom: 24px;
    right: 24px;
    margin: 0;
    width: 41px;
    height: 41px;
    z-index: 2; }
    .l-footer .pagetop a {
      display: block; }
      .l-footer .pagetop a img {
        width: 100%;
        height: auto;
        -webkit-transition: .4s;
        -o-transition: .4s;
        transition: .4s; }
      .l-footer .pagetop a:hover {
        background: url(../images/common/pagetop_on.png) no-repeat;
        background-size: cover;
        -ms-filter: "alpha(opacity=100)";
        opacity: 1; }
        .l-footer .pagetop a:hover img {
          -ms-filter: "alpha(opacity=0)";
          opacity: 0; }
  .l-footer__top {
    padding: 65px 0 35px; }
    .l-footer__top .c-layout-contents:after {
      content: "";
      display: block;
      clear: both; }
    .l-footer__top__list {
      float: left;
      width: 18.51852%;
      margin-right: 1.85185%; }
      .l-footer__top__list-item {
        margin-bottom: 30px; }
        .l-footer__top__list-item > a {
          display: block;
          color: #005491;
          font-size: 12px;
          font-size: 1.2rem;
          font-weight: bold;
          margin-bottom: 10px; }
        .l-footer__top__list-item a:hover {
          color: #7FA9C8; }
          html.touchDevice .l-footer__top__list-item a:hover {
            color: #005491; }
      .l-footer__top__list__sub-item {
        margin-bottom: 8px; }
        .l-footer__top__list__sub-item:first-child {
          display: none; }
        .l-footer__top__list__sub-item a {
          display: block;
          color: #005491;
          font-size: 11.5px;
          font-size: 1.15rem;
          font-weight: normal; }
    .l-footer__top__logo {
      float: right; }
      .l-footer__top__logo img {
        width: 110px;
        height: auto;
        margin: 5px 0 12px; }
  .l-footer__bottom {
    background: #005491;
    padding: 31px 0;
    color: #fff; }
    .l-footer__bottom:after {
      content: "";
      display: block;
      clear: both; }
    .l-footer__bottom__list {
      float: left; }
      .l-footer__bottom__list:after {
        content: "";
        display: block;
        clear: both; }
      .l-footer__bottom__list-item {
        margin-right: 19px;
        float: left; }
        .l-footer__bottom__list-item:last-child {
          margin-right: 0; }
        .l-footer__bottom__list-item a {
          color: #fff;
          font-size: 10px;
          font-size: 1rem; }
          .l-footer__bottom__list-item a:hover {
            opacity: 0.7; }
    .l-footer__bottom__copyright {
      float: right;
      text-align: right;
      font-size: 10.7px;
      font-size: 1.07rem; }

@media screen and (max-width: 999px) {
  .l-footer__top__list {
    width: 20%;
    margin-right: 5%; }
  .l-footer__top__logo {
    display: none; }
  .l-footer__bottom {
    padding-right: 40px; }
    .l-footer__bottom__list {
      width: 50%; }
    .l-footer__bottom__copyright {
      width: 50%; } }

@media screen and (max-width: 599px) {
  .l-footer .pagetop {
    bottom: 10px;
    right: 10px; }
  .l-footer__top {
    padding: 6px 0; }
    .l-footer__top .c-layout-contents:after {
      content: "";
      display: block;
      width: 100%;
      height: 1px;
      background: #fff;
      position: absolute;
      top: 6px;
      left: 0; }
    .l-footer__top__list {
      float: none;
      width: auto;
      margin-right: 0; }
      .l-footer__top__list-item {
        margin-bottom: 0;
        border-top: 1px solid #DCE5EB; }
        .l-footer__top__list-item > a {
          display: block;
          padding: 12px 0;
          margin-bottom: 0;
          position: relative; }
        .l-footer__top__list-item.child > a {
          background-image: url(../images/common/footer_open.png);
          background-repeat: no-repeat;
          background-position: 98% 50%;
          background-size: 10px auto; }
        .l-footer__top__list-item.child .open {
          background-image: url(../images/common/footer_close.png); }
      .l-footer__top__list__sub {
        display: none;
        padding: 0 0 5px; }
        .l-footer__top__list__sub-item:first-child {
          display: block; }
        .l-footer__top__list__sub-item a {
          padding: 0 15px 3px; }
    .l-footer__top__logo {
      display: none; }
  .l-footer__bottom {
    padding: 25px 0 15px; }
    .l-footer__bottom__list {
      float: none;
      width: auto;
      margin-bottom: 20px; }
      .l-footer__bottom__list-item {
        margin-right: 0;
        margin-bottom: 7px;
        float: none; }
        .l-footer__bottom__list-item a {
          font-size: 11px;
          font-size: 1.1rem; }
    .l-footer__bottom__copyright {
      float: none;
      width: auto;
      text-align: left;
      font-size: 8px;
      font-size: 0.8rem; } }

/**************************************************************
object
**************************************************************/
/* component
多くのプロジェクトで横断的に再利用できるような、小さな単位のモジュールを定義
固有の幅や装飾的なスタイルは極力指定しない
------------------------------------------------*/
.c-layout-contents {
  width: 1080px;
  margin: 0 auto; }

@media only screen and (max-width: 1160px) {
  .c-layout-contents {
    width: auto;
    margin: 0 40px; } }

@media only screen and (max-width: 599px) {
  .c-layout-contents {
    width: auto;
    margin: 0 20px; } }

/* bg
------------------------------------------------*/
body#service .c-main-container__bgimg,
body#future .c-main-container__bgimg,
body#company .c-main-container__bgimg,
body#ir .c-main-container__bgimg,
body#news .c-main-container__bgimg,
body#recruit .c-main-container__bgimg {
  background-position: center 115px; }
  body#service .c-main-container__bgimg:after,
  body#future .c-main-container__bgimg:after,
  body#company .c-main-container__bgimg:after,
  body#ir .c-main-container__bgimg:after,
  body#news .c-main-container__bgimg:after,
  body#recruit .c-main-container__bgimg:after {
    content: "";
    display: block;
    width: 2000px;
    height: 100%;
    background: url(../images/contents/contents_top_mask_bg_pc.png) no-repeat;
    position: absolute;
    top: 115px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%); }

#service .c-main-container__bgimg {
  background: url(../images/contents/service/service_bg.jpg) no-repeat; }

#future .c-main-container__bgimg {
  background: url(../images/contents/future/future_bg.jpg) no-repeat; }

#company .c-main-container__bgimg {
  background: url(../images/contents/company/company_bg.jpg) no-repeat; }

#ir .c-main-container__bgimg {
  background: url(../images/contents/ir/ir_bg.jpg) no-repeat; }

#news .c-main-container__bgimg {
  background: url(../images/contents/news/news_bg.jpg) no-repeat; }

#recruit .c-main-container__bgimg {
  background: url(../images/contents/recruit/recruit_bg.jpg) no-repeat; }

@media only screen and (max-width: 999px) {
  body#service .c-main-container__bgimg,
  body#future .c-main-container__bgimg,
  body#company .c-main-container__bgimg,
  body#ir .c-main-container__bgimg,
  body#news .c-main-container__bgimg,
  body#recruit .c-main-container__bgimg {
    overflow: hidden;
    background-position: center 60px; }
    body#service .c-main-container__bgimg:after,
    body#future .c-main-container__bgimg:after,
    body#company .c-main-container__bgimg:after,
    body#ir .c-main-container__bgimg:after,
    body#news .c-main-container__bgimg:after,
    body#recruit .c-main-container__bgimg:after {
      top: 60px; } }

@media only screen and (max-width: 599px) {
  body#service .c-main-container__bgimg:after,
  body#future .c-main-container__bgimg:after,
  body#company .c-main-container__bgimg:after,
  body#ir .c-main-container__bgimg:after,
  body#news .c-main-container__bgimg:after,
  body#recruit .c-main-container__bgimg:after {
    background: url(../images/contents/contents_top_mask_bg_sp.png) no-repeat;
    width: 1000px;
    background-size: 1000px auto; }
  #service .c-main-container__bgimg {
    background: url(../images/contents/service/service_bg_sp.jpg) no-repeat; }
  #future .c-main-container__bgimg {
    background: url(../images/contents/future/future_bg_sp.jpg) no-repeat; }
  #company .c-main-container__bgimg {
    background: url(../images/contents/company/company_bg_sp.jpg) no-repeat; }
  #ir .c-main-container__bgimg {
    background: url(../images/contents/ir/ir_bg_sp.jpg) no-repeat; }
  #news .c-main-container__bgimg {
    background: url(../images/contents/news/news_bg_sp.jpg) no-repeat; }
  #recruit .c-main-container__bgimg {
    background: url(../images/contents/recruit/recruit_bg_sp.jpg) no-repeat; } }

/* conteiner
------------------------------------------------*/
.c-main-container {
  position: relative;
  padding-top: 115px;
  background-color: #EEF2F5; }
  .c-main-container__bgimg {
    background: url(../images/contents/contents_base_bg.png) no-repeat top center #EEF2F5; }
  .c-main-container__inner {
    position: relative;
    z-index: 1;
    max-width: 1080px;
    width: auto;
    margin: 0 auto;
    padding: 0 40px 80px; }
  .c-main-container__box {
    padding-bottom: 50px;
    background-color: #FFF;
    -webkit-box-shadow: 0px 0px 2px 1px rgba(0, 53, 84, 0.1);
    box-shadow: 0px 0px 2px 1px rgba(0, 53, 84, 0.1);
    -webkit-box-sizing: border-box;
    box-sizing: border-box; }

@media only screen and (max-width: 999px) {
  .c-main-container {
    padding-top: 60px; }
    .c-main-container__inner {
      padding: 0 5px 80px; } }

@media only screen and (max-width: 599px) {
  .c-main-container__bgimg {
    background-image: none; }
  .c-main-container__inner {
    padding: 5px 5px 40px; }
  .c-main-container__box {
    padding-bottom: 15px; } }

.c-sub-container {
  position: relative;
  background-color: #FFF; }
  .c-sub-container__mail {
    border-top: 1px solid #DCE5EB; }
  .c-sub-container__blue {
    background-color: #005491; }
  .c-sub-container__inner {
    max-width: 1080px;
    padding: 64px 40px;
    margin: 0 auto; }
  .c-sub-container__movie__flame {
    border: 1px solid #DCE5EB;
    margin: 50px auto;
    padding: 10px; }
  .c-sub-container__title {
    margin-bottom: 26px;
    font-size: 20px;
    font-size: 2rem;
    text-align: center; }
    .c-sub-container__title__white {
      color: #FFF; }
  .c-sub-container__lead {
    text-align: center; }

@media only screen and (max-width: 599px) {
  .c-sub-container__inner {
    padding: 34px 20px 40px; }
  .c-sub-container__banner__inner {
    padding: 20px; }
  .c-sub-container__title {
    margin-bottom: 26px;
    font-size: 16px;
    font-size: 1.6rem; }
  .c-sub-container__banner__image img {
    width: 100%;
    height: auto; }
  .c-sub-container__lead {
    padding: 0 20px; } }

/* section section-column
------------------------------------------------*/
.c-section {
  padding: 0 50px;
  margin-top: 80px; }
  .c-section:first-child {
    padding-top: 80px;
    margin-top: 0; }
  .c-section__line {
    padding-bottom: 80px;
    border-bottom: 1px solid #DCE5EB; }
    .c-section__line:last-child {
      border-bottom: none;
      padding-bottom: 0; }
  .c-section__inner {
    max-width: 760px;
    margin: 38px auto 0; }
  .c-section__title {
    position: relative;
    border-top: 1px solid #DCE5EB;
    padding-top: 34px;
    margin-bottom: 30px;
    font-size: 20px;
    font-size: 2rem;
    font-weight: bold;
    line-height: 1.6; }
    .c-section__title:before {
      content: "";
      position: absolute;
      top: -3px;
      left: 0;
      height: 5px;
      width: 100px;
      background-color: #005491; }
  .c-section__headline {
    position: relative;
    font-size: 24px;
    font-size: 2.4rem;
    font-weight: bold;
    padding-bottom: 34px;
    margin-bottom: 70px;
    text-align: center; }
    .c-section__headline:after {
      content: "";
      position: absolute;
      bottom: 0;
      left: 50%;
      -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
      transform: translateX(-50%);
      width: 40px;
      height: 5px;
      background-color: #005491; }
    .c-section__headline__next-box {
      margin-bottom: 80px; }
  .c-section__text {
    margin: 30px 0 36px; }
    .c-section__text:last-child {
      margin-bottom: 0; }
  .c-section__image {
    margin: 45px 0 0;
    text-align: center; }
    .c-section__image img {
      max-width: 100%;
      height: auto; }
    .c-section__image__gray {
      padding: 50px;
      background-color: #F3F5F7; }
    .c-section__image__title {
      margin-bottom: 44px;
      font-weight: bold;
      text-align: left; }
  .c-section__movie {
    position: relative;
    margin: -30px 0; }
    .c-section__movie img {
      width: 100%;
      height: auto; }
  .c-section__lead {
    margin: 0 0 36px;
    text-align: center; }

.c-sub-section {
  margin-top: 30px; }
  .c-sub-section__title {
    position: relative;
    padding-left: 22px; }
    .c-sub-section__title:before {
      content: "";
      position: absolute;
      top: 4px;
      left: 0;
      bottom: 3px;
      width: 8px;
      background-color: #005491; }
  .c-sub-section__text {
    margin: 10px 0; }

.c-primary-section {
  margin-bottom: 80px; }
  .c-primary-section:last-child {
    margin-bottom: 0; }
  .c-primary-section__subhead {
    margin-bottom: 70px;
    font-size: 20px;
    font-size: 2rem;
    color: #005491;
    font-weight: bold;
    text-align: center; }
  .c-primary-section__summary {
    margin-bottom: 36px;
    padding: 0 80px; }

@media only screen and (max-width: 999px) {
  .c-section {
    padding: 0 30px; }
    .c-section__line {
      padding-bottom: 80px; }
    .c-section__image__gray {
      padding: 50px 30px; } }

@media only screen and (max-width: 599px) {
  .c-section {
    padding: 0 15px; }
    .c-section:first-child {
      padding-top: 40px; }
    .c-section__line {
      margin-top: 55px;
      padding-bottom: 55px; }
      .c-section__line__pcOnly {
        border-bottom: none; }
    .c-section__inner {
      width: auto; }
    .c-section__text-head {
      margin-bottom: -45px; }
    .c-section__image {
      margin: 20px 0 0; }
      .c-section__image__gray {
        padding: 15px; }
      .c-section__image__w100 {
        margin: 20px -15px 0; }
        .c-section__image__w100:last-child {
          margin-bottom: -15px; }
      .c-section__image__title {
        margin: 20px 0 35px; }
    .c-section__movie {
      margin: -40px 0; }
    .c-section__lead {
      text-align: left; }
    .c-section__title {
      font-size: 16px;
      font-size: 1.6rem; }
      .c-section__title:before {
        height: 4px; }
    .c-section__headline {
      font-size: 18px;
      font-size: 1.8rem;
      padding-bottom: 15px;
      margin-bottom: 55px; }
      .c-section__headline:after {
        height: 4px; }
      .c-section__headline__next-box {
        margin-bottom: 60px; }
  .c-primary-section {
    margin-bottom: 38px; }
    .c-primary-section__subhead {
      margin-bottom: 26px;
      font-size: 16px;
      font-size: 1.6rem; }
    .c-primary-section__summary {
      margin-bottom: 36px;
      padding: 0; } }

.c-col-contents {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: 0; }
  .c-col-contents__col2 {
    width: 47.44898%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin-top: 80px; }

@media only screen and (max-width: 599px) {
  .c-col-contents {
    display: block; }
    .c-col-contents__col2 {
      width: 100%;
      margin-top: 80px; } }

/* breadcrumbs
------------------------------------------------*/
.c-breadcrumbs {
  position: relative;
  z-index: 1;
  max-width: 1080px;
  width: auto;
  padding: 0 40px;
  margin: 0 auto; }
  .c-breadcrumbs__list {
    padding: 25px 0;
    font-size: 0; }
    .c-breadcrumbs__list li {
      position: relative;
      display: inline-block;
      padding-right: 23px;
      font-size: 11px;
      font-size: 1.1rem; }
      .c-breadcrumbs__list li:after {
        content: "";
        position: absolute;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        right: 10px;
        background: url(../images/common/arrow_right_black.png) no-repeat;
        width: 3px;
        height: 6px; }
      .c-breadcrumbs__list li:last-child:after {
        content: none; }

@media only screen and (max-width: 999px) {
  .c-breadcrumbs {
    padding: 0 20px; } }

@media only screen and (max-width: 599px) {
  .c-breadcrumbs {
    display: none; } }

/* headingtitle
------------------------------------------------*/
.c-heading {
  text-align: center; }
  .c-heading__inner {
    padding: 58px 0 125px; }
  .c-heading__title-en {
    margin-bottom: 15px;
    display: block; }
    .c-heading__title-en img {
      width: auto;
      height: 30px;
      -webkit-backface-visibility: hidden;
      backface-visibility: hidden; }
  .c-heading__title-ja {
    padding-bottom: 2px;
    font-weight: bold;
    border-bottom: 2px solid #333;
    letter-spacing: 0.2em; }

@media only screen and (max-width: 599px) {
  .c-heading__inner {
    padding: 45px 0 50px; }
  .c-heading__title-en {
    margin-bottom: 0;
    line-height: 0; }
    .c-heading__title-en img {
      height: 16px; }
  .c-heading__title-ja {
    font-size: 9px;
    font-size: 0.9rem; } }

/* pagetitle
------------------------------------------------*/
.c-pagetitle {
  padding: 100px 50px 2px;
  text-align: center; }
  .c-pagetitle span {
    display: block; }
  .c-pagetitle__title-en {
    margin-bottom: 50px;
    line-height: 0; }
    .c-pagetitle__title-en img {
      width: auto;
      height: 16px;
      -webkit-backface-visibility: hidden;
      backface-visibility: hidden; }
    .c-pagetitle__title-en-text {
      color: #005491;
      font-size: 20px;
      font-size: 2rem; }
  .c-pagetitle__title-ja {
    font-size: 34px;
    font-size: 3.4rem;
    letter-spacing: 0.2em; }
    .c-pagetitle__title-ja__only {
      padding: 10px 0 32px; }
    .c-pagetitle__title-ja-katakana {
      letter-spacing: 0.09em; }
    .c-pagetitle__title-ja-narrow {
      letter-spacing: 0.06em; }

@media only screen and (max-width: 599px) {
  .c-pagetitle {
    margin-bottom: -23px;
    padding: 65px 5px 0; }
    .c-pagetitle__title-en {
      margin-bottom: 26px; }
      .c-pagetitle__title-en img {
        height: 13px; }
      .c-pagetitle__title-en-text {
        margin-bottom: 31px;
        font-size: 17px;
        font-size: 1.7rem; }
    .c-pagetitle__title-ja {
      font-size: 23px;
      font-size: 2.3rem;
      line-height: 1.4; }
      .c-pagetitle__title-ja__only {
        padding: 7px 0 20px; }
      .c-pagetitle__title-ja-narrow {
        letter-spacing: 0.2em; } }

/* menutitle
------------------------------------------------*/
.c-menutitle {
  padding: 80px 0 84px;
  text-align: center; }
  .c-menutitle span {
    display: block; }

.c-menutitle__icon {
  margin-bottom: 20px; }
  .c-menutitle__icon img {
    width: 70px;
    height: auto; }

.c-menutitle__title-en {
  margin-bottom: 7px;
  line-height: 0; }
  .c-menutitle__title-en img {
    width: auto;
    height: 16px;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden; }

.c-menutitle__title-ja {
  color: #F2A600;
  font-size: 12px;
  font-size: 1.2rem;
  font-weight: bold;
  letter-spacing: 0.2em; }

@media only screen and (max-width: 599px) {
  .c-menutitle {
    padding: 40px 0 36px; }
  .c-menutitle__icon {
    margin-bottom: 15px; }
  .c-menutitle__title-en img {
    height: 13px; } }

/* button
------------------------------------------------*/
.c-section__button {
  text-align: center;
  margin-top: 40px; }
  .c-section__button__left {
    text-align: left; }
  .c-section__button__foot-mail {
    margin-top: 32px; }

.c-button {
  display: inline-block; }
  .c-button a {
    position: relative;
    display: block;
    padding: 16px 48px 15px 73px;
    color: #FFF;
    font-weight: bold;
    -webkit-transition: all .2s;
    -o-transition: all .2s;
    transition: all .2s; }
    .c-button a:before {
      content: "";
      position: absolute;
      top: 50%;
      left: 22px;
      background: url(../images/common/arrow_right_white.png);
      margin-top: -13px;
      width: 26px;
      height: 26px;
      background-size: 26px 26px;
      -webkit-transition: all .2s;
      -o-transition: all .2s;
      transition: all .2s; }
  .c-button__yellow a {
    border: 2px solid #FABF2E;
    background-color: #FABF2E; }
    .c-button__yellow a:hover {
      border: 2px solid #FDD033;
      background-color: #FDD033;
      opacity: 1; }
  .c-button__border a {
    border: 2px solid #FFF;
    -webkit-box-sizing: border-box;
    box-sizing: border-box; }
    .c-button__border a:hover {
      background-color: #FFF;
      opacity: 1;
      color: #005491; }
      .c-button__border a:hover:before {
        background: url(../images/common/arrow_right_blue.png);
        background-size: 26px 26px; }
  .c-button__mail a:before {
    content: none; }
  .c-button__mail a:hover:before {
    content: none; }
  .c-button__mail a:hover span:before {
    background: url(../images/common/icon_contact02_on.png);
    -webkit-transition: all .2s;
    -o-transition: all .2s;
    transition: all .2s; }
  .c-button__mail span {
    position: relative; }
    .c-button__mail span:before {
      content: "";
      position: absolute;
      top: 50%;
      left: -42px;
      width: 26px;
      height: 20px;
      background: url(../images/common/icon_contact02.png);
      background-size: 26px 20px !important;
      margin-top: -10px; }
  .c-button__large a {
    padding: 20px 78px 20px 118px;
    font-size: 18px;
    font-size: 1.8rem; }
    .c-button__large a:before {
      left: 75px; }
  .c-button__contact-box a {
    padding: 16px 20px 15px 63px; }
  .c-button__text-link {
    color: #005491; }
    .c-button__text-link__more {
      -webkit-transition: all .2s;
      -o-transition: all .2s;
      transition: all .2s;
      line-height: 1; }
      .c-button__text-link__more span {
        position: relative;
        display: inline-block;
        padding-right: 18px;
        cursor: pointer; }
        .c-button__text-link__more span:after {
          content: "";
          position: absolute;
          top: 50%;
          right: 0;
          margin-top: -4px;
          background: url(../images/contents/arrow_bottom_blue.png);
          width: 9px;
          height: 7px;
          background-size: 9px 7px !important;
          -webkit-transition: all .2s;
          -o-transition: all .2s;
          transition: all .2s; }
      .c-button__text-link__more:hover {
        color: #7FA9C8; }
        .c-button__text-link__more:hover span:after {
          background: url(../images/contents/arrow_bottom_lightblue.png); }
        html.touchDevice .c-button__text-link__more:hover {
          color: #005491; }
          html.touchDevice .c-button__text-link__more:hover span:after {
            background: url(../images/contents/arrow_bottom_blue.png); }
      .c-button__text-link__more.is-active span {
        padding-right: 12px; }
        .c-button__text-link__more.is-active span:after {
          width: 10px;
          height: 10px;
          background: url(../images/contents/icon_close.png);
          margin-top: -5px;
          background-size: 10px 10px !important; }
      .c-button__text-link__more.is-active:hover span:after {
        background: url(../images/contents/icon_close_on.png); }
      html.touchDevice .c-button__text-link__more.is-active:hover span:after {
        background: url(../images/contents/icon_close.png); }

@media only screen and (max-width: 599px) {
  .c-section__button__left {
    text-align: center; }
  .c-section__button__foot-mail {
    margin-top: -10px; }
  .c-button {
    display: block; }
    .c-button a {
      padding: 11px 0; }
      .c-button a:before {
        left: 18px;
        margin-top: -9px;
        width: 19px;
        height: 19px;
        background-size: 19px 19px; }
    .c-button__border a:hover:before {
      background-size: 19px 19px; }
    .c-button__large a {
      padding: 15px 30px 15px 70px;
      font-size: 14px;
      font-size: 1.4rem; }
    .c-button__contact-box {
      width: auto; }
      .c-button__contact-box a {
        padding: 11px 0 11px 20px; }
        .c-button__contact-box a:before {
          left: 11px; }
    .c-button__text-link__more:hover {
      color: #005491; }
      .c-button__text-link__more:hover span:after {
        background: url(../images/contents/arrow_bottom_blue.png);
        background-size: 9px 7px; }
    .c-button__text-link__more.is-active:hover span:after {
      background: url(../images/contents/icon_close.png); } }

/* IE9.10.11対応 */
@media screen and (min-width: 0\0) {
  .c-button a {
    padding: 17px 48px 14px 73px; }
  .c-button__large a {
    padding: 21px 78px 19px 118px; }
  .c-button__contact-box a {
    padding: 17px 20px 14px 63px; } }

@media screen and (max-width: 599px) and (min-width: 0\0) {
  .c-button a {
    padding: 12px 0 10px; }
  .c-button__large a {
    padding: 16px 30px 14px 70px; }
  .c-button__contact-box a {
    padding: 12px 0 10px 20px; } }

/* tag
------------------------------------------------*/
.c-tag {
  font-size: 12px;
  font-size: 1.2rem;
  text-align: center; }
  .c-tag span {
    display: block;
    padding: 4px 0;
    border: 1px solid #D3D3D3; }

.c-tag__ir {
  width: 70px; }

.c-tag__news {
  width: 137px; }

@media only screen and (max-width: 599px) {
  .c-tag {
    font-size: 10px;
    font-size: 1rem; }
    .c-tag span {
      padding: 0; }
  .c-tag__ir {
    width: 55px; }
  .c-tag__news {
    width: 109px; } }

/* list
------------------------------------------------*/
.c-date-list {
  border-bottom: 1px solid #DCE5EB; }
  .c-date-list__summary {
    display: table;
    width: 100%;
    border-top: 1px solid #DCE5EB;
    padding: 18px 0; }
  .c-date-list__col {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    border-bottom: none; }
  .c-date-list__col2 {
    width: 47.44898%; }
    .c-date-list__col2:last-child, .c-date-list__col2:nth-last-child(2) {
      border-bottom: 1px solid #DCE5EB; }
  .c-date-list__title, .c-date-list__date, .c-date-list__tag, .c-date-list__text {
    display: table-cell;
    vertical-align: text-top; }
  .c-date-list__date {
    width: 17.3%;
    font-size: 11px;
    font-size: 1.1rem;
    font-style: italic; }
  .c-date-list__title {
    width: 30%;
    vertical-align: top; }
  .c-date-list__tag {
    padding-right: 60px;
    -webkit-transition: all .2s;
    -o-transition: all .2s;
    transition: all .2s; }
    .c-date-list__tag span {
      -webkit-transition: all .2s;
      -o-transition: all .2s;
      transition: all .2s; }
  .c-date-list__list__summary {
    margin-bottom: 3px; }
    .c-date-list__list__summary:last-child {
      margin-bottom: 0; }
  .c-date-list__nest {
    position: relative;
    border-bottom: 1px solid #DCE5EB;
    padding-bottom: 18px;
    margin-bottom: 18px; }
    .c-date-list__nest:last-child {
      border-bottom: none;
      padding-bottom: 0;
      margin-bottom: 0; }
    .c-date-list__nest__table {
      display: table;
      width: 100%; }
    .c-date-list__nest__title, .c-date-list__nest__text {
      display: table-cell;
      vertical-align: top; }
    .c-date-list__nest__title {
      width: 96px; }
    .c-date-list__nest__map {
      margin-top: 20px; }
    .c-date-list__nest__powerplant {
      display: table;
      margin-top: 36px; }
      .c-date-list__nest__powerplant__image, .c-date-list__nest__powerplant__text {
        vertical-align: top;
        display: table-cell; }
      .c-date-list__nest__powerplant__image {
        padding-right: 25px; }
        .c-date-list__nest__powerplant__image img {
          width: 250px;
          height: auto; }
      .c-date-list__nest__powerplant__list {
        margin-top: 30px; }
    .c-date-list__nest__authentication {
      display: -webkit-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-flex: wrap;
      -webkit-flex: wrap;
      -ms-flex: wrap;
      flex: wrap;
      -webkit-box-align: end;
      -webkit-align-items: flex-end;
      -ms-flex-align: end;
      align-items: flex-end;
      margin-top: 18px; }
      .c-date-list__nest__authentication__image {
        margin-right: 34px; }
  .c-date-list__acc__detail {
    display: none; }

a.c-date-list__summary {
  color: #333; }
  a.c-date-list__summary:hover {
    color: #005491;
    opacity: 1; }
    a.c-date-list__summary:hover .c-date-list__tag span {
      border: 1px solid #005491;
      background-color: #005491;
      color: #FFF; }
    a.c-date-list__summary:hover .c_text__pdf {
      color: #005491; }

@media only screen and (max-width: 599px) {
  .c-date-list__summary {
    display: block;
    border-top: 1px solid #DCE5EB;
    padding: 26px 0; }
  .c-date-list__col {
    display: block;
    border-bottom: 1px solid #DCE5EB; }
  .c-date-list__col2 {
    width: 100%; }
    .c-date-list__col2:last-child, .c-date-list__col2:nth-last-child(2) {
      border-bottom: none; }
  .c-date-list__title {
    display: block;
    width: auto;
    margin-bottom: 4px; }
  .c-date-list__text {
    display: block;
    margin-top: 4px; }
  .c-date-list__date, .c-date-list__tag {
    display: inline-block;
    vertical-align: middle; }
  .c-date-list__date {
    width: auto; }
  .c-date-list__tag {
    padding: 0 0 0 20px; }
  .c-date-list__list__summary {
    margin-bottom: 0; }
    .c-date-list__list__summary:last-child {
      margin-bottom: 0; }
  .c-date-list__list__note__summary {
    font-size: 11px;
    font-size: 1.1rem; }
  .c-date-list__nest {
    padding-bottom: 16px;
    margin-bottom: 16px; }
    .c-date-list__nest__title, .c-date-list__nest__text {
      display: block; }
    .c-date-list__nest__title {
      width: auto; }
    .c-date-list__nest__map {
      margin-top: 15px; }
      .c-date-list__nest__map iframe {
        height: 280px; }
    .c-date-list__nest__powerplant {
      display: block;
      margin-top: 20px; }
      .c-date-list__nest__powerplant__image, .c-date-list__nest__powerplant__text {
        display: block; }
      .c-date-list__nest__powerplant__image {
        padding-right: 0;
        margin: 0 0 16px 0; }
        .c-date-list__nest__powerplant__image img {
          width: 100%; }
      .c-date-list__nest__powerplant__list {
        margin-top: 10px; }
    .c-date-list__nest__authentication {
      margin-top: 18px;
      -webkit-box-align: start;
      -webkit-align-items: flex-start;
      -ms-flex-align: start;
      align-items: flex-start; }
      .c-date-list__nest__authentication__image {
        width: 32.14%;
        margin-right: 12px; }
        .c-date-list__nest__authentication__image img {
          width: 100%;
          height: auto; } }

/* table
------------------------------------------------*/
.c-table__title {
  margin-bottom: 16px; }

.c-table__base {
  width: 100%;
  margin: 20px 0 0; }
  .c-table__base th,
  .c-table__base td {
    border: 1px solid #DCE5EB;
    border-collapse: collapse;
    padding: 20px 24px; }
  .c-table__base thead th {
    background-color: #F3F5F7; }

.c-table__number, .c-table__number-title {
  text-align: right; }

.c-table__bg-gray {
  background-color: #F3F5F7; }

table.p-stock__situation__table th {
  width: 55.1%; }

table.p-stock__shareholder__table th:first-child {
  width: 46%; }

table.p-stock__business__table th:first-child {
  width: 16.8%; }

table.p-sitepolicy__table th:first-child,
table.p-finance__table th:first-child {
  width: 47%; }

table.p-finance__table {
  table-layout: fixed; }

table.p-governance__stakefolder__table {
  table-layout: fixed; }
  table.p-governance__stakefolder__table th:first-child {
    width: 30.3%; }

table.p-info__purpose {
  table-layout: fixed; }
  table.p-info__purpose td {
    vertical-align: top; }

table.p-info__shareduse {
  margin-bottom: 30px; }
  table.p-info__shareduse th {
    width: 16.8%; }
  table.p-info__shareduse th,
  table.p-info__shareduse td {
    vertical-align: top; }

@media only screen and (max-width: 599px) {
  .c-table__base {
    border-bottom: 1px solid #DCE5EB; }
    .c-table__base th,
    .c-table__base td {
      display: block;
      padding: 8px 12px;
      border-bottom: none; }
    .c-table__base th {
      background-color: #F3F5F7; }
    .c-table__base thead {
      display: none; }
  .c-table__number-title {
    text-align: left; }
  table.p-stock__situation__table th {
    width: auto; }
  table.p-stock__shareholder__table th:first-child,
  table.p-stock__business__table th:first-child,
  table.p-sitepolicy__table th:first-child,
  table.p-governance__stakefolder__table th:first-child,
  table.p-finance__table th:first-child,
  table.p-info__shareduse th:first-child {
    width: auto; }
  table.p-stock__shareholder__table td,
  table.p-stock__business__table td,
  table.p-sitepolicy__table td,
  table.p-governance__stakefolder__table td,
  table.p-finance__table td,
  table.p-info__shareduse td {
    width: auto; }
  table.p-info__purpose thead {
    display: table-header-group; }
  table.p-info__purpose th,
  table.p-info__purpose td {
    display: table-cell; } }

/* text,link
------------------------------------------------*/
.c-link__pdf,
.c-link__other {
  position: relative; }
  .c-link__pdf:after,
  .c-link__other:after {
    content: "";
    display: inline-block;
    margin-left: 10px;
    -webkit-transition: all .2s;
    -o-transition: all .2s;
    transition: all .2s; }

.c-link__pdf {
  font-style: normal; }
  .c-link__pdf:after {
    background: url(../images/contents/icon_pdf.png);
    width: 14px;
    height: 15px;
    background-size: 14px 15px; }

.c-link__dl {
  position: relative;
  font-style: normal; }
  .c-link__dl:before {
    content: "";
    display: inline-block;
    vertical-align: -8%;
    background: url(../images/contents/icon_dl.png);
    width: 17px;
    height: 16px;
    background-size: 17px 16px;
    margin-right: 15px;
    -webkit-transition: all .2s;
    -o-transition: all .2s;
    transition: all .2s; }
  .c-link__dl:hover:before {
    background: url(../images/contents/icon_dl_on.png);
    background-size: 17px 16px; }

.c-link__other:after {
  background: url(../images/contents/icon_otherlink.png);
  width: 10px;
  height: 8px;
  background-size: 10px 8px; }

.c-link__other:hover:after {
  background: url(../images/contents/icon_otherlink_on.png);
  background-size: 10px 8px; }

.c-link__black {
  color: #333; }

.c-text__right {
  text-align: right;
  margin: 10px 0 16px; }

.c-text__note {
  font-size: 12px;
  font-size: 1.2rem; }
  .c-text__note__col2 {
    margin-top: 8px;
    width: 47.44898%;
    float: right; }

.c-text__date {
  font-size: 11px;
  font-size: 1.1rem;
  font-style: italic; }
  .c-text__date__right {
    float: right;
    margin-top: -60px; }
    .c-text__date__right__top {
      margin-top: -38px; }

.c_text__pdf {
  padding-left: 14px;
  font-size: 9px;
  font-size: 0.9rem;
  color: #333; }

.c-date__title {
  margin-bottom: 10px; }

.c-icon__right {
  position: relative;
  float: right;
  margin-top: -65px; }

.c-icon__rss {
  margin-right: 3px; }
  .c-icon__rss img {
    width: 16px;
    height: auto; }

@media only screen and (max-width: 599px) {
  .c-text__date__right {
    margin-top: -50px; }
    .c-text__date__right__top {
      margin-top: -26px; }
      .c-text__date__right__top__pdf {
        float: none;
        margin: -22px 0 38px;
        text-align: right; }
  .c-text__note__col2 {
    margin-top: 8px;
    width: auto;
    float: none; }
  .c-text__dl {
    float: none;
    margin: 0 0 29px; }
  .c-date__title {
    margin-bottom: 5px; }
  .c-icon__right {
    margin-top: -58px; } }

/* ol,ul
------------------------------------------------*/
.c-list__disc__summary {
  position: relative;
  padding-left: 16px; }
  .c-list__disc__summary:before {
    content: "・";
    position: absolute;
    left: 0; }
  .c-list__disc__summary__link:before {
    color: #005491; }

.c-list__disc__indent {
  padding-left: 60px; }

.c-list__order {
  list-style-type: decimal;
  -webkit-padding-start: 20px; }
  .c-list__order__indent {
    padding-left: 60px; }
  .c-list__order__summary {
    margin-bottom: 22px; }
    .c-list__order__summary__text {
      margin: 8px 0; }
  .c-list__order__enclose__summary {
    position: relative;
    padding-left: 80px; }
    .c-list__order__enclose__summary:before {
      content: "";
      position: absolute;
      left: 0;
      width: 40px;
      height: 40px;
      background-size: 40px 40px !important; }
    .c-list__order__enclose__summary:nth-child(1):before {
      background: url(../images/contents/list_number01.png); }

@media only screen and (max-width: 599px) {
  .c-list__order__indent {
    padding-left: 40px; } }

/* grid list
------------------------------------------------*/
.c-grid-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 40px;
  border-top: 1px solid #DCE5EB;
  border-left: 1px solid #DCE5EB; }
  .c-grid-list__item {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 33px 37px 8px;
    border-bottom: 1px solid #DCE5EB;
    border-right: 1px solid #DCE5EB; }
  .c-grid-list__item__col2 {
    width: 50%; }
  .c-grid-list__item__col3 {
    width: 33.3%; }
  .c-grid-list__item__col4 {
    width: 25%; }
  .c-grid-list__title {
    font-weight: bold;
    margin-bottom: 26px; }
    .c-grid-list__title a {
      display: block;
      position: relative;
      padding-right: 30px; }
      .c-grid-list__title a:after {
        content: "";
        position: absolute;
        top: 0;
        right: 0;
        background: url(../images/common/arrow_right_blue.png);
        width: 26px;
        height: 26px;
        background-size: 26px 26px;
        -webkit-transition: all .2s;
        -o-transition: all .2s;
        transition: all .2s; }
      .c-grid-list__title a:hover:after {
        background: url(../images/common/arrow_right_lightblue.png);
        background-size: 26px 26px; }
  .c-grid-list__date {
    margin-bottom: 3px;
    font-style: italic; }
  .c-grid-list__text {
    margin-bottom: 26px;
    color: #333; }

@media only screen and (max-width: 599px) {
  .c-grid-list {
    display: block;
    margin-bottom: 15px; }
    .c-grid-list__item {
      width: auto;
      padding: 26px 28px 6px; }
    .c-grid-list__title {
      margin-bottom: 18px; }
      .c-grid-list__title a {
        padding-right: 25px; }
        .c-grid-list__title a:after {
          top: 2px;
          background: url(../images/common/arrow_right_blue.png);
          width: 19px;
          height: 19px;
          background-size: 19px 19px !important; }
    .c-grid-list__text {
      margin-bottom: 22px; } }

/* grid menu
------------------------------------------------*/
.c-grid-menu {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }
  .c-grid-menu__item {
    width: 25%;
    height: 240px;
    border-top: 1px solid #DCE5EB;
    border-right: 1px solid #DCE5EB;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: all .2s;
    -o-transition: all .2s;
    transition: all .2s; }
    .c-grid-menu__item:nth-child(4n) {
      border-right: none; }
    .c-grid-menu__item.is-current, .c-grid-menu__item:hover {
      background-color: #005491; }
      .c-grid-menu__item.is-current .c-grid-menu__title, .c-grid-menu__item:hover .c-grid-menu__title {
        color: #FFF; }
      .c-grid-menu__item.is-current .c-grid-menu__summary__pdf, .c-grid-menu__item:hover .c-grid-menu__summary__pdf {
        color: #FFF; }
    .c-grid-menu__item a {
      display: table;
      width: 100%;
      height: 100%; }
      .c-grid-menu__item a:hover {
        opacity: 1; }
    .c-grid-menu__item__none:hover {
      background-color: #FFF !important; }
  .c-grid-menu__inner {
    display: table-cell;
    text-align: center;
    vertical-align: middle;
    padding: 0 10px; }
  .c-grid-menu__title {
    position: relative;
    font-weight: bold;
    padding-top: 91px;
    line-height: 1.2;
    -webkit-transition: all .2s;
    -o-transition: all .2s;
    transition: all .2s; }
    .c-grid-menu__title:before {
      content: "";
      position: absolute;
      top: 0;
      left: 50%;
      -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
      transform: translateX(-50%);
      width: 70px;
      height: 70px;
      -webkit-transition: all .2s;
      -o-transition: all .2s;
      transition: all .2s; }
  .c-grid-menu__summary {
    margin-top: 14px; }
    .c-grid-menu__summary__pdf {
      color: #333;
      -webkit-transition: all .2s;
      -o-transition: all .2s;
      transition: all .2s; }

@media only screen and (max-width: 599px) {
  .c-grid-menu:after {
    content: none; }
  .c-grid-menu__item {
    width: 50%;
    height: 120px; }
    .c-grid-menu__item:nth-child(2n) {
      border-right: none; }
  .c-grid-menu__inner {
    vertical-align: top;
    padding-top: 25px; }
  .c-grid-menu__title {
    padding-top: 54px; }
    .c-grid-menu__title:before {
      width: 35px;
      height: 35px;
      background-size: 35px 35px !important; }
  .c-grid-menu__summary {
    margin-top: 3px; }
    .c-grid-menu__summary__pdf {
      font-size: 12px;
      font-size: 1.2rem; } }

/*ir*/
.c-grid-menu__title__news:before {
  background: url(../images/contents/ir/ir_list_icon01.png); }

.c-grid-menu__title__calendar:before {
  background: url(../images/contents/ir/ir_list_icon02.png); }

.c-grid-menu__title__library:before {
  background: url(../images/contents/ir/ir_list_icon03.png); }

.c-grid-menu__title__shareholder:before {
  background: url(../images/contents/ir/ir_list_icon04.png); }

.c-grid-menu__title__stock:before {
  background: url(../images/contents/ir/ir_list_icon05.png); }

.c-grid-menu__title__glossary:before {
  background: url(../images/contents/ir/ir_list_icon06.png); }

.c-grid-menu__title__sitemap:before {
  background: url(../images/contents/ir/ir_list_icon07.png); }

/*company*/
.c-grid-menu__title__vision:before {
  background: url(../images/contents/company/company_list_icon01.png); }

.c-grid-menu__title__message:before {
  background: url(../images/contents/company/company_list_icon02.png); }

.c-grid-menu__title__field:before {
  background: url(../images/contents/company/company_list_icon03.png); }

.c-grid-menu__title__profile:before {
  background: url(../images/contents/company/company_list_icon04.png); }

.c-grid-menu__title__officer:before {
  background: url(../images/contents/company/company_list_icon05.png); }

.c-grid-menu__title__history:before {
  background: url(../images/contents/company/company_list_icon06.png); }

.c-grid-menu__title__governance:before {
  background: url(../images/contents/company/company_list_icon07.png); }

.c-grid-menu__title__plan:before {
  background: url(../images/contents/company/company_list_icon08.png); }

.c-grid-menu__item.is-current,
.c-grid-menu__item a:hover {
  /*ir*/
  /*company*/ }
  .c-grid-menu__item.is-current .c-grid-menu__title__news:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__news:before {
    background: url(../images/contents/ir/ir_list_icon01_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__calendar:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__calendar:before {
    background: url(../images/contents/ir/ir_list_icon02_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__library:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__library:before {
    background: url(../images/contents/ir/ir_list_icon03_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__shareholder:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__shareholder:before {
    background: url(../images/contents/ir/ir_list_icon04_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__stock:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__stock:before {
    background: url(../images/contents/ir/ir_list_icon05_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__glossary:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__glossary:before {
    background: url(../images/contents/ir/ir_list_icon06_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__sitemap:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__sitemap:before {
    background: url(../images/contents/ir/ir_list_icon07_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__vision:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__vision:before {
    background: url(../images/contents/company/company_list_icon01_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__message:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__message:before {
    background: url(../images/contents/company/company_list_icon02_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__field:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__field:before {
    background: url(../images/contents/company/company_list_icon03_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__profile:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__profile:before {
    background: url(../images/contents/company/company_list_icon04_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__officer:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__officer:before {
    background: url(../images/contents/company/company_list_icon05_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__history:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__history:before {
    background: url(../images/contents/company/company_list_icon06_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__governance:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__governance:before {
    background: url(../images/contents/company/company_list_icon07_on.png); }
  .c-grid-menu__item.is-current .c-grid-menu__title__plan:before,
  .c-grid-menu__item a:hover .c-grid-menu__title__plan:before {
    background: url(../images/contents/company/company_list_icon08_on.png); }

@media only screen and (max-width: 599px) {
  .c-grid-menu__title__governance {
    padding-top: 45px; }
  .c-grid-menu__title__plan {
    padding-top: 43px; } }

/* section foot link
------------------------------------------------*/
.c-section-foot {
  margin-top: 80px;
  border-top: 1px solid #DCE5EB; }

.c-section-foot__inner {
  padding: 0 50px; }

.c-section-foot__title {
  padding: 70px 0;
  font-size: 20px;
  font-size: 2rem; }

.c-foot-link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  .c-foot-link__list {
    width: 47.45%; }
    .c-foot-link__list a {
      position: relative;
      display: block;
      border-bottom: 1px solid #DCE5EB;
      padding: 16px 0;
      font-weight: bold;
      -webkit-transition: all .2s;
      -o-transition: all .2s;
      transition: all .2s; }
      .c-foot-link__list a:hover {
        opacity: 1; }
    .c-foot-link__list:nth-child(1), .c-foot-link__list:nth-child(2) {
      border-top: 1px solid #DCE5EB; }
    .c-foot-link__list a:before,
    .c-foot-link__list.is-current a:before {
      content: "";
      position: absolute;
      left: 0;
      width: 0;
      top: 50%;
      height: 1px;
      background-color: #005491; }
    .c-foot-link__list a:before {
      -webkit-transition: all .2s;
      -o-transition: all .2s;
      transition: all .2s; }
    .c-foot-link__list a:hover,
    .c-foot-link__list.is-current a {
      padding-left: 60px; }
      .c-foot-link__list a:hover:before,
      .c-foot-link__list.is-current a:before {
        width: 40px; }

@media only screen and (max-width: 599px) {
  .c-section-foot {
    margin-top: 80px; }
  .c-section-foot__inner {
    padding: 0 15px; }
  .c-section-foot__title {
    padding: 36px 0;
    font-size: 15px;
    font-size: 1.5rem; }
  .c-foot-link {
    display: block;
    margin-bottom: -15px; }
    .c-foot-link__list {
      width: auto; }
      .c-foot-link__list a {
        border-top: 1px solid #DCE5EB;
        border-bottom: none;
        padding: 16px 0; }
      .c-foot-link__list:nth-child(1), .c-foot-link__list:nth-child(2) {
        border-top: none; }
      .c-foot-link__list a:hover,
      .c-foot-link__list.is-current a {
        padding-left: 40px; }
        .c-foot-link__list a:hover:before,
        .c-foot-link__list.is-current a:before {
          width: 20px; } }

/* box
------------------------------------------------*/
.c-lead-box {
  background: url(../images/contents/contents_lead_bg_pc.jpg) no-repeat;
  margin-top: 80px; }
  .c-lead-box:first-child {
    margin-top: 0; }
  .c-lead-box__inner {
    display: table;
    width: 100%;
    padding: 76px 80px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: #FFF; }
  .c-lead-box__subcopy {
    margin-bottom: 18px;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: bold;
    text-align: center; }
  .c-lead-box__maincopy {
    font-size: 34px;
    font-size: 3.4rem;
    font-style: italic;
    text-align: center; }
  .c-lead-box__lead {
    font-size: 20px;
    font-size: 2rem;
    font-weight: bold; }
  .c-lead-box__left, .c-lead-box__right {
    display: table-cell;
    width: 50%; }
  .c-lead-box__left {
    padding-right: 40px; }

@media only screen and (max-width: 599px) {
  .c-lead-box {
    background: url(../images/contents/contents_lead_bg_sp.jpg) no-repeat #0491C2;
    background-size: 100% auto;
    margin-top: 80px; }
    .c-lead-box__inner {
      padding: 30px; }
    .c-lead-box__subcopy {
      margin-bottom: 14px;
      text-align: left; }
    .c-lead-box__maincopy {
      font-size: 23px;
      font-size: 2.3rem;
      font-style: normal;
      text-align: left;
      line-height: 1.4; }
      .c-lead-box__maincopy br {
        display: none; }
    .c-lead-box__lead {
      margin-bottom: 20px;
      font-size: 16px;
      font-size: 1.6rem; }
    .c-lead-box__left, .c-lead-box__right {
      display: block;
      width: auto; }
    .c-lead-box__left {
      padding-right: 0; } }

/* pull down menu
------------------------------------------------*/
.c-sort-menu {
  position: relative;
  width: 260px;
  display: inline-block;
  float: right;
  margin-top: -84px; }
  .c-sort-menu:after {
    content: "";
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 26px;
    background: url(../images/contents/arrow_bottom_white.png) no-repeat;
    width: 9px;
    height: 8px;
    background-size: 9px 8px; }
  .c-sort-menu__select {
    float: none;
    height: auto;
    padding: 17px 45px 17px 22px;
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    border-radius: 0;
    background-color: #005491;
    border: none;
    color: #FFF;
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.8; }
    .c-sort-menu__select:after {
      content: none; }
    .c-sort-menu__select .list {
      width: 100%;
      margin-top: 0;
      border-radius: 0;
      -webkit-box-shadow: none;
      box-shadow: none;
      background-color: #005491;
      color: #FFF;
      -webkit-transform: none;
      -ms-transform: none;
      transform: none; }
      .c-sort-menu__select .list .option {
        min-height: 0;
        padding: 8px 45px 8px 22px;
        line-height: 1.8; }
        .c-sort-menu__select .list .option:hover, .c-sort-menu__select .list .option.focus {
          background-color: #0A5E9E; }
  .c-sort-menu__news {
    float: left;
    margin-top: -154px; }

@media only screen and (max-width: 599px) {
  .c-sort-menu {
    width: auto;
    display: block;
    float: none;
    margin: 0 0 20px 0; }
    .c-sort-menu:after {
      right: 20px; }
    .c-sort-menu__select {
      padding: 12px 35px 12px 20px; }
      .c-sort-menu__select .list .option {
        padding: 12px 35px 12px 20px; }
    .c-sort-menu__ir {
      margin: 90px 15px 0; }
    .c-sort-menu__news {
      width: calc(100% - 31px);
      float: left; } }

/* tab
------------------------------------------------*/
.c-tab-list__ir {
  padding: 80px 50px 0;
  font-size: 0; }
  .c-tab-list__ir__tab {
    display: inline-block;
    font-size: 14px;
    font-size: 1.4rem;
    margin-right: 20px;
    padding: 10px 17px;
    cursor: pointer; }
    .c-tab-list__ir__tab.is-active {
      background-color: #005491;
      color: #FFF; }
    .c-tab-list__ir__tab:hover {
      background-color: #F3F5F7;
      color: #333;
      -webkit-transition: all .2s;
      -o-transition: all .2s;
      transition: all .2s; }

.c-tab-list__news {
  margin-top: 54px;
  border-top: 1px solid #DCE5EB;
  font-size: 0; }
  .c-tab-list__news__tab {
    display: inline-block;
    padding: 22px 40px;
    font-size: 14px;
    font-size: 1.4rem;
    cursor: pointer; }
    .c-tab-list__news__tab.is-active {
      position: relative;
      color: #005491;
      font-weight: bold; }
      .c-tab-list__news__tab.is-active:before {
        content: "";
        position: absolute;
        top: -3px;
        left: 0;
        right: 0;
        height: 5px;
        background-color: #005491; }

.c-tab-inner > div:not(:first-child) {
  display: none; }

@media only screen and (max-width: 999px) {
  .c-tab-list__ir {
    padding: 80px 30px 0; } }

@media only screen and (max-width: 599px) {
  .c-tab-list__ir {
    padding: 55px 15px 0; }
  .c-tab-list__news {
    margin-top: 0;
    display: table;
    width: 100%; }
    .c-tab-list__news__tab {
      display: table-cell;
      padding: 20px 0;
      text-align: center;
      font-size: 12px;
      font-size: 1.2rem; }
      .c-tab-list__news__tab.is-active:before {
        content: "";
        position: absolute;
        top: -3px;
        left: 0;
        right: 0;
        height: 5px;
        background-color: #005491; } }

/* pagination
------------------------------------------------*/
.c-pagination {
  margin-top: 80px; }

.c-pagination__summary {
  text-align: center;
  font-size: 0; }

.c-pagination__list {
  display: inline-block;
  vertical-align: middle;
  margin: 0 12px; }
  .c-pagination__list a {
    display: block; }

.c-pagination__prev a,
.c-pagination__prev .is-current,
.c-pagination__number a,
.c-pagination__number .is-current,
.c-pagination__next a,
.c-pagination__next .is-current {
  position: relative;
  display: block;
  width: 37px;
  height: 37px;
  text-align: center;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }
  .c-pagination__prev a:before,
  .c-pagination__prev .is-current:before,
  .c-pagination__number a:before,
  .c-pagination__number .is-current:before,
  .c-pagination__next a:before,
  .c-pagination__next .is-current:before {
    content: "";
    display: inline-block;
    height: 110%;
    vertical-align: middle; }

.c-pagination__number {
  font-size: 14px;
  font-size: 1.4rem; }
  .c-pagination__number a {
    border: 1px solid #DCE5EB; }
  .c-pagination__number a:hover,
  .c-pagination__number .is-current {
    border: 1px solid #005491;
    background-color: #005491;
    color: #FFF;
    font-weight: bold;
    opacity: 1; }

.c-pagination__ellipsis {
  margin: 0 6px; }

.c-pagination__ellipsis__dot {
  position: relative; }
  .c-pagination__ellipsis__dot:before {
    content: "";
    display: inline-block;
    margin: 0 6px;
    background-color: #DDD;
    width: 8px;
    height: 8px;
    border-radius: 50px; }

.c-pagination__prev a,
.c-pagination__next a {
  border: 1px solid #FFF;
  background-size: 10px 15px !important; }

.c-pagination__prev {
  display: none; }
  .c-pagination__prev a {
    background: url(../images/contents/arrow_page_prev.png) no-repeat center center; }

.c-pagination__next a {
  background: url(../images/contents/arrow_page_next.png) no-repeat center center; }

@media only screen and (max-width: 599px) {
  .c-pagination {
    margin: 40px 0; }
  .c-pagination__summary {
    margin: 0 -6px; }
  .c-pagination__list {
    margin: 0 6px; }
    .c-pagination__list:nth-child(5) {
      display: none; }
  .c-pagination__ellipsis {
    margin: 0 4px; }
  .c-pagination__ellipsis__dot:before {
    margin: 0 3px;
    width: 4px;
    height: 4px; } }

/* accordion
------------------------------------------------*/
.c-acc-list {
  border: 1px solid #DCE5EB;
  border-bottom: none; }
  .c-acc-list__title {
    position: relative;
    border-bottom: 1px solid #DCE5EB;
    padding: 28px 100px 28px 47px;
    -webkit-transition: all .2s;
    -o-transition: all .2s;
	cursor: pointer;
    transition: all .2s; }
    .c-acc-list__title:before, .c-acc-list__title:after {
      content: "";
      position: absolute; }
    .c-acc-list__title:after {
      top: 50%;
      right: 38px;
      background: url(../images/contents/arrow_bottom_blue.png);
      width: 9px;
      height: 7px;
      margin-top: -4px;
      background-size: 9px 7px; }
    .c-acc-list__title:hover:after, .c-acc-list__title.is-active:after {
      background-image: url(../images/contents/arrow_above_blue.png); }
    .c-acc-list__title:before, .c-acc-list__title.is-active:before {
      left: 47px;
      width: 0;
      top: 50%;
      height: 1px;
      background-color: #005491;
      -webkit-transition: all .2s;
      -o-transition: all .2s;
      transition: all .2s; }
    .c-acc-list__title:hover, .c-acc-list__title.is-active {
      padding-left: 96px; }
      .c-acc-list__title:hover:before, .c-acc-list__title.is-active:before {
        width: 24px; }
  .c-acc-list__summary {
    display: none;
    border-bottom: 1px solid #DCE5EB;
    padding: 32px 80px;
    background-color: #F3F5F7; }
  .c-acc-list__history {
    width: 100%; }
    .c-acc-list__history th {
      font-size: 11px;
      font-size: 1.1rem;
      font-style: italic;
      width: 18.2%; }
    .c-acc-list__history th,
    .c-acc-list__history td {
      padding: 4px 0; }

@media only screen and (max-width: 599px) {
  .c-acc-list__title {
    padding: 13px 40px 13px 20px; }
    .c-acc-list__title:after {
      right: 20px; }
    .c-acc-list__title:before, .c-acc-list__title.is-active:before {
      left: 20px; }
    .c-acc-list__title:hover, .c-acc-list__title.is-active {
      padding-left: 62px; }
      .c-acc-list__title:hover:before, .c-acc-list__title.is-active:before {
        width: 20px; }
  .c-acc-list__summary {
    padding: 16px 20px 4px; }
  .c-acc-list__history {
    width: 100%; }
    .c-acc-list__history th,
    .c-acc-list__history td {
      display: block; }
    .c-acc-list__history th {
      width: auto;
      padding: 0; }
    .c-acc-list__history td {
      padding: 0 0 10px 0; } }

/* modal
------------------------------------------------*/
.c-modal-movie {
  width: 1080px;
  margin: 0;
  padding: 0;
  background: #fff;
  position: fixed;
  display: none;
  z-index: 1001; }
  .c-modal-movie-close {
    display: inline-block;
    background: url(../images/common/movie_close.png) no-repeat;
    background-size: cover;
    width: 57px;
    height: 57px;
    position: absolute;
    top: -28.5px;
    right: -28.5px;
    z-index: 1001;
    cursor: pointer; }
    .c-modal-movie-close:hover {
      -ms-filter: "alpha(opacity=70)";
      opacity: 0.7; }
  .c-modal-movie-overlay {
    z-index: 1000;
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 120%;
    background-color: rgba(0, 0, 0, 0.6); }
  .c-modal-movie-inner {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    overflow: hidden; }
  .c-modal-movie-player {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%; }

.c-modal-movie__link__img {
  display: block;
  position: relative; }
  .c-modal-movie__link__img:after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    background: url(../images/contents/icon_play.png);
    width: 74px;
    height: 74px;
    background-size: 74px 74px; }

@media only screen and (max-width: 1180px) {
  .c-modal-movie {
    width: 90%; } }

@media only screen and (max-width: 599px) {
  .c-modal-movie-close {
    width: 40px;
    height: 40px;
    top: -10px;
    right: -10px; } }

/* sitemap
------------------------------------------------*/
.c-sitemap {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: -40px; }
  .c-sitemap__col {
    width: 21.4%;
    margin: 0 4.8% 40px 0;
    border-top: 1px solid #DCE5EB;
    padding-top: 30px; }
    .c-sitemap__col:nth-child(4n) {
      margin-right: 0; }
  .c-sitemap__col__link > a {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: bold; }
  html.touchDevice .c-sitemap__col__link a:hover {
    color: #005491; }
  .c-sitemap__col__inner {
    margin-top: 30px; }
  .c-sitemap__subtitle {
    margin-bottom: 8px;
    font-size: 11px;
    font-size: 1.1rem; }
  .c-sitemap__summary__link {
    margin-bottom: 6px; }

@media only screen and (max-width: 599px) {
  .c-sitemap {
    display: block;
    margin-bottom: 0; }
    .c-sitemap__col {
      width: auto;
      margin: 0;
      padding-top: 0; }
    .c-sitemap__col__link > a {
      position: relative;
      display: block;
      padding: 10px 0;
      font-size: 14px;
      font-size: 1.4rem; }
    .c-sitemap__col__inner {
      display: none;
      margin-top: 0;
      padding: 20px 0 0;
      border-top: 1px solid #DCE5EB; }
    .c-sitemap__subtitle {
      margin-bottom: 8px;
      font-size: 11px;
      font-size: 1.1rem; }
    .c-sitemap__summary__link {
      margin-bottom: 15px; }
      .c-sitemap__summary__link a {
        font-size: 12px;
        font-size: 1.2rem; }
  .js-toggleAcc--spOnly:before, .js-toggleAcc--spOnly:after {
    content: "";
    position: absolute;
    top: 50%;
    background-color: #005491; }
  .js-toggleAcc--spOnly:before {
    right: 5px;
    width: 11px;
    height: 1px; }
  .js-toggleAcc--spOnly:after {
    right: 10px;
    width: 1px;
    height: 11px;
    margin-top: -5px; }
  .js-toggleAcc--spOnly.is-active:after {
    content: none; } }

/* footer-contact
------------------------------------------------*/
.footer-contact {
  position: relative;
  z-index: 3;
  background: #005491;
  padding: 61px 0 45px;
  border-top: 1px solid rgba(220, 229, 235, 0.2); }
  .footer-contact .c-layout-contents:after {
    content: "";
    display: block;
    clear: both; }
  .footer-contact__title {
    color: #fff;
    float: left;
    text-align: left;
    font-size: 20px;
    font-size: 2rem;
    line-height: 70px; }
  .footer-contact__list {
    float: right;
    text-align: center; }
    .footer-contact__list:after {
      content: "";
      display: block;
      clear: both; }
    .footer-contact__list-item {
      display: inline-block;
      margin: 0 15px 20px 0; }
      .footer-contact__list-item:last-child {
        margin-right: 0; }
      .footer-contact__list-item a {
        display: inline-block;
        text-align: center;
        border: 2px solid #fff;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        padding: 23px 22px;
        color: #fff;
        font-weight: bold; }
        .footer-contact__list-item a:before {
          content: "";
          background-image: url(../images/common/arrow_right_white.png);
          background-repeat: no-repeat;
          background-size: cover;
          width: 26px;
          height: 26px;
          display: inline-block;
          vertical-align: middle;
          margin-right: 20px;
          -webkit-transition: all .2s;
          -o-transition: all .2s;
          transition: all .2s; }
        .footer-contact__list-item a:hover {
          -ms-filter: "alpha(opacity=100)";
          opacity: 1;
          color: #005491;
          background: #fff; }
          .footer-contact__list-item a:hover:before {
            background-image: url(../images/common/arrow_right_blue.png); }

@media screen and (max-width: 1079px) {
  .footer-contact__title {
    float: none;
    text-align: center;
    line-height: 1;
    margin-bottom: 40px; }
  .footer-contact__list {
    float: none; }
    .footer-contact__list-item {
      margin-right: 2%; }
      .footer-contact__list-item:last-child {
        margin-right: 0; } }

@media screen and (max-width: 649px) {
  .footer-contact {
    padding: 40px 0; }
    .footer-contact__title {
      font-size: 18px;
      font-size: 1.8rem;
      margin-bottom: 18px; }
    .footer-contact__list {
      float: none; }
      .footer-contact__list-item {
        float: none;
        width: 100%;
        margin-right: 0;
        margin-bottom: 18px; }
        .footer-contact__list-item:last-child {
          margin-bottom: 0; }
        .footer-contact__list-item a {
          display: block;
          padding: 15px 15px 15px 40px;
          position: relative; }
          .footer-contact__list-item a:before {
            position: absolute;
            top: 50%;
            -webkit-transform: translateY(-50%);
            -ms-transform: translateY(-50%);
            transform: translateY(-50%);
            left: 20px;
            width: 20px;
            height: 20px; } }

/* project
プロジェクト固有のビジュアルパターン（いわゆるUI）を定義
使い回すスタイルのほとんどはこのレイヤーに追加
------------------------------------------------*/
/* future
------------------------------------------------*/
.p-future__image-set {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  .p-future__image-set__image, .p-future__image-set__detail {
    width: 47.44898%; }
  .p-future__image-set__title {
    margin-bottom: 22px;
    font-size: 20px;
    font-size: 2rem;
    color: #005491;
    font-weight: bold; }
  .p-future__image-set__image img {
    width: 100%;
    height: auto; }

.p-future__box {
  margin-top: 40px;
  padding: 36px 36px;
  background-color: #F5F6F7; }
  .p-future__box__col-contents {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 0 4px; }
    .p-future__box__col-contents__col2 {
      width: 47.22%; }
  .p-future__box__movie {
    display: table; }
    .p-future__box__movie__image {
      width: 165px;
      height: auto; }
      .p-future__box__movie__image img {
        width: 100%;
        height: auto; }
      .p-future__box__movie__image a:after {
        width: 50px;
        height: 50px;
        background: url(../images/contents/future/future_icon_play.png);
        background-size: 50px 50px; }
    .p-future__box__movie__text {
      padding-left: 24px; }
    .p-future__box__movie__image, .p-future__box__movie__text {
      display: table-cell;
      vertical-align: middle; }

.p-future__list__summary {
  margin-bottom: 4px; }
  .p-future__list__summary:last-child {
    margin-bottom: 0; }

@media only screen and (max-width: 599px) {
  .p-future__image-set {
    display: block; }
    .p-future__image-set__image, .p-future__image-set__detail {
      width: auto; }
    .p-future__image-set__title {
      margin: 33px 0 29px;
      font-size: 16px;
      font-size: 1.6rem;
      text-align: center; }
    .p-future__image-set__image {
      margin-bottom: 14px; }
  .p-future__box {
    margin-top: 33px;
    padding: 26px; }
    .p-future__box__col-contents {
      display: block;
      padding: 0; }
      .p-future__box__col-contents__col2 {
        width: auto; }
    .p-future__box__movie {
      display: block; }
      .p-future__box__movie__image {
        margin: 6px 6px 14px;
        width: auto; }
        .p-future__box__movie__image img {
          width: 100%;
          height: auto; }
        .p-future__box__movie__image a:after {
          width: 74px;
          height: 74px;
          background: url(../images/contents/icon_play.png);
          background-size: 74px 74px; }
      .p-future__box__movie__text {
        padding: 0 6px;
        margin-bottom: 19px; }
      .p-future__box__movie__image, .p-future__box__movie__text {
        display: block; }
  .p-future__list__summary {
    margin-bottom: 7px; } }

/* services
------------------------------------------------*/
.p-agent__nav {
  position: fixed;
  z-index: 2;
  bottom: 0;
  width: 100%;
  padding: 20px 0;
  background-color: rgba(0, 84, 145, 0.8);
  text-align: center; }
  .p-agent__nav__inner {
    font-size: 0; }
  .p-agent__nav__button {
    margin: 0 10px; }
    .p-agent__nav__button a {
      font-size: 14px;
      font-size: 1.4rem; }

@media only screen and (max-width: 599px) {
  .p-agent__nav {
    display: none; } }

.p-service__grid-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-bottom: 50px; }
  .p-service__grid-list:last-child {
    margin-bottom: 0; }
  .p-service__grid-list__item {
    padding: 38px 36px 34px;
    margin-right: 5.1%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border: 1px solid #DCE5EB; }
    .p-service__grid-list__item__col3 {
      width: 29.89%; }
      .p-service__grid-list__item__col3:nth-child(3n), .p-service__grid-list__item__col3:last-child {
        margin-right: 0; }
    .p-service__grid-list__item__col2 {
      width: 47.44898%;
      padding: 38px 38px 34px 39px; }
      .p-service__grid-list__item__col2:nth-child(2n) {
        margin-right: 0; }
    .p-service__grid-list__item__col1 {
      width: 47.44898%;
      margin: 0; }
    .p-service__grid-list__item__w100 {
      margin-right: 0;
      padding: 38px 39px 34px 39px; }
  .p-service__grid-list__image {
    position: relative;
    margin-bottom: 38px;
    text-align: center; }
    .p-service__grid-list__image__last {
      margin: 35px 0 0; }
    .p-service__grid-list__image img {
      width: 100%;
      height: auto;
      -webkit-backface-visibility: hidden;
      backface-visibility: hidden; }
    .p-service__grid-list__image__support img, .p-service__grid-list__image__reason img, .p-service__grid-list__image__approach img {
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%); }
    .p-service__grid-list__image__reason, .p-service__grid-list__image__support {
      padding-top: 60.55%; }
    .p-service__grid-list__image__approach {
      padding-top: 65.8%; }
      .p-service__grid-list__image__approach-battery {
        padding-top: 70%; }
        .p-service__grid-list__image__approach-battery img {
          width: auto;
          height: 100%; }
  .p-service__grid-list__headline {
    margin: -7px 0 40px;
    padding-bottom: 31px;
    border-bottom: 1px solid #DCE5EB;
    font-size: 20px;
    font-size: 2rem;
    color: #005491;
    font-weight: bold;
    text-align: center; }
  .p-service__grid-list__title {
    font-weight: bold;
    margin-bottom: 12px; }
  .p-service__grid-list__text__center {
    text-align: center; }

@media only screen and (max-width: 599px) {
  .p-service__grid-list {
    display: block;
    margin-bottom: 15px; }
    .p-service__grid-list__item {
      padding: 31px 29px 26px !important;
      margin: 0 0 15px 0; }
      .p-service__grid-list__item:last-child {
        margin-bottom: 0; }
    .p-service__grid-list__item__col3 {
      width: auto; }
    .p-service__grid-list__item__col2 {
      width: auto; }
    .p-service__grid-list__item__col1 {
      width: auto; }
    .p-service__grid-list__image {
      margin-bottom: 26px; }
      .p-service__grid-list__image__last {
        margin: 28px 0 0; }
      .p-service__grid-list__image__support img, .p-service__grid-list__image__reason img, .p-service__grid-list__image__approach img {
        position: static;
        top: 50%;
        left: 50%;
        -webkit-transform: inherit;
        -ms-transform: inherit;
        transform: inherit; }
      .p-service__grid-list__image__support, .p-service__grid-list__image__reason {
        padding-top: 0; }
      .p-service__grid-list__image__approach {
        padding-top: 0; }
        .p-service__grid-list__image__approach-battery {
          padding-top: 0; }
          .p-service__grid-list__image__approach-battery img {
            width: 100%;
            height: height; }
    .p-service__grid-list__headline {
      margin: -5px 0 31px;
      padding-bottom: 24px;
      border-bottom: 1px solid #DCE5EB;
      font-size: 16px;
      font-size: 1.6rem;
      color: #005491;
      font-weight: bold;
      text-align: center; }
    .p-service__grid-list__title {
      margin-bottom: 19px; } }

.p-service__box {
  padding: 70px 80px 80px;
  background-color: #F5F6F7; }
  .p-service__box__title {
    margin-bottom: 67px;
    font-size: 20px;
    font-size: 2rem;
    font-weight: bold;
    color: #005491; }
  .p-service__box__section {
    margin-bottom: 76px; }
    .p-service__box__section:last-child {
      margin-bottom: 0; }
    .p-service__box__section__row:after {
      content: "";
      display: block;
      clear: both; }
    .p-service__box__section__subtitle {
      margin-bottom: 26px;
      font-weight: bold; }
    .p-service__box__section__left {
      float: left; }
    .p-service__box__section__right {
      float: right; }
    .p-service__box__section__text-area {
      width: 45.1%; }
    .p-service__box__section__image-area {
      width: 46.95%; }
    .p-service__box__section__image img {
      width: 100%;
      height: auto;
      -webkit-backface-visibility: hidden;
      backface-visibility: hidden; }
    .p-service__box__section__image-list {
      display: -webkit-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      -webkit-box-pack: justify;
      -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
      justify-content: space-between;
      margin-top: 38px; }
      .p-service__box__section__image-list__item {
        width: 46.95%; }
        .p-service__box__section__image-list__item img {
          width: 100%;
          height: auto; }
    .p-service__box__section__list {
      margin: 40px 26px 0 -14px; }
      .p-service__box__section__list__summary {
        position: relative;
        padding-left: 64px;
        margin-bottom: 14px; }
        .p-service__box__section__list__summary:last-child {
          margin-bottom: 0; }
        .p-service__box__section__list__summary:before {
          content: "";
          position: absolute;
          top: 6px;
          left: 0;
          width: 40px;
          height: 40px;
          background-size: 40px 40px !important; }
        .p-service__box__section__list__summary:nth-child(1):before {
          background: url(../images/contents/service/service_list_number01.png); }
        .p-service__box__section__list__summary:nth-child(2):before {
          background: url(../images/contents/service/service_list_number02.png); }
        .p-service__box__section__list__summary:nth-child(3):before {
          background: url(../images/contents/service/service_list_number03.png); }
        .p-service__box__section__list__summary:nth-child(4):before {
          background: url(../images/contents/service/service_list_number04.png); }

@media only screen and (max-width: 999px) {
  .p-service__box {
    padding: 70px 40px 80px; } }

@media only screen and (max-width: 599px) {
  .p-service__box {
    padding: 55px 15px 15px;
    margin: 0 -15px; }
    .p-service__box__title {
      margin-bottom: 46px;
      font-size: 16px;
      font-size: 1.6rem; }
    .p-service__box__section {
      margin-bottom: 55px; }
      .p-service__box__section__left {
        float: none; }
      .p-service__box__section__right {
        float: none; }
      .p-service__box__section__text-area {
        width: auto; }
      .p-service__box__section__image-area {
        width: auto; }
      .p-service__box__section__text {
        margin-bottom: 32px; }
      .p-service__box__section__image-list {
        display: block;
        margin-top: 32px; }
        .p-service__box__section__image-list__item {
          width: auto;
          margin-bottom: 15px; }
          .p-service__box__section__image-list__item:last-child {
            margin-bottom: 0; }
      .p-service__box__section__list {
        margin: 35px 0 0; }
        .p-service__box__section__list__summary {
          padding-left: 42px; }
          .p-service__box__section__list__summary:before {
            width: 32px;
            height: 32px;
            background-size: 32px 32px !important; } }

.p-service__supplydemand {
  margin-bottom: -30px; }

.p-service__case {
  margin-bottom: -30px;
  padding: 70px 50px 50px; }
  .p-service__case__list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: -63px;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between; }
    .p-service__case__list__item {
      position: relative;
      width: 47.16%;
      margin-bottom: 63px;
      padding: 36px 40px 20px;
      border: 1px solid #DCE5EB;
      border-radius: 8px;
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      background-color: #FFF; }
    .p-service__case__list__title {
      font-size: 20px;
      font-size: 2rem;
      font-weight: bold;
      padding-bottom: 14px;
      margin-bottom: 17px;
      border-bottom: 1px solid #DCE5EB; }
    .p-service__case__list__rate {
      position: absolute;
      top: -40px;
      right: 24px;
      display: table;
      width: 100px;
      height: 100px;
      border-radius: 100px;
      background-color: #FABF2E;
      text-align: center; }
      .p-service__case__list__rate__title {
        font-size: 16px;
        font-size: 1.6rem; }
      .p-service__case__list__rate > span {
        display: table-cell;
        vertical-align: middle;
        font-weight: bold;
        color: #FFF;
        line-height: 1.5; }
        .p-service__case__list__rate > span strong {
          font-size: 24px;
          font-size: 2.4rem; }
  .p-service__case__list__detail__row {
    display: table;
    width: 100%;
    padding-bottom: 6px; }
  .p-service__case__list__detail__title, .p-service__case__list__detail__number {
    display: table-cell; }
  .p-service__case__list__detail__number {
    text-align: right; }
  .p-service__case__list__detail__total {
    margin-top: 10px;
    padding-top: 5px;
    border-top: 1px solid #FABF2E;
    color: #F2A600; }
    .p-service__case__list__detail__total__title, .p-service__case__list__detail__total__number {
      font-weight: bold; }
    .p-service__case__list__detail__total__number {
      font-size: 24px;
      font-size: 2.4rem; }
  .p-service__case__list__detail th,
  .p-service__case__list__detail td {
    padding-bottom: 6px; }
  .p-service__case__list__detail td {
    text-align: right; }
  .p-service__case__list__detail tfoot th,
  .p-service__case__list__detail tfoot td {
    font-weight: bold; }

@media only screen and (max-width: 999px) {
  .p-service__supplydemand {
    margin-bottom: -55px; }
  .p-service__case {
    padding: 70px 30px 50px; }
    .p-service__case__list__item {
      padding: 36px 30px 20px; }
    .p-service__case__list__title {
      font-size: 20px;
      font-size: 2rem; }
    .p-service__case__list__rate {
      right: 14px;
      width: 80px;
      height: 80px; }
      .p-service__case__list__rate__title {
        font-size: 14px;
        font-size: 1.4rem; }
      .p-service__case__list__rate > span strong {
        font-size: 20px;
        font-size: 2rem; } }

@media only screen and (max-width: 599px) {
  .p-service__case {
    margin-bottom: -55px;
    padding: 55px 15px 15px; }
    .p-service__case__list {
      display: block;
      margin-bottom: -51px; }
      .p-service__case__list__item {
        width: auto;
        margin-bottom: 51px;
        padding: 28px 30px 20px;
        border-radius: 0; }
      .p-service__case__list__title {
        font-size: 14px;
        font-size: 1.4rem;
        padding-bottom: 8px;
        margin-bottom: 12px; }
      .p-service__case__list__rate {
        top: -31px;
        right: 12px;
        width: 75px;
        height: 75px; }
        .p-service__case__list__rate__title {
          font-size: 12px;
          font-size: 1.2rem; }
        .p-service__case__list__rate > span {
          font-size: 10px;
          font-size: 1rem; }
          .p-service__case__list__rate > span strong {
            font-size: 18px;
            font-size: 1.8rem; }
    .p-service__case__list__detail__row {
      padding-bottom: 3px; }
    .p-service__case__list__detail__total__number {
      font-size: 16px;
      font-size: 1.6rem; } }

.p-service__faq {
  border-top: 1px solid #DCE5EB;
  padding-top: 36px; }
  .p-service__faq__detail {
    margin-bottom: 36px; }
    .p-service__faq__detail:last-child {
      margin-bottom: 0; }
    .p-service__faq__detail__question {
      position: relative;
      margin-bottom: 32px;
      padding-left: 44px;
      font-size: 20px;
      font-size: 2rem;
      font-weight: bold;
      color: #005491; }
      .p-service__faq__detail__question:before {
        content: "";
        position: absolute;
        top: 8px;
        left: 0;
        width: 22px;
        height: 23px;
        background: url(../images/contents/service/service_faq_icon.png);
        background-size: 22px 23px; }
    .p-service__faq__detail__answer {
      padding: 32px 40px 10px;
      border: 1px solid #DCE5EB;
      background-color: #F3F5F7; }
    .p-service__faq__detail__text {
      margin-bottom: 22px; }

/* IE9.10.11対応 */
@media screen and (min-width: 0\0) {
  .p-service__faq__detail__question:before {
    top: 5px !important; } }

@media screen and (max-width: 599px) and (min-width: 0\0) {
  .p-service__faq__detail__question:before {
    top: 2px !important; } }

@media only screen and (max-width: 599px) {
  .p-service__faq {
    padding-top: 34px; }
    .p-service__faq__detail {
      margin-bottom: 34px; }
      .p-service__faq__detail__question {
        padding-left: 40px;
        font-size: 14px;
        font-size: 1.4rem; }
        .p-service__faq__detail__question:before {
          top: 6px; }
      .p-service__faq__detail__answer {
        padding: 24px 30px 6px; }
      .p-service__faq__detail__text {
        margin-bottom: 24px; } }

.p-service__menu {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  border-top: 1px solid #DCE5EB; }
  .p-service__menu__item {
    width: 50%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 65px 100px; }
    .p-service__menu__item:first-child {
      border-right: 1px solid #DCE5EB; }
  .p-service__menu__image {
    margin-bottom: 24px;
    overflow: hidden; }
    .p-service__menu__image img {
      width: 100%;
      height: auto;
      -webkit-transition: all .8s;
      -o-transition: all .8s;
      transition: all .8s; }
    .p-service__menu__image__link:hover {
      opacity: 1; }
      .p-service__menu__image__link:hover img {
        -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
        transform: scale(1.1); }
  .p-service__menu__tag {
    display: inline-block;
    border-radius: 50px;
    margin-bottom: 17px;
    padding: 3px 13px 2px;
    background-color: #0499CC;
    color: #FFF;
    font-weight: bold; }
  .p-service__menu__title {
    margin-bottom: 10px;
    font-size: 20px;
    font-size: 2rem; }
  .p-service__menu__button {
    margin-top: 18px; }
  .p-service__menu__top {
    margin-top: 80px;
    border: 1px solid #DCE5EB; }
    .p-service__menu__top__item {
      padding: 40px; }

@media only screen and (max-width: 999px) {
  .p-service__menu__item {
    padding: 65px 30px; }
  .p-service__menu__top {
    margin-top: 40px; } }

@media only screen and (max-width: 599px) {
  .p-service__menu {
    display: block;
    border-top: none; }
    .p-service__menu__item {
      width: auto;
      padding: 0; }
      .p-service__menu__item:first-child {
        border-right: none; }
    .p-service__menu__detail {
      margin: 0 20px; }
    .p-service__menu__image {
      margin-bottom: 20px; }
    .p-service__menu__tag {
      margin-bottom: 14px;
      font-size: 12px;
      font-size: 1.2rem; }
    .p-service__menu__title {
      margin-bottom: 8px;
      font-size: 16px;
      font-size: 1.6rem; }
    .p-service__menu__button {
      margin-top: 0;
      padding: 15px 20px 40px; }
    .p-service__menu__top {
      border: 1px solid #DCE5EB; }
      .p-service__menu__top__item {
        padding: 20px; }
        .p-service__menu__top__item:first-child {
          border-bottom: 1px solid #DCE5EB; }
      .p-service__menu__top__detail {
        margin: 0; }
      .p-service__menu__top__button {
        margin: 15px 0 0;
        padding: 0; } }

/* IE9.10.11対応 */
@media screen and (min-width: 0\0) {
  .p-service__menu__tag {
    padding: 3px 13px 2px; } }

/* ir common
------------------------------------------------*/
.p-ir-cantact__title {
  padding: 58px 0 54px;
  font-size: 20px;
  font-size: 2rem;
  color: #FFF;
  text-align: center; }

.p-ir_register__button,
.p-ir_contact__button {
  margin-top: 34px; }

.p-ir-contact-list {
  display: table;
  width: 100%;
  border-top: 1px solid #3376A7;
  border-bottom: 1px solid #3376A7; }
  .p-ir-contact-list__item {
    width: 50%;
    display: table-cell;
    vertical-align: top;
    padding: 70px 40px 52px;
    text-align: center; }
    .p-ir-contact-list__item:first-child {
      border-right: 1px solid rgba(255, 255, 255, 0.2); }
  .p-ir-contact-list__icon {
    line-height: 0; }
    .p-ir-contact-list__icon img {
      -webkit-backface-visibility: hidden;
      backface-visibility: hidden; }
    .p-ir-contact-list__icon__mail {
      margin-bottom: 18px; }
      .p-ir-contact-list__icon__mail img {
        width: 26px;
        height: 20px; }
    .p-ir-contact-list__icon__phone {
      margin-bottom: 12px; }
      .p-ir-contact-list__icon__phone img {
        width: 18px;
        height: 36px; }
  .p-ir-contact-list__title, .p-ir-contact-list__number, .p-ir-contact-list__note {
    color: #FFF; }
  .p-ir-contact-list__title {
    font-weight: bold; }
  .p-ir-contact-list__number {
    margin: 13px 0 14px;
    font-size: 24px;
    font-size: 2.4rem;
    line-height: 1.4;
    pointer-events: none; }
  .p-ir-contact-list__time {
    font-size: 14px;
    font-size: 1.4rem; }

@media only screen and (max-width: 599px) {
  .p-ir-cantact__title {
    padding: 36px 0 34px;
    font-size: 16px;
    font-size: 1.6rem; }
  .p-ir_register__button {
    margin-top: 28px; }
  .p-ir_contact__button {
    margin-top: 15px; }
  .p-ir-contact-list {
    display: block;
    border: none; }
    .p-ir-contact-list__item {
      width: auto;
      display: block;
      padding: 41px 20px;
      border-top: 1px solid #3376A7; }
      .p-ir-contact-list__item:first-child {
        border-right: none; }
    .p-ir-contact-list__icon__mail {
      margin-bottom: 16px; }
    .p-ir-contact-list__icon__phone {
      margin-bottom: 10px; }
    .p-ir-contact-list__note {
      text-align: left; }
    .p-ir-contact-list__title {
      font-weight: normal; }
    .p-ir-contact-list__number {
      margin: 11px 0 14px;
      font-size: 20px;
      font-size: 2rem;
      pointer-events: auto; }
      .p-ir-contact-list__number a {
        color: #FFF; }
    .p-ir-contact-list__time {
      display: block;
      margin-top: 5px; } }

.p-ir__nav-list__item {
  min-height: 194px; }

@media only screen and (max-width: 599px) {
  .p-ir__nav-list__item {
    min-height: inherit; } }

/* ir index
------------------------------------------------*/
.p-ir-top__sitemap {
  text-align: center; }

.p-ir-top__sitemap__title {
  position: relative;
  margin-top: 7px;
  padding-top: 86px;
  font-weight: bold; }
  .p-ir-top__sitemap__title:before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 70px;
    height: 70px; }

.p-ir-top__sitemap__summary {
  margin-bottom: 25px; }

.p-ir-top__sitemap__morelink {
  margin-top: 28px; }

.p-ir-top__sitemap__title__library:before {
  background: url(../images/contents/ir/ir_list_icon03.png); }

.p-ir-top__sitemap__title__shareholder:before {
  background: url(../images/contents/ir/ir_list_icon04.png); }

.p-ir-top__sitemap__title__stock:before {
  background: url(../images/contents/ir/ir_list_icon05.png); }

.p-ir-top__sitemap__title__glossary:before {
  background: url(../images/contents/ir/ir_list_icon06.png); }

.p-ir-top__sitemap__title__company:before {
  background: url(../images/contents/ir/ir_list_icon08.png); }

.p-ir-top__sitemap__title__sitemap:before {
  background: url(../images/contents/ir/ir_list_icon07.png); }

@media only screen and (max-width: 599px) {
  .p-ir-top__sitemap {
    padding-bottom: 24px; }
  .p-ir-top__sitemap__title {
    margin: 10px 0 10px;
    padding-top: 83px; }
  .p-ir-top__sitemap__summary__link {
    margin-bottom: 10px; }
  .p-ir-top__sitemap__summary {
    margin-bottom: 10px; }
  .p-ir-top__sitemap__morelink {
    margin-top: 30px; } }

/* ir library presentation
------------------------------------------------*/
.p-presentation__date-list {
  margin-bottom: -30px; }

@media only screen and (max-width: 599px) {
  .p-presentation__date-list {
    margin-bottom: -80px;
    border-bottom: none; } }

/* ir shareholder individual
------------------------------------------------*/
.p-individual__contact {
  background-color: #005491;
  padding: 58px 30px 64px;
  margin-bottom: -30px; }
  .p-individual__contact__title, .p-individual__contact__text, .p-individual__contact__mail {
    text-align: center;
    color: #FFF; }
  .p-individual__contact__title {
    margin-bottom: 24px;
    font-size: 20px;
    font-size: 2rem;
    font-weight: bold; }
  .p-individual__contact__text {
    margin-bottom: 16px; }
  .p-individual__contact__mail {
    margin-bottom: 22px; }
    .p-individual__contact__mail a {
      color: #FFF; }

@media only screen and (max-width: 599px) {
  .p-individual__contact {
    padding: 35px 20px 20px;
    margin-bottom: -65px; }
    .p-individual__contact__title {
      font-size: 14px;
      font-size: 1.4rem;
      font-weight: normal; }
    .p-individual__contact__text {
      margin-bottom: 26px; }
    .p-individual__contact__mail {
      margin-bottom: 25px; } }

/* ir glossary
------------------------------------------------*/
.p-glossary-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between; }

.p-glossary-list__item {
  width: 49.6%;
  margin-bottom: 8px;
  border: 1px solid #DCE5EB;
  padding: 36px 38px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

.p-glossary-list__term {
  font-size: 20px;
  font-size: 2rem;
  margin-bottom: 24px; }

@media only screen and (max-width: 599px) {
  .p-glossary-list {
    display: block; }
  .p-glossary-list__item {
    width: auto;
    padding: 26px 30px;
    margin-bottom: 12px; }
  .p-glossary-list__term {
    font-size: 16px;
    font-size: 1.6rem;
    margin-bottom: 20px; } }

/* ir earning
------------------------------------------------*/
.p-ir-earning__ir-icon {
  margin-top: -10px;
  line-height: 1; }

@media only screen and (max-width: 599px) {
  .p-ir-earning__ir-icon img {
    width: auto;
    height: 7px; } }

/* ir news
------------------------------------------------*/
.p-news__head:after {
  content: "";
  display: block;
  clear: both; }

.p-news__head__icon {
  float: right;
  margin-top: -134px; }

.p-news-article {
  max-width: 760px;
  margin: 0 auto; }
  .p-news-article__header {
    margin-bottom: 32px; }
    .p-news-article__header:after {
      content: "";
      display: block;
      clear: both; }
  .p-news-article__date {
    float: left;
    margin-top: 6px; }
  .p-news-article__tag {
    float: right; }
  .p-news-article__headline {
    font-size: 30px;
    font-size: 3rem;
    font-weight: bold;
    margin-bottom: 30px;
    padding-bottom: 28px;
    border-bottom: 1px solid #DCE5EB; }
  .p-news-article__subheading {
    margin: 30px 0 24px;
    font-size: 20px;
    font-size: 2rem;
    font-weight: bold; }
  .p-news-article__title {
    margin: 26px 0 10px;
    font-size: 20px;
    font-size: 2rem; }
  .p-news-article__text {
    margin-bottom: 14px; }
  .p-news-article__list {
    padding-left: 20px; }
  .p-news-article__image {
    margin: 34px 0; }
    .p-news-article__image img {
      width: 100%;
      height: auto; }
  .p-news-article__button {
    margin: 76px 0 30px; }

@media only screen and (max-width: 599px) {
  .p-news__head__icon {
    float: right;
    margin: 5px 0 0; }
  .p-news-article {
    margin-top: 0; }
    .p-news-article__header {
      margin-bottom: 5px; }
    .p-news-article__date {
      margin-top: 0; }
    .p-news-article__tag {
      display: none; }
    .p-news-article__headline {
      margin-bottom: 33px;
      padding-bottom: 23px;
      font-size: 23px;
      font-size: 2.3rem;
      line-height: 1.4; }
    .p-news-article__subheading {
      margin-bottom: 28px;
      font-size: 16px;
      font-size: 1.6rem; }
    .p-news-article__title {
      font-size: 16px;
      font-size: 1.6rem; }
    .p-news-article__list {
      padding-left: 16px; }
    .p-news-article__button {
      margin: 35px 0 0; } }

.p-news-movie {
  background-color: #FFF; }
  .p-news-movie__inner {
    max-width: 1080px;
    margin: 0 auto;
    padding: 50px 30px; }
    .p-news-movie__inner__frame {
      display: -webkit-box;
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
      -webkit-align-items: center;
      -ms-flex-align: center;
      align-items: center;
      -webkit-box-orient: horizontal;
      -webkit-box-direction: reverse;
      -webkit-flex-flow: row-reverse;
      -ms-flex-flow: row-reverse;
      flex-flow: row-reverse;
      border: 1px solid #DCE5EB;
      padding: 10px; }
      .p-news-movie__inner__frame__image {
        width: 50%; }
        .p-news-movie__inner__frame__image img {
          width: 100%;
          height: auto; }
      .p-news-movie__inner__frame__title {
        padding: 0 20px;
        width: 50%;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        text-align: center; }
        .p-news-movie__inner__frame__title-en {
          margin-bottom: 16px;
          line-height: 0; }
          .p-news-movie__inner__frame__title-en img {
            width: auto;
            height: 10px;
            -webkit-backface-visibility: hidden;
            backface-visibility: hidden; }
        .p-news-movie__inner__frame__title-ja {
          font-size: 20px;
          font-size: 2rem;
          color: #005491;
          font-weight: bold; }

@media only screen and (max-width: 599px) {
  .p-news-movie__inner {
    padding: 20px; }
    .p-news-movie__inner__frame {
      display: block; }
      .p-news-movie__inner__frame__image {
        width: auto; }
      .p-news-movie__inner__frame__title {
        width: auto;
        margin: 38px 0 26px; }
        .p-news-movie__inner__frame__title-en {
          margin-bottom: 11px; }
          .p-news-movie__inner__frame__title-en img {
            height: 7px; }
        .p-news-movie__inner__frame__title-ja {
          font-size: 14px;
          font-size: 1.4rem; } }

/* company index
------------------------------------------------*/
.p-company__grid-menu {
  margin: 80px 50px 0;
  border: 1px solid #DCE5EB;
  border-top: none; }
  .p-company__grid-menu__inner {
    vertical-align: top;
    padding-top: 68px; }

@media only screen and (max-width: 599px) {
  .p-company__grid-menu {
    margin: 0 0 -15px;
    border: none; }
    .p-company__grid-menu__inner {
      padding-top: 25px; } }

/* company vision
------------------------------------------------*/
.p-vision__checkbox {
  padding: 50px 30px;
  background-color: #F5F6F7;
  text-align: center; }
  .p-vision__checkbox__list {
    display: inline-block; }
    .p-vision__checkbox__list__summary {
      position: relative;
      margin-bottom: 40px;
      padding-left: 50px;
      font-size: 20px;
      font-size: 2rem;
      font-weight: bold;
      color: #005491;
      text-align: left; }
      .p-vision__checkbox__list__summary:last-child {
        margin-bottom: 0; }
      .p-vision__checkbox__list__summary:before {
        content: "";
        position: absolute;
        top: 3px;
        left: 0;
        background: url(../images/contents/icon_check.png);
        width: 38px;
        height: 32px;
        background-size: 38px 32px; }

@media only screen and (max-width: 599px) {
  .p-vision__checkbox {
    padding: 32px;
    text-align: left; }
    .p-vision__checkbox__list__summary {
      margin-bottom: 32px;
      padding-left: 48px;
      font-size: 14px;
      font-size: 1.4rem; }
      .p-vision__checkbox__list__summary:before {
        width: 29px;
        height: 25px;
        background-size: 29px 25px; } }

.p-vision__grid-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  .p-vision__grid-list__item {
    width: 47.44898%;
    padding: 40px 40px 34px;
    border: 1px solid #DCE5EB;
    -webkit-box-sizing: border-box;
    box-sizing: border-box; }
  .p-vision__grid-list__image {
    margin-bottom: 36px; }
    .p-vision__grid-list__image img {
      width: 100%;
      height: auto; }
  .p-vision__grid-list__title {
    margin-bottom: 26px;
    font-weight: bold;
    text-align: center; }
  .p-vision__grid-list__maincopy {
    margin-bottom: 10px;
    font-size: 20px;
    font-size: 2rem;
    text-align: center; }
  .p-vision__grid-list__subcopy {
    text-align: center; }

@media only screen and (max-width: 599px) {
  .p-vision__grid-list {
    display: block; }
    .p-vision__grid-list__item {
      width: auto;
      padding: 20px 20px 16px;
      margin-bottom: 12px; }
      .p-vision__grid-list__item:last-child {
        margin-bottom: 0; }
    .p-vision__grid-list__image {
      margin-bottom: 18px; }
    .p-vision__grid-list__title {
      margin-bottom: 10px; }
    .p-vision__grid-list__maincopy {
      font-size: 16px;
      font-size: 1.6rem; } }

/* company field
------------------------------------------------*/
.p-field__grid-list {
  margin-bottom: 0; }
  .p-field__grid-list__item {
    width: 100%;
    min-height: 170px; }

@media only screen and (max-width: 599px) {
  .p-field__grid-list__item {
    min-height: inherit; } }

/* company profile
------------------------------------------------*/
.p-profile__date-list {
  margin-bottom: -50px;
  border-bottom: none; }

.p-profile__button__more {
  position: absolute;
  top: 6px;
  right: 0; }

@media only screen and (max-width: 599px) {
  .p-profile__date-list {
    margin-bottom: -15px; }
  .p-profile__button__more {
    position: static;
    margin-top: 14px; } }

/* company officer
------------------------------------------------*/
.p-officer__profile {
  margin-bottom: 80px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  .p-officer__profile__image {
    width: 27%; }
    .p-officer__profile__image img {
      width: 100%;
      height: auto; }
  .p-officer__profile__detail {
    width: 69%; }
  .p-officer__profile__post {
    margin-bottom: 4px; }
  .p-officer__profile__name {
    font-size: 20px;
    font-size: 2rem;
    line-height: 1.4; }
    .p-officer__profile__name-en {
      padding-left: 22px;
      font-size: 14px;
      font-size: 1.4rem; }
  .p-officer__profile__birthday {
    margin-bottom: 34px; }
  .p-officer__profile__biography {
    display: none;
    margin-bottom: 36px; }
    .p-officer__profile__biography__subtitle {
      margin-left: -5px;
      margin-bottom: 10px; }
    .p-officer__profile__biography__detail {
      width: 100%; }
      .p-officer__profile__biography__detail th {
        width: 20%;
        font-size: 11px;
        font-size: 1.1rem; }
      .p-officer__profile__biography__detail th,
      .p-officer__profile__biography__detail td {
        padding: 2px 8px 2px 0;
        vertical-align: text-top; }
  .p-officer__profile__col3 {
    width: 33.3%; }

.p-officer__image {
  margin-top: 0; }

@media only screen and (max-width: 599px) {
  .p-officer__profile {
    margin-bottom: 40px;
    display: block; }
    .p-officer__profile__image {
      width: auto;
      margin-bottom: 15px; }
    .p-officer__profile__detail {
      width: auto; }
    .p-officer__profile__post {
      margin-bottom: 7px; }
    .p-officer__profile__name {
      margin-bottom: 10px;
      font-size: 16px;
      font-size: 1.6rem; }
    .p-officer__profile__birthday {
      margin-bottom: 32px; }
    .p-officer__profile__biography {
      margin-bottom: 10px; }
      .p-officer__profile__biography__detail th {
        border-top: 1px solid #DCE5EB;
        padding: 26px 0 0;
        width: 100%; }
      .p-officer__profile__biography__detail td {
        padding: 0 0 26px; }
      .p-officer__profile__biography__detail th,
      .p-officer__profile__biography__detail td {
        display: block; }
    .p-officer__profile__col3 {
      width: 100%;
      border-top: 1px solid #DCE5EB;
      padding: 12px 0; }
      .p-officer__profile__col3:last-child {
        border-bottom: 1px solid #DCE5EB; } }

/* company governance
------------------------------------------------*/
.p-governance__image {
  margin-top: 40px; }

/* company history
------------------------------------------------*/
.p-history__date-list {
  margin-bottom: -50px;
  border-bottom: none; }

@media only screen and (max-width: 599px) {
  .p-history__date-list {
    margin-bottom: -15px; } }

/* company message
------------------------------------------------*/
.p-message {
  margin-top: 80px;
  position: relative; }
  .p-message__photo img {
    width: 100%;
    height: auto; }
  .p-message__box {
    position: absolute;
    top: 50%;
    left: 8%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    background-color: #0499CC;
    padding: 30px 36px; }
    .p-message__box__lead {
      margin-bottom: 24px;
      font-size: 20px;
      font-size: 2rem;
      font-weight: bold;
      color: #FFF;
      letter-spacing: 0.06em; }
    .p-message__box__name {
      color: #FFF; }
  .p-message__text {
    padding: 0 110px;
    margin-bottom: 24px; }
  .p-message__name {
    padding: 0 110px;
    text-align: right; }

@media only screen and (max-width: 999px) {
  .p-message__text {
    padding: 0 50px; } }

@media only screen and (max-width: 599px) {
  .p-message {
    margin-top: 40px; }
    .p-message__box {
      position: static;
      -webkit-transform: inherit;
      -ms-transform: inherit;
      transform: inherit;
      padding: 26px 32px; }
      .p-message__box__lead {
        margin-bottom: 19px;
        font-size: 16px;
        font-size: 1.6rem; }
    .p-message__text {
      padding: 0; }
    .p-message__name {
      padding: 0; } }

/* recruit message
------------------------------------------------*/
/* recruit co2-bg
------------------------------------------------*/
.p-recruit__co2-bg {
  position: relative; }
  .p-recruit__co2-bg:after {
    content: "";
    display: block;
    clear: both; }
  .p-recruit__co2-bg__info {
    float: left;
    width: 41.83673%;
    padding: 45px 4.08163%;
    background-color: #0499cc;
    color: #fff; }
    .p-recruit__co2-bg__info__catch {
      font-size: 20px;
      font-size: 2rem;
      font-weight: bold;
      margin-bottom: 25px; }
  .p-recruit__co2-bg__image {
    width: 50%;
    float: right; }
    .p-recruit__co2-bg__image-box {
      display: block;
      position: relative;
      overflow: hidden; }
      .p-recruit__co2-bg__image-box img {
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
        width: auto;
        height: 100%; }

@media only screen and (max-width: 599px) {
  .p-recruit__co2-bg {
    display: block;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: vertical;
    -moz-flex-direction: vertical;
    -ms-flex-direction: column;
    -webkit-flex-direction: column;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    flex-direction: column; }
    .p-recruit__co2-bg__info {
      display: block;
      width: auto;
      padding: 25px 35px;
      -webkit-box-ordinal-group: 2;
      -moz-box-ordinal-group: 2;
      -ms-flex-order: 2;
      -webkit-order: 2;
      order: 2; }
      .p-recruit__co2-bg__info__catch {
        font-size: 16px;
        font-size: 1.6rem;
        margin-bottom: 25px; }
    .p-recruit__co2-bg__image {
      display: block;
      width: auto;
      -webkit-box-ordinal-group: 1;
      -moz-box-ordinal-group: 1;
      -ms-flex-order: 1;
      -webkit-order: 1;
      order: 1; }
      .p-recruit__co2-bg__image img {
        position: relative;
        top: inherit;
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
        left: auto;
        -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
        transform: translate(0, 0);
        width: 100%;
        height: auto; } }

/* recruit nav
------------------------------------------------*/
.p-recruit__nav {
  padding: 0 50px 50px; }
  .p-recruit__nav__list:after {
    content: "";
    display: block;
    clear: both; }
  .p-recruit__nav__list-item {
    float: left;
    width: 30.50847%;
    margin-right: 4.23729%; }
    .p-recruit__nav__list-item a {
      position: relative;
      overflow: hidden;
      display: block;
      height: 200px; }
      .p-recruit__nav__list-item a:after {
        content: "";
        position: absolute;
        top: 0;
        width: 100%;
        height: 100%;
        background-size: cover;
        background-position: center center;
        -webkit-transition: all .8s;
        -o-transition: all .8s;
        transition: all .8s; }
      .p-recruit__nav__list-item a:hover {
        color: #005491; }
        .p-recruit__nav__list-item a:hover:after {
          -webkit-transform: scale(1.1);
          -ms-transform: scale(1.1);
          transform: scale(1.1); }
    .p-recruit__nav__list-item__text {
      position: relative;
      z-index: 1;
      position: absolute;
      top: 50%;
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      transform: translateY(-50%);
      left: 25px;
      font-size: 16px;
      font-size: 1.6rem;
      font-weight: bold; }
      .p-recruit__nav__list-item__text__glow {
        text-shadow: 0px 0px 10px white;
        text-shadow: 1px 1px 2px #FFF, 0px 0px 2px #FFF, 0px 0px 2px #FFF,0px 0px 8px #FFF; }
      .p-recruit__nav__list-item__text img {
        width: auto;
        height: 9px;
        display: block;
        margin-bottom: 10px; }
    .p-recruit__nav__list-item:nth-child(3n) {
      margin-right: 0; }
    .p-recruit__nav__list-item:nth-child(1) a:after {
      background-image: url(../images/contents/recruit/recruit_nav_img01.jpg); }
    .p-recruit__nav__list-item:nth-child(2) a:after {
      background-image: url(../images/contents/recruit/recruit_nav_img02.jpg); }
    .p-recruit__nav__list-item:nth-child(3) a:after {
      background-image: url(../images/contents/recruit/recruit_nav_img03.jpg); }

@media only screen and (max-width: 999px) {
  .p-recruit__nav {
    padding: 0 40px 40px; }
    .p-recruit__nav__list-item__text {
      left: 15px; } }

@media only screen and (max-width: 599px) {
  .p-recruit__nav {
    padding: 0 20px 20px; }
    .p-recruit__nav__list-item {
      float: none;
      width: auto;
      margin: 0 0 20px; }
      .p-recruit__nav__list-item a {
        height: 157px; }
      .p-recruit__nav__list-item__text {
        left: 20px; }
        .p-recruit__nav__list-item__text img {
          height: 8px;
          margin-bottom: 5px; }
      .p-recruit__nav__list-item:last-child {
        margin-bottom: 0; } }

/* recruit type
------------------------------------------------*/
.p-recruit__type {
  background-color: #005491;
  border-bottom: 70px solid #eef2f5; }
  .p-recruit__type .c-sub-container__inner {
    padding-bottom: 30px; }
  .p-recruit__type .c-sub-container__title {
    color: #fff;
    font-size: 24px;
    font-size: 2.4rem; }
  .p-recruit__type .c-sub-container__lead {
    color: #fff;
    margin-bottom: 40px; }
  .p-recruit__type__menu:after {
    content: "";
    display: block;
    clear: both; }
  .p-recruit__type__menu-small {
    font-size: 12px;
    font-size: 1.2rem; }
  .p-recruit__type__menu li {
    float: left;
    width: 30.61224%;
    margin: 0 4.08163% 40px 0; }
    .p-recruit__type__menu li:nth-child(3n) {
      margin-right: 0; }
    .p-recruit__type__menu li a {
      position: relative;
      height: 94px;
      padding: 0 15px 0 73px;
      display: block; }
      .p-recruit__type__menu li a > span {
        position: absolute;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        font-size: 13px;
        font-size: 1.3rem;
        width: auto; }

@media only screen and (max-width: 999px) {
  .p-recruit__type__menu li {
    width: 49%;
    margin: 0 2% 20px 0; }
    .p-recruit__type__menu li:nth-child(3n) {
      margin-right: 2%; }
    .p-recruit__type__menu li:nth-child(2n) {
      margin-right: 0; }
    .p-recruit__type__menu li a > span {
      padding-right: 10px; } }

@media only screen and (max-width: 599px) {
  .p-recruit__type {
    border-bottom: 40px solid #eef2f5; }
    .p-recruit__type .c-sub-container__inner {
      padding-bottom: 20px; }
    .p-recruit__type .c-sub-container__title {
      font-size: 18px;
      font-size: 1.8rem; }
    .p-recruit__type .c-sub-container__lead {
      margin-bottom: 20px; }
    .p-recruit__type__menu-small {
      font-size: 14px;
      font-size: 1.4rem; }
    .p-recruit__type__menu li {
      float: none;
      width: auto;
      margin: 0 0 20px 0; }
      .p-recruit__type__menu li:nth-child(n) {
        margin-right: 0; }
      .p-recruit__type__menu li:last-child {
        margin-bottom: 0; }
      .p-recruit__type__menu li a {
        padding: 0 0 0 60px;
        font-size: 14px;
        font-size: 1.4rem; } }

/* recruit index
------------------------------------------------*/
#recruit.c-main-container__bgimg {
  background: url(../images/contents/recruit/recruit_base_bg.jpg) repeat-y; }

.p-recruit__index__symposium__image {
  position: relative; }
  .p-recruit__index__symposium__image__info {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 70px;
    background: #0499cc;
    width: 350px;
    height: 350px;
    display: table; }
    .p-recruit__index__symposium__image__info-box {
      display: table-cell;
      vertical-align: middle;
      text-align: left;
      font-size: 20px;
      font-size: 2rem;
      font-weight: bold;
      color: #fff;
      letter-spacing: 0.25em;
      padding: 40px 0 40px 40px; }
      .p-recruit__index__symposium__image__info-box img {
        display: block;
        width: auto;
        height: 16px;
        margin-bottom: 35px; }
      .p-recruit__index__symposium__image__info-box__catch {
        margin-bottom: 20px; }
      .p-recruit__index__symposium__image__info-box__title {
        margin-left: -0.25em; }

.p-recruit__index__message .p-recruit__co2-bg__info {
  width: 43.36735%;
  padding: 51px 0 51px 4.08163%; }
  .p-recruit__index__message .p-recruit__co2-bg__info__catch {
    letter-spacing: 0.15em; }
  .p-recruit__index__message .p-recruit__co2-bg__info__text {
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold; }

.p-recruit__index__message .p-recruit__co2-bg__image {
  width: 52.55102%; }

.p-recruit__index__type {
  border-bottom: 0;
  margin-bottom: -50px;
  padding: 64px 50px 30px; }

@media only screen and (max-width: 999px) {
  .p-recruit__index__symposium__image {
    overflow: hidden; }
    .p-recruit__index__symposium__image__info {
      right: 0;
      width: 40%; }
      .p-recruit__index__symposium__image__info-box {
        padding: 30px; }
  .p-recruit__index__message .p-recruit__co2-bg__info {
    width: 39.28571%;
    padding: 51px 4.08163%; }
  .p-recruit__index__type {
    padding: 64px 30px 30px; } }

@media only screen and (max-width: 599px) {
  .p-recruit__index__symposium__image__info, .p-recruit__index__message__image__info {
    position: relative;
    top: inherit;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    right: auto;
    width: auto;
    height: auto;
    display: block; }
    .p-recruit__index__symposium__image__info-box, .p-recruit__index__message__image__info-box {
      font-size: 16px;
      font-size: 1.6rem;
      padding: 30px; }
      .p-recruit__index__symposium__image__info-box img, .p-recruit__index__message__image__info-box img {
        height: 11px; }
  .p-recruit__index__message .p-recruit__co2-bg__info {
    width: auto;
    padding: 35px; }
  .p-recruit__index__message .p-recruit__co2-bg__image {
    width: auto; }
  .p-recruit__index__interview__list {
    margin-bottom: -10px; }
  .p-recruit__index__type {
    margin-bottom: -15px;
    padding: 30px 15px 20px; } }

/* recruit interview
------------------------------------------------*/
.p-recruit__interview {
  left: 10% !important;
  top: 50% !important; }
  .p-recruit__interview .p-recruit__ceo-message__title img {
    width: auto;
    height: 11px; }
  .p-recruit__interview .p-recruit__ceo-message__name strong {
    font-size: 24px;
    font-size: 2.4rem;
    display: block;
    margin-bottom: 10px; }
  .p-recruit__interview__note {
    margin: 10px 0 -15px;
    text-align: right;
    font-size: 12px;
    font-size: 1.2rem; }
  .p-recruit__interview__detail {
    margin-top: 110px; }
    .p-recruit__interview__detail:after {
      content: "";
      display: block;
      clear: both; }
    .p-recruit__interview__detail__caption {
      float: left;
      width: 50%; }
      .p-recruit__interview__detail__caption-title {
        font-size: 20px;
        font-size: 2rem;
        font-weight: bold;
        margin-bottom: 60px; }
    .p-recruit__interview__detail__image {
      float: right;
      width: 44.89796%; }
      .p-recruit__interview__detail__image img {
        width: 100%;
        height: auto; }
    .p-recruit__interview__detail:nth-child(2n) .p-recruit__interview__detail__caption {
      float: right; }
    .p-recruit__interview__detail:nth-child(2n) .p-recruit__interview__detail__image {
      float: left; }
  .p-recruit__interview__message {
    margin-top: 130px; }
    .p-recruit__interview__message__title {
      text-align: center;
      margin: 30px 0 40px; }
      .p-recruit__interview__message__title img {
        width: auto;
        height: 11px; }
  .p-recruit__interview__nav {
    margin: 11px 0 -10px; }
    .p-recruit__interview__nav:after {
      content: "";
      display: block;
      clear: both; }
    .p-recruit__interview__nav-item {
      float: left;
      width: 32.68519%;
      margin: 0 0.92593% 11px 0;
      -webkit-box-shadow: 0px 0px 2px 1px rgba(0, 53, 84, 0.1);
      box-shadow: 0px 0px 2px 1px rgba(0, 53, 84, 0.1); }
      .p-recruit__interview__nav-item a {
        display: table;
        background: #fff;
        padding: 24px; }
        .p-recruit__interview__nav-item a img {
          width: 80px;
          padding-right: 25px;
          height: auto;
          display: table-cell;
          vertical-align: middle; }
      .p-recruit__interview__nav-item__info {
        width: 100%;
        display: table-cell;
        vertical-align: middle; }
        .p-recruit__interview__nav-item__info__name {
          font-weight: bold; }
        .p-recruit__interview__nav-item__info__text {
          color: #333; }
      .p-recruit__interview__nav-item:nth-child(3n) {
        margin-right: 0; }

@media only screen and (max-width: 999px) {
  .p-recruit__interview {
    left: 5.1% !important; }
    .p-recruit__interview .p-recruit__ceo-message__lead {
      margin-top: -85px; }
    .p-recruit__interview__nav {
      margin: 11px 0 -10px; }
      .p-recruit__interview__nav-item {
        width: 49.5%;
        margin: 0 1% 11px 0; }
        .p-recruit__interview__nav-item:nth-child(3n) {
          margin-right: 1%; }
        .p-recruit__interview__nav-item:nth-child(2n) {
          margin-right: 0; }
    .p-recruit__interview__note {
      margin: 0 0 -5px;
      text-align: left; } }

@media only screen and (max-width: 599px) {
  .p-recruit__interview .p-recruit__ceo-message__lead {
    margin-top: -55px; }
  .p-recruit__interview .p-recruit__ceo-message__name strong {
    font-size: 20px;
    font-size: 2rem;
    margin-bottom: 0; }
  .p-recruit__interview__detail {
    margin-top: 35px; }
    .p-recruit__interview__detail:after {
      content: "";
      display: block;
      clear: both; }
    .p-recruit__interview__detail__caption {
      float: note;
      width: auto; }
      .p-recruit__interview__detail__caption-title {
        font-size: 16px;
        font-size: 1.6rem;
        margin-bottom: 30px; }
      .p-recruit__interview__detail__caption-text {
        margin-bottom: 40px; }
    .p-recruit__interview__detail__image {
      float: note;
      width: auto; }
    .p-recruit__interview__detail:nth-child(2n) .p-recruit__interview__detail__caption {
      float: none; }
    .p-recruit__interview__detail:nth-child(2n) .p-recruit__interview__detail__image {
      float: none; }
  .p-recruit__interview__message {
    margin-top: 80px; }
    .p-recruit__interview__message__title {
      margin: 30px 0 40px; }
      .p-recruit__interview__message__title img {
        width: auto;
        height: 11px; }
  .p-recruit__interview__nav-item {
    width: 265px;
    margin: 0 11px 11px 0 !important; }
    .p-recruit__interview__nav-item a {
      padding: 15px 20px; }
      .p-recruit__interview__nav-item a img {
        width: 70px;
        padding-right: 20px; }
  .p-recruit__interview__nav .slick-dots {
    text-align: center; }
    .p-recruit__interview__nav .slick-dots li {
      display: inline-block;
      margin: 0 6px; }
      .p-recruit__interview__nav .slick-dots li button {
        background-color: transparent;
        border: none;
        cursor: pointer;
        outline: none;
        padding: 0;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        text-indent: -9999px;
        width: 10px;
        height: 10px;
        border-radius: 50px;
        border: 1px solid #005491;
        -webkit-transition: all .3s;
        -o-transition: all .3s;
        transition: all .3s; }
      .p-recruit__interview__nav .slick-dots li.slick-active button {
        background-color: #005491; } }

/* recruit symposium
------------------------------------------------*/
.p-recruit__symposium .c-pagetitle {
  padding: 40px 50px 2px; }
  .p-recruit__symposium .c-pagetitle__title-en {
    margin-bottom: 10px; }
    .p-recruit__symposium .c-pagetitle__title-en img {
      height: 11px; }
  .p-recruit__symposium .c-pagetitle__title-ja {
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    font-style: italic;
    color: #0499cc;
    letter-spacing: 0.1em; }

.p-recruit__symposium-section {
  margin-top: 70px; }

.p-recruit__symposium .c-subtitle {
  text-align: center;
  font-size: 30px;
  font-size: 3rem;
  font-weight: bold;
  font-style: italic;
  color: #0499cc;
  letter-spacing: 0.15em; }
  .p-recruit__symposium .c-subtitle:after {
    content: "";
    display: block;
    height: 16px;
    background: url(../images/contents/recruit/recruit_symposium_wave.png) 50% 50% no-repeat;
    background-size: auto 100%;
    margin-top: 15px; }

.p-recruit__symposium__profile {
  background-color: #f5f6f7;
  padding: 25px 4.62963% 50px; }
  .p-recruit__symposium__profile__list {
    margin-bottom: 30px; }
    .p-recruit__symposium__profile__list:after {
      content: "";
      display: block;
      clear: both; }
    .p-recruit__symposium__profile__list-item {
      float: left;
      width: 31.48148%;
      text-align: center;
      position: relative;
      padding-right: 3.7037%; }
      .p-recruit__symposium__profile__list-item__name {
        font-weight: bold;
        margin-bottom: 10px; }
      .p-recruit__symposium__profile__list-item:after {
        content: "";
        display: inline-block;
        width: 40px;
        height: 26px;
        background: url(../images/contents/recruit/recruit_symposium_x.png) 50% 50% no-repeat;
        background-size: auto 100%;
        position: absolute;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        right: 0; }
      .p-recruit__symposium__profile__list-item:last-child {
        width: 27.77778%;
        padding-right: 0; }
        .p-recruit__symposium__profile__list-item:last-child:after {
          display: none; }
  .p-recruit__symposium__profile__note {
    text-align: center;
    font-size: 12px;
    font-size: 1.2rem;
    margin-bottom: 30px; }
  .p-recruit__symposium__profile__text {
    text-align: center; }

.p-recruit__symposium__image-last {
  margin-bottom: -50px; }

.p-recruit__symposium__section {
  border: 16px solid #f3f5f7;
  padding: 80px 8.33333%; }
  .p-recruit__symposium__section-title {
    font-size: 24px;
    font-size: 2.4rem;
    font-weight: bold;
    text-align: center; }
  .p-recruit__symposium__section-subtitle {
    font-size: 20px;
    font-size: 2rem;
    font-weight: bold;
    text-align: center;
    color: #005491;
    margin-bottom: 80px; }
    .p-recruit__symposium__section-subtitle img {
      width: auto;
      height: 44px;
      vertical-align: baseline;
      margin-right: 7px; }
  .p-recruit__symposium__section__list-item {
    margin-bottom: 40px; }
    .p-recruit__symposium__section__list-item:after {
      content: "";
      display: block;
      clear: both; }
    .p-recruit__symposium__section__list-item img {
      float: left;
      width: 90px;
      height: auto;
      margin-right: 40px; }
    .p-recruit__symposium__section__list-item__text {
      margin-left: 130px; }
    .p-recruit__symposium__section__list-item:last-child {
      margin-bottom: 0; }

@media only screen and (max-width: 999px) {
  .p-recruit__symposium__image-last {
    margin-bottom: -50px; } }

@media only screen and (max-width: 599px) {
  .p-recruit__symposium-section {
    margin-top: 50px; }
  .p-recruit__symposium .c-pagetitle {
    padding: 20px 20px 30px; }
    .p-recruit__symposium .c-pagetitle__title-en {
      margin-bottom: 10px; }
      .p-recruit__symposium .c-pagetitle__title-en img {
        height: 11px; }
    .p-recruit__symposium .c-pagetitle__title-ja {
      font-size: 11px;
      font-size: 1.1rem;
      letter-spacing: 0; }
  .p-recruit__symposium .c-subtitle {
    font-size: 23px;
    font-size: 2.3rem;
    line-height: 1.5;
    letter-spacing: 0.15em;
    margin-bottom: -10px; }
    .p-recruit__symposium .c-subtitle:after {
      height: 14px;
      margin-top: 10px; }
  .p-recruit__symposium__profile {
    padding: 30px 4.62963% 50px; }
    .p-recruit__symposium__profile__list {
      margin-bottom: 30px; }
      .p-recruit__symposium__profile__list-item {
        float: none;
        width: auto;
        padding-right: 0; }
        .p-recruit__symposium__profile__list-item__name {
          font-weight: bold;
          margin-bottom: 10px; }
        .p-recruit__symposium__profile__list-item:after {
          width: 40px;
          height: 26px;
          position: relative;
          top: inherit;
          -webkit-transform: translateY(0);
          -ms-transform: translateY(0);
          transform: translateY(0);
          right: 0;
          margin: 15px 0 10px; }
        .p-recruit__symposium__profile__list-item:last-child {
          width: auto; }
          .p-recruit__symposium__profile__list-item:last-child:after {
            display: none; }
    .p-recruit__symposium__profile__note {
      text-align: center;
      font-size: 12px;
      font-size: 1.2rem;
      margin-bottom: 30px; }
    .p-recruit__symposium__profile__text {
      text-align: left; }
  .p-recruit__symposium__image {
    position: relative;
    height: 103px;
    overflow: hidden; }
    .p-recruit__symposium__image img {
      position: absolute;
      top: 50%;
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      transform: translateY(-50%);
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      width: 110%;
      height: auto;
      max-width: inherit; }
    .p-recruit__symposium__image-main {
      height: 144px; }
    .p-recruit__symposium__image-last {
      margin-bottom: -15px; }
  .p-recruit__symposium__section {
    border: 8px solid #f3f5f7;
    padding: 30px 20px 15px; }
    .p-recruit__symposium__section-title {
      font-size: 18px;
      font-size: 1.8rem; }
    .p-recruit__symposium__section-subtitle {
      font-size: 16px;
      font-size: 1.6rem;
      margin-bottom: 25px; }
      .p-recruit__symposium__section-subtitle img {
        height: 22px;
        margin: 0 auto 10px;
        display: block; }
    .p-recruit__symposium__section__list-item {
      margin-bottom: 30px; }
      .p-recruit__symposium__section__list-item:after {
        content: "";
        display: block;
        clear: both; }
      .p-recruit__symposium__section__list-item img {
        float: none;
        width: 80px;
        margin: 0 auto -10px;
        display: block; }
      .p-recruit__symposium__section__list-item__text {
        margin-left: 0; }
      .p-recruit__symposium__section__list-item:last-child {
        margin-bottom: 0; } }

/* recruit message
------------------------------------------------*/
.p-recruit__ceo-message {
  position: absolute;
  left: 5.1%;
  top: 53%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%); }
  .p-recruit__ceo-message__title {
    margin-bottom: 40px; }
  .p-recruit__ceo-message__lead__inner {
    margin-bottom: 28px; }
    .p-recruit__ceo-message__lead__inner__tb {
      display: none; }
  .p-recruit__ceo-message__lead span {
    display: inline-block;
    margin-bottom: 8px;
    padding: 6px 14px;
    background-color: #0499CC;
    font-size: 22px;
    font-size: 2.2rem;
    font-weight: bold;
    font-style: italic;
    color: #FFF;
    letter-spacing: 0.08em; }
  .p-recruit__ceo-message__name {
    color: #0499CC;
    font-weight: bold; }

@media only screen and (max-width: 999px) {
  .p-recruit__ceo-message {
    position: static;
    -webkit-transform: inherit;
    -ms-transform: inherit;
    transform: inherit; }
    .p-recruit__ceo-message__title {
      position: absolute;
      top: 24px;
      left: 30px;
      line-height: 0; }
      .p-recruit__ceo-message__title img {
        width: auto;
        height: 8px !important;
        -webkit-backface-visibility: hidden;
        backface-visibility: hidden; }
    .p-recruit__ceo-message__lead {
      margin: -210px 0 0 30px; }
      .p-recruit__ceo-message__lead__inner {
        margin-bottom: 16px; }
        .p-recruit__ceo-message__lead__inner__tb {
          display: block; }
        .p-recruit__ceo-message__lead__inner__pc {
          display: none; } }

@media only screen and (max-width: 599px) {
  .p-recruit__ceo-message__title {
    left: 15px; }
  .p-recruit__ceo-message__lead {
    margin: -135px 0 0 15px; }
    .p-recruit__ceo-message__lead span {
      margin-bottom: 2px;
      padding: 4px 10px;
      font-size: 16px;
      font-size: 1.6rem; } }

/* recruit interview
------------------------------------------------*/
.p-recruit__interview__list:after {
  content: "";
  display: block;
  clear: both; }

.p-recruit__interview__list-item {
  float: left;
  width: 47.44898%;
  margin-right: 5.10204%; }
  .p-recruit__interview__list-item a {
    display: block; }
    .p-recruit__interview__list-item a img {
      width: 100%;
      height: auto;
      -webkit-transition: all .8s;
      -o-transition: all .8s;
      transition: all .8s; }
    .p-recruit__interview__list-item a:hover {
      opacity: 1; }
      .p-recruit__interview__list-item a:hover .p-recruit__interview__list-item__name {
        opacity: 0.7; }
      .p-recruit__interview__list-item a:hover img {
        -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
        transform: scale(1.1); }
  .p-recruit__interview__list-item__image {
    overflow: hidden;
    margin-bottom: 15px; }
  .p-recruit__interview__list-item__name {
    font-size: 20px;
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 10px;
    background: url(../images/common/arrow_right_blue.png) 100% 50% no-repeat;
    background-size: 26px 26px;
    display: block; }
  .p-recruit__interview__list-item__text {
    font-size: 14px;
    font-size: 1.4rem;
    color: #333; }
  .p-recruit__interview__list-item:nth-child(2n) {
    margin-right: 0; }

@media only screen and (max-width: 599px) {
  .p-recruit__interview__list {
    margin-bottom: 20px; }
    .p-recruit__interview__list-item {
      float: none;
      width: auto;
      margin: 0 0 30px; }
      .p-recruit__interview__list-item a {
        display: block; }
      .p-recruit__interview__list-item__name {
        font-size: 16px;
        font-size: 1.6rem;
        background-size: 19px auto; }
      .p-recruit__interview__list-item:nth-child(2n) {
        margin-right: 0; }
      .p-recruit__interview__list-item:last-child {
        margin: 0; } }

/* search
------------------------------------------------*/
.p-search__result {
  font-size: 20px;
  font-size: 2rem;
  text-align: center;
  margin: -10px 0 56px; }
  .p-search__result strong {
    font-weight: bold; }

.p-search__list {
  border-bottom: 1px solid #DCE5EB; }
  .p-search__list__summary {
    border-top: 1px solid #DCE5EB;
    padding: 18px 0; }
    .p-search__list__summary__title {
      margin-bottom: 12px; }
    .p-search__list__summary__text {
      margin-bottom: 12px; }

.p-search__pagination {
  margin-bottom: 30px; }

@media only screen and (max-width: 599px) {
  .p-search__result {
    font-size: 14px;
    font-size: 1.4rem;
    margin: -31px 0 36px; }
  .p-search__list__summary {
    padding: 26px 0; }
    .p-search__list__summary__title {
      margin-bottom: 8px; }
    .p-search__list__summary__text {
      margin-bottom: 6px; }
  .p-search__pagination {
    margin-bottom: 25px; } }

/* error
------------------------------------------------*/
.p-error__lead {
  text-align: center; }

.p-error__button {
  margin: 0 0 50px; }

@media only screen and (max-width: 599px) {
  .p-error__button {
    margin: 0; } }

/* utility
例外的なスタイルや汎用的に使えるスタイルを定義（!importantを指定）
------------------------------------------------*/
.u-spOnly {
  display: none !important; }

.u-pcOnly {
  display: inherit !important; }

.u-br {
  display: block; }
  .u-br-md {
    display: inline; }
  .u-br-sp {
    display: inline; }

.u-mb0 {
  margin-bottom: 0; }

.u-mt0 {
  margin-top: 0; }

@media screen and (max-width: 999px) {
  .u-br-md {
    display: block; } }

@media screen and (max-width: 599px) {
  .u-spOnly {
    display: inherit !important; }
  .u-pcOnly {
    display: none !important; }
  .u-br {
    display: inline; }
    .u-br-md {
      display: inline; }
    .u-br-sp {
      display: block; } }

/* e-ir
------------------------------------------------*/
#ir_list dl {
  border-bottom: 1px dotted #c1c1c1;
  margin-bottom: 19px;
  padding-bottom: 17px;
  font-size: 12px;
  font-size: 1.2rem; }

#ir_list dt {
  float: left;
  padding: 1px 0;
  width: 20%;
  letter-spacing: 0.05em; }

#ir_list dd {
  width: auto !important;
  padding: 1px 0;
  width: 80%;
  margin-left: 190px; }

.ir_list_c dt {
  padding: 1px 0;
  letter-spacing: 0.1em; }

.ir_list_c dd {
  padding: 1px 0; }

@media only screen and (max-width: 599px) {
  #ir_list dt {
    float: none;
    width: 100%; }
  #ir_list dd {
    float: none;
    width: 100% !important;
    margin-bottom: 5px;
    margin-left: 0; }
  #ir_list_c dd {
    float: none;
    width: 100%; } }

/* ir library
------------------------------------------------*/
div#ir_library dt {
  font-weight: normal;
  background: none repeat scroll 0 0 #E0F2FF;
  float: left;
  padding: 11px 0;
  text-align: center;
  width: 150px; }

div#ir_library dd {
  border: 1px solid #D3D3D3;
  float: right;
  padding: 8px 10px;
  width: 500px;
  line-height: 1.85em; }

/* アイコンの左右のアキ */
div#ir_library dt img,
div#ir_library dd img {
  margin-left: 0.5em;
  margin-top: -3px !important; }

/* ファイルサイズの色 */
#ir_library .Right
, #divDataArea .Right {
  color: #9D9D9D; }

div#ir_library dl {
  font-size: 12px;
  font-size: 1.2rem; }

div#ir_library dt {
  background: #ffffff none repeat scroll 0 0 !important;
  float: left;
  font-weight: normal;
  padding: 11px 0;
  text-align: left !important;
  width: 130px !important; }

div#ir_library dd {
  border: none !important;
  float: none !important;
  line-height: 1.85em;
  padding: 8px 10px;
  width: auto !important;
  margin-left: 136px; }

@media only screen and (max-width: 599px) {
  div#ir_library dd {
    border: none !important;
    float: none !important;
    margin-left: 110px; } }

.tit_txt_b {
  border-bottom: solid 1px #707070;
  padding: 3px 10px 3px 0;
  margin-bottom: 10px;
  color: #333;
  font-size: 14px;
  font-weight: bold; }

.txt_link_right {
  font-weight: normal;
  font-size: 12px;
  text-align: right;
  margin-top: -2.7em !important;
  padding-bottom: 10px; }

.txt_right {
  text-align: right; }

/* ir shareholder highlights
------------------------------------------------*/
#hqir table.frameTable {
  margin-top: -40px !important;
  width: 100% !important;
  font-size: 12px;
  font-size: 1.2rem; }

@media only screen and (max-width: 599px) {
  #hqir table.frameTable {
    margin-top: -80px !important;
    font-size: 11px;
    font-size: 1.1rem; } }

/* common
------------------------------------------------*/
.m_t50 {
  margin-top: 50px !important; }

.Right {
  float: right;
  margin: 0; }

/*+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+
+-----+// ContentClear
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----*/
.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden; }

* html .clearfix {
  height: 1%; }

*:first-child + html .clearfix {
  height: 1%; }

/**************************************************************
top
**************************************************************/
/* bg
------------------------------------------------*/
body#top .c-main-container__bgimg {
  position: relative;
  background-position: center 0; }
  body#top .c-main-container__bgimg:after {
    content: "";
    display: block;
    width: 2600px;
    height: 100%;
    background: url(../images/top/top_bg01_fixed.png) no-repeat;
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: 0; }

#top .c-main-container__bgimg {
  background: url(../images/top/top_bg01.jpg) no-repeat; }

@media only screen and (max-width: 999px) {
  body#top .c-main-container__bgimg {
    overflow: hidden;
    background-position: center 0; }
    body#top .c-main-container__bgimg:after {
      top: 0; } }

@media only screen and (max-width: 599px) {
  body#top .c-main-container__bgimg:after {
    background: url(../images/top/top_bg01_fixed_sp.png) no-repeat;
    width: 1400px;
    background-size: 1400px auto; }
  #top .c-main-container__bgimg {
    background: url(../images/top/top_bg01_sp.jpg) no-repeat; } }

body#english .c-main-container__bgimg {
  position: relative;
  background-position: center 0; }
  body#english .c-main-container__bgimg:after {
    content: "";
    display: block;
    width: 2600px;
    height: 100%;
    background: url(../images/top/top_bg01_fixed.png) no-repeat;
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: 0; }

#english .c-main-container__bgimg {
  background: url(../images/top/top_bg01.jpg) no-repeat; }

@media only screen and (max-width: 999px) {
  body#english .c-main-container__bgimg {
    overflow: hidden;
    background-position: center 0; }
    body#english .c-main-container__bgimg:after {
      top: 0; } }

@media only screen and (max-width: 599px) {
  body#english .c-main-container__bgimg:after {
    background: url(../images/top/top_bg01_fixed_sp.png) no-repeat;
    width: 1400px;
    background-size: 1400px auto; }
  #english .c-main-container__bgimg {
    background: url(../images/top/top_bg01_sp.jpg) no-repeat; } }
/* 共通
------------------------------------------------*/
body {
  background-color: #FFF;
  /*&:after {
		content: "";
		display: block;
		width: 100%;
		height: 100%;
		background: url(../images/top/top_bg01_fixed.png) no-repeat;
		background-position: 48.5% -40px;
		position: absolute;
		top: 0;
		left: 0;
		z-index: -1;
	}*/ }

.c-main-container__top {
  padding-top: 116px;
  line-height: 1.6; }
  .c-main-container__top a {
    color: #333; }
  .c-main-container__top .top-section__title {
    line-height: 1.2;
    text-align: center; }
    .c-main-container__top .top-section__title img {
      display: block;
      width: auto;
      height: 30px;
      margin: 0 auto 17px; }
    .c-main-container__top .top-section__title .sub {
      display: inline-block;
      padding-bottom: 5px;
      border-bottom: 2px solid #333;
      font-weight: bold;
      margin-bottom: 38px;
      letter-spacing: 0.2rem; }
  .c-main-container__top .top-section__lead {
    text-align: center; }
  .c-main-container__top .top-box:after {
    content: "";
    display: block;
    clear: both; }
  .c-main-container__top .top-box__shadow {
    -webkit-box-shadow: 0 0 6px 0 rgba(0, 0, 0, 0.15);
    -moz-box-shadow: 0 0 6px 0 rgba(0, 0, 0, 0.15);
    box-shadow: 0 0 6px 0 rgba(0, 0, 0, 0.15);
    background: rgba(253, 253, 253, 0.97); }
  .c-main-container__top .top-btn a {
    display: inline-block;
    text-align: center;
    color: #fff;
    font-weight: bold;
    padding: 15px 30px; }
    .c-main-container__top .top-btn a:before {
      content: "";
      background: url(../images/common/arrow_right_white.png) no-repeat;
      background-size: cover;
      width: 26px;
      height: 26px;
      display: inline-block;
      margin-right: 10px;
      vertical-align: middle; }
    .c-main-container__top .top-btn a:hover {
      text-decoration: none; }
  .c-main-container__top .top-btn__yellow a {
    background: #FABF2E;
    padding: 18px 27px 16px; }
    .c-main-container__top .top-btn__yellow a:hover {
      -ms-filter: "alpha(opacity=100)";
      opacity: 1;
      background: #FDD033; }

@media only screen and (max-width: 999px) {
  /*body {
		background-position: 45% 0;
		&:after {
			background-position: 45% 0;
		}
	}*/
  .c-main-container__top {
    padding-top: 60px; } }

@media only screen and (max-width: 599px) {
  /*body {
		background: url(../images/top/top_bg01_sp.jpg) no-repeat;
		background-position: 38% 0;
		&:after {
			background: url(../images/top/top_bg01_fixed_sp.png) no-repeat;
			width: 1400px;
			background-size: 1400px auto;
			left: 50%;
			transform: translateX(-50%);
		}
	}*/
  .c-main-container__top {
    line-height: 1.8; }
    .c-main-container__top .top-section__title img {
      height: 16.5px;
      margin-bottom: 8px; }
    .c-main-container__top .top-section__title .sub {
      -moz-transform: scale(0.6);
      -o-transform: scale(0.6);
      -ms-transform: scale(0.6);
      -webkit-transform: scale(0.6);
      transform: scale(0.6);
      border-bottom: 1.5px solid #333;
      margin-bottom: 15px; }
    .c-main-container__top .top-section__lead {
      text-align: left; }
    .c-main-container__top .top-btn a {
      display: block; }
      .c-main-container__top .top-btn a:before {
        width: 20px;
        height: 20px; }
    .c-main-container__top .top-btn__yellow a {
      padding: 14px; } }

.c-layout-contents {
  position: relative;
  z-index: 1; }

/* メインビジュアル
------------------------------------------------*/
.top-mainvisual .c-layout-contents {
  position: relative;
  height: 607px; }

.top-mainvisual__catch {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  top: 44.5%;
  color: #005491; }
  .top-mainvisual__catch__main {
    margin-bottom: 20px; }
    .top-mainvisual__catch__main img {
      width: 100%;
      height: auto; }
  .top-mainvisual__catch__sub {
    font-size: 17px;
    font-size: 1.7rem;
    font-weight: bold;
    letter-spacing: 0.47rem; }

.top-mainvisual__movie {
  position: absolute;
  right: 0;
  bottom: 45px;
  cursor: pointer; }
  .top-mainvisual__movie:hover .top-mainvisual__movie__play img {
    -webkit-transition: all .2s;
    -o-transition: all .2s;
    transition: all .2s;
    -ms-filter: "alpha(opacity=70)";
    opacity: 0.7; }
  .top-mainvisual__movie:hover .top-mainvisual__movie__play:after {
    background: url(../images/top/top_movie_splite.jpg) no-repeat 0 0;
    /*一秒間に動くフレーム数*/
    -webkit-animation: play 8.1s steps(245) infinite;
    animation: play 8.1s steps(245) infinite; }
  .top-mainvisual__movie__play {
    position: absolute;
    right: 159px;
    bottom: 0;
    z-index: 1;
    width: 260px;
    height: 260px;
    border-radius: 200px;
    background: url(../images/top/top_movie_img01.png) no-repeat 0 0 #fff;
    background-size: cover;
    -webkit-box-shadow: 0 0 6px 0 rgba(0, 0, 0, 0.1);
    -moz-box-shadow: 0 0 6px 0 rgba(0, 0, 0, 0.1);
    box-shadow: 0 0 6px 0 rgba(0, 0, 0, 0.1); }
    .top-mainvisual__movie__play img {
      position: absolute;
      top: 50%;
      left: 50%;
      -moz-transform: translate(-50%, -50%);
      -o-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      -webkit-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      display: inline-block;
      width: 73px;
      height: 73px;
      z-index: 1;
      -webkit-transition: all .2s;
      -o-transition: all .2s;
      transition: all .2s; }
    .top-mainvisual__movie__play:before, .top-mainvisual__movie__play:after {
      content: "";
      position: absolute;
      top: 50%;
      left: 50%;
      -moz-transform: translate(-50%, -50%);
      -o-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      -webkit-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      width: 100%;
      height: 100%;
      border-radius: 200px; }
    .top-mainvisual__movie__play:before {
      border-radius: 200px;
      border: 10px solid #fff;
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      z-index: 1; }
  .top-mainvisual__movie__text {
    position: absolute;
    right: -5px;
    bottom: 0;
    z-index: 1; }

@-webkit-keyframes play {
  0% {
    background-position: 0px 0; }
  100% {
    background-position: -61250px 0; } }

@keyframes play {
  0% {
    background-position: 0px 0; }
  100% {
    background-position: -61250px 0; } }

@media only screen and (max-width: 999px) {
  .top-mainvisual__movie {
    -moz-transform: scale(0.8);
    -o-transform: scale(0.8);
    -ms-transform: scale(0.8);
    -webkit-transform: scale(0.8);
    transform: scale(0.8); } }

@media only screen and (max-width: 599px) {
  .top-mainvisual .c-layout-contents {
    height: 323px;
    margin: 0 5px; }
  .top-mainvisual__catch {
    top: 40%;
    left: 15px; }
    .top-mainvisual__catch__main {
      margin-bottom: 5px; }
      .top-mainvisual__catch__main img {
        width: 260px;
        height: auto; }
    .top-mainvisual__catch__sub {
      font-size: 10px;
      font-size: 1rem;
      letter-spacing: 0.1rem; }
  .top-mainvisual__movie {
    right: 0;
    bottom: 0;
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    -webkit-transform: scale(1);
    transform: scale(1); }
    .top-mainvisual__movie__play {
      right: 0;
      bottom: 10px;
      width: 130px;
      height: 130px; }
      .top-mainvisual__movie__play:hover:after {
        -ms-filter: "alpha(opacity=0)";
        opacity: 0; }
      .top-mainvisual__movie__play img {
        width: 36.5px;
        height: auto; }
      .top-mainvisual__movie__play:before {
        border: 5px solid #fff; }
    .top-mainvisual__movie__text {
      right: 107px;
      bottom: 13px; }
      .top-mainvisual__movie__text img {
        width: 80px;
        height: auto; } }

/* NEWS
------------------------------------------------*/
.top-section {
  position: relative;
  z-index: 1; }

.top-news {
  margin-bottom: 60px; }
  .top-news .top-box__shadow {
    display: table;
    width: 100%;
    table-layout: fixed; }
  .top-news__title {
    color: #fff;
    display: table-cell;
    text-align: right;
    width: 180px;
    position: relative;
    font-size: 16px;
    font-size: 1.6rem;
    font-family: arial;
    font-weight: normal;
    font-style: italic;
    line-height: 1;
    letter-spacing: 0.2rem; }
    .top-news__title .bg {
      background: #005491;
      display: block;
      width: 96px;
      line-height:144px; }
    .top-news__title:after {
      content: "";
      display: block;
      position: absolute;
      right: 0;
      top: 0;
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 144px 84px 0 0;
      border-color: #005591 transparent transparent transparent; }
  .top-news__list {
    display: table-cell;
    vertical-align: middle;
    padding: 15px 10px 15px 0; }
  .top-news__list li:nth-child(3) {
  margin-bottom: 0px;}
    .top-news__list-item {
      position: relative;
	  margin-bottom: 10px;}
      .top-news__list-item__date, .top-news__list-item__category, .top-news__list-item__text {
        display: inline-block;
        vertical-align: middle;
        margin-right: 24px; }
      .top-news__list-item__category {
        margin-right: 10px;
        font-size: 12px;
        font-size: 1.2rem;
        border: 1px solid #D3D3D3;
        background: #fff;
        padding: 5px 10px;
        -webkit-transition: all .2s;
        -o-transition: all .2s;
        transition: all .2s; }
      .top-news__list-item__text {
        position: absolute;
        left: 0;
        right: 0;
        top: 5px;
        margin-left: 280px;
        height: 1.5em;
        overflow: hidden;
        -o-text-overflow: ellipsis;
        text-overflow: ellipsis;
        white-space: nowrap; }
      .top-news__list-item a:hover .top-news__list-item__date,
      .top-news__list-item a:hover .top-news__list-item__text {
        color: #005491; }
      .top-news__list-item a:hover .top-news__list-item__category {
        border: 1px solid #005491;
        background: #005491;
        color: #FFF; }
  .top-news__more {
    display: table-cell;
    vertical-align: middle;
    width: 85px;
    text-align: center;
    line-height: 1; }
    .top-news__more a {
      position: relative;
      display: block;
      width: 100%; }
      .top-news__more a:before {
        content: "";
        position: absolute;
        top: 50%;
        left: 0;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        width: 1px;
        height: 100px;
        background-color: #D3D3D3; }
    .top-news__more img {
      width: 26px;
      height: auto; }

@media screen and (max-width: 999px) {
  .top-news .c-layout-contents {
    margin: 0 5px; }
  .top-news__list-item__text {
    position: static;
    margin: 0;
    width: 100%; } }

@media screen and (max-width: 599px) {
  .top-news {
    margin-bottom: 30px; }
    .top-news .top-box__shadow {
      height: auto;
      display: block;
      position: relative; }
    .top-news__title {
      text-align: right;
      width: 90px;
      position: relative;
      font-size: 8px;
      font-size: 0.8rem; }
      .top-news__title .bg {
        width: 55px;
        line-height: 35px; }
      .top-news__title:after {
        border-width: 35px 35px 0 0; }
    .top-news__list {
      display: block;
      padding: 8px 15px 15px; }
      .top-news__list-item__date {
        margin-right: 12px;
        font-size: 12px;
        font-size: 1.2rem; }
      .top-news__list-item__category {
        margin-right: 0;
        padding: 1px 7px;
        font-size: 10px;
        font-size: 1rem; }
      .top-news__list-item__text {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        height: auto;
        white-space: normal; }
        .top-news__list-item__text a {
          display: -webkit-box;
          -webkit-box-orient: vertical;
          -webkit-line-clamp: 2; }
    .top-news__more {
      position: absolute;
      top: 15px;
      right: 0;
      width: 50px; }
      .top-news__more a:before {
        height: 15px; }
      .top-news__more img {
        width: auto;
        height: 13px;
        vertical-align: top; } }

/* サービス紹介
------------------------------------------------*/
.top-service {
  margin-bottom: 50px; }
  .top-service .top-box__shadow {
    padding: 70px 50px 50px; }
  .top-service__list-item {
    border-top: 1px solid #EAEAEA;
    margin-top: 50px;
    padding-top: 50px; }
    .top-service__list-item:after {
      content: "";
      display: block;
      clear: both; }
    .top-service__list-item__left {
      float: left;
      width: 32.78689%;
      overflow: hidden; }
      .top-service__list-item__left img {
        width: 100%;
        height: auto;
        -webkit-transition: all .8s;
        -o-transition: all .8s;
        transition: all .8s; }
      .top-service__list-item__left a:hover {
        opacity: 1; }
        .top-service__list-item__left a:hover img {
          -webkit-transform: scale(1.1);
          -ms-transform: scale(1.1);
          transform: scale(1.1); }
    .top-service__list-item__right {
      float: right;
      width: 62.5%; }
      .top-service__list-item__right .target {
        background: #0499CC;
        color: #fff;
        font-weight: bold;
        display: inline-block;
        padding: 5px 15px 4px;
        -webkit-border-radius: 100px;
        -moz-border-radius: 100px;
        -ms-border-radius: 100px;
        border-radius: 100px;
        margin-bottom: 13px;
        letter-spacing: 0.07rem; }
      .top-service__list-item__right .title {
        margin-bottom: 15px; }
        .top-service__list-item__right .title a {
          color: #005491;
          font-size: 30px;
          font-size: 3rem;
          letter-spacing: 0.2rem; }
      .top-service__list-item__right .text {
        margin-bottom: 27px; }

@media screen and (max-width: 999px) {
  .top-service .c-layout-contents {
    margin: 0 5px; }
  .top-service .top-box__shadow {
    padding-left: 20px;
    padding-right: 20px; } }

@media screen and (max-width: 599px) {
  .top-service {
    margin-bottom: 35px; }
    .top-service .top-box__shadow {
      padding: 35px 15px; }
    .top-service__list-item {
      margin-top: 20px;
      padding-top: 25px; }
      .top-service__list-item__left {
        float: none;
        width: auto;
        margin-bottom: 20px; }
      .top-service__list-item__right {
        float: none;
        width: auto; }
        .top-service__list-item__right .target {
          font-size: 11px;
          font-size: 1.1rem;
          padding: 3px 15px; }
        .top-service__list-item__right .title a {
          font-size: 22px;
          font-size: 2.2rem;
          line-height: 1.6;
          margin-bottom: 10px; }
        .top-service__list-item__right .text {
          margin-bottom: 20px; } }

/* 未来への取り組み
------------------------------------------------*/
.top-future {
  background: #005491;
  padding: 70px 0 50px;
  color: #fff;
}

.top-future.top-future__eng {
  padding: 70px 0;
}

  .top-future .top-section__title {
    color: #fff; }
    .top-future .top-section__title .sub {
      border-bottom: 2px solid #fff;
      margin-bottom: 55px; }
  .top-future .top-box {
    display: table;
    width: 100%; }
  .top-future__left {
    display: table-cell;
    vertical-align: top;
    width: 39.81481%; }
    .top-future__left__title {
      font-size: 30px;
      font-size: 3rem;
      color: #fff;
      margin-bottom: 15px; }
.top-future__left__title .u-br {
  color: #fff;
}
    .top-future__left__text {
      margin-bottom: 24px;
      line-height: 1.8;
      color: #fff;}

.top-future__left__text .u-br {
  color: #fff;
}
  .top-future__right {
    display: table-cell;
    vertical-align: top;
    width: 59.72222%; }
    .top-future__right__list:after {
      content: "";
      display: block;
      clear: both; }
    .top-future__right__list-item {
      float: left;
      text-align: center;
      width: 34.375%; }
      .top-future__right__list-item:last-child {
        float: right;
        width: 31.25%; }
      .top-future__right__list-item__image {
        width: 200px;
        margin: 0 auto 15px; }
        .top-future__right__list-item__image img {
          width: 100%;
          height: auto; }
      .top-future__right__list-item__text {
        font-weight: bold;
        color: #fff;
        }

.top-future__right__list-item__text .u-br {
  color: #fff;
}

@media screen and (max-width: 999px) {
  .top-future .top-box {
    display: block; }
  .top-future__left {
    display: block;
    width: 100%; }
    .top-future__left .u-br {
      display: inline; }
    .top-future__left .u-pcOnly {
      display: none !important; }
  .top-future__right {
    display: block;
    width: 100%; }
    .top-future__right__list {
      margin-bottom: 40px; }
    .top-future__right .u-spOnly {
      display: block !important;
      text-align: center; } }

@media screen and (max-width: 599px) {
  .top-future {
    padding: 35px 0; }
    .top-future .top-section__title .sub {
      border-bottom: 1.5px solid #fff;
      margin-bottom: 10px; }
    .top-future .top-box {
      display: block; }
    .top-future__left {
      display: block;
      width: auto; }
      .top-future__left__title {
        font-size: 20px;
        font-size: 2rem;
        margin-bottom: 10px; }
      .top-future__left__text {
        margin-bottom: 15px; }
    .top-future__right {
      display: block;
      width: auto; }
      .top-future__right__list {
        margin-bottom: 20px; }
        .top-future__right__list:after {
          content: "";
          display: block;
          clear: both; }
        .top-future__right__list-item {
          float: none;
          text-align: left;
          width: auto;
          display: table;
          margin-bottom: 20px; }
          .top-future__right__list-item:last-child {
            float: none;
            width: auto; }
          .top-future__right__list-item__image {
            margin-bottom: 0;
            display: table-cell;
            vertical-align: middle;
            width: 30%; }
            .top-future__right__list-item__image img {
              width: 100%;
              height: auto; }
          .top-future__right__list-item__text {
            display: table-cell;
            vertical-align: middle;
            padding-left: 10px; } }

/* バナー
------------------------------------------------*/
.top-banner {
  background: url(../images/top/top_bg02.png) no-repeat #cedee4;
  background-position: 50% 0;
  padding: 70px 0; }
  .top-banner__list {
    text-align: center; }
    .top-banner__list:after {
      content: "";
      display: block;
      clear: both; }
    .top-banner__list-item {
      display: inline-block;
      margin-right: 3.7037%;
      width: 31.11111%;
      text-align: center; }
      .top-banner__list-item:last-child {
        margin-right: 0; }
      .top-banner__list-item a {
        display: block;
        background: #fff;
        padding: 60px 0 55px; }
      .top-banner__list-item__image {
        margin: 0 auto 15px;
        width: 70px; }
        .top-banner__list-item__image img {
          width: 100%;
          height: auto; }
      .top-banner__list-item__text {
        color: #f2a600;
        font-size: 12px;
        font-size: 1.2rem;
        font-weight: bold; }
        .top-banner__list-item__text img {
          width: auto;
          height: 15px;
          display: block;
          margin: 0 auto 5px; }

@media screen and (max-width: 999px) {
  .top-banner__list-item {
    margin-right: 4%;
    width: 47%; } }

@media screen and (max-width: 599px) {
  .top-banner {
    padding: 35px 0; }
    .top-banner__list-item {
      display: block;
      margin-right: 0;
      margin-bottom: 20px;
      width: auto; }
      .top-banner__list-item:last-child {
        margin-bottom: 0; }
      .top-banner__list-item a {
        padding: 26px 40px 14px; }
      .top-banner__list-item__image img {
        width: 55px;
        height: auto; }
      .top-banner__list-item__text img {
        height: 17px;
        margin-bottom: 2px; } }

/* IE9.10.11対応 */
@media screen and (min-width: 0\0) {
  .top-service__list-item__right .target {
    padding: 6px 15px 3px 15px; }
  .c-main-container__top .top-btn__yellow a {
    padding: 18px 27px 16px 27px; } }

@media screen and (max-width: 599px) and (min-width: 0\0) {
  .top-service__list-item__right .target {
    padding: 5px 15px 1px 15px; }
  .c-main-container__top .top-btn__yellow a {
    padding: 16px 14px 12px 14px !important; } }
