/* ==========================================================================
   toppage
   ========================================================================== */
.p-concept
{
    position: relative;
}

.p-concept:before
{
    position: absolute;
    bottom: 0;
    left: -50vw;

    display: block;

    width: 150vw;
    height: calc(100% - 1.8vw);

    content: '';

    background: #f2f2f2;
}

@media screen and (max-width: 1023px)
{
    .p-concept:before
    {
        height: calc(100% - 4.5vw);
    }
}

@media screen and (max-width: 767px)
{
    .p-concept:before
    {
        height: calc(100% - 7vw);
    }
}

.p-concept__wrap
{
    position: relative;
    z-index: 20;
}

.p-concept__inner
{
    display: block;
    overflow: hidden;
}

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

        -ms-flex-wrap: wrap;

            flex-wrap: wrap;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: space-between;
    }
}

@media screen and (max-width: 767px)
{
    .p-concept__list
    {
        width: 100%;
    }
}

.p-concept__listItem
{
    width: calc(( 100% / 2 ) - 30px);
}

@media screen and (max-width: 1023px)
{
    .p-concept__listItem
    {
        width: 100%;
    }
    .p-concept__listItem:nth-child(n + 2)
    {
        margin-top: 60px;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1479px) and (min-width: 1280px)
{
    .p-concept__listItem:nth-child(n + 2)
    {
        margin-top: 3.13953vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1279px) and (min-width: 1024px)
{
    .p-concept__listItem:nth-child(n + 2)
    {
        margin-top: 3.24324vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1023px) and (min-width: 768px)
{
    .p-concept__listItem:nth-child(n + 2)
    {
        margin-top: 6.44531vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 767px)
{
    .p-concept__listItem:nth-child(n + 2)
    {
        margin-top: 8.59375vw;
    }
}

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

    -webkit-box-align: center;

        -ms-flex-align: center;

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

@media screen and (min-width: 1024px)
{
    .p-concept__imageArea
    {
        width: 270px;
    }
}

@media screen and (max-width: 1023px) and (min-width: 768px)
{
    .p-concept__imageArea
    {
        width: 40%;
    }
}

@media screen and (max-width: 767px)
{
    .p-concept__imageArea
    {
        width: 50%;
    }
}

.p-message
{
    position: relative;
}

.p-message__inner
{
    display: block;
}

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

        -ms-flex-wrap: wrap;

            flex-wrap: wrap;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: space-between;
    }
}

@media screen and (max-width: 767px)
{
    .p-message__list
    {
        width: 100%;
    }
}

.p-message__listItem
{
    width: calc(( 100% / 2 ) - 30px);
}

@media screen and (max-width: 1023px)
{
    .p-message__listItem
    {
        width: 100%;
    }
    .p-message__listItem:nth-child(n + 2)
    {
        margin-top: 60px;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1479px) and (min-width: 1280px)
{
    .p-message__listItem:nth-child(n + 2)
    {
        margin-top: 3.13953vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1279px) and (min-width: 1024px)
{
    .p-message__listItem:nth-child(n + 2)
    {
        margin-top: 3.24324vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1023px) and (min-width: 768px)
{
    .p-message__listItem:nth-child(n + 2)
    {
        margin-top: 6.44531vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 767px)
{
    .p-message__listItem:nth-child(n + 2)
    {
        margin-top: 8.59375vw;
    }
}

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

    -webkit-box-align: center;

        -ms-flex-align: center;

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

.p-message__imageArea
{
    position: relative; 

    width: calc(100% - .75vw);
    margin-top: -.75vw;
    margin-left: -.75vw;
}

@media screen and (max-width: 1023px)
{
    .p-message__imageArea
    {
        width: calc(80% - 1vw); 
        margin-top: -1vw;
        margin-left: -1vw;
    }
}

@media screen and (max-width: 767px)
{
    .p-message__imageArea
    {
        width: calc(100% - 1.5vw); 
        margin-top: -1.5vw;
        margin-left: -1.5vw;
    }
}

.p-message__imageArea:before
{
    position: absolute;
    z-index: -10; 
    top: 1.5vw;
    left: 1.5vw;

    display: block;

    width: 100%;
    height: 100%;

    content: '';

    opacity: .5;
    background: #3e5333;
}

@media screen and (max-width: 1023px)
{
    .p-message__imageArea:before
    {
        top: 2vw;
        left: 2vw;
    }
}

@media screen and (max-width: 767px)
{
    .p-message__imageArea:before
    {
        top: 3vw;
        left: 3vw;
    }
}

.p-message__image
{
    width: 100%;
    height: 100%;
}

.p-message__name
{
    font-size: 25px;
    font-size: 2.5rem;
    font-weight: 400;

    margin-top: 20px; 

    text-align: right;
}

@media screen and (max-width: 1479px) and (min-width: 1280px)
{
    .p-message__name
    {
        font-size: 1.45349vw;
    }
}

@media screen and (max-width: 1279px) and (min-width: 1024px)
{
    .p-message__name
    {
        font-size: 1.68919vw;
    }
}

@media screen and (max-width: 1023px) and (min-width: 768px)
{
    .p-message__name
    {
        font-size: 20px;
    }
}

@media screen and (max-width: 767px)
{
    .p-message__name
    {
        font-size: 17px;
    }
}

@media screen and (max-width: 767px)
{
    .p-message__name
    {
        font-size: 20px;
    }
}

.p-message__skilList
{
    font-weight: 400;

    margin-top: 20px;
    padding: 5px 10px;

    color: #fff; 
    background: #aacc03;
}

@media screen and (min-width: 768px)
{
    .p-message__skilList
    {
        font-size: 14px;

        display: -webkit-box;

        display: -ms-flexbox;

        display: flex;

        -webkit-box-align: center;

            -ms-flex-align: center;

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

@media screen and (min-width: 768px) and (max-width: 1023px)
{
    .p-message__skilList
    {
        font-size: 18px;
        font-size: 1.8rem;
    }
}

@media screen and (min-width: 768px) and (max-width: 1023px) and (max-width: 1479px) and (min-width: 1280px)
{
    .p-message__skilList
    {
        font-size: 1.04651vw;
    }
}

@media screen and (min-width: 768px) and (max-width: 1023px) and (max-width: 1279px) and (min-width: 1024px)
{
    .p-message__skilList
    {
        font-size: 1.21622vw;
    }
}

@media screen and (min-width: 768px) and (max-width: 1023px) and (max-width: 1023px) and (min-width: 768px)
{
    .p-message__skilList
    {
        font-size: 2.10938vw;
    }
}

@media screen and (min-width: 768px) and (max-width: 1023px) and (max-width: 767px)
{
    .p-message__skilList
    {
        font-size: 2.8125vw;
    }
}

.p-career
{
    position: relative;
}

.p-career:before
{
    position: absolute;
    bottom: 0;
    left: -50vw;

    display: block;

    width: 150vw;
    height: calc(100% - 1.8vw);

    content: '';

    background: #f9feda;
}

@media screen and (max-width: 1023px)
{
    .p-career:before
    {
        height: calc(100% - 4.5vw);
    }
}

@media screen and (max-width: 767px)
{
    .p-career:before
    {
        height: calc(100% - 7vw);
    }
}

.p-career__wrap
{
    position: relative;
    z-index: 20;
}

.p-career__inner
{
    display: block;
    overflow: hidden;
}

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

        -webkit-box-pack: justify;

            -ms-flex-pack: justify;

                justify-content: space-between;
    }
}

.p-career__item:nth-child(n+2)
{
    padding-top: 30px;
}

@media screen and (max-width: 1479px) and (min-width: 1280px)
{
    .p-career__item:nth-child(n+2)
    {
        padding-top: 1.56977vw;
    }
}

@media screen and (max-width: 1279px) and (min-width: 1024px)
{
    .p-career__item:nth-child(n+2)
    {
        padding-top: 1.62162vw;
    }
}

@media screen and (max-width: 1023px) and (min-width: 768px)
{
    .p-career__item:nth-child(n+2)
    {
        padding-top: 3.22266vw;
    }
}

@media screen and (max-width: 767px)
{
    .p-career__item:nth-child(n+2)
    {
        padding-top: 4.29688vw;
    }
}

.p-career__title
{
    font-size: 25px;
    font-size: 2.5rem;
    font-weight: 400;

    display: -webkit-box;

    display: -ms-flexbox;

    display: flex;
    display: flex;

    width: calc(20% - 20px);
    padding-bottom: 30px; 

    border-bottom: 1px solid #aacc03;

    -webkit-box-align: center;

        -ms-flex-align: center;

            align-items: center;
    align-items: center;
}

@media screen and (max-width: 1479px) and (min-width: 1280px)
{
    .p-career__title
    {
        font-size: 1.45349vw;
    }
}

@media screen and (max-width: 1279px) and (min-width: 1024px)
{
    .p-career__title
    {
        font-size: 1.68919vw;
    }
}

@media screen and (max-width: 1023px) and (min-width: 768px)
{
    .p-career__title
    {
        font-size: 20px;
    }
}

@media screen and (max-width: 767px)
{
    .p-career__title
    {
        font-size: 17px;
    }
}

@media screen and (max-width: 1023px)
{
    .p-career__title
    {
        width: 100%;
    }
}

@media screen and (max-width: 1479px) and (min-width: 1280px)
{
    .p-career__title
    {
        padding-bottom: 1.56977vw;
    }
}

@media screen and (max-width: 1279px) and (min-width: 1024px)
{
    .p-career__title
    {
        padding-bottom: 1.62162vw;
    }
}

@media screen and (max-width: 1023px) and (min-width: 768px)
{
    .p-career__title
    {
        padding-bottom: 3.22266vw;
    }
}

@media screen and (max-width: 767px)
{
    .p-career__title
    {
        padding-bottom: 4.29688vw;
    }
}

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

    width: calc(80% - 20px);
    padding-bottom: 30px; 

    border-bottom: 1px solid #ccc;

    -webkit-box-align: center;

        -ms-flex-align: center;

            align-items: center;
}

@media screen and (max-width: 1023px)
{
    .p-career__text
    {
        width: 100%;
        padding-top: 30px;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1479px) and (min-width: 1280px)
{
    .p-career__text
    {
        padding-top: 1.56977vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1279px) and (min-width: 1024px)
{
    .p-career__text
    {
        padding-top: 1.62162vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1023px) and (min-width: 768px)
{
    .p-career__text
    {
        padding-top: 3.22266vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 767px)
{
    .p-career__text
    {
        padding-top: 4.29688vw;
    }
}

@media screen and (max-width: 1479px) and (min-width: 1280px)
{
    .p-career__text
    {
        padding-bottom: 1.56977vw;
    }
}

@media screen and (max-width: 1279px) and (min-width: 1024px)
{
    .p-career__text
    {
        padding-bottom: 1.62162vw;
    }
}

@media screen and (max-width: 1023px) and (min-width: 768px)
{
    .p-career__text
    {
        padding-bottom: 3.22266vw;
    }
}

@media screen and (max-width: 767px)
{
    .p-career__text
    {
        padding-bottom: 4.29688vw;
    }
}

.p-career__icon
{
    display: inline-block;

    width: 20px;
    margin-right: 20px;
    margin-bottom: 5px;
}

@media screen and (max-width: 1479px) and (min-width: 1280px)
{
    .p-career__icon
    {
        width: 1.16279vw;
    }
}

@media screen and (max-width: 1279px) and (min-width: 1024px)
{
    .p-career__icon
    {
        width: 1.35135vw;
    }
}

@media screen and (max-width: 1023px) and (min-width: 768px)
{
    .p-career__icon
    {
        width: 2.14844vw;
    }
}

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

/* p-company
-------------------------------------------------------------------------- */
.p-company
{
    position: relative;
}

.p-company__inner
{
    display: block;
}

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

        -ms-flex-wrap: wrap;

            flex-wrap: wrap;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: space-between;
    }
}

@media screen and (max-width: 767px)
{
    .p-company__list
    {
        width: 100%;
    }
}

.p-company__listItem
{
    width: calc(( 100% / 2 ) - 30px);
}

@media screen and (max-width: 1023px)
{
    .p-company__listItem
    {
        width: 100%;
    }
    .p-company__listItem:nth-child(n + 2)
    {
        margin-top: 90px;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1479px) and (min-width: 1280px)
{
    .p-company__listItem:nth-child(n + 2)
    {
        margin-top: 4.7093vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1279px) and (min-width: 1024px)
{
    .p-company__listItem:nth-child(n + 2)
    {
        margin-top: 4.86486vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 1023px) and (min-width: 768px)
{
    .p-company__listItem:nth-child(n + 2)
    {
        margin-top: 9.66797vw;
    }
}

@media screen and (max-width: 1023px) and (max-width: 767px)
{
    .p-company__listItem:nth-child(n + 2)
    {
        margin-top: 12.89063vw;
    }
}

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

    -webkit-box-align: center;

        -ms-flex-align: center;

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

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

    -ms-flex-wrap: wrap;

        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
}

.p-company__photoItem
{
    aspect-ratio: 4 / 3;
}

.p-company__photoItem:nth-child(1)
{
    width: 100%;
}

.p-company__photoItem:nth-child(n + 2)
{
    width: calc((100% / 2) - 5px);
    margin-top: 10px;
}

.p-company__photoItem img
{
    width: 100%; 
    height: 100%;
}

.p-company__table
{
    font-weight: 300; 

    color: #333;
}

.p-company__table table
{
    width: 100%;
}

.p-company__table tr:nth-child(odd)
{
    background: #f9feda;
}

.p-company__table th
{
    font-weight: 500;

    width: 25%;
    padding: 30px 0 30px 120px;

    text-align: left;

    color: #5e5a61;
}

@media screen and (min-width: 768px) and (max-width: 1023px)
{
    .p-company__table th
    {
        width: 37%; 
        padding: 30px 40px;
    }
}

@media screen and (max-width: 767px)
{
    .p-company__table th
    {
        position: relative;

        padding: 4vw 6.67vw 0vw 6.67vw;
    }
}

.p-company__table td
{
    padding: 30px 0 30px 80px;
}

@media screen and (min-width: 768px) and (max-width: 1023px)
{
    .p-company__table td
    {
        padding: 30px 40px;
    }
}

@media screen and (max-width: 767px)
{
    .p-company__table td
    {
        min-height: 59.83px;
        padding: 4vw 6.67vw 4vw 6.67vw;
    }
}

.p-company__table th,
.p-company__table td
{
    line-height: 1.8;

    vertical-align: top;
}

@media screen and (max-width: 767px)
{
    .p-company__table th,
    .p-company__table td
    {
        font-size: 32px;
        font-size: 4.27vw; 

        display: block;

        width: 100%;
    }
}

.p-map
{
    overflow: hidden; 

    aspect-ratio: 50 / 48;
}

@media screen and (max-width: 1023px)
{
    .p-map
    {
        width: 100%;
        margin: 60px auto 0;

        aspect-ratio: 6 / 4;
    }
}

@media screen and (max-width: 767px)
{
    .p-map
    {
        width: 100%;
        margin: 30px auto 0;

        aspect-ratio: 3 / 4;
    }
}

@media screen and (min-width: 1024px)
{
    .p-map
    {
        width: 100%;
    }
}

@media screen and (max-width: 767px)
{
    .p-map__text
    {
        margin-top: 15px;
    }
}

.p-map__textArea
{
    margin-top: 20px;
}

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

        -webkit-box-align: center;

            -ms-flex-align: center;

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

@media screen and (max-width: 767px)
{
    .p-map__textArea
    {
        text-align: center;
    }
}

.p-map__image
{
    width: 40px;
}

@media screen and (min-width: 768px)
{
    .p-map__image
    {
        margin-right: 15px;
    }
}

@media screen and (max-width: 767px)
{
    .p-map__image
    {
        margin: 0 auto;
    }
}
