﻿.flexBox {
    display: flex;
    flex-flow: row nowrap;
    align-items: flex-start;
    justify-content: flex-start;
}

#pr1, #pr2 {
    display: flex;
    flex-flow: row wrap;
    align-items: flex-start;
    justify-content: flex-start;
}

#pr1 {
    width: 510px;
}

#pr2 {
    width: 340px;
    flex-shrink: 0;
}

#pr1 * {
    line-height: 150%;
}

#pr1 > div {
    box-sizing: border-box;
    width: 100%;
    font-weight: normal;
    background-color: #ffffdd;
    padding: 10px;
}

.companyMenu {
    padding-left: 50px;
}

    .companyMenu > a {
        display: block;
        margin-bottom: 1em;
    }

.companyMessage {
    flex-shrink: 1;
    color: #3366ff;
    line-height: 130%;
}

    .companyMessage p {
        margin-bottom: 2em;
    }

.img170 {
    width: 170px;
    height: 170px;
    border: none;
}

.companyInfo {
    line-height: 20px;
}

    .companyInfo dt, .companyInfo dd {
        display: flex;
        flex-flow: row wrap;
        justify-content: flex-start;
        align-items: center;
    }

    .companyInfo dt {
        color: var(--theme-color);
    }

        .companyInfo dt:before {
            content: "";
            width: 10px;
            height: 10px;
            background-color: var(--theme-color);
            margin-right: 10px;
        }

    .companyInfo dd {
        margin-left: 20px;
    }

.companyPhoto {
    margin-top: 20px;
    max-width: 508px;
    width: 100%;
    height: auto;
}

.map {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
}

    .map iframe,
    .map object,
    .map embed {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }

@media (max-width: 1000px) {
    .flexBox {
        flex-flow: column-reverse nowrap;
    }

    .companyMenu {
        width: 100%;
        font-size: 4.5rem;
    }

    #pr1, #pr2 {
        width: 100%;
        font-size: 4em;
    }

        #pr1 .img170 {
            width: 33.3%;
            height: auto;
        }

        #pr2 .img170 {
            width: 25%;
            height: auto;
        }

    .companyMessage {
        display: none;
    }

    .companyInfo {
        font-size: 1.5rem;
        line-height: unset;
    }

        .companyInfo dt {
            padding-top: 10px;
            padding-bottom: 5px;
        }

            .companyInfo dt:before {
                content: "";
                width: 1.5rem;
                height: 1.5rem;
                margin-right: 1.5rem;
            }

        .companyInfo dd {
            margin-left: 3rem;
            margin-bottom: 1.5rem;
        }

    .map {
        padding-bottom: 100%;
        /*-webkit-text-size-adjust: auto;*/
    }

        .map * {
            /*-webkit-text-size-adjust: auto;*/
        }
}
