.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
    line-height: 1.2;
    hyphens: auto;
    /*padding-top: 10px;*/
}

h1 {
    font-family: var(--font-bold), sans-serif;
    font-size: 60px;
    line-height: 1.07;
    color: var(--text-primary);
    letter-spacing: -1px;
    hyphens: none;
    margin-bottom: 48px;
}

h1.plugin-listing-title {
    margin-bottom: 48px;
}

h2 {
    font-family: var(--font-bold), sans-serif;
    font-size: 36px;
    color: var(--text-primary);
    letter-spacing: -1px;
    margin-bottom: 24px;
}

h2.plugin-listing-title {
    margin-bottom: 48px;
}

.model-detail h2.plugin-listing-title {
    margin-bottom: 24px;
}

h2.h2-thin {
    font-family: var(--font-roma), sans-serif;
    /*font-size: 28px;*/
    color: var(--text-primary);
    margin-bottom: 16px;
}

h2.h2-thin-grey {
    font-family: var(--font-roma), sans-serif;
    color: var(--signal-grey);
    margin-bottom: 16px;
}

h2.h2-thin strong {
    font-family: var(--font-bold), sans-serif;
}

h2:has(+ p.p-extra-large) {
    margin-bottom: 8px;
}

h2:has(+ h3) {
    margin-bottom: 32px;
}

h2.h2-small {
    font-size: 24px;
    letter-spacing: -0.5px;
    margin-bottom: 16px;
}

h3 {
    font-family: var(--font-bold), sans-serif;
    font-size: 24px;
    color: var(--text-primary);
    letter-spacing: -0.5px;
    margin-bottom: 16px;
}

.text-h3-thin-grey {
    font-family: var(--font-roma), sans-serif;
    font-size: 23px;
    color: var(--text-secondary-dark);
}

h4 {
    font-family: var(--font-bold), sans-serif;
    font-size: 24px;
    color: var(--text-primary);
    letter-spacing: -0.5px;
    margin-bottom: 16px;
}

.p-extra-large {
    font-family: var(--font-roma), sans-serif;
    font-size: 34px;
    line-height: 1.2;
    color: var(--text-secondary);
    letter-spacing: -1px;
    margin-top: 0;
    margin-bottom: 24px;
}

h1:has(+ p.p-extra-large),
h1.product-top-content-title {
    margin-bottom: 16px;
}

h1 + p.p-extra-large {
    margin-bottom: 48px !important;
}

p.p-description {
    font-size: 24px;
    color: var(--text-secondary);
    letter-spacing: -0.5px;
    margin-bottom: 48px;
}

h2 + p.p-description {
    margin-bottom: 48px;
}

ul,
ol {
    margin-bottom: 1.12rem;
    padding-left: 1.15rem;
}

ul {
    list-style-type: square;
}

ul ul,
ol ol {
    padding-left: 1.75rem;
}

ul li,
ol li {
    /*font-size: 16px;*/
    position: relative;
    margin-bottom: 12px;
}

ul li::marker,
ol li::marker {
    color: var(--text-link-primary);
}

ul li strong,
ol li strong {
    font-size: 16px;
    color: var(--text-primary);
}

ul li:has(> strong) {
    font-size: 14px !important;
}

ul li li,
ol li li {
    margin-bottom: 8px;
}

ul.ul-list-style-check {
    list-style: none;
    padding-left: 0;
}

ul.ul-list-style-check li {
    padding-left: 30px;
}

ul.ul-list-style-check li:before {
    content: '\f058';
    font-family: "Font Awesome 6 Pro", sans-serif;
    font-size: 20px;
    line-height: 1.2;
    font-weight: 100;
    color: var(--text-primary);
    position: absolute;
    left: 0;
}

.content-box ul.ul-list-style-check li {
    font-size: inherit;
}

.font-size-small ul.ul-list-style-check li {
    font-size: inherit;
}

.font-size-small ul.ul-list-style-check li:before {
    font-size: 18px;
    line-height: 1.3;
}

.font-size-extra-small ul.ul-list-style-check li {
    font-size: inherit;
    padding-left: 22px;
}

.font-size-extra-small ul.ul-list-style-check li:before {
    font-size: 14px;
    line-height: 1.4;
}

@media (max-width: 1199px) {
    h1 {
        font-size: 40px;
    }

    h1 + p.p-extra-large {
        margin-bottom: 32px;
    }

    h2 {
        font-size: 28px;
        margin-bottom: 8px;
    }

    h2:has(+ h3) {
        margin-bottom: 16px;
    }

    h1.plugin-listing-title {
        margin-bottom: 32px;
    }

    h2.plugin-listing-title {
        margin-bottom: 24px;
    }

    h2 + p.p-description {
        margin-bottom: 32px;
    }

    h2:has(+ .download-card) {
        margin-bottom: 12px;
    }

    h3 {
        font-size: 20px;
        letter-spacing: -0.5px;
    }

    .text-h3-thin-grey {
        font-size: 20px;
    }

    .p-extra-large {
        font-size: 28px;
    }

    p.p-description {
        font-size: 20px;
        margin-bottom: 32px;
    }

    ul li strong,
    ol li strong {
        font-size: 14px;
    }

    ul.ul-list-style-check li:before {
        line-height: 1.1;
    }
}

@media (max-width: 639px) {
    h1 {
        font-size: 28px;
        margin-bottom: 24px;
    }

    h1 + p.p-extra-large {
        margin-bottom: 24px !important;
        letter-spacing: -0.5px;
    }

    h1.plugin-listing-title {
        margin-bottom: 16px;
    }

    h2 {
        font-size: 22px;
        letter-spacing: -0.5px;
    }

    h2 + p.p-description {
        margin-bottom: 24px;
        /*letter-spacing: -0.5px;*/
    }

    h2.plugin-listing-title {
        margin-bottom: 16px;
    }

    h3 {
        font-size: 16px;
        letter-spacing: 0;
        margin-bottom: 8px;
    }

    .text-h3-thin-grey {
        font-size: 20px;
    }

    h3 .text-h3-thin-grey {
        font-size: 16px;
    }

    .p-extra-large {
        font-size: 22px;
        letter-spacing: -0.5px;
    }

    p.p-description {
        font-size: 16px;
        letter-spacing: 0;
        margin-bottom: 24px;
    }

    .ul-list-style-check li:before {
        line-height: 1.1;
    }

    h1.product-top-content-title {
        margin-bottom: 8px;
    }
}