/* ==========================================================================
     BANNER CSS
   ========================================================================== */

/* VARIABLES */

:root {
    /* Colors */
    --c-white: #FFFFFF;
    --c-black: #1C1C1C;
    --c-gray-500: #818181;
    --c-brand-orange: #f18489;
    --c-brand-orange-gradient-v: linear-gradient(180deg, #FFB984 0%, #ED728B 100%);
    --c-brand-orange-gradient-h: linear-gradient(270deg, #FFB984 0%, #ED728B 100%);
    /* Shadows */
    --shadow-01: 0px 5px 10px rgba(0, 0, 0, 0.25);
    --shadow-02: 0px 2px 8px rgba(0, 0, 0, 0.15);
    /* Font Sizes */
    --fs-t-01: 2.5rem;
    --fs-t-02: 1.875rem;
    --fs-t-03: 1.5rem;
    --fs-p-01: 1.125rem;
}

.banner {
    width: 100%;
    padding: 30px;
    display: flex;
    flex-flow: column;
    color: var(--c-white);
    background: var(--c-brand-orange-gradient-h);
    border-radius: 30px;
}

.banner__title {
    font-family: Rubik, sans-serif;
    margin: 0;
    margin-bottom: 24px;
    font-weight: 500;
    font-size: var(--fs-t-02);
}

.banner__subtitle {
    margin: 0;
    font-size: var(--fs-t-03);
}

.banner__description {
    margin: 0;
    font-size: var(--fs-p-01);
}

.banner__title,
.banner__subtitle,
.banner__description {
    width: 100%;
}

.banner__link {
    color: var(--c-white);
    font-weight: bold;
    transition: .5s text-decoration;
}

.banner__link:hover,
.banner__link:focus,
.banner__link:active {
    color: var(--c-white);
    text-decoration: underline;
}

.banner__icon {
    margin-right: 8px;
}

.banner__icon path {
    transition: .6s;
}

.banner__btn:hover .banner__icon path,
.banner__btn:focus .banner__icon path,
.banner__btn:active .banner__icon path {
    fill: var(--c-brand-orange);
}

.banner__col {
    display: flex;
    flex-flow: column;
    grid-gap: 16px;
    justify-content: flex-start;
    align-items: center;
}

.banner__col-separator {
    margin: 20px 0;
    border-bottom: 2px solid var(--c-white);
}

.banner__btn {
    width: fit-content;
    padding: 10px 20px;
    border-radius: 30px;
    border: 2px solid var(--c-white);
    box-shadow: var(--shadow-02);
    text-transform: uppercase;
    color: var(--c-white);
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: .6s color, .6s background-color;
}

.banner__btn:hover,
.banner__btn:active {
    color: var(--c-brand-orange);
    background-color: var(--c-white);
}

.banner--no-rounded {
    border-radius: 0;
}

@media (min-width: 640px) {
    .banner {
        padding: 40px;
    }

    .banner__body {
        display: grid;
        grid-template-columns: 1fr auto 1fr;
    }

    .banner__title {
        font-size: var(--fs-t-01);
    }

    .banner__subtitle {
        font-size: var(--fs-t-02);
    }

    .banner__btn {
        padding: 16px 20px;
    }

    .banner__col {
        align-items: flex-start;
        justify-content: space-between;
    }

    .banner__col-separator {
        margin: 0 20px;
        border-left: 2px solid var(--c-white);
    }

    .banner__col--aling-start {
        justify-content: flex-start;
    }
}