@charset "utf-8";
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box
}
html {
    font-size: 62.5%;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
}
html,
body {
    width: 100%;
    height: 100%
}
body {
    line-height: 1.4;
    font-family: 'Open Sans', sans-serif;
    font-weight: 400;
    font-size: 1.6rem;
    color: #101010;
}
/*_:lang(x)::-ms-backdrop, body {
    font-family: "Segoe UI", Meiryo, sans-serif;
}*/

@media screen and (min-width:768px) {
    body {
        line-height: 1.5;
        font-size: 1.8rem
    }
}

img {
    display: block;
    margin: 0;
    width: 100%;
    height: auto;
    font-size: 0
}
@media screen and (min-width:768px) {
    img {
        width: auto;
        max-width: 100%;
    }
}

svg {
    width: 100%;
    height: 100%;
}
figure {
    display: block;
    margin: 0
}
picture {
    display: block;
    margin: 0
}
ul,
li {
    list-style: none
}
a, a:link a:visited {
    /*width: 100%;
    height: 100%;*/
    color: #EA5504;
    word-break: break-word;
    text-decoration: none;
}
a:hover {
    /*transition: color .1s ease, opacity .1s ease, background .1s ease;*/
}
h1, h2, h3, h4, h5 {
    margin: 0;
    font-weight: 400;
    font-size: 2.2rem
}
p {
    line-height: 1.6;
}
input,
textarea,
select {
    font-family:inherit;
    font-size:inherit;
    font-weight:inherit;
    border: none;
    outline: none;
    color: #2E2E2E;
}
/*to enable resizing for IE*/
input,
textarea,
select {
  *font-size:100%;
}

/* Basic Modules
---------------------------------------*/
/* Margin SP */
@media screen and (max-width : 767px) {
    .mt0 { margin-top: 0!important }
    .mt-5 { margin-top: .5rem!important }
    .mt1 { margin-top: 1rem!important }
    .mt1-5 { margin-top: 1.5rem!important }
    .mt2 { margin-top: 2rem!important }
    .mt3 { margin-top: 3rem!important }
    .mt4 { margin-top: calc(4rem/2)!important }
    .mt5 { margin-top: calc(5rem/2)!important }
    .mt6 { margin-top: calc(6rem/2)!important }
    .mt7 { margin-top: calc(7rem/2)!important }
    .mt8 { margin-top: calc(8rem/2)!important }
    .mt9 { margin-top: calc(9rem/2)!important }
    .mt10 { margin-top: calc(10rem/2)!important }
    .mt15 { margin-top: calc(15rem/2)!important }

    .mb0 { margin-bottom: 0!important }
    .mb1 { margin-bottom: 1rem!important }
    .mb2 { margin-bottom: 2rem!important }
    .mb3 { margin-bottom: 3rem!important }
    .mb4 { margin-bottom: calc(4rem/2)!important }
    .mb5 { margin-bottom: calc(5rem/2)!important }
    .mb6 { margin-bottom: calc(6rem/2)!important }
    .mb7 { margin-bottom: calc(7rem/2)!important }
    .mb8 { margin-bottom: calc(8rem/2)!important }
    .mb9 { margin-bottom: calc(9rem/2)!important }
    .mb10 { margin-bottom: calc(10rem/2)!important }
    .mb15 { margin-bottom: calc(15rem/2)!important }

    .ml0 { margin-left: 0!important }
    .ml1 { margin-left: 1rem!important }
    .ml2 { margin-left: 2rem!important }
    .ml3 { margin-left: 3rem!important }
    .ml4 { margin-left: calc(4rem/2)!important }

    .mr0 { margin-right: 0!important }
    .mr1 { margin-right: 1rem!important }
    .mr2 { margin-right: 2rem!important }
    .mr4 { margin-right: calc(4rem/2)!important }

    /* Padding */
    .pt0 { padding-top: 0!important }
    .pt1 { padding-top: 1rem!important }
    .pt2 { padding-top: 2rem!important }
    .pt3 { padding-top: 3rem!important }
    .pt4 { padding-top: calc(4rem/2)!important }
    .pt5 { padding-top: calc(5rem/2)!important }
    .pt6 { padding-top: calc(6rem/2)!important }
    .pt7 { padding-top: calc(7rem/2)!important }
    .pt8 { padding-top: calc(8rem/2)!important }
    .pt9 { padding-top: calc(9rem/2)!important }
    .pt10 { padding-top: calc(10rem/2)!important }
    .pt15 { padding-top: calc(15rem/2)!important }

    .pb0 { padding-bottom: 0!important }
    .pb1 { padding-bottom: 1rem!important }
    .pb2 { padding-bottom: 2rem!important }
    .pb3 { padding-bottom: 3rem!important }
    .pb4 { padding-bottom: calc(4rem/2)!important }
    .pb5 { padding-bottom: calc(5rem/2)!important }
    .pb6 { padding-bottom: calc(6rem/2)!important }
    .pb7 { padding-bottom: calc(7rem/2)!important }
    .pb8 { padding-bottom: calc(8rem/2)!important }
    .pb9 { padding-bottom: calc(9rem/2)!important }
    .pb10 { padding-bottom: calc(10rem/2)!important }
    .pb15 { padding-bottom: calc(15rem/2)!important }

    .pl0 { padding-left: 0!important }
    .pr0 { padding-right: 0!important }
}

