/* ==========================================================================
   flow
   ========================================================================== */
/* p-page
-------------------------------------------------------------------------- */
.p-page
{
    overflow: hidden;
}

.p-page__heading
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    width: 100%;

    text-align: center; 

    -ms-flex-pack: distribute; 

        justify-content: space-around;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
}

@media screen and (max-width: 767px)
{
    .p-page__heading
    {
        height: 32vw;

        border-top: .53333vw solid #dadada;
        border-bottom: 1.06667vw solid #ffa300;
    }
}

@media screen and (min-width: 768px)
{
    .p-page__heading
    {
        height: 206px;

        border-top: 2px solid #dadada;
        border-bottom: 6px solid #ffa300;
    }
}

.p-page__lead
{
    font-weight: normal;
    line-height: 1.3em; 

    text-align: center;
    letter-spacing: .05em;
}

@media screen and (max-width: 767px)
{
    .p-page__lead
    {
        font-size: 65px;
        font-size: 8.67vw; 

        margin-top: 10.67vw;
        margin-bottom: 10.67vw;
    }
}

@media screen and (min-width: 768px)
{
    .p-page__lead
    {
        font-size: 40px;
        font-size: 4rem; 

        margin-top: 48px;
        margin-bottom: 60px;
    }
}

@media screen and (max-width: 1023px)
{
    .pc
    {
        display: none;
    }
}

@media screen and (min-width: 1024px)
{
    .tb
    {
        display: none;
    }
}

@media screen and (max-width: 767px)
{
    .tb
    {
        display: none;
    }
}

@media screen and (min-width: 768px)
{
    .sp
    {
        display: none;
    }
}

@media screen and (min-width: 1024px)
{
    .tb_sp
    {
        display: none;
    }
}

/* p-subPage
   ----------------------------------------------------------------- */
.p-subPage__heading
{
    background-color: #7f191b;
}

@media screen and (min-width: 1024px)
{
    .p-subPage__heading
    {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;

        -webkit-box-align: center;

            -ms-flex-align: center;

                align-items: center;
    }
}

.p-subPage__heading::after
{
    display: block;

    content: '';

    background-image: url(../image/company_img_01.jpg); 
    background-position: center;
    background-size: cover;
}

@media screen and (max-width: 767px)
{
    .p-subPage__heading::after
    {
        height: 34.66667vw;
    }
}

@media screen and (min-width: 768px)
{
    .p-subPage__heading::after
    {
        width: 100%;
        padding-top: 34%; 

        -webkit-box-flex: 1; 

            -ms-flex: 1; 

                flex: 1;
    }
}

@media screen and (min-width: 1024px)
{
    .p-subPage__heading::after
    {
        width: 55.5%;
        height: 380px;
        padding-top: 0;
    }
}

.p-subPage__wrap
{
    position: relative;
}

@media screen and (max-width: 767px)
{
    .p-subPage__wrap
    {
        padding: 8vw 5.33vw 8vw 5.33vw;
    }
}

@media screen and (min-width: 768px)
{
    .p-subPage__wrap
    {
        width: 100%;
        padding: 40px 0;
    }
}

@media screen and (min-width: 1024px)
{
    .p-subPage__wrap
    {
        width: 44.5%;
        padding-top: 0;
        padding-bottom: 0;
        padding-left: 20px;

        background: #7f191b;
    }
}

@media screen and (max-width: 767px)
{
    .p-subPage__lead
    {
        width: 74.66667vw;
    }
}

@media screen and (min-width: 768px)
{
    .p-subPage__lead
    {
        text-align: center;
    }
}

@media screen and (min-width: 1024px)
{
    .p-subPage__lead
    {
        max-width: 490px;
        margin-left: auto;
        padding-right: 20px;

        text-align: left;
    }
}

@media screen and (max-width: 767px)
{
    .p-subPage__inner
    {
        padding: 0vw 5.33vw 0vw 5.33vw;
    }
}

@media screen and (min-width: 768px)
{
    .p-subPage__inner
    {
        max-width: 1240px;
        margin-right: auto;
        margin-left: auto;
        padding-right: 20px; 
        padding-left: 20px;
    }
}

/* p-sitemap
   ----------------------------------------------------------------- */
.p-subPage .p-gnav__link
{
    color: #000;
}

.p-subPage .p-gnav__menu
{
    margin-bottom: 60px;
}

.p-subPage .p-gnav__title
{
    color: #7f191b;
}

.p-subPage .p-gnav__title
{
    font-size: 20px;
    font-size: 2.0rem;

    margin-top: 30px; 
    padding-top: 5px;
    padding-left: 35px;
}

.p-subPage .p-gnav__title::before
{
    position: absolute;
    top: 50%;
    left: 0;

    display: block;

    content: '';
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);

    background-color: #ffa300;
}

.p-sitemap
{
    color: #fff;
}

.p-sitemap__label
{
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    line-height: 1;
    line-height: 1;
}

@media screen and (max-width: 767px)
{
    .p-sitemap__label
    {
        font-size: 36px;
        font-size: 4.8vw;

        margin-top: .75em;
        margin-bottom: .75em;
        margin-bottom: 1em;

        text-align: center;
    }
}

@media screen and (min-width: 768px)
{
    .p-sitemap__label
    {
        font-size: 20px;
        font-size: 2rem; 

        margin-bottom: 20px;
    }
}

.p-sitemap__list
{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;

    -ms-flex-wrap: wrap;

        flex-wrap: wrap;
}

@media screen and (max-width: 767px)
{
    .p-sitemap__list
    {
        font-size: 30px;
        font-size: 4vw;

        margin-left: 4vw;
    }
}

@media screen and (min-width: 768px)
{
    .p-sitemap__list
    {
        max-width: 850px;
        margin: 0 auto;
    }
}

.p-sitemap__item
{
    line-height: 1;
}

@media screen and (max-width: 767px)
{
    .p-sitemap__item
    {
        width: 50%;
        margin-bottom: 4vw;
    }
}

@media screen and (min-width: 768px)
{
    .p-sitemap__item
    {
        margin-right: 10px;
        margin-bottom: 12px;
        padding-right: 10px;

        border-right: 1px solid #fff;
    }
}

@media screen and (min-width: 1024px)
{
    .p-sitemap__item:nth-child(6n)
    {
        border-right: none;
    }
}

@media screen and (max-width: 767px)
{
    .p-sitemap__item:nth-child(2n)
    {
        padding-left: 1em;
    }
}

@media screen and (min-width: 768px)
{
    .p-sitemap__item:last-child
    {
        border-right: none;
    }
}

.p-sitemap__link
{
    text-decoration: none; 

    color: #fff;
}

.p-sitemap__link:hover
{
    text-decoration: underline;
}
