.underContents {
  padding-bottom: 150px; }
  @media only screen and (max-width: 768px) {
    .underContents {
      padding-bottom: 60px; } }

.tableBlockWrap {
  display: -webkit-box;
  display: -moz-box;
  display: box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -moz-box-align: start;
  -ms-flex-align: start;
  -webkit-align-items: flex-start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -moz-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  justify-content: flex-start; }
  @media only screen and (max-width: 768px) {
    .tableBlockWrap {
      display: block; } }
  .tableBlockWrap .tableBlock {
    width: 47.4%; }
    @media only screen and (max-width: 768px) {
      .tableBlockWrap .tableBlock {
        width: 100%; } }
    .tableBlockWrap .tableBlock:first-of-type {
      margin-right: auto; }
      @media only screen and (max-width: 768px) {
        .tableBlockWrap .tableBlock:first-of-type {
          margin-right: 0;
          margin-bottom: 15px; } }
    .tableBlockWrap .tableBlock dl {
      display: table;
      width: 100%;
      padding: 25px 0;
      border-bottom: 1px solid #231815; }
      @media only screen and (max-width: 768px) {
        .tableBlockWrap .tableBlock dl {
          padding: 15px 0; } }
      .tableBlockWrap .tableBlock dl:first-of-type {
        padding-top: 0; }
      .tableBlockWrap .tableBlock dl dt, .tableBlockWrap .tableBlock dl dd {
        display: table-cell;
        vertical-align: top;
        font-size: 16px;
        line-height: 1.8; }
        @media only screen and (max-width: 768px) {
          .tableBlockWrap .tableBlock dl dt, .tableBlockWrap .tableBlock dl dd {
            font-size: 13px; } }
      .tableBlockWrap .tableBlock dl dt {
        padding-left: 5px;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        -ms-box-sizing: border-box;
        -o-box-sizing: border-box;
        box-sizing: border-box;
        width: 38%; }
        @media only screen and (max-width: 768px) {
          .tableBlockWrap .tableBlock dl dt {
            padding-left: 0;
            width: 32%; } }

#company {
  margin-top: 95px;
  margin-bottom: 120px; }
  @media only screen and (max-width: 768px) {
    #company {
      margin-top: 30px;
      margin-bottom: 60px; } }

#group {
  background-color: #f7f8f8;
  padding: 80px 0; }
  @media only screen and (max-width: 768px) {
    #group {
      padding: 35px 0; }
      #group .inner {
        width: 90%; } }
  #group .groupCompanyWrap {
    margin-top: 75px;
    text-align: center;
    position: relative;
    width: 820px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 105px;
    padding-bottom: 125px; }
    @media only screen and (max-width: 768px) {
      #group .groupCompanyWrap {
        width: 100%;
        margin-top: 30px;
        max-width: 336px;
        padding-top: 50px;
        padding-bottom: 50px; }
        #group .groupCompanyWrap > img {
          width: 70%; } }
    #group .groupCompanyWrap .groupLink {
      width: 174px;
      background-repeat: no-repeat;
      background-position: center center;
      background-size: 100% auto;
      position: absolute;
      z-index: 3; }
      @media only screen and (max-width: 768px) {
        #group .groupCompanyWrap .groupLink {
          width: 72px; } }
      #group .groupCompanyWrap .groupLink img {
        width: 75%;
        -webkit-transition-property: opacity;
        -moz-transition-property: opacity;
        -ms-transition-property: opacity;
        -o-transition-property: opacity;
        transition-property: opacity;
        -webkit-transition-duration: 0.3s;
        -moz-transition-duration: 0.3s;
        -ms-transition-duration: 0.3s;
        -o-transition-duration: 0.3s;
        transition-duration: 0.3s;
        -webkit-transition-timing-function: ease;
        -moz-transition-timing-function: ease;
        -ms-transition-timing-function: ease;
        -o-transition-timing-function: ease;
        transition-timing-function: ease;
        -webkit-transition-delay: 0s;
        -moz-transition-delay: 0s;
        -ms-transition-delay: 0s;
        -o-transition-delay: 0s;
        transition-delay: 0s; }
        @media only screen and (max-width: 768px) {
          #group .groupCompanyWrap .groupLink img {
            width: 80%; } }
        
      #group .groupCompanyWrap .groupLink a {
        display: block; }
        @media only screen and (min-width: 960px) {
          #group .groupCompanyWrap .groupLink a:hover img {
            opacity: 0;
            filter: alpha(opacity=0); } }
      #group .groupCompanyWrap .groupLink#group1 {
        background-image: url("../images/company/en/group1_on.png");
        background-size: 75%;
        top: 60px;
        right: 150px; }
        @media only screen and (max-width: 768px) {
          #group .groupCompanyWrap .groupLink#group1 {
            background-image: none;
            top: 30px;
            right: 60px; } }
      #group .groupCompanyWrap .groupLink#group2 {
        background-image: url("../images/company/en/group2_on.png");
        background-size: 75%;
        top: 210px;
        right: 60px; }
        @media only screen and (max-width: 768px) {
          #group .groupCompanyWrap .groupLink#group2 {
            background-image: none;
            top: 95px;
            right: 25px; } }
      #group .groupCompanyWrap .groupLink#group3 {
        background-image: url("../images/company/en/group3_on.png");
        background-size: 75%;
        bottom: 205px;
        right: 90px; }
        @media only screen and (max-width: 768px) {
          #group .groupCompanyWrap .groupLink#group3 {
            background-image: none;
            bottom: 80px;
            right: 35px; } }
      #group .groupCompanyWrap .groupLink#group4 {
        background-image: url("../images/company/en/group4_on.png");
        background-size: 75%;
        bottom: 90px;
        right: 230px; }
        @media only screen and (max-width: 768px) {
          #group .groupCompanyWrap .groupLink#group4 {
            background-image: none;
            bottom: 30px;
            right: 93px;} }
      #group .groupCompanyWrap .groupLink#group5 {
        background-image: url("../images/company/en/group5_on.png");
        background-size: 75%;
        bottom: 90px;
        left: 230px; }
        @media only screen and (max-width: 768px) {
          #group .groupCompanyWrap .groupLink#group5 {
            background-image: none;
            bottom: 30px;
            left: 93px;} }
      #group .groupCompanyWrap .groupLink#group6 {
        background-image: url("../images/company/en/group6_on.png");
        background-size: 75%;
        bottom: 205px;
        left: 95px;}
        @media only screen and (max-width: 768px) {
          #group .groupCompanyWrap .groupLink#group6 {
            background-image: none;
            bottom: 80px;
            left: 37px; } }
      #group .groupCompanyWrap .groupLink#group7 {
        background-image: url("../images/company/en/group7_on.png");
        background-size: 75%;
       top: 210px;
       left: 60px;}
        @media only screen and (max-width: 768px) {
          #group .groupCompanyWrap .groupLink#group7 {
            background-image: none;
            top: 95px;
            left: 25px;} }
            
     #group .groupCompanyWrap .groupLink#group8 {
        background-image: url("../images/company/en/group8_on.png");
        background-size: 75%;
       top: 60px;
       left: 150px;}
        @media only screen and (max-width: 768px) {
          #group .groupCompanyWrap .groupLink#group8 {
            background-image: none;
            top: 30px;
            left: 60px; } }

