/* === Typografia treści newsa (TelerikEditor output) ===
   Editor outputuje surowe HTML — h1-h6, p, ul, ol, blockquote, strong, em, a, img.
   Stylowanie poniżej daje czytelny "long-form article" look bez polegania na Telerikowych
   defaultach (które są ugly editor-friendly, nie reader-friendly). */

/* === Reading progress bar ===
   Fixed, pod top-navem (h-[72px] z _Layout). Wewnętrzny .reading-progress__bar wypełnia
   się od 0% do 100% w miarę scrolla strony — JS w share-buttons.js requestAnimationFrame.
   Track jest delikatnie szary; bar — primary (#b0001e).
*/
.reading-progress {
    top: 72px;
    height: 3px;
    background: rgba(0, 0, 0, 0.06);
}

.reading-progress__bar {
    height: 100%;
    width: 0%;
    transition: width 100ms linear;
}

@media (prefers-reduced-motion: reduce) {
    .reading-progress__bar {
        transition: none;
    }
}

/* === Lead — duży akapit "wprowadzenie" przed pełnym contentem ===
   Renderuje się z News.Intro w detalu. Większy text-size, lekko cieplejszy color,
   podkreślenie wejścia w artykuł.
*/
.news-article-lead {
    font-size: 1.5rem;
    line-height: 1.55;
    font-weight: 400;
    color: var(--color-on-surface);
    margin-block: 0 2.5rem;
    text-wrap: pretty;
}

@media (max-width: 768px) {
    .news-article-lead {
        font-size: 1.25rem;
    }
}

.news-article-content {
    font-size: 1.125rem;
    line-height: 1.7;
    color: var(--color-on-surface);
}

.news-article-content > * + * {
    margin-top: 1.25em;
}

.news-article-content h2 {
    font-size: 1.875rem;
    font-weight: 800;
    letter-spacing: -0.025em;
    line-height: 1.2;
    margin-top: 2em;
    margin-bottom: 0.5em;
    color: var(--color-on-surface);
}

.news-article-content h3 {
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: -0.015em;
    line-height: 1.3;
    margin-top: 1.75em;
    margin-bottom: 0.5em;
}

.news-article-content h4 {
    font-size: 1.25rem;
    font-weight: 700;
    margin-top: 1.5em;
    margin-bottom: 0.5em;
}

.news-article-content p {
    color: var(--color-on-surface);
}

.news-article-content a {
    color: var(--color-primary);
    text-decoration: underline;
    text-underline-offset: 0.2em;
    text-decoration-thickness: 1px;
    transition: color var(--transition-fast);
}
.news-article-content a:hover {
    color: var(--color-primary-hover);
}

.news-article-content strong { font-weight: 700; }
.news-article-content em { font-style: italic; }

.news-article-content ul,
.news-article-content ol {
    padding-left: 1.5em;
}
.news-article-content ul { list-style: disc; }
.news-article-content ol { list-style: decimal; }
.news-article-content li + li { margin-top: 0.4em; }

.news-article-content blockquote {
    border-left: 3px solid var(--color-primary);
    padding-left: 1.5em;
    font-style: italic;
    color: var(--color-on-surface-variant);
    margin-block: 1.5em;
}

.news-article-content img {
    width: 100%;
    height: auto;
    border-radius: var(--radius-xl);
    margin-block: 1.5em;
}

.news-article-content hr {
    border: 0;
    border-top: 1px solid var(--color-outline-variant);
    margin-block: 2em;
}

.news-article-content code {
    background: var(--color-surface-container);
    padding: 0.2em 0.4em;
    border-radius: var(--radius-md);
    font-size: 0.9em;
}

.news-article-content pre {
    background: var(--color-surface-container);
    padding: 1em;
    border-radius: var(--radius-lg);
    overflow-x: auto;
}
.news-article-content pre code {
    background: transparent;
    padding: 0;
}

.news-article-content table {
    width: 100%;
    border-collapse: collapse;
    margin-block: 1.5em;
}
.news-article-content th,
.news-article-content td {
    border: 1px solid var(--color-outline-variant);
    padding: 0.75em;
    text-align: left;
}
.news-article-content th {
    background: var(--color-surface-container-low);
    font-weight: 700;
}
