@charset "UTF-8";

.spmt {
  margin-top: 56px !important;
}

/* --------------------------------------------------------------

                        コンテンツスタート

----------------------------------------------------------------*/
/* sp */
@media only screen and (max-width: 460px) {
  .sp-block-radio .mwform-radio-field {display: block;}
  .en-page #top-head #global-nav .sp-top-nav li {
    float: none;
    width: 100%;
  }
  #top-head #global-nav .sp-top-nav li:last-child {margin-bottom: 0;}
  .vc_col-sm-6 .mod-inquery_box .mod-inquery_box_inner > div.mod-icon-js {
    margin: 0 10%;
  }
  .vc_col-sm-12 .mod-inquery_box .mod-inquery_box_inner > div.mod-icon-js {
    margin: 0 auto;
    max-width: 100%;
}
}
@media only screen and (max-width: 768px) {
  .mod-container .mod-form td input.L,
  .mod-container .mod-form td input.M {width: 100%;}
  a {text-decoration: underline;}
  .mod-container .wp-pagenavi {
    margin: 0 -5px;
    padding: 10px 0!important;
  }
  .mod-container .wp-pagenavi a, .mod-container .wp-pagenavi span.pages, .mod-container .wp-pagenavi span.extend {
    padding: 6px 8px !important;
  }
  .fl {
    float: none !important;
  }

  .sp {
    display: block;
  }

  .pc {
    display: none;
  }

  /* /フォーム基本レイアウト */
  /* フォーム周りリセット */
  .sp-search input, .sp-search button, .sp-search textarea, .sp-search select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
  }

  .sp-search input, .sp-search button, .sp-search textarea, .sp-search select {
    margin: 0;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
  }

  /* /フォーム周りリセット */
  .sp-search input.textBox {
    width: 83%;
    height: 40px;
    padding: 4px;
    border: 1px solid #ccc;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background-color: #fff;
  }

  /* --------------------------------------------------------------
  ヘッダー
  ----------------------------------------------------------------*/
  .header-wrp {
    display: none;
  }

  #top-head,
  .inner {
    width: 100%;
    padding: 0;
    border-bottom: solid #b62038 3px;
  }
  #top-head h1 a,
  .inner h1 a {
    text-decoration: none;
  }
  #top-head h1 a img,
  .inner h1 a img {
    width: 215px;
    height: auto;
    float: left;
  }

  #top-head {
    top: 0;
    position: fixed;
    margin-top: 0;
    display: block;
    z-index: 101;
  }

  /* Fixed reset */
  #top-head.fixed {
    padding-top: 0;
    background: transparent;
  }

  #mobile-head {
    background: #fff;
    width: 100%;
    height: 50px;
    z-index: 999;
    position: relative;
  }

  #top-head.fixed .logo,
  #top-head .logo {
    position: absolute;
    left: 20px;
    top: 15px;
  }

  #global-nav {
    position: absolute;
    /* 開いてないときは画面外に配置 */
    top: -500px;
    background: #fff;
    width: 100%;
    text-align: center;
    -webkit-transition: .5s ease-in-out;
    -moz-transition: .5s ease-in-out;
    transition: .5s ease-in-out;
    z-index: -1;
    overflow: scroll;
  }

  #global-nav .sp-top-nav {
    list-style: none;
    position: static;
    right: 0;
    bottom: 0;
    padding: 23px 20px;
    overflow: hidden;
  }

  #global-nav .sp-top-nav li {
    float: left;
    position: static;
    width: 47%;
    margin-bottom: 15px;
  }

  #global-nav .sp-top-nav li:nth-child(2),
  #global-nav .sp-top-nav li:nth-child(4) {
    margin-right: 0;
    float: right;
  }

  #global-nav .sp-top-nav .last {
    background: none;
  }

  #top-head #global-nav .sp-top-nav li a,
  #top-head.fixed #global-nav .sp-top-nav li a {
    width: auto;
    display: block;
    color: #333;
    text-align: center;
    padding: 15px 0px;
    text-decoration: none;
    font-size: 11px;
    font-weight: bold;
    background-color: #fff;
    border: 1px solid #999999;
  }
