.subtitle {
    color: var(--subtitle-color);
    font-weight: 500;
    text-transform: uppercase;
}

.title {
    color: var(--title-color);
    font-weight: 700;
    line-height: 1;
}

.content {
    display: flex;
    flex-direction: column;
    gap: 1.5em;

    .subtitle {
        font-size: 0.875em;
        margin-bottom: -1em;
    }

    .title {
        font-size: 2.5em;
    }

    .description {
        font-size: 1.125em;
    }

    .buttons {
        font-size: 0.875em;
    }
}

.wysiwyg {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5em;

    h3 {
        font-size: 1.5em;
        color: var(--text-strong);
        font-weight: 600;


        &::after {
            height: 2px;
            display: block;
            width: 2em;
            background-color: var(--primary);
        }

        &:not(:first-child) {
            border-top: 1px solid var(--background);
            padding-top: 1.5em;
        }
    }
    h4 {
        font-size: 1.25em;
        color: var(--primary);
        font-weight: 600;
    }

    h5 {
        font-size: 1em;
        color: var(--text-strong);
        font-weight: 600;
    }

    img {
        border-radius: 1em;
    }

    blockquote {
        font-size: 1.125em;
        color: var(--text-strong);
        font-style: italic;
        font-weight: 500;
        line-height: 1.6;
        background: linear-gradient(135deg, var(--white-bis) 0%, var(--white) 100%);
        border-left: 4px solid var(--primary);
        border-radius: 0 0.75em 0.75em 0;
        padding: 1.5em 2em;
        margin: 2em auto;
        max-width: 600px;
        position: relative;
        box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    }

    blockquote::before {
        content: '"';
        font-size: 3em;
        color: var(--primary);
        position: absolute;
        top: 0.2em;
        left: 0.3em;
        font-family: Georgia, serif;
        line-height: 1;
        opacity: 0.3;
    }

    blockquote.is-blog {
        font-size: 0.95em;
        color: var(--text-strong);
        font-style: italic;
        font-weight: 500;
        line-height: 1.5;
        background: linear-gradient(135deg, var(--white-bis) 0%, var(--white) 100%);
        border-left: 3px solid var(--primary);
        border-radius: 0 0.5em 0.5em 0;
        padding: 1.25em 1.75em;
        margin: 1.5em 0;
        width: 100%;
        position: relative;
        box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
        transform: translateX(0);
        transition: transform 0.2s ease;
    }

    blockquote.is-blog::before {
        content: '"';
        font-size: 2.5em;
        color: var(--primary);
        position: absolute;
        top: 0.1em;
        left: 0.25em;
        font-family: Georgia, serif;
        line-height: 1;
        opacity: 0.25;
    }

    blockquote.is-blog::after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 3px;
        height: 100%;
        background: linear-gradient(to bottom, var(--primary), var(--violet-bis));
        border-radius: 0 0 0.5em 0;
    }

    a {
        color: var(--pink);
    }

    a:hover {
        color: var(--violet-bis);
    }
}

@media screen and (max-width: 599px) {
    .wysiwyg blockquote {
        font-size: 1em;
        padding: 1.25em 1.5em;
        margin: 1.5em auto;
        max-width: 100%;
    }

    .wysiwyg blockquote::before {
        font-size: 2.5em;
        top: 0.1em;
        left: 0.2em;
    }

    .wysiwyg blockquote.is-blog {
        font-size: 0.875em;
        padding: 1em 1.25em;
        margin: 1.25em 0;
        width: 100%;
    }

    .wysiwyg blockquote.is-blog::before {
        font-size: 2em;
        top: 0.05em;
        left: 0.15em;
    }
}

@media screen and (min-width: 600px) {
    .content,
    .wysiwyg {
        font-size: 1.125em;
    }
}

@media screen and (min-width: 1200px) {
    .content,
    .wysiwyg {
        font-size: 1.25em;
    }

    .wysiwyg {
        grid-template-columns: var(--section-padding) 1fr var(--section-padding);

        > * {
            grid-column: 2;
        }

        blockquote,
        img {
            grid-column: 1 / span 3;
        }

        blockquote {
            padding: 2em 3em;
            max-width: 700px;
            justify-self: center;
        }

        blockquote.is-blog {
            padding: 1.5em 2.25em;
            width: 100%;
        }
    }
}

@media screen and (min-width: 1400px) {
    .content,
    .wysiwyg {
        font-size: 1.375em;
    }
}

@media screen and (min-width: 1600px) {
    .content,
    .wysiwyg {
        font-size: 1.5em;
    }
}
