.cap-wrap {
    display: flex;
    flex-direction: column;
    margin: 96px auto 0 auto;
}

.cap-tile {
    display: flex;
    flex-direction: row;
    margin: auto;
    margin-bottom: 110px;
}

.cap-tile .cap-img-wrap {
    display: flex;
    align-items: center;
}

.cap-tile .cap-desc {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    max-width: none;
    margin: 0;    
}

.cap-tile:nth-of-type(even) .cap-desc {
    margin: 0 48px 0 0;
}

.cap-tile .cap-desc div {
    color: #123156;
    font-size: 32px; line-height: 30px;
    font-weight: 800;
    margin-bottom: 8px;
}

.cap-tile .cap-desc p,
.cap-tile .cap-desc ul {
    color: #424753;
    font-size: 14px; line-height: 21px;
    margin-bottom: 12px;
}

.cap-tile .cap-desc a {
    font-size: 14px;
}

.cap-wrap.container {
    align-items: center;
    padding: 0 30px;
}

.cap-tile {
    margin-bottom: 40px;
}

.cap-tile:nth-of-type(n) { flex-direction: column; }

.cap-tile img {
    width: 100%;
    max-width: 580px;
    margin: auto;
    margin-bottom: 25px;
}

@media (min-width: 577px) {

    .cap-tile {
        margin-bottom: 110px;
    }

    .cap-tile:nth-of-type(even) { flex-direction: row-reverse; }
    .cap-tile:nth-of-type(odd) { flex-direction: row; }

    .cap-tile .cap-desc {
        max-width: 50%;
        margin: 0 0 0 48px;
    }

    .cap-tile img {
        height: auto;
        margin: auto;
    }
}