.about {
    padding: 0;
    padding-bottom: var(--spacing-lg);
    position: relative;
}

.about-bg {
    position: absolute;
    bottom: 0;
}

.about-flex {
    margin: var(--spacing-x-lg) var(--spacing-md);
    color: var(--color-primary-dark);
    display: flex;
    flex-direction: column-reverse;
    gap: var(--spacing-x-lg);
    position: relative;
}

.about-flex>* {
    width: 100%;
}

.about-text {
    background-color: var(--color-primary-light);
    border-radius: var(--spacing-tiny);
    padding: var(--spacing-md);
}

.about-heading {
    line-height: 2rem;
    color: var(--color-primary-dark);
    margin-bottom: var(--spacing-md);
}

.about-desc {
    font-size: 1.125rem;
    position: relative;
    margin-bottom: var(--spacing-sm);
}

/* RIGHT SIDE */

.about-image {
    position: relative;
    min-height: 280px;
}

.about-image-shadow,
.about-image img {
    margin: 0 auto;
    width: 240px;
    height: 240px;
    border-radius: var(--spacing-md);
}

.about-image-shadow {
    position: absolute;
    background-color: var(--color-primary-light);
    right: 0;
}

.about-image img {
    position: absolute;
    top: var(--spacing-lg);
    right: var(--spacing-lg);
    object-fit: cover;
}

.about-stats {
    margin-top: var(--spacing-md);
    display: flex;
}

.about-stat {
    width: 33%;
    text-align: center;
    padding: var(--spacing-sm);
    border-right: 2px solid var(--color-primary-dark);
}

.about-stat:last-child {
    border-right: 0;
}

.about .stat-heading {
    font-size: 1.6rem;
    line-height: 1.6rem;
    color: var(--color-primary-dark);
}

.stat-sm-text {
    color: var(--color-highlight);
}

@media screen and (min-width: 500px) {

    .about .stat-heading {
        font-size: 2.4rem;
        line-height: 2.4rem;
    }

    .about-image {
        min-height: 420px;
    }

    .about-image-shadow,
    .about-image img {
        width: 360px;
        height: 360px;
    }

}

@media screen and (min-width: 700px) {

    .about-flex {
        margin: var(--spacing-jumbo) var(--spacing-lg);
    }

    .about-text {
        padding: var(--spacing-lg);
    }

}

@media screen and (min-width: 970px) {

    .about-stat {
        padding: var(--spacing-md) var(--spacing-md-lg);
    }

}

@media screen and (min-width: 1040px) {

    .about-flex {
        flex-direction: row;
        gap: var(--spacing-md);
    }

}

@media screen and (min-width: 1400px) {

    .about-flex {
        margin: var(--spacing-jumbo) var(--spacing-mega);
    }

}