/* ============================================================
   Страницы блога
   ============================================================ */

/* Листинг */

.blog-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: var(--sp-6);
}

.blog-card {
    display: flex;
    flex-direction: column;
    background: var(--color-bg);
    border: 1px solid var(--color-line);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: transform var(--dur-base) var(--ease-out),
                border-color var(--dur-base) var(--ease-out),
                box-shadow var(--dur-base) var(--ease-out);
}

.blog-card:hover {
    transform: translateY(-4px);
    border-color: var(--color-primary);
    box-shadow: var(--shadow-lg);
}

.blog-card__cover {
    aspect-ratio: 16 / 9;
    background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: var(--fw-black);
    font-size: var(--fs-2xl);
    text-align: center;
    padding: var(--sp-6);
}

.blog-card__body {
    padding: var(--sp-5) var(--sp-5) var(--sp-6);
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
    flex-grow: 1;
}

.blog-card__meta {
    font-size: var(--fs-xs);
    color: var(--color-ink-soft);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.blog-card__title {
    font-size: var(--fs-xl);
    font-weight: var(--fw-bold);
    color: var(--color-ink);
    line-height: var(--lh-tight);
}

.blog-card__excerpt {
    color: var(--color-ink-muted);
    font-size: var(--fs-sm);
    line-height: var(--lh-relaxed);
}

.blog-card__footer {
    margin-top: auto;
    padding-top: var(--sp-4);
}

/* Статья */

.article {
    max-width: 760px;
    margin-inline: auto;
    padding-block: var(--sp-8) var(--sp-16);
}

.article__header {
    margin-bottom: var(--sp-10);
}

.article__eyebrow {
    display: inline-block;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    color: var(--color-primary);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: var(--sp-3);
}

.article__title {
    font-size: var(--fs-4xl);
    font-weight: var(--fw-black);
    line-height: var(--lh-tight);
    margin-bottom: var(--sp-4);
    letter-spacing: -0.02em;
}

.article__meta {
    display: flex;
    gap: var(--sp-4);
    align-items: center;
    font-size: var(--fs-sm);
    color: var(--color-ink-muted);
}

.article__author {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    font-weight: var(--fw-semibold);
    color: var(--color-ink);
}

.article__author-avatar {
    width: 32px;
    height: 32px;
    border-radius: var(--radius-full);
    background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: var(--fw-bold);
    font-size: var(--fs-sm);
}

.article__content {
    font-size: 1.125rem;
    line-height: 1.75;
}

.article__content p { margin-bottom: var(--sp-5); }

.article__content h2 {
    font-size: var(--fs-2xl);
    margin-top: var(--sp-10);
    margin-bottom: var(--sp-4);
}

.article__content h3 {
    font-size: var(--fs-xl);
    margin-top: var(--sp-8);
    margin-bottom: var(--sp-3);
}

.article__content ul,
.article__content ol {
    margin-bottom: var(--sp-5);
    padding-left: var(--sp-6);
}

.article__content ul { list-style: disc; }
.article__content ol { list-style: decimal; }

.article__content li { margin-bottom: var(--sp-2); }

.article__content a {
    color: var(--color-primary);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.article__content blockquote {
    margin-block: var(--sp-6);
    padding: var(--sp-4) var(--sp-6);
    border-left: 4px solid var(--color-primary);
    background: var(--color-bg-soft);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    font-style: italic;
    color: var(--color-ink-muted);
}

.article__content table {
    margin-block: var(--sp-6);
    font-size: var(--fs-base);
}

.article__content th,
.article__content td {
    padding: var(--sp-3);
    text-align: left;
    border-bottom: 1px solid var(--color-line);
}

.article__content th {
    background: var(--color-bg-soft);
    font-weight: var(--fw-semibold);
}

.article__cta {
    margin-top: var(--sp-12);
    padding: var(--sp-8);
    background: linear-gradient(135deg, rgba(43, 79, 237, 0.08), rgba(255, 92, 57, 0.08));
    border-radius: var(--radius-xl);
    text-align: center;
}

.article__cta h3 {
    font-size: var(--fs-2xl);
    margin-bottom: var(--sp-3);
}

.article__cta p {
    max-width: 500px;
    margin-inline: auto;
    margin-bottom: var(--sp-6);
}
