/* --- Prose styling for Markdown content in modals --- */
.prose :where(h1):not(:where([class~="not-prose"] *)) {
    font-size: var(--kamos-font-size-h1);
    font-weight: 700;
    margin-bottom: var(--kamos-space-lg);
    color: var(--kamos-primary-color);
}
/* Dark Mode: prose h1 color */
:root.dark .prose :where(h1):not(:where([class~="not-prose"] *)) {
    color: var(--kamos-primary-color);
}

.prose :where(h2):not(:where([class~="not-prose"] *)) {
    font-size: var(--kamos-font-size-h2);
    margin-top: var(--kamos-space-2xl);
    margin-bottom: var(--kamos-space-md);
    color: var(--kamos-secondary-color);
}
/* Dark Mode: prose h2 color */
:root.dark .prose :where(h2):not(:where([class~="not-prose"] *)) {
    color: var(--kamos-secondary-color);
}

.prose :where(h3):not(:where([class~="not-prose"] *)) {
    font-size: var(--kamos-font-size-h3);
    margin-top: var(--kamos-space-xl);
    margin-bottom: var(--kamos-space-sm);
    color: var(--kamos-text-color-default);
}
/* Dark Mode: prose h3 color */
:root.dark .prose :where(h3):not(:where([class~="not-prose"] *)) {
    color: var(--kamos-text-color-default);
}

.prose :where(p):not(:where([class~="not-prose"] *)) {
    font-size: var(--kamos-font-size-body);
    line-height: var(--kamos-line-height-base);
    color: var(--kamos-text-color-default);
    margin-bottom: var(--kamos-space-md);
}
/* Dark Mode: prose p color */
:root.dark .prose :where(p):not(:where([class~="not-prose"] *)) {
    color: var(--kamos-text-color-default);
}

.prose :where(ul):not(:where([class~="not-prose"] *)) {
    list-style-type: disc;
    padding-left: var(--kamos-space-lg);
    margin-bottom: var(--kamos-space-md);
}
.prose :where(ol):not(:where([class~="not-prose"] *)) {
    list-style-type: decimal;
    padding-left: var(--kamos-space-lg);
    margin-bottom: var(--kamos-space-md);
}
.prose :where(li):not(:where([class~="not-prose"] *)) {
    margin-bottom: var(--kamos-space-sm);
}
.prose :where(a):not(:where([class~="not-prose"] *)) {
    color: var(--kamos-accent-blue);
    text-decoration: underline;
}
.prose :where(strong):not(:where([class~="not-prose"] *)) {
    font-weight: 700;
}
.prose :where(em):not(:where([class~="not-prose"] *)) {
    font-style: italic;
}
.prose :where(code):not(:where([class~="not-prose"] *)) {
    background-color: var(--kamos-bg-color-container-light);
    border-radius: var(--kamos-border-radius-sm);
    padding: 0.1em 0.4em;
    font-family: monospace;
    font-size: 0.9em;
    color: var(--kamos-secondary-color);
}
/* Dark Mode: prose code background and text color */
:root.dark .prose :where(code):not(:where([class~="not-prose"] *)) {
    background-color: var(--kamos-secondary-color);
    color: var(--kamos-text-color-default);
}

.prose :where(pre):not(:where([class~="not-prose"] *)) {
    background-color: var(--kamos-secondary-color);
    color: var(--kamos-text-color-inverted);
    border-radius: var(--kamos-border-radius-md);
    padding: var(--kamos-space-md);
    overflow-x: auto;
    font-family: monospace;
    font-size: var(--kamos-font-size-small);
    line-height: 1.5;
    margin-top: var(--kamos-space-md);
    margin-bottom: var(--kamos-space-md);
}
/* Dark Mode: prose pre background and text color */
:root.dark .prose :where(pre):not(:where([class~="not-prose"] *)) {
    background-color: var(--kamos-secondary-color);
    color: var(--kamos-text-color-default);
}

.prose :where(blockquote):not(:where([class~="not-prose"] *)) {
    border-left: 4px solid var(--kamos-border-color-default);
    padding-left: var(--kamos-space-md);
    color: var(--kamos-text-color-light);
    font-style: italic;
    margin-top: var(--kamos-space-md);
    margin-bottom: var(--kamos-space-md);
}
/* Dark Mode: prose blockquote border and text color */
:root.dark .prose :where(blockquote):not(:where([class~="not-prose"] *)) {
    border-color: var(--kamos-border-color-default);
    color: var(--kamos-text-color-light);
}

.prose :where(hr):not(:where([class~="not-prose"] *)) {
    border: none;
    border-top: 1px solid var(--kamos-border-color-light);
    margin-top: var(--kamos-space-lg);
    margin-bottom: var(--kamos-space-lg);
}
/* Dark Mode: prose hr border */
:root.dark .prose :where(hr):not(:where([class~="not-prose"] *)) {
    border-color: var(--kamos-border-color-default);
}