/* Margin PC */
@media screen and (min-width : 768px) {
    .mt0 { margin-top: 0!important }
    .mt1 { margin-top: 1rem!important }
    .mt1-5 { margin-top: 1.5rem!important }
    .mt2 { margin-top: 2rem!important }
    .mt3 { margin-top: 3rem!important }
    .mt4 { margin-top: 4rem!important }
    .mt5 { margin-top: 5rem!important }
    .mt6 { margin-top: 6rem!important }
    .mt7 { margin-top: 7rem!important }
    .mt8 { margin-top: 8rem!important }
    .mt9 { margin-top: 9rem!important }
    .mt10 { margin-top: 10rem!important }
    .mt15 { margin-top: 15rem!important }

    .mb0 { margin-bottom: 0!important }
    .mb1 { margin-bottom: 1rem!important }
    .mb2 { margin-bottom: 2rem!important }
    .mb3 { margin-bottom: 3rem!important }
    .mb4 { margin-bottom: 4rem!important }
    .mb5 { margin-bottom: 5rem!important }
    .mb6 { margin-bottom: 6rem!important }
    .mb7 { margin-bottom: 7rem!important }
    .mb8 { margin-bottom: 8rem!important }
    .mb9 { margin-bottom: 9rem!important }
    .mb10 { margin-bottom: 10rem!important }
    .mb15 { margin-bottom: 15rem!important }

    .ml0 { margin-left: 0!important }
    .ml1 { margin-left: 1rem!important }
    .ml2 { margin-left: 2rem!important }
    .ml3 { margin-left: 3rem!important }
    .ml4 { margin-left: 4rem!important }

    .mr0 { margin-right: 0!important }
    .mr1 { margin-right: 1rem!important }
    .mr2 { margin-right: 2rem!important }
    .mr4 { margin-right: 4rem!important }

    /* Padding */
    .pt0 { padding-top: 0!important }
    .pt1 { padding-top: 1rem!important }
    .pt2 { padding-top: 2rem!important }
    .pt3 { padding-top: 3rem!important }
    .pt4 { padding-top: 4rem!important }
    .pt5 { padding-top: 5rem!important }
    .pt6 { padding-top: 6rem!important }
    .pt7 { padding-top: 7rem!important }
    .pt8 { padding-top: 8rem!important }
    .pt9 { padding-top: 9rem!important }
    .pt10 { padding-top: 10rem!important }
    .pt15 { padding-top: 15rem!important }

    .pb0 { padding-bottom: 0!important }
    .pb1 { padding-bottom: 1rem!important }
    .pb2 { padding-bottom: 2rem!important }
    .pb3 { padding-bottom: 3rem!important }
    .pb4 { padding-bottom: 4rem!important }
    .pb5 { padding-bottom: 5rem!important }
    .pb6 { padding-bottom: 6rem!important }
    .pb7 { padding-bottom: 7rem!important }
    .pb8 { padding-bottom: 8rem!important }
    .pb9 { padding-bottom: 9rem!important }
    .pb10 { padding-bottom: 10rem!important }
    .pb15 { padding-bottom: 15rem!important }

    .pl0 { padding-left: 0!important }
    .pr0 { padding-right: 0!important }
}

.mla { margin-left: auto; }
.mra { margin-right: auto; }

/* inner */
.inner {
    margin: 0 auto;
    padding: 0 6vw;
    width: 100%;
    max-width: 1280px;
}
@media screen and (min-width:768px) {
    .inner {
        padding: 0 3vw;
    }
}
@media screen and (min-width:1600px) {
    .inner {
        padding: 0;
    }
}

