/*
 * Blog single post: layout, sidebar, comments.
 * Uses Bold tokens: --bg-900, --bg-800, --fg, --muted, --cta, --line2.
 * Contrast: link-on-dark and muted-on-dark meet WCAG AA on dark backgrounds.
 */

.blog-show-page {
    --blog-container-max: 1180px;
}

/* Section-level width: hero and content section share same max-width and padding so they align */
.blog-show-page .blog-show-hero,
.blog-show-page .blog-show-section {
    width: 100%;
    max-width: var(--blog-container-max);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--space-5, 1.25rem);
    padding-right: var(--space-5, 1.25rem);
    box-sizing: border-box;
}
@media (min-width: 640px) {
    .blog-show-page .blog-show-hero,
    .blog-show-page .blog-show-section {
        padding-left: var(--space-6, 1.5rem);
        padding-right: var(--space-6, 1.5rem);
    }
}
@media (min-width: 1024px) {
    .blog-show-page .blog-show-hero,
    .blog-show-page .blog-show-section {
        padding-left: var(--space-8, 2rem);
        padding-right: var(--space-8, 2rem);
    }
}
@media (max-width: 480px) {
    .blog-show-page .blog-show-hero,
    .blog-show-page .blog-show-section {
        padding-left: var(--space-4, 1rem);
        padding-right: var(--space-4, 1rem);
    }
}

/* Shared container width for hero, featured image, and content (same on desktop and mobile) */
.blog-show-page .blog-show-container {
    width: 100%;
    max-width: var(--blog-container-max);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--space-5, 1.25rem);
    padding-right: var(--space-5, 1.25rem);
    box-sizing: border-box;
}
@media (min-width: 640px) {
    .blog-show-page .blog-show-container {
        padding-left: var(--space-6, 1.5rem);
        padding-right: var(--space-6, 1.5rem);
    }
}
@media (min-width: 1024px) {
    .blog-show-page .blog-show-container {
        padding-left: var(--space-8, 2rem);
        padding-right: var(--space-8, 2rem);
    }
}
@media (max-width: 480px) {
    .blog-show-page .blog-show-container {
        padding-left: var(--space-4, 1rem);
        padding-right: var(--space-4, 1rem);
    }
}

/* Hero: top rounded corners (blog show only) */
.blog-show-hero .blog-show-container {
    border-top-left-radius: 1rem;
    border-top-right-radius: 1rem;
}