.global-nav-01 a {background-image: url(../../assets/img/gnav/gnav01.png);}
.global-nav-02 a {background-image: url(../../assets/img/gnav/gnav02.png);}
.global-nav-03 a {background-image: url(../../assets/img/gnav/gnav03.png);}
.global-nav-04 a {background-image: url(../../assets/img/gnav/gnav04.png);}
.global-nav-05 a {background-image: url(../../assets/img/gnav/gnav05.png);}
.global-nav-01 a, .global-nav-02 a, .global-nav-03 a, .global-nav-04 a, .global-nav-05 a {
    background-repeat: no-repeat;
    background-position: 4px center;
    -webkit-background-size: 30px;
    background-size: 30px;
  }
  .sp-bottom-nav {
    overflow: hidden;
    clear: both;
    width: auto;
    padding: 0 20px;
  }
  .sp-bottom-nav ul {
    border-top: 1px #ccc solid;
  }
  .sp-bottom-nav li {
    border-bottom: 1px #ccc solid;
  }
  .sp-bottom-nav li a {
    text-decoration: none;
    color: #333;
    font-size: 14px;
    font-weight: bold;
    display: block;
    text-align: left;
    width: auto;
    padding: 15px;
    background-image: url(../../assets/img/arw01.png);
    background-repeat: no-repeat;
    background-position: right;
    -webkit-background-size: 6px;
    background-size: 6px;
    margin-right: 10px;
  }

  .sp-bottom-nav .rss-link {
        background-image: url(../../assets/img/index/icon-rss.png);
        -webkit-background-size: 22px 22px;
        background-size: 22px 22px;
    }

  .sp-search {
    margin-top: 20px;
    margin-bottom: 100px;
    width: auto;
    padding: 0 20px;
    display: none;
  }
  #top-head.open .sp-search {display: block;}
  .sp-search input {
    float: left;
    width: 83%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    height: 36px;
    font-size: 14px;
    padding-left: 10px;
  }
  .sp-search a {
    float: left;
    width: 15%;
    height: 40px;
    background-color: #b62038;
  }
  .sp-search a img {
    width: 15px;
    height: 18px;
    padding: 10px;
  }

    .nav-toggle_area {
        border: 1px solid #ccc;
        width: 30px;
        height: 30px;
        right: 5px;
        top: 10px;
        position: absolute;
    }

  #nav-toggle {
    display: block;
    position: absolute;
    right: 7px;
    top: 10px;
    width: 15px;
    height: 15px;
    cursor: pointer;
    z-index: 99999;
  }

  #nav-toggle span {
    display: block;
    position: absolute;
    height: 2px;
    width: 100%;
    background: #333;
    left: 0;
    -webkit-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
  }

  #nav-toggle span:nth-child(1) {
    top: 0;
  }

  #nav-toggle span:nth-child(2) {
    top: 4px;
  }

  #nav-toggle span:nth-child(3) {
    top: 8px;
  }

  /* #nav-toggle 切り替えアニメーション */
  .open #nav-toggle span:nth-child(1) {
    top: 3px;
    -webkit-transform: rotate(315deg);
    transform: rotate(315deg);
  }

  .open #nav-toggle span:nth-child(2) {
    width: 0;
    left: 50%;
  }

  .open #nav-toggle span:nth-child(3) {
    top: 3px;
    -webkit-transform: rotate(-315deg);
    transform: rotate(-315deg);
  }

  /* #global-nav スライドアニメーション */
  .open #global-nav {
    top: 56px;
    background-color: #f2f2f2;
    z-index: 100;
  }

  .top-head-line {
    height: 34px;
    width: 1px;
    display: block;
    background-color: #cccccc;
    position: absolute;
    right: 35px;
    top: 9px;
  }

  .header-open {
    overflow: hidden;
    height: 100%;
  }

  /* --------------------------------------------------------------
  グローバルナビ
  ----------------------------------------------------------------*/
  .global-nav-wrp {
    display: none;
  }

  /* --------------------------------------------------------------
  　メイン
  ----------------------------------------------------------------*/
  .bx-viewport {
    overflow: hidden !important;
  }

  a.bx-prev {
    display: none !important;
  }

  a.bx-next {
    display: none !important;
  }

  .bx-wrapper .bx-pager {
    bottom: -40px !important;
  }

  .mainVisual {
    width: auto;
    position: relative;
    margin: 56px 0 0 0;
  }
  .mainVisual .mask-left {
    display: none;
  }
  .mainVisual .mask-right {
    display: none;
  }

  .mainVisual-wrp {
    width: 100%;
    overflow: hidden;
    padding-bottom: 60px;
  }
  .en-page .mainVisual-wrp {
    padding-bottom: 0;
    margin-bottom: 60px;
  }

  /* --------------------------------------------------------------
  　コンテンツ
  ----------------------------------------------------------------*/
  .container {
    width: auto;
    overflow: hidden;
  }
  .container h3 {
    font-size: 20px;
    text-align: center;
    width: 270px;
    margin: 0 auto;
  }
  .container p.center {
    font-size: 14px;
    text-align: left;
    padding: 0 20px;
      margin-top: 10px;
  }

  .icon {
    display: none;
  }

  .sp-h3-01 {
    background-image: url(../../assets/img/icon-top01.png);
    background-repeat: no-repeat;
    background-position: 65px center;
    -webkit-background-size: 30px;
    background-size: 30px;
  }

  .sp-h3-02 {
    background-image: url(../../assets/img/icon-top02.png);
    background-repeat: no-repeat;
    background-position: 40px center;
    -webkit-background-size: 30px;
    background-size: 30px;
  }

  .sp-h3-03 {
    padding-top: 2px;
    padding-bottom: 2px;
    background-image: url(../../assets/img/icon-top03.png);
    background-repeat: no-repeat;
    background-position: 0px center;
    -webkit-background-size: 24px;
    background-size: 24px;
  }

    .top-system-wrp h3.sp-h3-02, .top-product-wp h3.sp-h3-03, .top-company-wrp h3.sp-h3-04 {
        font-size: 20px;
        margin: 0 auto;
        padding: 0 40px;
        width: auto;
        background-position: left center;
        display: inline-block;
        position: relative;
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
    }
  /* --------------------------------------------------------------
    お知らせ
  ----------------------------------------------------------------*/
  .mt40 {
    margin-top: 25px !important;
  }

  .btn-nav-list.mt40 {
    margin-top: 0px !important;
  }
.btn-nav {
    padding: 0 20px;
    overflow: hidden;
  }
.btn-nav li {
    width: 50%;
    float: left;
    margin-right: 0;
    padding-bottom: 0px;
    cursor: pointer;
    margin-bottom: 15px;
    background-image: url(../../assets/img/sp-line.png);
    background-repeat: no-repeat;
    background-position: left;
    -webkit-background-size: 1px;
    background-size: 1px;
  }
.btn-nav .btn-nav-line {
    background-image: url(../../assets/img/sp-line.png);
    background-repeat: no-repeat;
    background-position: right;
    -webkit-background-size: 1px;
    background-size: 1px;
  }
.btn-nav li p {
    font-size: 12px;
    text-align: center;
    font-weight: bold;
    border: none;
    padding: 3px 0 8px 0;
    line-height: 12px;
    border-bottom: 1px solid #cccccc;
    margin: 0 5px;
  }
.btn-nav li:last-child {
    width: 50%;
    float: left;
    margin-right: 0;
  }
.btn-nav .btn-nav-on {
    padding-bottom: 0;
    background-image: url(../../assets/img/sp-line.png);
    background-repeat: no-repeat;
    background-position: left;
    -webkit-background-size: 1px;
    background-size: 1px;
  }
.btn-nav .btn-nav-on p, .btn-nav li:hover p {
    border: none;
    border-bottom: 2px solid #b62038;
    padding: 3px 0 7px 0;
    background-color: #fff;
    color: #b62038;
    margin: 0 5px;
  }

  .btn-nav-list {
    margin: 0 20px;
  }

  .btn-nav-list dt, .btn-nav-list dd {
    float: left;
    padding-left: 0px;
      font-size: 14px;
      color: #333;
      margin: 0;
      line-height: 20px;
    background-image: url(../../assets/img/arw01.png);
    background-position: top right;
    background-repeat: no-repeat;
    -webkit-background-size: 6px;
    background-size: 6px;
    margin-top: 0px;
  }
    .btn-nav-list dd.arw-nolink {
        background-image: none;
    }
  .btn-nav-list dt a, .btn-nav-list dd a {
    text-decoration: none;
  }
  .btn-nav-list dt span, .btn-nav-list dd span {
    font-weight: bold;
    margin-right: 5px;
    float: left;
    margin-top: 12px;
    margin-left: 0px;
  }
    .btn-nav-list dd a span {
        float: none;
    }
  .btn-nav-list dt a span.categpry-name, .btn-nav-list dd a span.categpry-name {
    font-size: 10px;
    width: 90px;
    border: solid 1px #cccccc;
    background-color: #fff7f8;
    line-height: 10px;
    font-weight: normal;
    text-align: center;
    display: block;
    padding: 3px 0;
    margin-top: 12px;
    margin-left: 0px;
    height: auto;
  }
  .btn-nav-list dt {
    width: 100%;
    background-image: none;
    border-top: 1px solid #ccc;
  }
  .btn-nav-list dd {
    width: 100%;
    padding: 3px 10px 7px 0px;
    margin-right: 0px;
    margin-bottom: 0px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  .btn-nav-list dd a {
    margin-left: 0;
  }
  .btn-nav-list dd.pdf-icon {
    background-image: url(../../assets/img/icon-pdf.png);
    background-position: top right;
    background-repeat: no-repeat;
    -webkit-background-size: 15px;
    background-size: 15px;
  }
  .btn-nav-list dd.pdf-icon a {
    background-image: none;
  }

  dl.btn-nav-b-inner, dl.btn-nav-c-inner, dl.btn-nav-d-inner {
    display: none;
  }

    #more_topics, #more_release, #more_media {
        width: 70%;
        margin: 0 auto;
        display: none;
    }

    .news-button-area {
        width: 70% !important;
        padding-left: 0;
    }

    .news-button-area .news-button-2column {
        width: auto;
        float: none;
        margin-right: 0;
    }

    .btn-news-list_sp {
        margin: 0;
    }
    .btn-news-list_sp dt:first-child {
        border-top: none;
    }
    .btn-news-list_sp dd:last-child {
        border-bottom: 1px solid #ccc;
    }

    .btn-nav-list dt a span.category-name {
        margin-top: 12px;
    }

    .rss-button {
        position: relative;
        margin-bottom: 24px;
    }

    .rss-button::after {
        content: " ";
        background-image: url(../../assets/img/index/icon-rss.png);
        -webkit-background-size: 24px 24px;
        background-size: 24px 24px;
        position: absolute;
        top: -8px;
        right: 20px;
        width: 24px;
        height: 24px;
        border: none;
    }

    /* --------------------------------------------------------------
    お知らせ IR
    ----------------------------------------------------------------*/
    .ir-nav-list {
        margin: 20px 0 0 0;
    }