/* row */
.row {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.aic { align-items: center!important; }
.ais { align-items: flex-start!important; }
.aie { align-items: flex-end!important; }

.jcsb { justify-content: space-between!important; }
.jcs { justify-content: flex-start!important; }
.jce { justify-content: flex-end!important; }


/* Text-align */
.tal { text-align: left !important }
.tar { text-align: right !important }
.tac { text-align: center !important }
.tac > img {
    margin-left: auto;
    margin-right: auto;
}
.tac-pc { text-align: left !important }
@media screen and (min-width : 768px) {
    .tac-pc { text-align: center !important }
}

/* Vergical-align */
.vat { vertical-align: top !important }
.vab { vertical-align: bottom !important }
.vam { vertical-align: middle !important }

/* responsive */
.sp { display: block!important; }
.pc { display: none!important; }
.sp-dib { display: inline-block!important; }
.pc-dib { display: nline-block!important; }
.dib { display: inline-block!important; }
@media screen and (min-width : 768px) {
    .sp { display: none!important; }
    .pc { display: block!important; }
    .sp-dib { display: inline-block!important; }
    .pc-dib { display: inline-block!important; }
    .dib { display: inline-block!important; }
}

/* Tel
---------------------------------------*/
@media(min-width: 768px){
  a[href^="tel:"]{
    pointer-events: none;
    color: #2E2E2E;
    text-decoration: none;
  }
}

/* Animation
---------------------------------------*/
/* Scroll Animation */
.sca-fadein {
    opacity: 0;
    transition: opacity .5s ease, transform .5s ease;
    animation-delay: .2s;
}
.sca-fadein.is-show {
    opacity: 1;
}

.sca-fadein-up {
    opacity: 0;
    transition: opacity .5s ease, transform .5s ease;
    animation-delay: .2s;
    transform: translateY(20px);
}
.sca-fadein-up.is-show {
    opacity: 1;
    transform: translateY(0);
}


/* library */
@keyframes fadein {
  0% {
      opacity: 0;
  }

  100% {
      opacity: 1;
  }
}

@keyframes fadeinUp {
  0% {
    opacity: 0;
    transform: translateY(15px);
    transition: opacity .5s ease-in, transform .5s ease-in;
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@media screen and (min-width : 768px) {
    .header_logo {
        opacity: 0;
        animation-name: fadein;
        animation-duration: 1.2s;
        animation-delay: 0;
        animation-fill-mode: forwards;
    }
    .header_nav {
        opacity: 0;
        animation-name: fadein;
        animation-duration: 1.2s;
        animation-delay: 0;
        animation-fill-mode: forwards;
    }
}

/* wrapper
---------------------------------------*/
.wrapper {
    position: relative;
    /*padding-top: 53px; ヘッダー高さ */
    opacity: 0;
    animation-name: fadein;
    animation-duration: 1.2s;
    animation-delay: 0;
    animation-fill-mode: forwards;

}
@media screen and (min-width : 768px) {
    .wrapper {
        /*padding-top: 60px; ヘッダー高さ */
    }
}

/* header
---------------------------------------*/
.header {
    height: 60px;
    position: relative;
    background: rgba(255,255,255,.85);
    z-index: 99;
}
.header_inner {
    padding: 13px 5vw 13px 2vw;
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 100%;
}

@media screen and (min-width : 768px) {
    .header {
        height: 110px;
    }
    .header_inner {
        padding: 22px 1.5vw;
    }
}

/* header_logo */
.header_logo {margin: .5rem 0 0;}
.header_logo a {
    display: block;
    font-size: 0;
}
.header_logo_img {
    width: 46px;
    background: #fff;
    padding: .7rem;
}
.header_logo_mark {
    display: none;
    width: 36px;
    margin: 0 0 0 .5rem;
}
@media screen and (min-width : 768px) {
    .header_logo {
        margin: 0;
        opacity: 0;
    }
    .header_logo_img {
        width: 70px;
        padding: 1rem;
    }
    .header_logo_mark {
        width: 50px;
        margin: 0 0 0 1.5rem;
    }
}

/* トップページとaboutusトップはロゴマークのみ */
.home .header_logo_img,
.aboutus_index .header_logo_img {
    display: none;
}
.home .header_logo_mark,
.aboutus_index .header_logo_mark {
    display: block;
}

/* header_nav
---------------------------------------*/
/* header_nav_btn */
.header_nav_btn {
    width: 22px;
    height: 22px;
    cursor: pointer;
    z-index: 100;
    transform: translateX(0);
    transition: transform .5s;
    margin: 5px 0 0!important;
}

/* header_nav_btn_lines */
.header_nav_btn_lines {
    position: relative;
    width: 22px;
    height: 18px;
    cursor: pointer;
    z-index: 100;
    transform: translateX(0);
    transition: transform .5s;
    margin: .1rem auto 0;
}
.header_nav_btn_lines span {
    display: inline-block;
    box-sizing: border-box;
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #EA5504;
    transition: all .4s;
}
.header_nav_btn_lines span:nth-of-type(1) {
    top: 0;
}
.header_nav_btn.is-active .header_nav_btn_lines span:nth-of-type(1) {
    top: -5px;
    transform: translateY(12px) rotate(-45deg);
}
.header_nav_btn_lines span:nth-of-type(2) {
    top: 8px;
}
.header_nav_btn.is-active .header_nav_btn_lines span:nth-of-type(2) {
    opacity: 0;
}
.header_nav_btn_lines span:nth-of-type(3) {
    bottom: 0;
}
.header_nav_btn.is-active .header_nav_btn_lines span:nth-of-type(3) {
    top: 11px;
    transform: translateY(-4px) rotate(45deg);
}

.header_nav_btn.is-active {
    padding: 0;
}
/*.header_nav_btn.is-active .header_nav_btn_lines span {
    background-color: #35BEF4;
}*/
.header_nav_btn.is-active .header_nav_btn-txt {
    display: none;
}

@media(min-width: 768px){
    .header_nav_btn {
        display: none;
    }
}

/* header_nav SP */
@media(max-width: 767px){
    .header_nav {
        position: absolute;
        top: 60px;
        left: 0;
        background: #ECE7E3;
        width: 100%;
        height: calc(100vh - 60px);
        padding: 30px;
        opacity: 0;
        z-index: -1;
        visibility: hidden;
        transition: opacity .3s ease, z-index .3s ease, visibility .3s ease;
    }
    .header_nav.is-open {
        opacity: 1;
        z-index: 99;
        visibility: visible;
    }
    .header_nav_list a {
        display: inline-block;
        padding: 3px;
        margin: 10px 0;
        font-size: 2.5rem;
        position: relative;
    }
    .header_nav_list_sub {
        margin: 0 0 10px;
    }
    .header_nav_list_sub a {
        font-size: 2rem;
        padding: 3px 3px 3px 30px;
        margin: 5px 0;
    }
    .header_nav_list_sub a::before {
        content: "";
        display: block;
        width: 16px;
        height: 2px;
        background: #FFB187;
        position: absolute;
        top: 19px;
        left: 0;
    }
}

/* header_nav PC */
@media(min-width: 768px){
    .header_nav_list {
        display: flex;
        padding: 10px 10px 0;
        margin: 0 0 0 0;
    }
    .header_nav_list li {
        margin: 0 20px;
        position: relative;
        text-align: center
    }
    .header_nav_list li a {
        display: block;
        padding: 2px 0 10px;
        font-size: 2.0rem;
        position: relative;
    }
    .header_nav_list li a::before {
        content: "";
        display: block;
        position: absolute;
        bottom: 0;
        left: 50%;
        width: 0;
        height: 2px;
        background: #EA5504;
        transition: .2s ease-out;
    }
    .header_nav_list li:hover > a:before,
    .header_nav_list li > a.is-current:before {
        left: 0;
        width: 100%;
    }
    .header_nav_list_sub {
        position: absolute;
        top: 42px;
        left: -150%;
        margin: auto;
        background: #ECE7E3;
        width: 400%;
        padding: 30px 25px 25px;
        opacity: 0;
        z-index: -1;
        visibility: hidden;
        transition: opacity .3s ease, z-index .3s ease, visibility .3s ease;
    }
    .header_nav_list_sub li {
        margin: 10px 0;
    }
    .header_nav_list_sub li a {
        display: inline-block;
    }

    /* 第3階層メニュー */
    .header_nav_list > li > a:hover + .header_nav_list_sub,
    .header_nav_list_sub:hover {
        opacity: 1;
        z-index: 99;
        visibility: visible;
    }
}

/* breadcrumb
---------------------------------------*/
.breadcrumb {
    position: relative;
    width: 100%;
    z-index: 2;
    margin: 0;
    padding: 20px 2vw;
}
.breadcrumb ul {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    line-height: 1.2;
}
.breadcrumb li {
    padding: 0 11px 0 0;
    color: #2E2E2E;
    line-height: 2;
    font-size: 1.4rem;
}
.breadcrumb li a {
    display: inline-block;
}
.breadcrumb li a:hover {
    text-decoration: underline;
}
.breadcrumb li+li::before {
    content: '';
    display: inline-block;
    vertical-align: middle;
    width: 13px;
    height: 5px;
    margin: 2px 8px 2px 0!important;
    border-top: solid 1px #B2B2B2;
    transform: rotate(-65deg);
    position: static;
    border-radius: 0;
    top: inherit;
    left: inherit;
    background: none;
}
.breadcrumb li:first-child {
    padding-right: 0;
}
.breadcrumb li:first-child a {
    padding: 2px 0 0 34px;
    background: url(/assets/images/common/icon_home.svg) no-repeat 0 0;
    background-size: 22px;
    font-size: 0;
    line-height: 26px;
}

@media screen and (max-width : 767px) {
    .breadcrumb {
        display: none;
        height: 72px;
    }
}

/* pagetop
---------------------------------------*/
.pagetop {
    width: 40px;
    height: 40px;
    position: fixed;
    bottom: 10px;
    right: 10px;
    background: url(/assets/images/common/pagetop.svg) no-repeat 0 0;
    background-size: 100%;
    cursor: pointer;
    visibility: hidden;
    opacity: 0;
    transition: opacity .2s ease-in-out, visibility .2s ease-in-out;
}
.pagetop svg .cls-1 {
    fill:#fff;
}
.pagetop svg .cls-2 {
    fill:#b2b2b2;
}
.pagetop.is-show {
    visibility: visible;
    opacity: 1;
}

@media screen and (min-width : 768px) {
    .pagetop {
        display: block;
        bottom: 1.8vw;
        right: 1.8vw;
    }
    /*.pagetop.is-bottom {
        bottom: 80px;
    }*/
}

/* footer
---------------------------------------*/
.footer {
    position: relative;
    padding: 5rem 4vw 3rem;
}
.footer_links {
    margin: 0;
}
.footer_links li {
    margin: 12px 0;
}
.footer_links a {
    font-size: 1.8rem;
}
.footer_links a:hover {
    text-decoration: none;
    text-decoration: underline;
}
.footer_logo {
    margin: 20px 0 10px;
    font-size: 2.0rem
}
.footer_logo img {
    width: 100%;
}
.footer_address {
    margin: 0;
    font-size: 1.4rem;
}
.footer_policies {
    margin: 25px 0;
}
.footer_policies a {
    font-size: 1.4rem;
}
.footer_policies a:hover {
    text-decoration: underline;
}
.copyright {
    margin: 2rem 0 0;
    font-size: 1.0rem;
}

@media screen and (min-width : 1280px) {
    .footer {
        padding: 8rem 2vw 8rem;
    }
    .footer_links {
        margin: 0;
    }
    .footer_links ul {
        display: flex;
        justify-content: space-between;
        margin: 3px -25px 0 0;
    }
    .footer_links li {
        margin: 0 25px;
        padding: 0;
    }
    .footer_row {
        display: flex;
        justify-content: space-between;
        flex-flow: row-reverse;
        align-items: center;
    }
    .footer_logo {
        margin-top: 0;
        font-size: 3.2rem
    }
    .footer_address {
        font-size: 1.6rem;
    }
    .footer_policies {
        display: flex;
        margin: 25px 0 10px;
    }
    .footer_policies > li {
        margin: 0 3rem 0 0;
    }
    .footer_policies a {
        font-size: 1.6rem;
    }
    .copyright {
        font-size: 1.6rem;
    }
}


/* contents
---------------------------------------*/
.page_container {
    position: relative;
    z-index: 0;
}
.main {
    position: relative;
    z-index: 0;
}

@media screen and (min-width : 768px) {
    .page_container {
        padding: 0;
    }
    .page_container.is-wide {
        padding: 0;
    }

}

.main_contents {
    padding: 0;
}

@media screen and (min-width : 768px) {
    .main_contents {
        padding: 0;
    }
}

@media screen and (max-width : 768px) {
    .main_contents {
        transition: transform .4s ease-in-out;
    }
    .main_contents.is-slide {
        transform: translateX(90vw);
    }
}

/* Parts
---------------------------------------*/
/* link */
.main_contents a {
    display: inline-block;
    text-decoration: underline;
}
.main_contents a:hover {
    text-decoration: none;
}

.main_contents a.arrow {
    display: inline-block;
    margin: 2px 0;
    padding: 0 0 0 25px;
    background: url(/assets/images/common/icon_link.svg) no-repeat 0 6px;
}

.blank {
    display: inline-block;
    position: relative;
}
.blank::after {
    content: "";
    display: inline-block;
    width: 10px;
    height: 10px;
    background: url(/assets/images/common/icon_blank.svg) no-repeat 0 0;
    background-size: 10px;
    vertical-align: top;
    margin: 10px 2px 0 4px;
}


/* page_head */
.page_head {
    margin: 5rem 3vw 5rem;
}
.page_ttl {
    font-size: 4.0rem!important;
    font-weight: 400!important;
    text-align: center!important;
    position: relative;
    margin: 0 0 4rem;
    padding: 0 0 3.5rem;
}
.page_ttl::after {
    content: "";
    display: block;
    width: 32px;
    height: 4px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    background: linear-gradient(90deg, #F6AB00 0%, #F6AB00 50%, #EA5504 50%, #EA5504 100%);
}
.page_ttl_sub {
    font-size: 2.8rem;
}

@media screen and (min-width : 768px) {
    .page_head {
        margin: 0 0 6rem;
        padding: 4rem 0 0;
    }
    .page_ttl {
        font-size: 5.6rem!important;
        padding: 0 0 3.5rem;
    }
    .page_ttl_sub {
        font-size: 4rem;
    }
}

/* H */
.main_contents h1 {
    font-size: 3.2rem;
    font-weight: 400;
    line-height: 1.5;
    margin: 10px 0 20px;
    opacity: 0;
    animation-name: fadein;
    animation-duration: 1.2s;
    animation-delay: 0;
    animation-fill-mode: forwards;
}

.main_contents h2 {
    font-weight: 400;
    line-height: 1.5;
    font-size: 2.8rem;
    margin: 5rem 0 3.5rem;
    padding: 0 0 2.5rem;
    position: relative;
}
.main_contents h2::after {
    content: "";
    display: block;
    width: 32px;
    height: 2px;
    position: absolute;
    bottom: 0;
    left: 0;
    background: linear-gradient(90deg, #F6AB00 0%, #F6AB00 50%, #EA5504 50%, #EA5504 100%);
}
.main_contents h2.tac::after {
    left: 0;
    right: 0;
    margin: auto;
}

.main_contents h2.larger {
    font-size: 3.2rem;
    padding: 0;
    text-align: center;
}
.main_contents h2.larger::after {
    display: none;
}

.main_contents h3 {
    font-size: 2.4rem;
    font-weight: 400;
    line-height: 1.5;
    margin: 2.5rem 0 1rem;
}
.main_contents h4 {
    font-size: 2.2rem;
    font-weight: 400;
    line-height: 1.5;
    margin: 2.5rem 0 1rem;
}

@media screen and (min-width : 768px) {
    .main_contents h1 {
        font-size: 4.5rem;
        font-weight: 400;
        line-height: 1.4;
        margin: 0 0 3.0rem;
    }
    .main_contents h2 {
        font-size: 3.6rem;
        font-weight: 400;
        line-height: 1.5;
        margin: 6.0rem 0 3.5rem;
    }
    .main_contents h3 {
        font-size: 2.8rem;
        font-weight: 400;
        line-height: 1.5;
        margin: 3.0rem 0 2.0rem;
    }
    .main_contents h4 {
        font-size: 2.4rem;
        font-weight: 400;
        line-height: 1.5;
        margin: 3.0rem 0 2.0rem;
    }
}

/* p */
.main_contents p + p {
    margin-top: 1rem;
}

/* Text */
.large_txt {
    font-size: 1.8rem;
}
@media screen and (min-width : 768px) {
    .large_txt {
        font-size: 2.2rem;
    }
}

.large_txt + .large_txt {
    margin-top: 3rem;
}

.small_txt {
    font-size: 1.4rem;
}
@media screen and (min-width : 768px) {
    .small_txt {
        font-size: 1.6rem;
    }
}

.normal_txt {
    font-weight: 400;
}

.highlight_txt {
    color: #EA5504;
}

/* note */
.note {
    font-size: 1.4rem;
    color: #776B63;
}
@media screen and (min-width : 768px) {
    .note {
        font-size: 1.5rem;
    }
}

/* インデント */
.indent {
    padding-left: 1.2rem;
    text-indent: -1.2rem;
}

/* テキストリンク */
.main_contents a {
    color: #EA5504;
    text-decoration: none;
    transition: color .5s ease-in-out, opacity .5s ease-in-out;
}
.main_contents a:hover {
    text-decoration: underline;
}

/* リンク画像 */
.main_contents a img {
    display: block;
    transition: opacity .3s ease-in-out;
}
.main_contents a:hover img {
    opacity: .7;
}

/* 丸リンク */
.main_contents .link01 {
    position: relative;
    display: inline-block;
    margin: 30px 0;
    padding: 0 74px 0 20px;
    line-height: 50px;
    text-align: right;
    z-index: 1;
    line-height: 1.4;
}
.main_contents .link01:hover {
    text-decoration: none;
}
.main_contents .link01::before { /* 丸 */
    content:
    '';
    display: block;
    position:
    absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    right: 0;
    width:50px;
    height:50px;
    background: rgba(234,85,4,.2);
    border-radius:25px;
    z-index: -1;
    transition:.3s ease-out;
}
.main_contents .link01:hover::before { /* hoverで丸が広がる */
    width: 100%;
}
.main_contents .link01::after { /* 矢印 */
    position: absolute;
    content: '';
    display: block;
    top: 0;
    bottom: 0;
    margin: auto;
    right: 28px;
    width: 31px;
    height: 4px;
    background: url(/assets/images/common/icon_arrow.svg) no-repeat 0 0;
}

@media screen and (min-width : 768px) {
    .main_contents .link01 {
        display: inline-block;
        margin: 15px 0;
    }
}

/* 丸リンク　戻る */
.main_contents .link02 {
    position: relative;
    display: inline-block;
    margin: 30px 0;
    padding: 0 20px 0 74px;
    line-height: 50px;
    text-align: left;
    z-index: 1;
}
.main_contents .link02:hover {
    text-decoration: none;
}
.main_contents .link02::before { /* 丸 */
    content:'';
    display: block;
    position:absolute;
    top: -1px;
    left: 0;
    width:50px;
    height:50px;
    background: rgba(234,85,4,.2);
    border-radius:25px;
    z-index: -1;
    transition:.3s ease-out;
}
.main_contents .link02:hover::before { /* hoverで丸が広がる */
    width: 100%;
}
.main_contents .link02::after { /* 矢印 */
    position: absolute;
    content: '';
    display: block;
    top: 1.2em;
    left: 28px;
    width: 31px;
    height: 4px;
    background: url(/assets/images/common/icon_arrow.svg) no-repeat 0 0;
    transform: scale(-1, 1);
}

@media screen and (min-width : 768px) {
    .main_contents .link02 {
        display: inline-block;
        margin: 15px 0;
    }
}

/* ボタン */
.main_contents .btn01 {
    display: block;
    font-size: 1.8rem;
    color: #fff;
    text-align: center;
    background: #EA5504;
    border: solid 1px #EA5504;
    margin: 1rem 2rem;
    padding: 1.5rem 2rem;
    transition: border-radius .3s ease, background .6s ease, color .6s ease;
}
.main_contents .btn01:hover {
    border-radius: 50px;
    background: #fff;
    color: #EA5504;
    text-decoration: none;
}
.main_contents .btn01.blank::after {
    background: url(/assets/images/common/icon_blank_wh.svg) no-repeat 0 0;
    transition: background .3s ease;
}
.main_contents .btn01.blank:hover:after {
    background: url(/assets/images/common/icon_blank.svg) no-repeat 0 0;
}

@media screen and (min-width : 1025px) {
    .main_contents .btn01 {
        display: inline-block;
        font-size: 2.0rem;
        padding: 25px 35px;
        margin: 10px 0;
        min-width: 308px;
    }
    .main_contents .btn01 + .btn01 {
        margin-left: 10px;
    }
}

/* リスト */
.main_contents ul {
    margin: 18px 0;
}
.main_contents ul.is-style-default li, .main_contents ul:not([class]) li {
    position: relative;
    padding: 0 0 0 2.6rem;
    margin: 12px 0;
}
.main_contents ul.is-style-default li::before, .main_contents ul:not([class]) li::before {
    content: "";
    display: block;
    width: 6px;
    height: 6px;
    border-radius: 6px;
    background: #776B63;
    position: absolute;
    top: .55em;
    left: 0;
}

/* ol */
.main_contents ol:not([class]) {
    margin: 18px 0;
    counter-reset: count 0;
}
.main_contents ol:not([class]) li {
    position: relative;
    padding: 0 0 0 2.6rem;
    margin: 16px 0;
    counter-reset: item 0;
}
.main_contents ol:not([class]) li::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    content: counter(count) ". ";
    counter-increment: count 1;
}

/* 表組み */
.main_contents table {
    border-collapse: collapse;
    margin: 20px 0;
    border-top: solid 2px #776B63;
    border-bottom: solid 2px #776B63;
}
.main_contents table th, table td {
    border: solid 1px #776B63;
    padding: 15px 20px;
    line-height: 1.8;
}
.main_contents table th {
    font-weight: 600;
    border-left: none;
}
.main_contents table td {
    border-right: none;
}

/* figcaption */
figcaption {
    margin: 1.5rem 0 0;
}


/* 404 Not Found
---------------------------------------*/
.page_container {
    padding: 0;
}
.page_container .main {
    padding-top: 0;
}
.notfound_ttl {
    font-size: 3.0rem;
    font-weight: 700;
    margin: 0 0 20px;
}
.notfound_blk {
    margin: 0 0 30px;
}

@media screen and (min-width : 768px) {
    .notfound_ttl {
        font-size: 4.8rem;
        margin: 30px 0 40px;
   }
    .notfound_blk {
        margin: 0 0 30px;
    }
}

/* Modal
---------------------------------------*/
.lightbox .lb-image {
    border: none;
    border-radius: 0;
}

@media screen and (max-width : 767px) {
    .lb-nav a.lb-next, .lb-nav a.lb-prev {
        opacity: 1;
        background-size: 20px;
    }
    .lb-nav a.lb-next {
        background-position: 94% 48%;
    }
    .lb-nav a.lb-prev {
        background-position: 6% 48%;
    }
    .lb-data .lb-close {
        width: 40px;
        height: 40px;
    }
    .lb-dataContainer {
        position: absolute;
        top: -50px;
        left: 0;
        right: 0;
    }
    .lb-data .lb-number {
        margin-bottom: 0;
        padding-top: 1.2em;
        font-size: 12px;
        color: #999;
    }
}

@media screen and (min-width : 768px) {
    .lb-nav a.lb-next, .lb-nav a.lb-prev {
        opacity: 1;
        background-size: 40px;
    }
    .lb-nav a.lb-next {
        margin-right: -80px;
    }
    .lb-nav a.lb-prev {
        margin-left: -80px;
    }
    .lb-data .lb-close {
        width: 40px;
        height: 40px;
    }
    .lb-dataContainer {
        position: absolute;
        top: -50px;
        left: 0;
        right: 0;
    }
    .lb-data .lb-number {
        margin-bottom: 0;
        padding-top: 1.2em;
        font-size: 12px;
        color: #999;
    }
}

/* Projects
---------------------------------------*/
.main_contents .projects_inner h2 {
    margin-left: 6vw;
    margin-right: 6vw;
}
.main_contents .projects_list > li {
    margin: 0 0 6rem;
}
.main_contents .projects_list_txt {
    padding: 2rem 6vw 0;
}
.main_contents .projects_ttl {
    font-weight: 400;
    line-height: 1.5;
    font-size: 2.4rem;
    margin: 0;
    padding: 0 0 1rem;
    position: relative;
}
.main_contents .projects_ttl::after {
    /* content: ""; */
    display: block;
    width: 32px;
    height: 2px;
    position: absolute;
    bottom: 0;
    left: 0;
    background: linear-gradient(90deg, #F6AB00 0%, #F6AB00 50%, #EA5504 50%, #EA5504 100%);
}
.main_contents .projects_list_txt .note {
    margin-top: .5rem;
}
@media screen and (min-width : 768px) {
    .main_contents .projects_ttl {
        font-size: 3.3rem;
        font-weight: 400;
        line-height: 1.5;
        margin: 0;
    }
}

.main_contents .projects_list .btn01 {
    display: inline-block;
    margin: 1.2rem 0 0;
}

.main_contents .jp_works {
    display: flex;
}
.main_contents .jp_works_img {
    flex: 0 0 30%;
    height: auto;
    background: url(/assets/images/projects/jp_works.jpg) no-repeat 20% 0;
    background-size: cover;
}
.main_contents .jp_works_txt {
    flex: 0 1 70%;
    background: #ECE7E3;
    margin: 0 0 0 auto;
    padding: 4rem 5vw 1rem;
}
.main_contents .jp_works_lead {
    font-size: 1.8rem;
}

@media screen and (min-width : 768px) {
    .main_contents .projects_inner {
        padding: 0 3vw;
    }
    .main_contents .projects_inner h2 {
        margin-left: 0;
        margin-right: 0;
    }
    .main_contents .projects_list {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        margin: 5rem 0 0;
    }
    .main_contents .projects_list > li {
        width: 49%;
        max-width: 860px;
        margin: 0 0 10rem;
    }
    .main_contents .projects_list_txt {
        padding: 1.5rem 0 0;
    }
    .main_contents .jp_works {
        background-position: 0 0;
        height: 578px;
        overflow: hidden;
    }
    .main_contents .jp_works_img {
        flex: 0 0 60%;
        height: auto;
    }
    .main_contents .jp_works_txt {
        flex: 0 1 40%;
        text-align: left;
        padding: 20rem 4vw;
    }
    .main_contents .jp_works_lead {
        font-size: 2.8rem;
    }
}
@media screen and (min-width : 1900px) {
    .main_contents .jp_works_txt {
        width: calc(100% - 1180px);
        padding: 18rem 4vw 0;
    }
}

/* Group
---------------------------------------*/
.main_contents .group_anchor {
    margin: 0;
    padding: 0 0 2.5rem;
    background: url(/assets/images/aboutus/hoosiers-group/group_bg.png) no-repeat center;
    background-size: 200%;
}
.main_contents .group_anchor_list {
    text-align: center;
}
.main_contents .group_anchor_list a {
    font-size: 2.2rem;
    text-align: center;
    margin: 1rem 0;
}

@media screen and (min-width : 768px) {
    .main_contents .group_anchor {
        margin: 0 0 17rem;
        padding: 33rem 0 0;
        background-size: 100%;
        background-position: center top;
    }
    .main_contents .group_anchor_list {
        display: flex;
        justify-content: center;
    }
    .main_contents .group_anchor_list > li {
        position: relative;
    }
    .main_contents .group_anchor_list > li + li a {
        border-left: solid 1px #C5BDB8;
    }
    .main_contents .group_anchor_list a {
        margin: 0;
        padding: 0 4rem .2rem;
        line-height: 1;
        font-size: 3.6rem;
    }
}

.main_contents .group_region {
    margin: 0 0 7rem;
}
.main_contents .group_region_ttl {
    font-size: 3.2rem;
    color: #C5BDB8;
    position: relative;
    display: flex;
    align-items: center;
}
.main_contents .group_region_ttl::after {
    content: "";
    background: #C5BDB8;
    height: 1px;
    flex: 1 0 auto;
    margin: .5rem 0 0 2.5rem;
}
.group_region section:first-of-type h2 {
    margin-top: 3rem;
}
.main_contents .group_overview {
    margin: 3rem 0;
    font-size: 1.8rem;
}
.main_contents .group_overview dt {
    font-size: 1.6rem;
    color: #776B63;
}
.main_contents .group_overview dd {
    margin: 1rem 0 3rem;
}

@media screen and (min-width : 768px) {
    .main_contents .group_region_ttl {
        font-size: 4.8rem;
        margin: 0 0 5rem;
    }
    .main_contents .group_region_ttl::after {
        flex: 0 0 125px;
        margin: .5rem 0 0 4rem;
    }
    .main_contents .group_company {
        padding: 0 0 0 25rem;
    }
    .main_contents .group_overview {
        display: flex;
        flex-wrap: wrap;
        margin: 6.5rem 0 11rem;
    }
    .main_contents .group_overview dt,
    .main_contents .group_overview dd {
        padding: 1.2rem 0;
    }
    .main_contents .group_overview dt {
        width: 200px;
        text-align: right
    }
    .main_contents .group_overview dd {
        width: calc(100% - 200px);
        margin: 0;
        padding-left: 6rem;
    }
}

/* Works
---------------------------------------*/
/* 事例絞り込み SP */
@media screen and (max-width : 1280px) {
    .main_contents .works_filter_list {
        margin: 3rem 4vw 2rem;
    }
    .main_contents .works_filter_list li {
        display: inline-block;
        background: #FBDDCD;
        border-radius: 0px;
        margin: 9px 5px 0 0;
        padding: 8px 13px;
        color: #EA5504;
        cursor: pointer;
        font-size: 1.5rem;
    }
    .main_contents .works_filter_list .mixitup-control-active {
        color: #EA5504;
        background: #fff;
        border: solid 1px #EA5504;
    }
}

/* 事例絞り込み PC */
@media screen and (min-width : 1281px) {
    .works_filter {
        padding: 0 3vw;
    }
    .main_contents .works_filter_list {
        display: flex;
        justify-content: center;
        margin: 6.5rem 0 5rem;
        gap: 0 2.2rem;
        flex-wrap: wrap;
    }
    .main_contents .works_filter_list > li {
        margin: 0;
        position: relative;
        padding: 2.4rem 0 0;
        font-size: 1.8rem;
        color: #EA5504;
        cursor: pointer;
    }
    .main_contents .works_filter_list > li:hover {
        text-decoration: underline;
    }
    .main_contents .works_filter_list .mixitup-control-active {
        color: #101010;
    }
    .main_contents .works_filter_list .mixitup-control-active::before {
        content: '';
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        margin: auto;
        width: 18px;
        height: 18px;
        background: url(/assets/images/aboutus/works/icon_selected.svg) no-repeat center 0;
        background-size: 18px;
    }
}

/* 事例リスト */
.main_contents .works_container {
    padding: 1rem 5vw;
    background: #ECE7E3;
}
.main_contents .works_list > li {
    margin: 0 0 3rem;
}
.main_contents .works_list_img {
    margin: 0 0 1rem;
    box-shadow: 0 3px 3px rgba(0,0,0,.16);
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 53vw;
}
.main_contents .works_list_img img {
    font-size: 0;
    position: absolute;
    top: 0;
    left: 0;
    transition: transform .6s ease-in-out, opacity .6s ease-in-out;
    height: auto;
    width: 100%;
    max-width: inherit;
}
.main_contents .works_list_img a {
    display: block;
    width: 100%;
    height: 100%;
}
.main_contents .works_list_img a:hover img {
    transform: scale(1.2);
}
.main_contents .works_list_ttl {
    font-size: 1.8rem;
    margin: 0 0 .8rem;
}
.main_contents .works_tag {
    font-size: 1.4rem;
    color: #776B63;
    display: inline-block;
    margin: .5rem 1rem .5rem 0;
    cursor: pointer;
}
.main_contents .works_tag:hover {
    text-decoration: underline;
}

@media screen and (min-width : 768px) {
    .main_contents .works_container {
        padding: 6.5rem 3vw 10rem;
        min-height: 80vh;
    }
    .main_contents .works_list {
        display: flex;
        flex-wrap: wrap;
        gap: 2rem 1.3rem;
        max-width: 1760px;
        margin: 0 -1.3rem 0 0;
    }
    .main_contents .works_list > li {
        flex: 0 1 24%;
        max-width: 430px;
    }
    .main_contents .works_list > li:last-of-type {
        margin-right: auto;
    }
    .main_contents .works_list_img {
        height: 13.5vw;
    }
    .main_contents .works_list_img img {
        margin: 0 0 1rem;
    }
    .main_contents .works_list_ttl {
        font-size: 2.0rem;
    }
}

/* works_detail */
.main_contents .works_detail_tags .works_tag {
    cursor: inherit;
}
.main_contents .works_detail_tags .works_tag:hover {
    text-decoration: none;
}
.main_contents .works_detail_gallery {
    width: 100%;
    padding: 1.5rem 0;
    margin: 0 0 2rem;
    overflow-x: auto;
    white-space: nowrap;
}
.main_contents .works_detail_gallery_list {
    display: flex;
    gap: .6rem;
    width: auto;
    min-width: 1280px;
    margin: 0 0 2.5rem;
}
.main_contents .works_detail_gallery_list li {
    padding: 0;
    flex: 1 0 auto;
    max-width: 130px;
}
.main_contents .works_detail_gallery_list li::before {
    display: none;
}
.main_contents .works_detail_txt {
    margin: 0 0 4rem;
}
.main_contents .works_detail_gallery_list li img {
    box-shadow: 0 3px 3px rgba(0,0,0,.16);
}
.main_contents .works_detail_gallery_list li a {
    position: relative;
}
.main_contents .works_detail_gallery_list li a:hover img {
    opacity: 1;
}

/* マウスオーバーの黒背景 */
.main_contents .works_detail_gallery_list li a::before {
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: rgba(16,16,16,.6);
    opacity: 0;
    transition: opacity .3s ease-in-out;
}
.main_contents .works_detail_gallery_list li a:hover:before {
    opacity: 1;
}

@media screen and (min-width : 768px) {
    .works_detail_mv {
        width: 100%;
        height: calc(100vh - 110px - 72px);
        overflow: hidden;
        margin: 0 0 7rem;
    }
    .works_detail_mv img {
        position: absolute;
        top: 0;
        left: 0;
        height: auto;
        width: 100%;
        max-width: inherit;
    }
    .works_detail_tags {
        margin-top: -2rem;
    }
    .main_contents .works_detail_gallery {
        margin: 1rem 0 4rem;
    }
    .main_contents .works_detail_gallery_list {
        gap: 1rem;
    }
    .main_contents .works_detail_gallery_list li {
        max-width: 248px;
    }

    /* マウスオーバーのアイコン */
    .main_contents .works_detail_gallery_list li a::after {
        content: '';
        display: block;
        width: 40px;
        height: 40px;
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        margin: auto;
        background: url(/assets/images/common/icon_zoomin.svg) no-repeat center;
        background-size: 100%;
        transition: opacity .2s ease-in-out, transform .4s ease-in-out;
        opacity: 0;
        transform: translateY(10px);
    }
    .main_contents .works_detail_gallery_list li a:hover:after {
        opacity: 1;
        transform: translateY(0px);
    }
}

/* 事例のメイン画像 */
.works_detail_mv {
    width: 100%;
    height: 53vh;
    overflow: hidden;
    margin: 0 0 3rem;
    position: relative;
    opacity: 0;
    animation-name: fadein;
    animation-duration: 1.2s;
    animation-delay: .2s;
    animation-fill-mode: forwards;
}
.works_detail_mv img {
    position: absolute;
    top: 0;
    left: -50%;
    height: 100%;
    width: auto;
}
.aboutus_works01 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_01_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works02 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_02_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works03 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_03_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works04 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_04_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works05 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_05_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works06 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_06_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works07 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_07_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works08 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_08_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works09 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_09_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works10 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_10_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works11 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_11_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works12 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_12_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works13 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_13_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works14 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_14_main_sp.jpg) no-repeat center;
    background-size: cover;
}
.aboutus_works15 .works_detail_mv {
    background: url(/assets/images/aboutus/works/works_15_main_sp.jpg) no-repeat center;
    background-size: cover;
}

@media screen and (min-width : 768px) {
    .works_detail_mv {
        width: 100%;
        height: 80vh;
        overflow: hidden;
        margin: 0 0 3rem;
        position: relative;
        opacity: 0;
        animation-name: fadein;
        animation-duration: 1.2s;
        animation-delay: .2s;
        animation-fill-mode: forwards;
    }
    .works_detail_mv img {
        position: absolute;
        top: 0;
        left: -50%;
        height: 100%;
        width: auto;
    }
    .aboutus_works01 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_01_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works02 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_02_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works03 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_03_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works04 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_04_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works05 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_05_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works06 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_06_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works07 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_07_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works08 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_08_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works09 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_09_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works10 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_10_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works11 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_11_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works12 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_12_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works13 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_13_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works14 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_14_main.jpg) no-repeat center;
        background-size: cover;
    }
    .aboutus_works15 .works_detail_mv {
        background: url(/assets/images/aboutus/works/works_15_main.jpg) no-repeat center;
        background-size: cover;
    }
}

.main_contents .works_page_links {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 40px 0 20px;
}
.main_contents .works_page_link {
    margin: 20px 0;
}
.main_contents .works_page_link:last-of-type {
    margin-left: auto;
}
.main_contents .works_page_link a {
    margin: 0;
}

/* mCustomScrollbar js
---------------------------------------*/
.mCSB_horizontal.mCSB_inside>.mCSB_container {
    margin-bottom: 0;
}
.mCS-dark-3.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar {
    background: #EA5504!important;
    margin: 2px 0;
    height: 8px;
}
.mCS-dark-3.mCSB_scrollTools .mCSB_draggerRail {
    display: none;
}
.mCSB_scrollTools .mCSB_draggerContainer {
    background: #FBDDCD;
    border-radius: 16px;
    height: 12px;
}

/* Contact
---------------------------------------*/
.main_contents .contact_blk {
    margin: 6rem 0 0;
    padding: 6rem 6vw 5rem;
    color: #fff;
    text-align: center;
    background: linear-gradient(120deg, #EA5504 0%, #EA5504 50%, #EC6319 50%, #EC6319 100%);
}
.main_contents .contact_blk_ttl {
    background: url(/assets/images/common/icon_contact.svg) no-repeat center 0;
    background-size: 48px;
    padding: 56px 0 0;
    font-size: 2.4rem;
}
.main_contents .contact_blk_btn a {
    display: block;
    font-size: 1.8rem;
    color: #EA5504;
    text-align: center;
    background: #fff;
    border: solid 1px #fff;
    margin: 10px 20px;
    padding: 15px 20px;
    transition: background .3s ease, color .3s ease;
    border-radius: 50px;
}
.main_contents .contact_blk_btn a:hover {
    background: #EA5504;
    color: #fff;
    text-decoration: none;
}
@media screen and (min-width : 768px) {
    .main_contents .contact_blk {
        padding: 11rem 0 10rem;
    }
    .main_contents .contact_blk_ttl {
        font-size: 3.2rem;
        margin: 0 0 1.5rem;
    }
    .main_contents .contact_blk_btn a {
        display: inline-block;
        font-size: 2.0rem;
        padding: 25px 35px;
        margin: 10px 0;
    }
}