/* Hero / index: category chip — theme tokens (WCAG AA on dark + light; see base.css --badge-*) */
.blog-show-category-badge {
    display: inline-block;
    padding: 0.5rem 1rem;
    background: var(--badge-bg, rgba(37, 99, 235, 0.12));
    color: var(--badge-fg, #1e3a8a);
    border: 1px solid var(--badge-border, rgba(37, 99, 235, 0.28));
    border-radius: 9999px;
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: 1rem;
}

/* Beat app.css .bg-bg-900 a:not([class*="text-"]) so anchor badges keep --badge-fg */
.bg-bg-900 a.blog-show-category-badge,
.bg-bg-800 a.blog-show-category-badge {
    color: var(--badge-fg, #1e3a8a);
}

/* Grid and sticky sidebar: main content + aside side-by-side on desktop */
.blog-show-section .blog-show-grid {
    display: grid;
    gap: 2.5rem;
    grid-template-columns: 1fr;
}
@media (min-width: 992px) {
    .blog-show-section .blog-show-grid {
        grid-template-columns: 2fr 1fr;
    }
    .blog-show-main {
        min-width: 0; /* allow content to shrink in grid */
    }
    .blog-show-sidebar {
        position: sticky;
        top: 6rem;
        align-self: start;
    }
}

/* Main content: thin border, rounded, distinct from sidebar */
.blog-show-main {
    background: var(--bg-900, #0C0C1F);
    border: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
    border-radius: 1rem;
    padding: 1.5rem;
    min-height: 12rem;
}
@media (min-width: 768px) {
    .blog-show-main {
        padding: 2rem;
    }
}

/* Post body (prose): ensure readable when utility/bundle load order varies */
.blog-show-main .prose {
    color: var(--fg, #EAF4FF);
    max-width: none;
    line-height: 1.7;
}
.blog-show-main .prose p {
    margin-bottom: 1rem;
}
.blog-show-main .prose h1, .blog-show-main .prose h2, .blog-show-main .prose h3 {
    color: var(--fg, #EAF4FF);
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
}
/* Links: distinguishable by underline (not color alone) + sufficient contrast on dark */
.blog-show-main .prose a {
    color: var(--cta-on-dark, #93c5fd);
    text-decoration: underline;
    text-underline-offset: 0.15em;
}
.blog-show-main .prose a:hover {
    color: #bfdbfe;
}
.blog-show-main .prose a:focus-visible {
    outline: 2px solid var(--cta-on-dark, #93c5fd);
    outline-offset: 2px;
}
/* All links in main (breadcrumb, edit, etc.) – underline + contrast */
.blog-show-main a {
    color: var(--cta-on-dark, #93c5fd);
    text-decoration: underline;
    text-underline-offset: 0.15em;
}
.blog-show-main a:hover {
    color: #bfdbfe;
}
.blog-show-main a:focus-visible {
    outline: 2px solid var(--cta-on-dark, #93c5fd);
    outline-offset: 2px;
}
.blog-show-breadcrumb a {
    color: var(--cta-on-dark, #93c5fd);
    text-decoration: underline;
    text-underline-offset: 0.15em;
}
.blog-show-breadcrumb a:hover {
    color: #bfdbfe;
}
.blog-show-main .text-cta {
    color: var(--cta-on-dark, #93c5fd);
}

/* Reaction buttons: Like / Dislike – same size, no fill, bold white text, rounded border, SVG icon */
.blog-show-reactions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}
.blog-show-reactions-label,
.blog-show-reactions-count {
    font-size: 0.875rem;
    color: var(--muted);
}
.blog-show-reaction-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
    min-width: 6.5rem;
    min-height: 2.25rem;
    padding: 0.375rem 0.75rem;
    background: transparent;
    border: 2px solid var(--line1, rgba(255, 255, 255, 0.5));
    border-radius: 9999px;
    color: var(--fg);
    font-size: 0.875rem;
    font-weight: 700;
    cursor: pointer;
    transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.blog-show-reaction-btn:hover {
    border-color: var(--line2, rgba(255, 255, 255, 0.85));
    color: var(--fg);
    background: var(--glass, rgba(255, 255, 255, 0.08));
}
.blog-show-reaction-btn:focus-visible {
    outline: 2px solid var(--cta-on-dark, #93c5fd);
    outline-offset: 2px;
}
.blog-show-reaction-icon {
    flex-shrink: 0;
    width: 1.125rem;
    height: 1.125rem;
    stroke: currentColor;
}

.blog-show-main .prose ul, .blog-show-main .prose ol {
    margin-bottom: 1rem;
    padding-left: 1.5rem;
}

/* Code blocks: scrollable, monospace, copy-friendly */
.blog-show-main .prose pre {
    margin: 1.25rem 0;
    padding: 0;
    background: var(--bg-800, rgba(15, 23, 42, 0.85));
    border: 1px solid var(--line2, rgba(37, 99, 235, 0.2));
    border-radius: 0.75rem;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
    box-sizing: border-box;
}
.blog-show-main .prose pre code {
    display: block;
    padding: 1rem 1.125rem;
    font-size: 0.875rem;
    line-height: 1.6;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;
    color: var(--fg, #EAF4FF);
    white-space: pre;
    word-break: normal;
    overflow-wrap: normal;
    background: transparent;
    border: 0;
    border-radius: 0;
}
.blog-show-main .prose p code,
.blog-show-main .prose li code {
    font-size: 0.9em;
    padding: 0.15em 0.4em;
    border-radius: 0.35rem;
    background: rgba(37, 99, 235, 0.12);
    border: 1px solid rgba(37, 99, 235, 0.2);
    word-break: break-word;
}

/* Related Services block (in main content) */
.blog-show-related-services {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
}
.blog-show-related-services h2 {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 0.75rem;
    color: var(--fg, #EAF4FF);
}
.blog-show-related-services-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.blog-show-related-services-links a {
    display: inline-block;
    padding: 0.5rem 1rem;
    border-radius: 9999px;
    border: 1px solid var(--cta-on-dark, #93c5fd);
    color: var(--cta-on-dark, #93c5fd);
    font-size: 0.875rem;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}
.blog-show-related-services-links a:hover {
    background: rgba(147, 197, 253, 0.15);
    color: #bfdbfe;
}

/* Tags block (in main content) */
.blog-show-tags-block {
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
}
.blog-show-tags-block h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin: 0 0 1rem;
    color: var(--fg, #EAF4FF);
}
.blog-show-tags-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.blog-show-tags-links a {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background: var(--bg-800, #12122a);
    color: var(--muted, #CFE3FF);
    border-radius: 9999px;
    font-size: 0.875rem;
    text-decoration: none;
    transition: color 0.2s, background 0.2s;
}
.blog-show-tags-links a:hover {
    color: var(--fg, #EAF4FF);
}

/* Sidebar cards */
.blog-show-sidebar-card {
    background: var(--bg-900, rgba(15, 23, 42, 0.6));
    border: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
    border-radius: 1rem;
    padding: 1.25rem;
    margin-bottom: 0;
}
.blog-show-sidebar-card + .blog-show-sidebar-card {
    margin-top: 1.5rem;
}
.blog-show-sidebar-card h3 {
    color: var(--fg, #EAF4FF);
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 0.75rem;
}

/* Service and article cards in sidebar */
.blog-show-service-card,
.blog-show-article-card {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    border: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
    border-radius: 0.75rem;
    background: rgba(12, 12, 31, 0.5);
    padding: 0.75rem;
    text-decoration: none;
    color: inherit;
    /* No transition on border/background – avoids non-composited animation (CLS/jank) */
}
.blog-show-service-card:hover,
.blog-show-article-card:hover {
    border-color: rgba(37, 99, 235, 0.35);
    background: var(--bg-800, rgba(15, 23, 42, 0.6));
}
.blog-show-article-cards .blog-show-article-card + .blog-show-article-card,
.blog-show-service-cards .blog-show-service-card + .blog-show-service-card {
    margin-top: 0.75rem;
}
.blog-show-article-card-img-wrap {
    width: 5rem;
    height: 5rem;
    flex-shrink: 0;
    border-radius: 0.5rem;
    overflow: hidden;
    background: var(--bg-800, rgba(15, 23, 42, 0.6));
    border: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
    display: flex;
    align-items: center;
    justify-content: center;
}
.blog-show-article-card-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.blog-show-article-card-img-wrap .blog-show-placeholder-svg {
    width: 2rem;
    height: 2rem;
    opacity: 0.6;
}
.blog-show-article-card-content,
.blog-show-service-card-content {
    min-width: 0;
    flex: 1;
}
.blog-show-article-card-content h4,
.blog-show-service-card-content h4 {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--fg, #EAF4FF);
    margin: 0 0 0.25rem;
}
.blog-show-article-card-content p,
.blog-show-service-card-content p {
    font-size: 0.75rem;
    color: var(--muted, #CFE3FF);
    margin: 0 0 0.5rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.blog-show-article-card-content .text-cta,
.blog-show-service-card-content .text-cta {
    font-size: 0.75rem;
    color: var(--cta-on-dark, #93c5fd);
    font-weight: 500;
}
/* Sidebar cards: links and CTA text – sufficient contrast on dark bg */
.blog-show-sidebar-card a {
    color: inherit;
}
.blog-show-sidebar-card a:hover {
    color: inherit;
}
.blog-show-sidebar-card .blog-show-service-card,
.blog-show-sidebar-card .blog-show-article-card {
    color: var(--fg, #EAF4FF);
}
.blog-show-sidebar-card .blog-show-service-card .text-cta,
.blog-show-sidebar-card .blog-show-service-card span.text-xs.text-cta,
.blog-show-sidebar-card .blog-show-article-card .text-cta {
    color: var(--cta-on-dark, #93c5fd);
}
.blog-show-sidebar-card .blog-show-service-card:hover .text-cta,
.blog-show-sidebar-card .blog-show-article-card:hover .text-cta {
    color: #bfdbfe;
}

/* Search form inside sidebar card */
.blog-show-sidebar-card .blog-aside__search-form {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.blog-show-sidebar-card .blog-aside__search-form .flex {
    display: flex;
    gap: 0.5rem;
}
.blog-show-sidebar-card .blog-aside__search-form input {
    flex: 1;
    padding: 0.5rem 0.75rem;
    background: var(--bg-900, #0C0C1F);
    border: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
    border-radius: 0.5rem;
    color: var(--fg, #EAF4FF);
    font-size: 0.875rem;
}
.blog-show-sidebar-card .blog-aside__search-form input::placeholder {
    color: var(--muted, #CFE3FF);
    opacity: 0.8;
}
.blog-show-sidebar-card .blog-aside__search-form input:focus {
    border-color: var(--cta, #2563eb);
    outline: none;
}
.blog-show-sidebar-card .blog-aside__search-form button {
    padding: 0.5rem 1rem;
    background: var(--cta, #2563eb);
    color: var(--color-on-accent, #fff);
    border: none;
    border-radius: 0.5rem;
    font-weight: 500;
    cursor: pointer;
}
.blog-show-sidebar-card .blog-aside__search-form button:hover {
    opacity: 0.9;
}

/* Tag pills in sidebar */
.blog-show-sidebar-card .flex.flex-wrap.gap-2 {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.blog-show-sidebar-card .flex.flex-wrap.gap-2 a {
    padding: 0.25rem 0.75rem;
    background: var(--bg-800, rgba(15, 23, 42, 0.6));
    color: var(--muted, #CFE3FF);
    border-radius: 9999px;
    font-size: 0.875rem;
    text-decoration: none;
    transition: color 0.2s;
}
.blog-show-sidebar-card .flex.flex-wrap.gap-2 a:hover {
    color: var(--cta-on-dark, #93c5fd);
}

/* Categories list in sidebar */
.blog-show-sidebar-card nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.blog-show-sidebar-card nav ul li {
    margin-bottom: 0.5rem;
}
.blog-show-sidebar-card nav ul li:last-child {
    margin-bottom: 0;
}
.blog-show-sidebar-card nav a {
    color: var(--muted);
    text-decoration: none;
}
.blog-show-sidebar-card nav a:hover {
    color: var(--cta-on-dark, #93c5fd);
}

/* CTA buttons in sidebar */
.blog-show-sidebar-card .flex.flex-col.gap-2 {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.blog-show-sidebar-card .flex.flex-col.gap-2 a {
    display: block;
    padding: 0.625rem 1rem;
    text-align: center;
    font-weight: 600;
    border-radius: 0.5rem;
    text-decoration: none;
    transition: opacity 0.2s;
}
.blog-show-sidebar-card .flex.flex-col.gap-2 a:first-of-type {
    background: var(--cta, #2563eb);
    color: var(--color-on-accent, #fff);
    border: none;
}
.blog-show-sidebar-card .flex.flex-col.gap-2 a:last-of-type {
    border: 1px solid rgba(147, 197, 253, 0.4);
    color: var(--cta-on-dark, #93c5fd);
    background: transparent;
}
.blog-show-sidebar-card .flex.flex-col.gap-2 a:last-of-type:hover {
    color: #bfdbfe;
}

/* Comments section container */
.blog-show-comments {
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
}

/* Comment item and replies */
.blog-show-comment-item {
    margin-bottom: 1rem;
}
.blog-show-comment-item:last-child {
    margin-bottom: 0;
}
.blog-show-comment-body {
    color: var(--fg, #EAF4FF);
}
.blog-show-comment-meta {
    color: var(--muted, #CFE3FF);
}
.blog-show-reply-item {
    margin-bottom: 0.75rem;
}
.blog-show-reply-item:last-child {
    margin-bottom: 0;
}

/* Details/summary for reply form */
.blog-show-details {
    margin-top: 0.5rem;
}
.blog-show-details summary {
    list-style: none;
}
.blog-show-details summary::-webkit-details-marker {
    display: none;
}
.blog-show-details[open] summary {
    margin-bottom: 0.25rem;
}
.blog-show-reply-form-wrap input,
.blog-show-reply-form-wrap textarea {
    background-color: var(--bg-900, #0C0C1F);
    border: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
    color: var(--fg, #EAF4FF);
}
.blog-show-reply-form-wrap input:focus,
.blog-show-reply-form-wrap textarea:focus {
    border-color: var(--cta, #2563eb);
    outline: 0;
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.2);
}

/* Leave comment form */
.blog-show-leave-comment {
    background: var(--bg-800, rgba(15, 23, 42, 0.6));
    border: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
    border-radius: 1rem;
    padding: 1.5rem;
}
.blog-show-leave-comment h3 {
    color: var(--fg, #EAF4FF);
    font-size: 1.25rem;
    font-weight: 700;
    margin: 0 0 1rem;
}
.blog-show-leave-comment .space-y-4 > * + * {
    margin-top: 1rem;
}
.blog-show-leave-comment label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--muted, #CFE3FF);
    margin-bottom: 0.375rem;
}
.blog-show-leave-comment label .text-red-400 {
    color: #f87171;
}
.blog-show-leave-comment input[type="text"],
.blog-show-leave-comment input[type="email"],
.blog-show-leave-comment textarea {
    width: 100%;
    min-height: 2.75rem;
    padding: 0.625rem 0.875rem;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--fg, #EAF4FF);
    background: var(--bg-900, #0C0C1F);
    border: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
    border-radius: 0.5rem;
    box-sizing: border-box;
    transition: border-color 0.2s;
}
.blog-show-leave-comment textarea {
    min-height: 6rem;
    resize: vertical;
}
.blog-show-leave-comment input::placeholder,
.blog-show-leave-comment textarea::placeholder {
    color: var(--muted, #CFE3FF);
    opacity: 0.7;
}
.blog-show-leave-comment input:focus,
.blog-show-leave-comment textarea:focus {
    border-color: var(--cta, #2563eb);
    outline: none;
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.2);
}
.blog-show-leave-comment input:read-only,
.blog-show-leave-comment textarea:read-only {
    opacity: 0.85;
    cursor: not-allowed;
}
.blog-show-leave-comment p.text-xs {
    margin: 0.25rem 0 0;
    font-size: 0.75rem;
    color: var(--muted, #CFE3FF);
}
.blog-show-leave-comment button[type="submit"] {
    width: 100%;
    min-height: 2.75rem;
    padding: 0.625rem 1.25rem;
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-on-accent, #fff);
    background: var(--cta, #2563eb);
    border: none;
    border-radius: 0.5rem;
    cursor: pointer;
    transition: background 0.2s, opacity 0.2s;
}
.blog-show-leave-comment button[type="submit"]:hover {
    background: #1d4ed8;
    opacity: 1;
}
.blog-show-leave-comment button[type="submit"]:focus {
    outline: none;
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.4);
}

/* Post featured image: reserve 16:9 box so decode does not shift layout (Lighthouse CLS) */
.blog-show-featured-media {
    aspect-ratio: 16 / 9;
    width: 100%;
    max-height: min(60vh, 540px);
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    border-radius: 1rem;
    background: var(--bg-800, #15152a);
}
.blog-show-featured-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Line clamp fallback (if not in utilities) */
.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Blog index cards: same colours as .blog-show-main (NVT layout, blog-show styling) */
.blog-index-page .blog-index-card {
    background: var(--bg-900, #0C0C1F);
    border: 1px solid var(--line2, rgba(37, 99, 235, 0.12));
    border-radius: 1rem;
    padding: 0;
    overflow: hidden;
    position: relative;
    transition: border-color 0.2s ease;
}
.blog-index-page .blog-index-card:hover {
    border-color: var(--line1, rgba(37, 99, 235, 0.25));
}
.blog-index-page .blog-index-card__link {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
}
.blog-index-page .blog-index-card__img-wrap {
    position: relative;
    display: block;
    aspect-ratio: 16 / 9;
    background: var(--bg-800, #15152a);
    overflow: hidden;
}
.blog-index-page .blog-index-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.blog-index-page .blog-index-card__img-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: var(--bg-800, #15152a);
}
.blog-index-page .blog-index-card__img-placeholder-icon {
    width: 3.5rem;
    height: 3.5rem;
    color: rgba(255, 255, 255, 0.3);
}
.blog-index-page .blog-index-card__date {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    padding: 0.25rem 0.5rem;
    background: rgba(0, 0, 0, 0.6);
    color: var(--color-on-accent, #fff);
    border-radius: 0.5rem;
    font-size: 0.75rem;
    line-height: 1.2;
}
.blog-index-page .blog-index-card__date-day {
    display: block;
    font-weight: 700;
    font-size: 1rem;
}
.blog-index-page .blog-index-card__date-month {
    display: block;
    text-transform: uppercase;
}
.blog-index-page .blog-index-card__body {
    display: block;
    padding: 1.25rem 1.5rem;
    flex: 1;
}
.blog-index-page .blog-index-card__title {
    font-size: 1.125rem;
    font-weight: 700;
    margin: 0 0 0.5rem;
    color: var(--fg, #EAF4FF);
    line-height: 1.35;
}
.blog-index-page .blog-index-card__link:hover .blog-index-card__title {
    color: var(--cta-on-dark, #93c5fd);
}
.blog-index-page .blog-index-card__excerpt {
    margin: 0 0 0.75rem;
    font-size: 0.875rem;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.blog-index-page .blog-index-card__footer {
    margin: 0;
    font-size: 0.8125rem;
}
.blog-index-page .blog-index-card__category {
    position: absolute;
    bottom: 0.75rem;
    right: 0.75rem;
    margin: 0;
    text-decoration: none;
}
/* Breadcrumb: links distinguishable and sufficient contrast (WCAG) */
.blog-index-page .blog-index-breadcrumb a,
.blog-index-page .blog-index-breadcrumb a.text-cta {
    color: var(--cta-on-dark, #93c5fd);
    text-decoration: underline;
    text-underline-offset: 0.15em;
}
.blog-index-page .blog-index-breadcrumb a:hover,
.blog-index-page .blog-index-results strong {
    color: var(--fg, #EAF4FF);
}

/* Light theme: related cards on blog index/sidebar use dark-tinted panels — switch to surface tokens */
html[data-theme="light"] .blog-show-service-card,
html[data-theme="light"] .blog-show-article-card {
    background: var(--color-surface, #fff);
    border-color: var(--line2);
}
html[data-theme="light"] .blog-show-service-card:hover,
html[data-theme="light"] .blog-show-article-card:hover {
    background: var(--color-surface-deep, #f1f5f9);
    border-color: var(--line1);
}
html[data-theme="light"] .blog-show-article-card-img-wrap {
    background: var(--color-surface-deep, #f1f5f9);
    border-color: var(--line2);
}
html[data-theme="light"] .blog-show-article-card-content .text-cta,
html[data-theme="light"] .blog-show-service-card-content .text-cta {
    color: var(--cta);
}
html[data-theme="light"] .blog-show-sidebar-card .blog-show-service-card .text-cta,
html[data-theme="light"] .blog-show-sidebar-card .blog-show-article-card .text-cta {
    color: var(--cta);
}
html[data-theme="light"] .blog-show-sidebar-card .blog-show-service-card:hover .text-cta,
html[data-theme="light"] .blog-show-sidebar-card .blog-show-article-card:hover .text-cta {
    color: var(--cta-hover);
}
html[data-theme="light"] .blog-index-page .blog-index-card__link:hover .blog-index-card__title {
    color: var(--cta);
}

html[data-theme="light"] .blog-show-main .prose pre {
    background: var(--color-surface-deep, #f1f5f9);
    border-color: var(--line2);
}
html[data-theme="light"] .blog-show-main .prose pre code {
    color: var(--fg, #0f172a);
}
html[data-theme="light"] .blog-show-main .prose p code,
html[data-theme="light"] .blog-show-main .prose li code {
    background: rgba(37, 99, 235, 0.08);
    border-color: rgba(37, 99, 235, 0.2);
}