.ir-nav li:last-child {
        background-image: url(../../assets/img/sp-line.png);
        background-position: right;
        position: relative;
    }
.ir-nav li:last-child::before {
        content: " ";
        display: block;
        position: absolute;
        bottom: 2px;
        background-image: url(../../assets/img/sp-line.png);
        background-position: left;
        width: 1px;
        height: 17px;
    }

    .ir-news-link li {
        margin-top: 5px !important;
    }

    .ir-news-link .rss-button {
        padding-left: 35px;
    }

    .ir-news-link .rss-button::after {
        top: 0;
        right: 0;
    }

  /* --------------------------------------------------------------
    英語ページtop
  ----------------------------------------------------------------*/
  .entop-category-wrap {
    padding: 40px 20px;
    text-align: center;
  }
  .en-page .entop-category-wrap .sp-h3-02, .en-page .entop-category-wrap .sp-h3-04 {
    display: inline-block;
    width: auto;
    padding-left: 40px;
    background-position: left center;
  }
  .entop-category-list {margin-top: 40px;}
  .entop-category-list li {
    width: 48%;
    margin-right: 0;
    float: left;
    margin-bottom: 15px;
  }
  .entop-category-list p {
    width: 100%;
    font-size: 14px;
  }
  .entop-category-list li:nth-child(2n) {float: right;}
  .entop-category-list li:nth-child(3), .entop-category-list li:nth-child(5) {clear: both;}

  /* --------------------------------------------------------------
    システム開発
  ----------------------------------------------------------------*/
  .container.mt50 {
    margin-top: 44px !important;
  }

  .top-system-wrp.mt100 {
    margin-top: 0;
  }

  .top-system-wrp {
    background-repeat: no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
    overflow: hidden;
    padding-bottom: 56px;
  }

  .top-system-list.mt60 {
    margin-top: 20px !important;
  }

  .top-system-list {
    overflow: hidden;
    margin: 0 20px;
  }
  .top-system-list li {
    width: 48%;
    margin-right: 0;
    float: left;
    position: relative;
    overflow: hidden;
  }
  .top-system-list li:nth-child(2n) {
    float: right;
  }
  .top-system-list li p {
    position: absolute;
    padding: 5px 0;
    width: 100%;
    text-align: center;
    color: #fff;
    bottom: 0;
    left: 0;
    font-size: 14px;
    font-weight: bold;
    background-color: rgba(183, 33, 57, 0.8);
  }
  .top-system-list li a img:hover {
    -webkit-transform: none;
    transform: none;
  }
  .top-system-list li:hover p {
    background-color: rgba(183, 33, 57, 0.8);
  }

  /* --------------------------------------------------------------
    製品・ソリューション
  ----------------------------------------------------------------*/
  .container.mt80 {
    margin-top: 40px !important;
  }

  .top-product-list.mt60 {
    margin-top: 20px !important;
  }

  .top-product-list-sp {
    border-bottom: #eee 1px solid;
    margin-top: 20px;
  }
  .top-product-list-sp li {
    border-top: #eee 1px solid;
    overflow: hidden;
    padding: 15px 20px;
  }
  .top-product-list-sp li img {
    width: 30%;
    height: auto;
    float: left;
  }
  .top-product-list-sp .top-product-txt-sp {
    float: right;
    width: 65%;
    background-image: url(../../assets/img/arw01.png);
    background-position: right;
    background-repeat: no-repeat;
    -webkit-background-size: 6px;
    background-size: 6px;
    padding-right: 8px;
  }
  .top-product-list-sp .top-product-txt-sp h4 {
    font-size: 14px;
    color: #333;
    text-decoration: none;
    line-height: 17px;
    font-weight: bold;
    padding-bottom: 10px;
  }
  .top-product-list-sp .top-product-txt-sp p {
    color: #333;
    text-decoration: none;
    font-size: 12px;
    line-height: 17px;
  }

  /* --------------------------------------------------------------
    企業情報
  ----------------------------------------------------------------*/
  .top-company-wrp.mt80 {
    margin-top: 40px !important;
  }
  .top-company-wrp.mt80 .container.mt80 {
    margin-top: 45px !important;
    padding: 0 20px;
  }
  .top-company-wrp.mt80 .container.mt80 a.top-company-sp-btn {
    width: 200px;
    display: block;
    margin: 0 auto;
    border: 1px #b62038 solid;
    background-color: #fff;
    font-size: 14px;
    font-weight: bold;
    background-image: url(../../assets/img/arw01.png);
    background-position: 150px center;
    background-repeat: no-repeat;
    -webkit-background-size: 6px;
    background-size: 6px;
    padding: 15px 0;
    text-align: center;
    color: #333;
    text-decoration: none;
  }

  .top-company-wrp {
    background-position: top;
    background-repeat: repeat-x;
    -webkit-background-size: 500%;
    background-size: 500%;
    overflow: hidden;
  }

    .sp-company-icon {
        background-image: url(../../assets/img/icon-top04.png);
        background-repeat: no-repeat;
        background-position: 60px center;
        -webkit-background-size: 30px;
        background-size: 30px;
    }

  .top-company-list.mt60 {
      margin: 0 20px;
    margin-top: 30px !important;
  }

  .top-company-list {
    overflow: hidden;
  }
  .top-company-list li {
    width: 48%;
    margin-right: 0;
    float: left;
    margin-bottom: 15px;
  }
  .top-company-list li:nth-child(3n+4) {clear: none;}
  .top-company-list li:nth-child(odd) {clear: both;}
  .top-company-list li:nth-child(2n) {
    float: right;
  }
  .top-company-list li p {
    padding: 5px 0;
    width: 100%;
    color: #fff;
    font-size: 12px;
    background-color: rgba(183, 33, 57, 0.8);
  }
  .top-company-list li p img:hover {
    -webkit-transform: none;
    transform: none;
    -webkit-transition: 0s;
    transition: 0s;
  }
  .top-company-list li:nth-child(2n) {
    margin-right: 0;
    float: right;
  }
  .top-company-list li:hover p {
    background-color: rgba(183, 33, 57, 0.8);
    -webkit-transition: 0s;
    transition: 0s;
  }

  /* --------------------------------------------------------------
    採用情報
  ----------------------------------------------------------------*/
  .top-recruit-wrp {
    margin-top: 40px;
    padding: 45px 0;
  }

  /* --------------------------------------------------------------
    フッター
  ----------------------------------------------------------------*/
    .btn-top.mt100 {
        margin-top: 30px !important;
    }

    .btn-top {
        width: 33px;
        height: 14px;
        margin: 0 auto;
        overflow: hidden;
    }

    p.btn-top-txt {
        width: 100%;
        font-size: 14px;
        font-weight: bold;
        color: #fff;
        padding: 10px 0;
        text-align: center;
        background-color: #b9b9b9;
    }

    .footer-wrp {
        background: none;
        padding: 0;
        -webkit-tap-highlight-color: rgba(0,0,0,0);
    }
    .footer-wrp .footer-sp {
        width: auto;
    }
    .footer-wrp .footer-sp .footer-home {
        width: auto;
        border-bottom: 1px #ccc solid;
    }
    .footer-wrp .footer-sp .footer-home a {
        font-size: 13px;
        font-weight: bold;
        text-decoration: none;
        color: #333;
        text-align: left;
        display: block;
        padding: 15px 0px;
        margin: 0 20px;
    }
    .footer-wrp .footer-sp .acMenu02 dt {
        display: block;
        width: auto;
        cursor: pointer;
        border-bottom: 1px #ccc solid;
    }
    .footer-wrp .footer-sp .acMenu02 dt p {
        font-size: 13px;
        font-weight: bold;
        text-decoration: none;
        color: #333;
        text-align: left;
        display: block;
        padding: 15px 0px;
        background: url(../../assets/img/footer-off.png);
        background-position: right;
        background-repeat: no-repeat;
        -webkit-background-size: 12px;
        background-size: 12px;
        margin: 0 20px;
    }
    .footer-wrp .footer-sp .acMenu02 dt.open p {
        background: url(../../assets/img/footer-on.png);
        background-position: right;
        background-repeat: no-repeat;
        -webkit-background-size: 12px;
        background-size: 12px;
    }
    .footer-wrp .footer-sp .acMenu02 dd {
        display: none;
    }
    .footer-wrp .footer-sp .acMenu02 dd ul li {
        display: block;
        width: auto;
        cursor: pointer;
        border-bottom: 1px #ccc solid;
        background-color: #eee;
    }
    .footer-wrp .footer-sp .acMenu02 dd ul li a {
        font-size: 11px;
        font-weight: normal;
        text-decoration: none;
        color: #333;
        text-align: left;
        display: block;
        padding: 15px 0px;
        margin: 0 20px;
    }
    .footer-wrp .footer-sp .acMenu02 dd ul ul li {
        padding-left: 2.5em;
    }
    .footer-wrp .footer-sp .acMenu02 dd ul ul li:first-child {
        border-top: 1px solid #ccc;
    }
    .footer-wrp .footer-sp .acMenu02 dd ul ul .indent {
        display: block;
        float: left;
        margin-top: 15px;
    }

  /* --------------------------------------------------------------
    モジュール
  ----------------------------------------------------------------*/
  p.mod-title {
    width: auto;
  }

    .mod-text p {
        font-size: 14px;
    }

    .mod-list ul li {
        font-size: 14px;
        line-height: 1.5;
        margin-left: 0;
    }
    .mod-list ol li {
        font-size: 14px;
        line-height: 1.5;
    }
    .mod-list ol.brackets li {
        font-size: 14px;
        line-height: 1.5;
        margin-top: 20px;
        margin-left: 0;
    }

    .mod-notice p {
        padding-left: 20px;
        font-size: 14px;
        line-height: 1.5;
    }

  .mod-container {
    width: auto;
    overflow: hidden;
    padding: 0 20px;
  }

  .mod-container-visible {
    width: auto;
    padding: 0 20px;
  }

  .mod-heading h2 {
    font-size: 28px;
    background-position: left 10px;
    -webkit-background-size: 22px;
    background-size: 22px;
    padding-left: 29px;
    margin-top: 30px;
  }

    .mod-heading h2::before {
        -webkit-background-size: 22px;
        background-size: 22px;
        width: 22px;
        height: 24px;
        position: absolute;
        left: 0px;
        top: 10px;
    }

    .wpb_wrapper > .mod-heading:first-child h2 {
        margin-top: 0;
    }

  .mod-heading h3 {
    font-size: 24px;
    line-height: 30px;
    margin-top: 30px;
      padding-bottom: 10px;
  }
  .mod-heading .center {
    margin-top: 15px;
  }
  .mod-heading .center h3 {
    font-size: 22px;
    font-weight: bold;
    text-align: center;
    border-bottom: none;
    line-height: 1em;
  }
  .mod-heading .center .line {
    margin: 10px auto 0 auto;
  }
  .mod-heading h4 {
    font-size: 18px;
    font-weight: bold;
    color: #333;
    font-weight: bold;
    background-image: url(../../assets/img/mod/mod-heading-h4.png);
    background-repeat: no-repeat;
    background-position: left 7px;
    -webkit-background-size: 6px;
    background-size: 6px;
    margin-top: 20px;
    padding-left: 15px;
  }
  .mod-heading h4.dot {
    font-size: 15px;
    font-weight: bold;
    background-image: none;
    color: #333;
    border-left: none;
    border-bottom: dotted 1px #b62038;
    padding-bottom: 10px;
    padding-left: 0;
    margin-top: 40px;
  }

  .mod-flow dl dt {
    width: 30px;
    font-size: 16px;
    font-weight: bold;
    line-height: 20px;
    margin-top: 20px;
  }
  .mod-flow dl dd {
    font-size: 14px;
    line-height: 20px;
    width: 87%;
  }
  .mod-flow dl dd span {
    font-size: 16px;
  }

  .mod-2column {
    width: 100%;
    overflow: hidden;
  }
  .mod-2column .mod-2column-inner {
    margin-top: 20px;
    width: 49%;
    margin-right: 0;
    float: left;
  }
  .mod-2column .mod-2column-inner p {
    font-size: 11px;
    line-height: 20px;
  }
  .mod-2column .mod-2column-inner.mr0 {
    float: right;
  }

  .mod-2col_message {
    width: 100%;
    overflow: hidden;
  }
  .mod-2col_message .mod-2col_message-inner {
    margin-top: 20px;
    width: 48%;
    margin-right: 10px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    float: left;
  }
  .mod-2col_message .mod-2col_message-inner.mr0 {
    margin-right: 0;
  }

    .mod-2col_message .mod-2col_message-inner p {
        font-size: 14px;
        color: #333;
        line-height: 22px;
        text-align: center;
        margin-top: 10px;
    }

    .mod-2col_message .mod-2col_message-inner p span {
        font-size: 18px;
    }

  .mod-about_box {
    width: 100%;
    overflow: hidden;
    margin-top: 20px;
  }
  .mod-about_box .mod-about_box-inner {
    width: auto;
    height: 94px;
    border: solid #eee 1px;
    padding: 30px 40px;
  }
  .mod-about_box .mod-about_box_2-inner {
    width: auto;
    height: auto;
    margin-right: 0px;
    float: none;
    border: solid #eee 1px;
    padding: 30px 40px;
    margin-bottom: 20px;
  }
  .mod-about_box .mod-about_box_2-inner.mr0 {
    margin-right: 0;
  }

  .mod-backnumber ul li {
    padding: 10px;
  }
  .mod-backnumber ul li a {
    padding: 15px 0 15px 16px;
    display: block;
  }

  .mod-map-anchor {
  padding: 240px 20px 20px 20px;
  height: auto;
  background-position: center 20px;
  -webkit-background-size: 195px auto;
  background-size: 195px auto;
}

  .mod-map_anchor .mod-map_anchor_pc {
    display: none;
  }
  .mod-map_anchor .mod-map_anchor_sp_wrp {
    margin-top: 25px;
    display: block;
    width: 100%;
    background-color: #f3f3f3;
  }
  .mod-map_anchor .mod-map_anchor_sp {
    margin-top: 25px;
    width: 280px;
    height: 220px;
    margin: 0 auto;
    background-image: url(../../assets/img/mod/mod-map_anchor_sp.png);
    background-repeat: no-repeat;
    -webkit-background-size: 100%;
    background-size: 100%;
    position: relative;
  }
  .mod-map_anchor .mod-map-btn_sp a {
    font-size: 11px;
    background-image: url(../../assets/img/arw04.png);
    background-repeat: no-repeat;
    font-weight: bold;
    -webkit-background-size: 6px;
    background-size: 6px;
    display: block;
    border: 1px #b62038 solid;
    background-color: #fff;
    text-decoration: none;
    color: #333;
    text-align: center;
    width: 100px;
    background-position: 155px center;
    position: absolute;
  }
  .mod-map_anchor .mod-map-btn_sp dt {
    font-size: 11px;
    background-image: url(../../assets/img/arw04.png);
    background-repeat: no-repeat;
    font-weight: bold;
    -webkit-background-size: 6px;
    background-size: 6px;
    display: block;
    border: 1px #b62038 solid;
    background-color: #fff;
    text-decoration: none;
    color: #333;
    text-align: center;
    width: 100px;
    background-position: 155px center;
  }
  .mod-map_anchor .mod-map-btn_sp dd {
    display: none;
  }
  .mod-map_anchor .mod-map-btn_sp dd ul li a {
    font-size: 10px;
    font-weight: bold;
    -webkit-background-size: 6px;
    background-size: 6px;
    display: block;
    border: 1px #b62038 solid;
    background-color: #fff;
    text-decoration: none;
    color: #333;
    text-align: center;
    width: 90px;
    background-position: 155px center;
    position: static;
    border-top: none;
    padding: 5px;
    text-align: left;
  }
  .mod-map_anchor .mod-map-btn_sp a:hover {
    background-image: url(../../assets/img/arw05.png);
    background-color: #b62038;
    color: #fff;
  }
  .mod-map_anchor .mod-map-btn_sp a.sapporo {
    top: 30px;
    left: 35px;
  }
  .mod-map_anchor .mod-map-btn_sp a.hokuruku {
    top: 88px;
    left: 15px;
  }
  .mod-map_anchor .mod-map-btn_sp a.kyusyu {
    top: 130px;
    left: 5px;
  }
  .mod-map_anchor .mod-map-btn_sp a.touhoku {
    top: 75px;
    right: 5px;
  }
  .mod-map_anchor .mod-map-btn_sp a.kansai {
    bottom: 30px;
    left: 50px;
  }
  .mod-map_anchor .mod-map-btn_sp dl.tokyo-sp {
    position: absolute;
    top: 130px;
    right: 40px;
    z-index: 10;
  }

  .mod-map_column {
    width: auto;
    overflow: hidden;
  }
  .mod-map_column .mod-map_column-txt {
    width: auto;
    float: none;
  }
  .mod-map_column .mod-map_column-txt li {
    margin-bottom: 15px;
  }
  .mod-map_column .mod-map_column-txt li h4 {
    font-size: 18px;
    margin-top: 0px;
  }
  .mod-map_column .mod-map_column-txt li p {
    padding-left: 10px;
    margin-top: 8px;
    font-size: 14px;
  }
  .mod-map_column .mod-map_column-map {
    width: auto;
    float: none;
    margin-top: 25px;
    margin-bottom: 25px;
  }
  .mod-map_column .mod-map_column-map .googlemap {
    width: auto;
    background: #eaeaea;
  }
  .mod-map_column .mod-map_column-map .mod-button a.more {
    width: auto;
    margin-top: 1px;
    background-position: 300px center;
    margin-top: 10px;
  }

    .mod-button a {
        width: auto;
        margin: 0 auto;
        margin-top: 20px;
        font-size: 14px;
    }
  .mod-button .wpButtonConfirmSend, .mod-button .wpButtonBack {
    display: block;
    position: relative;
  }
  .mod-button .wpButtonConfirmSend {
    margin: 20px auto;
    min-width: 60%;
  }

    .mod-button a.pdf::after {
        top: 14px;
    }
    .mod-button a.pdf {
        width: auto;
        padding: 15px;
    }

    .mod-button a.size-s {
        width: 60%;
    }

    .mod-button a.size-m {
        width: 80%;
    }

    .mod-button a.size-l {
        width: 100%;
    }

  .mod-timelinen {
    width: auto;
    margin: 0 auto;
    margin-top: 20px;
  }
  .mod-timelinen h5 {
    clear: both;
    font-family: "Roboto Slab" , Garamond , "Times New Roman" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
    line-height: 28px;
    -moz-border-radius: 50px;
    -webkit-border-radius: 50px;
    border-radius: 50px;
    background-color: #b62038;
    text-align: center;
    font-size: 20px;
    color: #fff;
    margin-left: 0;
  }
  .mod-timelinen h5 span {
    font-size: 11px;
  }
  .mod-timelinen .timelinen-wrp {
    width: auto;
  }
  .mod-timelinen .timelinen-wrp .timelinen-left {
    width: 90%;
    border-left: 1px solid #eed6d6;
    border-right: none;
    position: relative;
    float: right;
  }
  .mod-timelinen .timelinen-wrp .timelinen-left h6 {
    width: auto;
    font-family: "Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
    padding: 10px 0px 3px 50px;
    color: #b62038;
    text-align: left;
    border-bottom: 1px solid #eed6d6;
  }
  .mod-timelinen .timelinen-wrp .timelinen-left h6 span {
    font-size: 12px;
  }
  .mod-timelinen .timelinen-wrp .timelinen-left h6.pt30 {
    padding-top: 10px !important;
  }
  .mod-timelinen .timelinen-wrp .timelinen-left p {
    padding: 0px 0px 10px 50px;
    font-size: 14px;
    color: #333;
    margin: 0;
    line-height: 24px;
    text-align: left;
      padding-top: 4px;
  }
  .mod-timelinen .timelinen-wrp .timelinen-left .parts {
    height: 12px;
    width: 12px;
    display: block;
    background-color: #eed6d6;
    position: absolute;
    top: 34px;
    left: -6px;
    -moz-border-radius: 14px;
    -webkit-border-radius: 14px;
    border-radius: 14px;
  }
  .mod-timelinen .timelinen-wrp .timelinen-right {
    width: 90%;
    border-left: 1px solid #eed6d6;
    position: relative;
    float: right;
  }
  .mod-timelinen .timelinen-wrp .timelinen-right h6 {
    width: auto;
    font-family: "Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
    padding: 10px 0px 3px 50px;
    font-size: 24px;
    color: #b62038;
    text-align: left;
    border-bottom: 1px solid #eed6d6;
  }
  .mod-timelinen .timelinen-wrp .timelinen-right h6 span {
    font-size: 11px;
  }
  .mod-timelinen .timelinen-wrp .timelinen-right p {
    padding: 0px 0px 10px 50px;
    font-size: 13px;
    color: #333;
    margin: 0;
    line-height: 24px;
    text-align: left;
      padding-top: 3px;
  }
  .mod-timelinen .timelinen-wrp .timelinen-right .parts {
    height: 12px;
    width: 12px;
    display: block;
    background-color: #eed6d6;
    position: absolute;
    top: 34px;
    left: -6px;
    -moz-border-radius: 14px;
    -webkit-border-radius: 14px;
    border-radius: 14px;
  }

  .mod-related_links {
    width: auto;
    border-top: #ccc 2px solid;
    border-bottom: #ccc 2px solid;
    margin-top: 25px;
  }
  .mod-related_links p {
    margin-top: 15px;
  }
  .mod-related_links ul {
    margin: 30px 0;
    width: auto;
    overflow: hidden;
  }
  .mod-related_links li {
    width: 48%;
    height: auto;
    float: left;
    position: relative;
    overflow: hidden;
    margin-right: 0;
    margin-bottom: 10px;
  }
  .mod-related_links li:nth-child(2n) {
    margin-right: 0%;
    float: right;
  }
  .mod-related_links li:nth-child(n+3) {margin-top: 20px; margin-bottom: 0}
  .mod-related_links li a img {
    -webkit-transition: -webkit-transform 0.3s ease-out;
    transition: transform 0.3s ease-out;
  }
  .mod-related_links li a p {
    position: absolute;
    padding: 10px 0;
    width: 100%;
    text-align: center;
    color: #fff;
    bottom: 0;
    left: 0;
    font-size: 11px;
    font-weight: bold;
    background-color: rgba(183, 33, 57, 0.8);
  }
  .mod-related_links ul li a:hover img {
    -webkit-transform: none;
    transform: none;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  .mod-related_links ul li a:hover p {
    background-color: rgba(61, 61, 61, 0.8);
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }

  .mod-ir_box dl {
    margin-top: 25px;
    width: auto;
  }
  .mod-inquery_box {
    width: 100%;
    margin-top: 25px;
  }
  .mod-inquery_box .mod-inquery_box_inner {
    width: 100%;
    margin-right: 0;
    border: solid 1px #eee;
    padding: 20px 0;
    float: left;
  }
  .mod-inquery_box .mod-inquery_box_inner .center {
    margin-top: 0px;
  }
  .mod-inquery_box .mod-inquery_box_inner .center h3 {
    margin-top: 0px;
    color: #333;
    font-size: 18px;
  }

  .mod-inquery_box .mod-inquery_box_inner p {
    text-align: center;
    font-size: 14px;
    margin-top: 15px;
  }
  .mod-inquery_box .mod-inquery_box_inner p span {
    margin: 0 auto;
    font-size: 15px;
    font-weight: bold;
    color: #b62038;
    display: inline-block;
    margin-top: 6px;
  }
    .mod-inquery_box .mod-inquery_box_inner p span::before {
        content: " ";
        -webkit-background-size: 25px;
        background-size: 25px;
        width: 25px;
        height: 25px;
        top: -2px;
        left: -30px;
    }
    .mod-inquery_box .mod-inquery_box_inner p span.mail::before {
        content: " ";
        width: 25px;
        height: 25px;
        top: -2px;
        left: -30px;
    }

  .mod-anchor {
    width: auto;
    margin: 0 auto;
    margin-top: 40px;
  }
  .mod-anchor li {
    width: 50%;
    float: left;
    margin-right: 0;
    padding-bottom: 0px;
    cursor: pointer;
    margin-bottom: 15px;
    background-image: url(../../assets/img/sp-line.png);
    background-repeat: no-repeat;
    background-position: left;
    -webkit-background-size: 1px;
    background-size: 1px;
    border-bottom: 1px #eee solid;
    padding-bottom: 10px;
  }
  .mod-anchor .btn-nav-line {
    background-image: url(../../assets/img/sp-line.png);
    background-repeat: no-repeat;
    background-position: right;
    -webkit-background-size: 1px;
    background-size: 1px;
  }
  .mod-anchor li a {
    font-size: 12px;
    text-align: center;
    font-weight: bold;
    border: none;
    line-height: 12px;
    margin: 0 5px;
    padding-bottom: 16px;
    background-position: center 90%;
  }
  .en-page .mod-anchor li a {display: block;}
    .mod-anchor li:nth-child(2n) a {
        border: none;
    }
    .mod-anchor li:nth-child(even) {
        background-image: none;
    }

    .anchor_2_bar .anchor_main {
        padding-bottom: 20px;
    }
    .anchor_2_bar ul {
        display: none;
    }
    .anchor_2_bar {
        position: relative;
    }
    .anchor_2_bar select {
        display: inline-block;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        padding: 10px;
        border: 1px solid #ccc;
    }

    .my-mod li{
        width: 50%;
        padding: 0 2px 0 3px;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
    }
    .my-mod li a {
        text-align: center;
        display: block;
        font-size: 12px;
        font-weight: bold;
        text-decoration: none;
        line-height: 1em;
        padding-bottom: 10px !important;
        padding-top: 8px;
        background-image: none;
        color: #333;
    }

    .my-mod li:last-child a {
        border-right: none;
    }


  .mod-table2 {
    width: auto;
  }
  .mod-table2 table {
    width: 100%;
  }
  .mod-table2 tr {
    border-bottom: dotted 1px #999;
    font-size: 14px;
  }
  .mod-table2 tr th {
    width: auto;
    font-weight: bold;
    padding: 10px;
    display: block;
    padding-bottom: 0;
  }
  .mod-table2 tr td {
    font-weight: normal;
    padding: 10px;
    display: block;
    padding-top: 0;
  }
  .mod-table2 .ind {
    display: block;
    font-weight: bold;
    width: auto;
  }
  .mod-table2 .ind:not(:first-child) {margin-top: 5px;}

    .mod-table4 table th, .mod-table4 table td {
        border-left: 0;
    }

    .mod-table6.factbook-table th:first-child {
        padding-top: 10px;
        padding-bottom: 0;
    }
    .mod-table6 tr th, .mod-table6 tr td {
        padding: 5px 5px;
    }

    .mod-table5 tr, .mod-table6 tr {
        border-bottom: 1px dotted #999;
    }

    .mod-table4 tr th, .mod-table4 tr td, .mod-table5 tr th, .mod-table5 tr td, .mod-table6 tr th, .mod-table6 tr td {
        width: 100% !important;
        display: block;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
    }

    .mod-table4 tr td:empty, .mod-table5 tr td:empty, .mod-table6 tr td:empty {
        display: none;
    }

    .mod-table5 tr th {
        padding-bottom: 10px;
    }

    .mod-table5 tr th, .mod-table5 tr td, .mod-table6 tr th, .mod-table6 tr td {
        padding: 7px 0;
    }

    .mod-table5 tr td a span.pdf::after, .mod-table6 tr td a span.pdf::after {
        position: absolute;
    }

    .mod-table5 tr td {
        text-align: left;
    }

    .mod-table5 tr td:last-child {
        padding-bottom: 10px;
    }

    .mod-table5.annreport-table tr td, .mod-table6.factbook-table tr td, .mod-table6.meeting-table tr td, .mod-table5.annreport-table tr th {
        width: auto;
    }

    .mod-table7 {
        width: auto;
        position: relative;
    }

    .mod-table7 table {
        word-break: normal;
        margin-top: 10px;
    }
    .mod-table7 tr th {
        white-space: nowrap;
    }

    .mod-table7 tr th, .mod-table7 tr td {
        padding: 12px;
        font-size: 14px;
    }

    .mod-table8 tr th, .mod-table8 tr td {
        width: 100%;
        padding: 10px 5px;
        display: block;
    }
    .mod-table8 tr td {
        padding-top: 0;
    }

    #rss-icon > a {
        background-size: 26px 26px;
        -webkit-background-size: 26px 26px;
        display: block;
        width: 26px;
        height: 26px;
    }

  .mod-form {
    width: 100%;
  }
  .mod-form table {
    width: 100%;
  }
  .mod-form tr {
    border-bottom: dotted 1px #999;
    font-size: 16px;
    text-align: right;
  }
  .mod-form tr th {
    width: auto;
    font-weight: bold;
    padding: 0;
    text-align: left;
    padding-top: 25px;
    display: block;
  }
  .mod-form tr th span {
    background-color: #b62038;
    color: #fff;
    font-size: 10px;
    padding: 5px;
  }
  .mod-form tr th.no-icon {
    padding-top: 20px;
    display: block;
  }
  .mod-form tr td {
    font-weight: normal;
    padding: 15px 0;
    font-size: 14px;
    display: block;
  }
  .mod-form tr td input, .mod-form tr td button, .mod-form tr td textarea, .mod-form tr td select {
    margin: 0;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: 1px #999 solid;
  }
  .mod-form td input:not([type="radio"]):not([type="checkbox"]) {
    font-size: 14px;
  }
  .mod-form tr td input.error {
    background-color: #fee5e9;
    border: 1px #b62038 solid;
  }
  .mod-form tr td select {
    width: 100%;
    padding: 10px;
    color: #333;
    font-size: 14px;
    background-image: url(../../assets/img/mod/select.png);
    background-position: right;
    background-repeat: no-repeat;
    -webkit-background-size: 46px;
    background-size: 46px;
  }
  .mod-form tr td textarea {
    font-size: 14px;
    padding: 10px;
  }
  .mod-form tr:last-child {
    border-bottom: dotted 1px #999;
  }
  .mod-form .radio {
    overflow: hidden;
    width: 100%;
    background-color: transparent;
    line-height: 19px;
    font-size: 16px;
    padding: 20px 0px;
  }
  .mod-form .radio .radio-inner {
    width: auto;
    float: none;
  }
  .mod-form .radio .radio-inner li {
    float: none;
    background-color: #f8f8f8;
    padding: 20px 0;
  }
  .mod-form .radio .radio-inner .radio-sp {
    width: 200px;
    margin: 0 auto;
  }
  .mod-form .radio .radio-inner li:last-child {
    background-color: transparent;
    margin-left: 0px;
  }
  .mod-form .radio p {
    margin-top: 0px;
  }
  .mod-form .radio p em {
    font-size: 11px;
    font-weight: normal;
    margin-left: 19px;
  }
  .mod-form .mod-button a {
      width: 100%;
    background-position: 220px center;
    margin: 40px auto 0 auto;
  }

    .mod-table table {
        border-top: none;
        border-bottom: none;
    }
    .mod-table table tr {
        border-bottom: none;
    }
    .mod-table table tr:last-child {
        border-bottom: none;
    }
    .mod-table table th {
        display: block;
        padding: 10px;
        background-color: #fff0f0;
        font-size: 14px;
        font-weight: bold;
        color: #333;
        line-height: 24px;
        border-right: none;
        width: auto;
    }
    .mod-table table td {
        display: block;
        padding: 10px;
        font-size: 14px;
    }

    .mod-table_s table th, .mod-table table td {
        padding: 8px;
        width: auto !important;
        line-height: 1.5;
    }

  .mod-thumnail {
    width: auto;
  }
    .mod-thumnail .height300, .mod-thumnail .height190, .mod-thumnail .height250, .mod-thumnail .height148 {
        height: auto;
    }
    .mod-thumnail .mod-thumnail-txt-wrp-height190 {
        width: auto;
    }

    .mod-thumnail p.mod-thumnail-txt {
        margin-top: 10px;
        font-size: 14px;
        line-height: 1.5;
    }

    .mod-thumnail-w300_disabled > span {
        display:block;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        padding: 50px;
        font-size:16px;
    }

    .mod-thumnail .mod-thumnail-item p {
        padding: 5px 0;
        font-size: 14px;
        line-height: 1.5;
    }

    .mod-ir-icon_link p {
        background-position: left 6px;
        -webkit-background-size: 45px;
        background-size: 45px;
    }
    .mod-ir-icon_link p a[target*="_blank"] {
        padding-left: 55px;
    }
    .mod-table3 {
        width: auto;
        position: relative;
        margin-top: 40px;
    }
    .mod-table3 table {
        font-size: 12px;
        margin-top: 10px;
    }
    .mod-table3 table th {
        font-size: 12px;
    }
    .mod-table3 table td {
        font-size: 12px;
    }

    .mod-table4 {
        width: auto;
    }

    .mod-table-inner {
        overflow-x: scroll;
    }

    p.scroll {
        background-image: url(../../assets/img/mod/mod-table3-01.png);
        background-position: left;
        background-repeat: no-repeat;
        -webkit-background-size: 25px;
        background-size: 25px;
        position: absolute;
        top: -30px;
        right: 0;
    }
    p.scroll span {
        background-image: url(../../assets/img/mod/mod-table3-02.png);
        background-position: right;
        background-repeat: no-repeat;
        -webkit-background-size: 18px;
        background-size: 18px;
        padding: 10px 25px 10px 30px;
        font-weight: bold;
        font-size: 10px;
    }

  /* --------------------------------------------------------------
    下層二層目
  ----------------------------------------------------------------*/
  .underlayer-wrp {
    margin-top: 0;
    width: 100%;
    background-repeat: no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
    padding: 20px 0;
  }

  .underlayer-wrp h3 {
    width: auto;
    padding-left: 56px;
    margin-top: 50px;
  }

  .underlayer-wrp .sp-h3-04 {
    background-position: 20px center;
    background-repeat:no-repeat;
  }

  .two-layers, .two-layers-wrp:before {
    background-repeat: no-repeat;
    background-position: top;
  }

  .two-layers-wrp {
    position: relative;
    z-index: 0;
    overflow: hidden;
    background: none;
  }

  .two-layers-wrp:before {
    content: "";
    z-index: -1;
    -webkit-filter: blur(0px);
    filter: blur(0px);
      background-color: rgba(255, 255, 255, 1);
    position: absolute;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    -webkit-background-size: cover;
    background-size: cover;
  }

    .two-layers-wrp h1 {
        font-size: 28px;
        text-align: center;
    }

    .two-layers-wrp h1::after {
        content: " ";
        display: block;
        background-image: url(../../assets/img/icon-top04.png);
        background-repeat: no-repeat;
        -webkit-background-size: 40px;
        background-size: 40px;
        width: 40px;
        height: 53px;
        margin: 0 auto;
        margin-top: 5px;
    }

  .breadcrumb {
    margin-top: 10px;
    padding: 0 20px;
  }
  .breadcrumb li {
    float: left;
      font-size: 12px;
  }
  .breadcrumb li a {
    text-decoration: none;
    color: #333;
  }
  .breadcrumb li a span {
    color: #b62038;
  }
  .breadcrumb li a span.choice {
    color: #333;
  }
    .two-layers-wrp h3 {
        padding: 30px 0 0;
    }

    .breadcrumb {
        margin-bottom: 0;
    }

    .mod-list ul li:first-child {
        margin-top: 20px;
    }
    .mod-list ul li {
        font-size: 14px;
        margin-top: 10px;
    }

  /* --------------------------------------------------------------
    下層三層目
  ----------------------------------------------------------------*/
  .underlayer-wrp {
    margin-top: 0;
    width: 100%;
    background-repeat: no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
    padding: 20px 0;
  }

   .three-layers-wrp h1 {
    text-align: left;
    width: auto;
    margin-top: 46px;
    padding: 40px 0 30px 0;
    padding-left: 18px;
       font-size: 24px;
  }

    .three-layers-wrp .sp-h3-04 {
        background-position: 20px center !important;
    }
    .three-layers-wrp h1::before {
        -webkit-background-size: 30px;
        background-size: 30px;
        width: 30px;
        height: 24px;
        background-position: center left;
        padding-left: 40px;
    }

  .three-layers-wrp:before {
    content: "";
    z-index: -1;
    -webkit-filter: blur(0px);
    filter: blur(0px);
    background-color: rgba(255, 255, 255, 1);
    position: absolute;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
      margin-top: 30px;
  }

  .three-layers .mod-timelinen.fl {
    overflow: hidden;
    padding-right: 0;
    border-right: none;
    padding-bottom: 0;
  }

  .mbthree {
    margin-top: 30px !important;
  }

    /* --------------------------------------------------------------
    下層四層目
    ----------------------------------------------------------------*/
    .underlayer-wrp {
        margin-top: 0;
        width: 100%;
        background-repeat: no-repeat;
        -webkit-background-size: cover;
        background-size: cover;
        padding: 20px 0;
    }

    .four-layers-wrp h1 {
        text-align: left;
        width: auto;
        margin-top: 46px;
        padding: 40px 0 30px 0;
        padding-left: 18px;
        font-size: 24px;
    }

    .underlayer-wrp .sp-h3-04.ir {
        background-position: 25px center !important;
        -webkit-background-size: 30px !important;
        background-size: 30px !important;
    }

    .four-layers, .four-layers-wrp:before {
        background-repeat: no-repeat;
        background-position: top;
    }
    .four-layers-wrp {
        position: relative;
        z-index: 0;
        overflow: hidden;
        background: none;
    }

    .four-layers-wrp h1::before {
        -webkit-background-size: 30px;
        background-size: 30px;
        width: 30px;
        height: 24px;
        background-position: center left;
        padding-left: 40px;
    }

    .four-layers-wrp:before {
        content: "";
        z-index: -1;
        -webkit-filter: blur(0px);
        filter: blur(0px);
        background-color: rgba(255, 255, 255, 1);
        position: absolute;
        width: 100%;
        height: 100%;
        margin: 0;
        padding: 0;
        margin-top: 30px;
    }

    .four-layers .mod-timelinen.fl {
        overflow: hidden;
        padding-right: 0;
        border-right: none;
        padding-bottom: 0;
    }

    .mbfour {
        margin-top: 30px !important;
    }
  }
}


