.ipa {
    overflow: hidden;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 650px;
    margin: 0 auto;
    width: 100%;
}
    .ipa--floating {
        height: 650px;
        background: #F6F6F6;
    }
.ipa__bg-element {
    position: absolute;
}
    .ipa__bg-element-1 {
        left: -103px;
        top: 0;
    }
    .ipa__bg-element-2 {
        right: -189px;
        bottom: 0;
    }
    .ipa__bg-element--floating-1 {
        top: -7px;
        left: -27px;
        width: 148px;
    }
    .ipa__bg-element--floating-2 {
        bottom: -65px;
        left: 6px;
        width: 40px;
    }
    .ipa__bg-element--floating-3 {
        margin: 100px 100px 0px 0px;
        width: 190px;
    }
.ipa__portrait-box {
    display: flex;
    justify-content: center;
}
.ipa__portrait {
    width: 160px;
    height: auto;
    margin: 0 0 50px -100px;
    z-index: 1;
}
    .ipa__portrait--floating {
        margin: 35px 0 0 133px;
    }

.ipa__text-box {
    display: flex;
    flex-direction: column;
    width: 70%;
    max-width: 510px;
    position: relative;
}
.ipa__text {
    color: #002E3B;
    font-weight: 500;
    z-index: 1;
}
    .ipa__text--byline {
        font-size: 16px;
    }
    .ipa__text--byline a {
        font-weight: 300;
    }

    @media only screen and (min-width: 800px) { 
        .ipa {
            flex-direction: row;
            height: 250px;
        }       
        .ipa--floating {
            height: 300px;
        }
        .ipa__portrait {
            width: 160px;
            height: auto;
            margin: 0 50px 0 10px;
        }
        .ipa__portrait-box {
            margin: 60px 0 30px 0;
        }
        .ipa__portrait--floating {
            margin: 35px 0 0 133px;
        }
        .ipa__bg-element-1 {
            left: 0px;
            top: 0px;
        }
        .ipa__bg-element-2 {
            right: -100px;
        }
            .ipa__bg-element--floating-2 {
                bottom: -47px;
                left: 70px;
                width: 50px;
            }
        .ipa__text-box--floating {
            margin-right: -100px;
        }
    }

    /* Version 2 */

.ipa-2 {
background: #424A98;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
height: 600px;
width: 100%;
overflow: hidden;
}
.ipa-2--floating {
    background: #FFF;
}
.ipa-2__container {
    width: 1000px;
    display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
    
}
.ipa-2__byline {
    margin: 0 0 0 70px;
}

.ipa-2__name {
    color: #424A98 ;
    clip-path: polygon(9% 0, 94% 9%, 100% 100%, 0% 100%);
    background: #FFF;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    min-height: 42px;
    text-decoration: underline;
    max-width: 80vw;
    padding: 5px 30px;
} 
.ipa-2__name:hover {
    transition: 0.4s;
    opacity: 0.8;
}
    .ipa-2__name--floating {
        background: #5760AE;
        color: #FFF;
    }
.ipa-2__site-name {
    color: #FFF;
    text-align: center;
    font-weight: 700;
    margin: -10px 0 0 0!important;
    max-width: 80vw;
}
.ipa-2__site-name--floating {
}
    .ipa-2__site-name--floating {
        color: #0E141D;
    }
.ipa-2__portrait {
    margin: 0 80px -40px 0;

}

.ipa-2__text-box {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 350px;
    height: 232px;
    margin-bottom: -40px;

}
.ipa-2__text-background {
    position: absolute;
    max-width: 200%;
}
.ipa-2__text-background--floating {
    width: 424px;
}
.ipa-2__text-background--mobile {
    width: 424px;
}
.ipa-2__text-background--desktop {
    width: 450px;
    display: none;
}


.ipa-2__text {
    position: absolute;
    text-align: center;
    width: 300px;
    z-index: 1;
    margin-top: -30px;
}
.ipa-2__text--floating {
    margin-top: -30px;
}

@media only screen and (min-width: 800px) {

    .ipa-2 {
        display: flex;
        flex-direction: row-reverse;
        justify-content: center;
        align-items: center;
        height: 350px;
        width: 100%;
        overflow: hidden;
        }
        .ipa-2__container {
            flex-direction: row-reverse;
        }
        .ipa-2__container--floating {
            flex-direction: row;
        }
        .ipa-2__byline {
            margin: 0 -20px 0 0;
        }
        .ipa-2__byline--floating {
            margin: 0 0px 0 -30px;
        }
        .ipa-2__portrait {
            margin: 0 0 -38px 0;
        }
        .ipa-2__text-box {
            margin-bottom: -16px;
        }
        .ipa-2__text {
            margin-top: 0px;
        }
        .ipa-2__text--floating {
            margin-top: -30px;
        }
        .ipa-2__site-name {
            text-align: left;
            margin: -10px 0 0 35px!important;
            width: 300px;
        }
        .ipa-2__site-name--floating {
            width: auto;
        }
        .ipa-2__text-background--mobile {
            display: none;
        }
        .ipa-2__text-background--desktop {
            display: block;
        }
        .ipa-2__text-background--floating {
            width: 450px;
        }
 }