/* Typography Styles */

[class*=has-typography][class*=primary],
[class*=is-style][class*=primary] {
    font-family: "Portrait", sans-serif;
    font-weight: 400;
    font-style: normal;

    &[class*=bold],
    & strong {
        font-weight: 500;
    }

    &[class*=display] {
        font-size: 2.0625rem;
        line-height: 2.5rem;
        @media (min-width: 481px) {
            font-size: 4.3125rem;
            line-height: 5.25rem;
        }
    }

    &[class*=heading-1] {
        font-size: 1.8125rem;
        line-height: 2.25rem;
        @media (min-width: 481px) {
            font-size: 3.375rem;
            line-height: 4rem;
        }

    }

    &[class*=heading-2] {
        font-size: 1.5625rem;
        line-height: 2rem;
        @media (min-width: 481px) {
            font-size: 2.8125rem;
            line-height: 3.25rem;
        }

    }

    &[class*=heading-3] {
        font-size: 1.3125;
        line-height: 1.5rem;
        @media (min-width: 481px) {
            font-size: 2.3125rem;
            line-height: 2.75rem;
        }

    }
    &[class*=title-1] {
        font-size: 1.5625rem;
        line-height: 2rem;
        letter-spacing: 0.0078rem;
        @media (min-width: 481px) {
            font-size: 1.9375rem;
            line-height: 2.25rem;
        }

    }
    &[class*=title-2] {
        font-size: 1.25rem;
        line-height: 1.75rem;
        @media (min-width: 481px) {
            font-size: 1.625rem;
            line-height: 2rem;
        }

    }
    &[class*=title-3] {
        font-size: 1.25rem;
        line-height: 1.75rem;
        @media (min-width: 481px) {
            font-size: 1.5rem;
            line-height: 2rem;
        }

    }
    &[class*=label-1] {
        font-size: 1rem;
        line-height: 1.5rem;
        letter-spacing: 0.02rem;
        @media (min-width: 481px) {
            font-size: 1.125rem;
            line-height: 1.5rem;
            letter-spacing: 0.0023rem;
        }
    }

    &[class*=label-2] {

        font-size: 0.875rem;
        line-height: 1.25rem;
        @media (min-width: 481px) {
            font-size: 0.9375rem;
            line-height: 1.125rem;
        }
        
    }
    &[class*=label-3] {
        @media (min-width: 481px) {
            font-size: 0.8125rem;
            line-height: 1.25rem;
        }
        font-size: 0.75rem;
        line-height: 1rem;
    }
    &[class*=body] {
        font-size: 1rem;
        line-height: 1.5rem;

        @media (min-width: 481px) {
            font-size: 1.125rem;
            line-height: 1.75rem;
        }

    }
}

[class*=has-typography][class*=secondary],
[class*=is-style][class*=secondary] {
    --font-family: "DM Sans";
    --font-weight: 400;
    --style: normal;

    &[class*=bold],
    & strong {
        --font-weight: 600;
    }

    &[class*=display] {
        font-size: 2.0625rem;
        line-height: 2.5rem;

        @media (min-width: 481px) {
            font-size: 4rem;
            line-height: 4rem;
        }
    }

    &[class*=heading-1] {
        font-size: 1.8125rem;
        line-height: 2.25rem;

        @media (min-width: 481px) {
            font-size: 3.375rem;
            line-height: 4rem;
        }
    }

    &[class*=heading-2] {
        font-size: 1.5625rem;
        line-height: 2rem;

        @media (min-width: 481px) {
            font-size: 2.8125rem;
            line-height: 3.25rem;
        }
    }
    &[class*=heading-3] {
        font-size: 1.3125rem;
        line-height: 1.5rem;

        @media (min-width: 481px) {
            font-size: 2.3125rem;
            line-height: 2.75rem;
        }

    }
    &[class*=title-1] {
        font-size: 2.0625rem;
        line-height: 2.5rem;
        letter-spacing: 0.0078rem;

        @media (min-width: 481px) {
            font-size: 1.9375rem;
            line-height: 2.25rem;
        }
    }
    &[class*=title-2] {
        font-size: 1.375rem;
        line-height: 2rem;

        @media (min-width: 481px) {
            font-size: 1.625rem;
            line-height: 2rem;
        }
    }
    &[class*=title-3] {
        font-size: 1.25rem;
        line-height: 1.75rem;

        @media (min-width: 481px) {
            font-size: 1.375rem;
            line-height: inherit;
        }

    }
    &[class*=label-1] {
        font-size: 1rem;
        line-height: 1.5rem;
        letter-spacing: 0.02rem;

        @media (min-width: 481px) {
            font-size: 1.125rem;
            line-height: 1.5rem;
            letter-spacing: 0.0023rem;
        }
    }
    &[class*=label-2] {
        font-size: 0.875rem;
        line-height: 1.22rem;

        @media (min-width: 481px) {
            font-size: 0.9375rem;
            line-height: 1.25rem;
        }
    }
    &[class*=label-3] {
        font-size: 0.75rem;
        line-height: 1rem;

        @media (min-width: 481px) {
            font-size: 0.8125rem;
            line-height: 1.25rem;
        }
    }
    &[class*=body] {
        font-size: 1rem;
        line-height: 1.5rem;

        @media (min-width: 481px) {
            font-size: 1.125rem;
            line-height: 1.75rem;
        }
    }
}
