@import url("https://fonts.googleapis.com/css?family=Montserrat:300,400");
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, main, menu, nav, section, summary {
  display: block; }

article#wrap {
  padding-top: 0; }

header {
  width: 100%;
  background-color: #fff;
  position: fixed;
  z-index: 10; }
  header > div > div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    position: relative; }
    header > div > div p {
      width: 240px;
      padding: 13px 0;
      margin-bottom: 0;
      line-height: 1; }
      header > div > div p a {
        -webkit-transition: .5s;
        transition: .5s; }
        header > div > div p a:hover {
          opacity: .6;
          -webkit-transition: .5s;
          transition: .5s; }
    header > div > div nav {
      width: 100%;
      max-width: 700px;
      margin-left: 10px; }
      header > div > div nav > input#h_menu {
        display: none; }
      header > div > div nav > form {
        position: absolute;
        right: 0;
        top: 14px; }
        header > div > div nav > form input[type=text] {
          width: 0;
          position: absolute;
          top: -7px;
          right: 0px;
          opacity: 0;
          -webkit-transition: .5s;
          transition: .5s;
          border: none;
          font-size: 14px;
          background-color: #F1F2F4;
          background-image: url(/application/themes/nikkei_bpc/common/images/common/search_icon.png);
          background-repeat: no-repeat;
          background-position: 10px center; }
        header > div > div nav > form input[type=checkbox] {
          display: none; }
          header > div > div nav > form input[type=checkbox]:checked ~ span input[type=text] {
            opacity: 1;
            padding: 8px 8px 8px 30px;
            width: 210px;
            -webkit-transition: .5s;
            transition: .5s;
            -webkit-box-sizing: border-box;
                    box-sizing: border-box; }
          header > div > div nav > form input[type=checkbox]:checked ~ label {
            margin-top: 2px;
            background-image: none; }
            header > div > div nav > form input[type=checkbox]:checked ~ label:before, header > div > div nav > form input[type=checkbox]:checked ~ label:after {
              content: '';
              display: block;
              background: #666;
              height: 4px;
              width: 100%;
              -webkit-transform: rotate(45deg);
                      transform: rotate(45deg);
              margin-top: 7px; }
            header > div > div nav > form input[type=checkbox]:checked ~ label:after {
              margin-top: -4px;
              -webkit-transform: rotate(-45deg);
                      transform: rotate(-45deg); }
        header > div > div nav > form label {
          margin-right: 5px;
          position: relative;
          z-index: 5;
          cursor: pointer;
          -webkit-transition: .5s;
          transition: .5s;
          display: block;
          width: 23px;
          height: 23px;
          background-image: url(/application/themes/nikkei_bpc/common/images/common/search_icon.png);
          background-repeat: no-repeat; }
          header > div > div nav > form label:hover {
            opacity: .6;
            -webkit-transition: .5s;
            transition: .5s; }
      header > div > div nav > ul {
        padding-right: 50px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: space-between;
        font-size: 15px;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center; }
        header > div > div nav > ul > li > input[type=radio] {
          display: none; }
        header > div > div nav > ul > li label {
          width: 100%;
          padding: 16px 0;
          display: block;
          -webkit-box-sizing: border-box;
                  box-sizing: border-box; }
          header > div > div nav > ul > li label:hover {
            text-decoration: none; }
        header > div > div nav > ul > li:hover > label > a {
          position: relative; }
          header > div > div nav > ul > li:hover > label > a:after {
            content: "";
            display: block;
            height: 4px;
            width: 100%;
            background-color: #00559A;
            position: absolute;
            bottom: 0; }
        header > div > div nav > ul > li:hover > ul {
          display: block; }
          header > div > div nav > ul > li:hover > ul li a {
            padding-top: 20px;
            padding-bottom: 20px;
            opacity: 1;
            -webkit-transition: .3s;
            transition: .3s;
            height: auto; }
        header > div > div nav > ul > li:nth-child(5) ul {
          right: 0; }
        header > div > div nav > ul > li > ul {
          position: absolute;
          top: 47px;
          background-color: #E5EEF5; }
          header > div > div nav > ul > li > ul > li > a {
            padding-top: 0;
            padding-bottom: 0;
            padding-left: 20px;
            padding-right: 20px;
            height: 0;
            overflow: hidden;
            font-size: 14px;
            font-weight: bold;
            display: block;
            width: 100%;
            -webkit-box-sizing: border-box;
                    box-sizing: border-box;
            opacity: 0;
            -webkit-transition: .3s;
            transition: .3s;
            color: #333;
            text-decoration: none; }
            header > div > div nav > ul > li > ul > li > a:hover {
              background-color: #fff;
              color: #00559A;
              text-decoration: none; }

footer {
  padding: 0 10px;
  background-color: #F8F9F9; }
  footer > p.totop {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 15;
    display: none; }
    footer > p.totop a.totopBtn {
      padding-top: 15px;
      width: 60px;
      height: 40px;
      display: block;
      text-align: center;
      background-color: #00559A;
      -webkit-box-sizing: border-box;
              box-sizing: border-box;
      border-radius: 5px;
      -webkit-transition: .5s;
      transition: .5s; }
      footer > p.totop a.totopBtn:before {
        margin: 0 auto -20px;
        content: '';
        display: block;
        width: 10px;
        height: 10px;
        border-top: #fff solid 2px;
        border-left: #fff solid 2px;
        -webkit-transform: rotate(45deg);
                transform: rotate(45deg); }
      footer > p.totop a.totopBtn:hover {
        opacity: .5;
        -webkit-transition: .5s;
        transition: .5s; }
  footer > ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding-bottom: 30px; }
    footer > ul > li {
      width: 22%; }
      footer > ul > li h4 {
        font-weight: bold; }
        footer > ul > li h4 label {
          padding: 30px 0 20px;
          display: block; }
        footer > ul > li h4 + input[type=radio] {
          display: none; }
      footer > ul > li a {
        color: #333;
        text-decoration: none; }
      footer > ul > li ul {
        font-size: 14px; }
        footer > ul > li ul li {
          line-height: 1.8; }
          footer > ul > li ul li.top_hr {
            margin-top: 10px;
            padding-top: 10px;
            border-top: #D1D5DB solid 1px; }
          footer > ul > li ul li.f_sns {
            padding-top: 10px;
            display: -webkit-box;
            display: -ms-flexbox;
            display: flex;
            -webkit-box-align: center;
                -ms-flex-align: center;
                    align-items: center; }
            footer > ul > li ul li.f_sns a {
              margin-right: 10px;
              padding-top: 8px;
              display: block;
              width: 36px;
              height: 36px;
              -webkit-box-align: center;
                  -ms-flex-align: center;
                      align-items: center;
              background-color: #22222C;
              border-radius: 50%;
              text-align: center;
              -webkit-box-sizing: border-box;
                      box-sizing: border-box;
              -webkit-transition: .5s;
              transition: .5s; }
              footer > ul > li ul li.f_sns a img {
                height: 15px; }
              footer > ul > li ul li.f_sns a:hover {
                opacity: .5;
                -webkit-transition: .5s;
                transition: .5s; }
              footer > ul > li ul li.f_sns a:before {
                display: none; }
  footer > div {
    padding: 20px 0;
    width: 100%;
    background-color: #fff; }
    footer > div > div {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
      -webkit-box-pack: justify;
          -ms-flex-pack: justify;
              justify-content: space-between; }
      footer > div > div p {
        font-size: 12px;
        margin-bottom: 15px; }
        footer > div > div p a {
          -webkit-transition: 5s;
          transition: 5s; }
          footer > div > div p a:hover {
            opacity: .5;
            -webkit-transition: 5s;
            transition: 5s; }
        footer > div > div p img {
          margin-bottom: 10px;
          width: 240px; }
      footer > div > div ul {
        padding-right: 80px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: space-between;
        max-width: 690px;
        max-width: 680px;
        width: 100%;
        font-size: 14px;
        -webkit-box-sizing: border-box;
                box-sizing: border-box; }
        footer > div > div ul li a {
          text-decoration: none;
          color: #333; }

.top_speciality {
  background-color: #F1F2F4; }
  .top_speciality ul {
    padding-top: 50px;
    padding-bottom: 50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between; }
    .top_speciality ul li {
      max-width: 348px;
      width: 31%;
      background-color: #fff;
      position: relative; }
      .top_speciality ul li a {
        padding-bottom: 70px;
        display: block;
        text-decoration: none;
        -webkit-transition: .5s;
        transition: .5s; }
        .top_speciality ul li a:hover div {
          opacity: .5;
          -webkit-transition: .5s;
          transition: .5s; }
        .top_speciality ul li a div:first-child {
          margin-bottom: 30px;
          display: table;
          width: 100%; }
          .top_speciality ul li a div:first-child p {
            height: 300px;
            display: table-cell;
            text-align: center;
            vertical-align: middle; }
            .top_speciality ul li a div:first-child p img {
              max-width: 90%; }
        .top_speciality ul li a div:last-child p {
          margin: 0 30px;
          line-height: 1.5;
          color: #333;
          font-size: 15px; }
          .top_speciality ul li a div:last-child p:last-child {
            margin: 0;
            text-align: center;
            text-decoration: underline;
            color: #00559A;
            position: absolute;
            bottom: 30px;
            width: 100%;
            text-align: center; }
      .top_speciality ul li:nth-child(1) a div:first-child {
        background-color: #00559A; }
      .top_speciality ul li:nth-child(2) a div:first-child {
        background-color: #fff; }
      .top_speciality ul li:nth-child(3) a div:first-child {
        background-color: #CE2C2A; }

.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between; }

.wrap_width {
  max-width: 1230px;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }

main {
  padding-top: 47px; }
  main div#plan02, main div#plan01, main div#plan04 {
    display: none; }
  main div#plan02:target {
    display: table; }
    main div#plan02:target ~ #plan03 {
      display: none; }
  main div#plan01:target {
    display: table; }
    main div#plan01:target ~ #plan03 {
      display: none; }
  main div#plan04:target {
    display: block; }
    main div#plan04:target ~ #plan03 {
      display: none; }
  main div.mv_top {
/*     margin-bottom: 60px; */
    width: 100%;
    height: 480px;
    text-align: center;
    display: table;
    background-size: cover;
    background-position: center top; }
    main div.mv_top h1 {
      color: #fff;
      display: table-cell;
      font-size: 38px;
      font-family: serif;
      line-height: 1.6; }
    main div.mv_top.plan01 {
      background-image: url(/common/images/top/mv_top1.jpg); }
      main div.mv_top.plan01 h1 {
        vertical-align: middle; }

      main div.mv_top.plan02 h1 {
        padding-bottom: 30px;
        vertical-align: bottom;
        background: -webkit-gradient(linear, left top, left bottom, color-stop(1%, transparent), color-stop(55%, transparent), to(rgba(0, 0, 0, 0.75)));
        background: linear-gradient(to bottom, transparent 1%, transparent 55%, rgba(0, 0, 0, 0.75) 100%);
        filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#bf000000',GradientType=0 ); }
    main div.mv_top.plan03 {
      overflow: hidden;
      position: relative; }
      main div.mv_top.plan03 video {
        width: 100%;
        position: absolute;
        top: 50%;
        left: 0%;
        right: auto;
        margin-top: -25%;
        margin-right: -20%; }
    main div.mv_top.plan04 {
      background-image: url(/common/images/top/mv_top1.jpg); }
      main div.mv_top.plan04 h1 {
        vertical-align: middle; }
  main ul.slide_banner {
    max-width: 1200px;
    width: 100%;
    margin: -45px auto 50px; }
    main ul.slide_banner button.slick-arrow {
      padding: 0;
      overflow: hidden;
      width: 20px;
      height: 20px;
      border: none;
      border-top: #666 solid 1px;
      border-right: #666 solid 1px;
      text-indent: 100em;
      outline: none;
      cursor: pointer;
      -webkit-transform: rotate(45deg);
              transform: rotate(45deg);
      position: absolute;
      right: -20px;
      top: 50%;
      margin-top: -12px;
      background-color: transparent; }
    main ul.slide_banner button.slick-prev {
      -webkit-transform: rotate(-135deg);
              transform: rotate(-135deg);
      right: auto;
      left: -20px; }
    main ul.slide_banner .slick-slide a img {
      margin: 0 auto; }
    main ul.slide_banner .slick-slide.slick-active:before {
      display: none; }
  main section.list_news {
    padding-bottom: 50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
    main section.list_news div {
      width: 20%;
      text-align: center; }
      main section.list_news div h2 {
        font-size: 20px;
        margin-bottom: 20px; }
      main section.list_news div > a {
        padding: 10px 5px;
        text-decoration: none;
        display: inline-block;
        font-size: 14px;
        min-width: 100px;
        color: #00559A;
        border: #00559A solid 1px;
        border-radius: 20px;
        -webkit-transition: .5s;
        transition: .5s; }
        main section.list_news div > a:hover {
          background-color: rgba(0, 85, 154, 0.2);
          -webkit-transition: .5s;
          transition: .5s; }
    main section.list_news ul {
      padding-left: 10px; }
      main section.list_news ul li {
        margin-bottom: 20px; }
        main section.list_news ul li a {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          font-size: 14px;
          text-decoration: none;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          line-height: 1.4;
          -webkit-transition: .5s;
          transition: .5s; }
          main section.list_news ul li a:hover p {
            text-decoration: underline;
            -webkit-transition: .5s;
            transition: .5s; }
          main section.list_news ul li a time {
            font-size: 12px;
            color: #333; }
          main section.list_news ul li a span {
            margin: 0 20px;
            padding: 5px 0;
            color: #fff;
            font-size: 13px;
            min-width: 125px;
            text-align: center;
            display: block;
            background-color: #9EA5B4;
            border-radius: 20px; }
          main section.list_news ul li a p {
            color: #00559A;
            font-size: 15px; }
  main section.sol3core > div {
    padding: 40px;
    background-size: cover; }
    main section.sol3core > div.sol3ttl {
      padding: 60px 0;
      text-align: center;
      background-color: #F1F2F4; }
      main section.sol3core > div.sol3ttl h2 {
        margin-bottom: 30px;
        font-size: 30px; }
      main section.sol3core > div.sol3ttl p {
        font-size: 14px;
        color: #5E5E65; }
    main section.sol3core > div div {
      padding: 50px;
      width: 385px;
      text-align: center;
      -webkit-box-sizing: border-box;
              box-sizing: border-box;
      color: #fff;
      font-family: 'Montserrat', sans-serif; }
      main section.sol3core > div div h3 {
        padding: 20px 0 8px;
        font-size: 34px;
        font-weight: 300; }
      main section.sol3core > div div p.sol3text {
        padding: 20px 0;
        line-height: 1.5;
        font-size: 14px; }
      main section.sol3core > div div a {
        padding: 10px 25px;
        display: inline-block;
        font-size: 14px;
        text-decoration: none;
        color: #fff;
        border: #fff solid 1px;
        border-radius: 20px;
        -webkit-transition: .5s;
        transition: .5s; }
        main section.sol3core > div div a:hover {
          -webkit-transition: .5s;
          transition: .5s;
          background-color: rgba(255, 255, 255, 0.5); }

      main section.sol3core > div:nth-child(2) div {
        background-color: rgba(13, 50, 96, 0.9); }

      main section.sol3core > div:nth-child(3) div {
        margin-left: auto;
        color: #333;
        background-color: rgba(208, 212, 32, 0.9); }
        main section.sol3core > div:nth-child(3) div a {
          color: #333;
          border: #333 solid 1px; }

      main section.sol3core > div:nth-child(4) div {
        background-color: rgba(231, 79, 83, 0.9); }
  main section.case_study {
    padding: 80px 0;
    background-color: #00559A; }
    main section.case_study h2 {
      margin-bottom: 70px;
      text-align: center;
      font-size: 28px;
      color: #fff; }
    main section.case_study ul {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
      -webkit-box-pack: justify;
          -ms-flex-pack: justify;
              justify-content: space-between;
      width: 100%; }
      main section.case_study ul li {
        width: 23.8%;
        background-color: #fff; }
        main section.case_study ul li a {
          text-decoration: none;
          -webkit-transition: .5s;
          transition: .5s; }
          main section.case_study ul li a:hover img {
            opacity: .5;
            -webkit-transition: .5s;
            transition: .5s; }
          main section.case_study ul li a img {
            width: 100%;
            height: auto; }
          main section.case_study ul li a dl {
            padding: 20px;
            line-height: 1.5; }
            main section.case_study ul li a dl dt {
              font-size: 15px;
              font-weight: 800;
              margin-bottom: 15px;
              color: #00559A;
              text-decoration: underline; }
            main section.case_study ul li a dl dd {
              font-size: 14px;
              color: #333; }
            @media (max-width: 768px) {
    header {
      height: auto; }
      header > div > div p {
        padding-left: 15px;
        width: 60%; }
      header > div > div nav {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: end;
            -ms-flex-pack: end;
                justify-content: flex-end;
        max-width: 100px; }
        header > div > div nav > form {
          position: static; }
          header > div > div nav > form label {
            display: block;
            padding: 6px;
            background-position: center; }
          header > div > div nav > form input[type=checkbox]:checked ~ span {
            display: block; }
            header > div > div nav > form input[type=checkbox]:checked ~ span:before {
              content: "";
              position: fixed;
              top: 45px;
              left: 0;
              width: 100%;
              height: 100%;
              background-color: #E5EEF5;
              -webkit-transition: .5s;
              transition: .5s; }
            header > div > div nav > form input[type=checkbox]:checked ~ span input[type=text] {
              width: 90%;
              top: 60px;
              left: 5%;
              padding: 15px 15px 15px 40px;
              -webkit-box-sizing: border-box;
                      box-sizing: border-box;
              background-color: #fff; }
        header > div > div nav > input#h_menu ~ ul li label:after {
          content: '';
          display: block;
          width: 12px;
          height: 12px;
          border-right: #00559A solid 2px;
          border-bottom: #00559A solid 2px;
          -webkit-transform: rotate(45deg);
                  transform: rotate(45deg);
          position: absolute;
          right: 10px;
          top: 50%;
          margin-top: -12px;
          -webkit-transition: .5s;
          transition: .5s; }
        header > div > div nav > input#h_menu ~ ul li label.arrow_right:after {
          -webkit-transform: rotate(-45deg);
                  transform: rotate(-45deg); }
        header > div > div nav > input#h_menu:checked ~ ul {
          display: block;
          top: 45px;
          position: fixed;
          left: 0;
          width: 100%;
          height: 100%;
          background: #E5EEF5;
          overflow: auto; }
          header > div > div nav > input#h_menu:checked ~ ul li label {
            padding: 16px;
            display: block;
            position: relative; }
        header > div > div nav > label.sp_menu {
          padding: 10px; }
          header > div > div nav > label.sp_menu:before, header > div > div nav > label.sp_menu:after {
            content: '';
            display: block;
            width: 18px; }
          header > div > div nav > label.sp_menu:before {
            height: 4px;
            border-top: solid 2px #00559A;
            border-bottom: solid 2px #00559A; }
          header > div > div nav > label.sp_menu:after {
            content: '';
            height: 4px;
            border-bottom: solid 2px #00559A; }
        header > div > div nav > ul {
          display: none; }
          header > div > div nav > ul > li label a {
            padding: 15px 10px;
            position: relative;
            pointer-events: none; }
            header > div > div nav > ul > li label a:after {
              content: '';
              display: block;
              width: 10px;
              height: 10px;
              border-bottom: #00559A solid 1px;
              border-right: #00559A solid 1px;
              -webkit-transform: rotate(45deg);
                      transform: rotate(45deg);
              position: absolute;
              top: 50%;
              right: 20px;
              margin-top: -9px;
              -webkit-transition: .5s;
              transition: .5s; }
          header > div > div nav > ul > li:hover > label > a:after {
            width: 10px;
            height: 10px;
            background-color: transparent; }
          header > div > div nav > ul > li input[type=radio] {
            display: none; }
            header > div > div nav > ul > li input[type=radio]:checked ~ ul li a {
              padding-top: 16px;
              padding-bottom: 16px;
              opacity: 1;
              -webkit-transition: .3s;
              transition: .3s;
              height: auto; }
            header > div > div nav > ul > li input[type=radio]:checked + label a:after {
              -webkit-transform: rotate(-135deg);
                      transform: rotate(-135deg);
              margin-top: -3px;
              -webkit-transition: .5s;
              transition: .5s; }
            header > div > div nav > ul > li input[type=radio]:checked + label:after {
              -webkit-transform: rotate(-135deg) !important;
                      transform: rotate(-135deg) !important;
              margin-top: -4px !important;
              -webkit-transition: .5s;
              transition: .5s; }
          header > div > div nav > ul > li ul {
            position: static;
            background-color: #fff; }
            header > div > div nav > ul > li ul li a {
              padding-left: 10px;
              font-weight: normal;
/*               pointer-events: none; */}
              header > div > div nav > ul > li ul li a:before {
                content: '';
                display: inline-block;
                width: 6px;
                height: 6px;
                border-top: #00559A solid 1px;
                border-right: #00559A solid 1px;
                -webkit-transform: rotate(45deg);
                        transform: rotate(45deg);
                margin-right: 8px; }
          header > div > div nav > ul > li:hover ul li a {
            padding-top: 0px;
            padding-bottom: 0px;
            opacity: 0;
            -webkit-transition: 0s;
            transition: 0s;
            height: 0; }
    footer {
      padding: 0; }
      footer > p.totop {
        width: 100%;
        right: -2%;
        display: none; }
        footer > p.totop a.totopBtn {
          width: 96%; }
      footer > ul {
        padding-bottom: 0; }
        footer > ul li {
          width: 100%; }
          footer > ul li h4 {
            position: relative;
            padding: 0 10px; }
            footer > ul li h4 label {
              padding: 20px 0; }
            footer > ul li h4:after {
              content: '';
              display: block;
              width: 8px;
              height: 8px;
              margin-top: -8px;
              position: absolute;
              top: 50%;
              right: 3%;
              border-bottom: solid 2px #00559A;
              border-right: solid 2px #00559A;
              -webkit-transform: rotate(45deg);
                      transform: rotate(45deg); }
            footer > ul li h4 + input[type=radio] {
              display: none; }
              footer > ul li h4 + input[type=radio]:checked + ul li a {
                padding-top: 10px;
                padding-bottom: 10px;
                opacity: 1;
                height: auto;
                -webkit-transition: .5s;
                transition: .5s; }
              footer > ul li h4 + input[type=radio]:checked + ul li.f_sns {
                margin-top: 20px;
                padding-bottom: 30px; }
                footer > ul li h4 + input[type=radio]:checked + ul li.f_sns a {
                  padding-top: 9px;
                  padding-bottom: 0px;
                  height: 36px;
                  opacity: .8; }
          footer > ul li ul {
            background-color: #fff;
            padding: 0 10px; }
            footer > ul li ul li a {
              padding-top: 0;
              padding-bottom: 0;
              height: 0;
              opacity: 0;
              overflow: hidden;
              display: block;
              -webkit-transition: .5s;
              transition: .5s; }
              footer > ul li ul li a:before {
                content: '';
                display: inline-block;
                width: 6px;
                height: 6px;
                border-top: #00559A solid 1px;
                border-right: #00559A solid 1px;
                -webkit-transform: rotate(45deg);
                        transform: rotate(45deg);
                margin-right: 8px; }
            footer > ul li ul li.top_hr {
              border: none;
              margin-top: 0;
              padding-top: 0; }
            footer > ul li ul li.f_sns {
              height: 0; }
      footer > div {
        padding-bottom: 70px; }
        footer > div > div p {
          -webkit-box-ordinal-group: 3;
              -ms-flex-order: 2;
                  order: 2;
          width: 100%;
          padding: 10px;
          font-size: 11px; }
        footer > div > div ul {
          padding-right: 0;
          -webkit-box-ordinal-group: 2;
              -ms-flex-order: 1;
                  order: 1;
          width: 100%;
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -ms-flex-wrap: wrap;
              flex-wrap: wrap; }
          footer > div > div ul li {
            width: 50%; }
            footer > div > div ul li a {
              padding: 0 10px 30px;
              display: block; }
    .top_speciality ul {
      padding: 40px 0 10px; }
      .top_speciality ul li {
        width: 100%;
        max-width: 92%;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 20px; }
        .top_speciality ul li a {
          display: table;
          padding-bottom: 0; }
          .top_speciality ul li a > div:first-child {
            width: 40%;
            height: 150px;
            display: table-cell;
            vertical-align: middle;
            text-align: center; }
            .top_speciality ul li a > div:first-child p {
              height: auto;
              display: inline; }
              .top_speciality ul li a > div:first-child p img {
                width: 80%;
                height: auto; }
          .top_speciality ul li a > div:last-child {
            padding: 20px 15px;
            width: 60%;
            display: table-cell; }
            .top_speciality ul li a > div:last-child p {
              margin: 0;
              font-size: 14px; }
              .top_speciality ul li a > div:last-child p:last-child {
                padding-top: 5px;
                position: static;
                text-align: left; }
        main div.mv_top.plan03 video {
          width: 2000px;
          height: 130%;
          top: 50%;
          left: 50%;
          margin-top: -180px;
          margin-left: -1000px; }
      main div.mv_top h1 {
        height: 600px; }
        main ul.slide_banner button.slick-arrow {
          right: 15px;
          z-index: 10; }
        main ul.slide_banner button.slick-prev {
          left: 15px;
          z-index: 10; }
      main section.list_news {
        padding-left: 4%;
        padding-right: 4%;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap; }
        main section.list_news div {
          margin-bottom: 40px;
          width: 100%;
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          -webkit-box-pack: justify;
              -ms-flex-pack: justify;
                  justify-content: space-between; }
          main section.list_news div h2 {
            margin-bottom: 0; }
          main section.list_news div a {
            padding: 8px 5px; }
        main section.list_news ul {
          padding-left: 0;
          width: 100%; }
          main section.list_news ul li a {
            -ms-flex-wrap: wrap;
                flex-wrap: wrap; }
            main section.list_news ul li a span {
              font-size: 11px; }
            main section.list_news ul li a p {
              margin-top: 8px;
              width: 100%;
              line-height: 1.5; }
    main section.sol3core > div {
      padding: 100px 30px; }
      main section.sol3core > div.sol3ttl {
        padding: 30px 15px; }
        main section.sol3core > div.sol3ttl h2 {
          font-size: 26px;
          margin-bottom: 20px; }
        main section.sol3core > div.sol3ttl p {
          text-align: left;
          line-height: 1.5; }
      main section.sol3core > div div {
        width: 100%;
        padding: 50px 29px; }
        main section.sol3core > div div img {
          width: 40px;
          height: auto; }
        main section.sol3core > div div h3 {
          font-size: 22px; }
        main section.sol3core > div div p {
          font-size: 12px; }
          main section.sol3core > div div p.sol3text {
            font-size: 14px; }
      main section.case_study {
        padding: 50px 0 20px; }
        main section.case_study h2 {
          margin-bottom: 50px;
          font-size: 24px; }
        main section.case_study ul {
          padding: 0 30px;
          -webkit-box-sizing: border-box;
                  box-sizing: border-box; }
          main section.case_study ul li {
            margin-bottom: 20px;
            width: 100%; } }




header{
	top: 0;
	z-index: 100;
}
.breadListTop{
	padding-top: 15px;
}
section main p{
    margin-bottom: 1.5em;
}
section main p,section main li,section main dd,aside#subNav nav>ul>li,td{
line-height: 1.8;
}
.cont_style01 p {
font-size: 1.00rem;
margin-bottom: 5px;
}
.cont_style01 ul li:last-child em {
background-size: auto 50%;
}
.lnContact .btn02{
	padding: 20px 0;
}
.btn02.iconArrow::after {
margin-top: -8px;
}
.btn02.iconArrow::after {
margin-top: -14px;
}
.btn02 {
margin-bottom: 30px;
}

header > div > div nav > form input[type=text] {
top: -24px;
height: 0;
padding: 0;
}
header > div > div nav > form input[type=checkbox]:checked ~ span input[type=text] {
    height: auto;
    top: -10px;
}
@media (max-width: 768px){
header > div > div nav > form input[type=checkbox]:checked ~ span input[type=text] {
    height: auto;
    top: 70px;
}
header > div > div nav > input[type=checkbox]:checked ~ label.sp_menu:before {
    content: '';
display: block;
height: 4px;
width: 100%;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
margin-top: 7px;
border-bottom: none;
height: 0;
}
header > div > div nav > input[type=checkbox]:checked ~ label.sp_menu:after {
    margin-top: -2px;
-webkit-transform: rotate(-45deg);
transform: rotate(-45deg);
height: 0;
}
}
#wrap {
padding-top: 35px;
}
.page-template-book-list #wrap,.page-template-book-detail #wrap{
    padding-top: 35px;
}
@media screen and (max-width: 960px){
header {
    height: auto;
}
.page-template-works-list-temp #wrap,.page-template-book-list #wrap,.page-template-book-detail #wrap{
     padding-top:  45px;
}
}

table.tType02 {
border-top: #e0e0e0 solid 1px;
border-left: #e0e0e0 solid 1px;
}
.page-template-news-list #wrap,.page-template-news-detail #wrap{
 padding-top:  45px;
}

  main section.list_news01 {
    padding: 60px 0 50px;
    width: 100%;
    position: relative;
    z-index: 5;
    background-color: #fff; }
    main section.list_news01 > div {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex; }
      main section.list_news01 > div > div {
        width: 20%;
        text-align: center; }
        main section.list_news01 > div > div h2 {
          font-size: 20px;
          margin-bottom: 20px; }
        main section.list_news01 > div > div > a {
          padding: 10px 5px;
          text-decoration: none;
          display: inline-block;
          font-size: 14px;
          min-width: 100px;
          color: #00559A;
          border: #00559A solid 1px;
          border-radius: 20px;
          -webkit-transition: .5s;
          transition: .5s; }
          main section.list_news01 > div > div > a:hover {
            background-color: rgba(0, 85, 154, 0.2);
            -webkit-transition: .5s;
            transition: .5s; }
    main section.list_news01 ul {
        width: 80%;
      padding-left: 10px; }
      main section.list_news01 ul li {
        margin-bottom: 20px; }
        main section.list_news01 ul li a {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          font-size: 14px;
          text-decoration: none;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          line-height: 1.4;
          -webkit-transition: .5s;
          transition: .5s; }
          main section.list_news01 ul li a:hover p {
            text-decoration: underline;
            -webkit-transition: .5s;
            transition: .5s; }
          main section.list_news01 ul li a time {
            font-size: 12px;
            color: #333; }
          main section.list_news01 ul li a span {
            margin: 0 20px;
            padding: 5px 0;
            color: #fff;
            font-size: 13px;
            min-width: 125px;
            text-align: center;
            display: block;
            background-color: #9EA5B4;
            border-radius: 20px; }
          main section.list_news01 ul li a p {
            color: #00559A;
            font-size: 15px; }
@media (max-width: 768px) {
    main section.list_news01{
        padding: 30px 0 25px;
    }
    main section.list_news01 ul{
        width: 100%;
    }
      main section.list_news01 > div {
        padding-left: 4%;
        padding-right: 4%;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap; }
        main section.list_news01 > div > div {
          margin-bottom: 40px;
          width: 100%;
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          -webkit-box-pack: justify;
              -ms-flex-pack: justify;
                  justify-content: space-between; }
          main section.list_news01 > div > div h2 {
            margin-bottom: 0; }
          main section.list_news01 > div > div a {
            padding: 8px 5px; }
        main section.list_news01 > div ul {
          padding-left: 0;
          width: 100%; }
          main section.list_news01 > div ul li a {
            -ms-flex-wrap: wrap;
                flex-wrap: wrap; }
            main section.list_news01 > div ul li a span {
              font-size: 11px; }
            main section.list_news01 > div ul li a p {
              margin-top: 8px;
              width: 100%;
              line-height: 1.5; }
  main div.mv_top {
    height: 320px;
    }
}

.wrap_width p > a > img{
    max-height: 18px;
}
table.scrollTable {
  border: #e0e0e0 solid 1px;
  border-right: none;
}