/* modal */
.modalArea {
  display: none; }

#cboxClose {
  width: 20px;
  height: 20px;
  font-size: 0;
  background-image: url("../images/icon/navClose.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 100% auto; }
  @media only screen and (max-width: 768px) {
    #cboxClose {
      top: 20px;
      right: 20px; } }

.modalBox {
  display: -webkit-box;
  display: -moz-box;
  display: box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center; }
  .modalBox .modalInner {
    width: 1000px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    padding: 8% 5%; }
    @media only screen and (max-width: 768px) {
      .modalBox .modalInner {
        width: 300px;
        padding: 18% 5% 8%; } }

#access {
  padding-top: 120px; }
  @media only screen and (max-width: 768px) {
    #access {
      padding-top: 60px; } }
  #access .inner {
    max-width: 900px; }
  #access .pageTitleArea {
    margin-bottom: 75px; }
    @media only screen and (max-width: 768px) {
      #access .pageTitleArea {
        margin-bottom: 35px; } }
  #access .officeWrap .officeBlock .mapArea {
    margin-bottom: 40px; }
    @media only screen and (max-width: 768px) {
      #access .officeWrap .officeBlock .mapArea {
        margin-bottom: 30px; } }
    #access .officeWrap .officeBlock .mapArea .map {
      position: relative;
      width: 100%;
      padding-top: 56.25%; }
      #access .officeWrap .officeBlock .mapArea .map iframe {
        position: absolute;
        top: 0;
        right: 0;
        width: 100% !important;
        height: 100% !important; }
  #access .officeWrap .officeBlock .officeDetail .detailBlock {
    margin-top: 40px;
    font-size: 18px; }
    @media only screen and (max-width: 768px) {
      #access .officeWrap .officeBlock .officeDetail .detailBlock {
        font-size: 13px;
        margin-top: 30px; } }
    #access .officeWrap .officeBlock .officeDetail .detailBlock:first-of-type {
      margin-top: 0; }
    #access .officeWrap .officeBlock .officeDetail .detailBlock dl dt, #access .officeWrap .officeBlock .officeDetail .detailBlock dl dd {
      line-height: 1.6; }
    #access .officeWrap .officeBlock .officeDetail .detailBlock dl dt {
      font-weight: bold;
      margin-bottom: 5px; }
  #access .officeWrap .officeBlock#office1 .contact {
    display: -webkit-box;
    display: -moz-box;
    display: box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -moz-box-align: start;
    -ms-flex-align: start;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    -webkit-box-pack: start;
    -moz-box-pack: start;
    -ms-flex-pack: start;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; }
    @media only screen and (max-width: 768px) {
      #access .officeWrap .officeBlock#office1 .contact {
        display: block; } }
    #access .officeWrap .officeBlock#office1 .contact dl {
      width: 46%; }
      @media only screen and (max-width: 768px) {
        #access .officeWrap .officeBlock#office1 .contact dl {
          width: 100%; } }
      #access .officeWrap .officeBlock#office1 .contact dl:nth-child(2n+1) {
        margin-right: auto; }
      #access .officeWrap .officeBlock#office1 .contact dl:nth-child(n+3) {
        margin-top: 35px; }
      @media only screen and (max-width: 768px) {
        #access .officeWrap .officeBlock#office1 .contact dl:first-of-type {
          margin-bottom: 35px; } }
  #access .officeWrap .officeBlock#office2 {
    margin-top: 150px; }
    @media only screen and (max-width: 768px) {
      #access .officeWrap .officeBlock#office2 {
        margin-top: 65px; } }
