/* ==========================================================================
   blog2026.css — CSS exclusivo do template blog2026.blade.php
   Prefixo: .blog2026-*
   Não carrega site2026.css. Tokens definidos aqui.
   Seções de views (list, show, categories, search) são adicionadas ao final.
   ========================================================================== */

/* ── Alpine cloak ─────────────────────────────────────────────────────────── */
[x-cloak] { display: none !important; }

/* ── Base reset ───────────────────────────────────────────────────────────── */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* ── Design tokens: projeto (projeto design2026.md) ──────────────────────── */
:root {
    --color-primary-50:  #eff9fb;
    --color-primary-100: #d7f0f4;
    --color-primary-200: #b2e0e8;
    --color-primary-300: #82c9d5;
    --color-primary-400: #4caec0;
    --color-primary-500: #1d8a9c;
    --color-primary-600: #187285;
    --color-primary-700: #145c6c;
    --color-primary-800: #124a56;
    --color-primary-900: #103b45;

    --color-accent-50:  #fdf1f0;
    --color-accent-100: #fbe0de;
    --color-accent-200: #f6c1be;
    --color-accent-300: #ee9793;
    --color-accent-400: #e36f6b;
    --color-accent-500: #d9534f;
    --color-accent-600: #bd4340;
    --color-accent-700: #9d3836;
    --color-accent-800: #7d302f;
    --color-accent-900: #642928;

    --color-neutral-0:   #ffffff;
    --color-neutral-50:  #f8fafb;
    --color-neutral-100: #eef2f4;
    --color-neutral-200: #d9e2e7;
    --color-neutral-300: #b8c6cf;
    --color-neutral-400: #7f929d;
    --color-neutral-500: #5d6e78;
    --color-neutral-600: #43515a;
    --color-neutral-700: #2e3940;
    --color-neutral-800: #1f282d;
    --color-neutral-900: #141a1d;

    --font-heading: 'Bricolage Grotesque', sans-serif;
    --font-body:    'Plus Jakarta Sans', sans-serif;
}

/* ── Tokens semânticos: tema claro (padrão) ───────────────────────────────── */
[data-theme="light"], :root {
    --blog-bg:              var(--color-neutral-0);
    --blog-surface:         var(--color-neutral-50);
    --blog-surface-strong:  var(--color-neutral-100);
    --blog-border:          rgba(20, 26, 29, 0.09);
    --blog-text:            var(--color-neutral-900);
    --blog-text-muted:      var(--color-neutral-500);
    --blog-text-subtle:     var(--color-neutral-400);
    --blog-link:            var(--color-primary-500);
    --blog-link-hover:      var(--color-primary-600);
    --blog-accent:          var(--color-accent-500);
    --blog-code-bg:         var(--color-neutral-100);
    --blog-blockquote-border: var(--color-primary-300);
    --blog-header-bg:       rgba(255, 255, 255, 0.95);
    --blog-header-border:   rgba(20, 26, 29, 0.08);
    --blog-modal-bg:        var(--color-neutral-0);
}

/* ── Tokens semânticos: tema escuro ──────────────────────────────────────── */
[data-theme="dark"] {
    --blog-bg:              var(--color-neutral-900);
    --blog-surface:         var(--color-neutral-800);
    --blog-surface-strong:  var(--color-neutral-700);
    --blog-border:          rgba(248, 250, 251, 0.11);
    --blog-text:            var(--color-neutral-50);
    --blog-text-muted:      var(--color-neutral-400);
    --blog-text-subtle:     var(--color-neutral-500);
    --blog-link:            var(--color-primary-300);
    --blog-link-hover:      var(--color-primary-200);
    --blog-accent:          var(--color-accent-400);
    --blog-code-bg:         var(--color-neutral-700);
    --blog-blockquote-border: var(--color-primary-400);
    --blog-header-bg:       rgba(20, 26, 29, 0.96);
    --blog-header-border:   rgba(248, 250, 251, 0.1);
    --blog-modal-bg:        var(--color-neutral-800);
}

/* ── Tamanho de fonte do artigo ───────────────────────────────────────────── */
[data-font="sm"] { --blog-body-size: 1rem;    --blog-body-lh: 1.75; }
[data-font="md"] { --blog-body-size: 1.125rem; --blog-body-lh: 1.8;  }
[data-font="lg"] { --blog-body-size: 1.25rem;  --blog-body-lh: 1.85; }

/* ── Body base ───────────────────────────────────────────────────────────── */
html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body.blog2026 {
    font-family: var(--font-body);
    background-color: var(--blog-bg);
    color: var(--blog-text);
    line-height: 1.6;
    transition: background-color 0.2s ease, color 0.2s ease;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* ── Utilitário: visualmente oculto mas acessível ────────────────────────── */
.blog2026-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0;
}

/* ── Skip link ───────────────────────────────────────────────────────────── */
.blog2026-skip-link {
    position: absolute;
    top: -100%;
    left: 1rem;
    z-index: 9999;
    padding: 0.5rem 1rem;
    background: var(--blog-link);
    color: #fff;
    font-family: var(--font-body);
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: 0 0 6px 6px;
    text-decoration: none;
    transition: top 0.2s;
}
.blog2026-skip-link:focus {
    top: 0;
    outline: 2px solid var(--color-primary-300);
    outline-offset: 2px;
}

/* ── Alpine transitions ──────────────────────────────────────────────────── */
.blog2026-t             { transition: opacity 0.18s ease, transform 0.18s ease; }
.blog2026-t--hidden     { opacity: 0; transform: translateY(-6px); }
.blog2026-t--visible    { opacity: 1; transform: translateY(0); }

.blog2026-modal-t           { transition: opacity 0.22s ease, transform 0.22s ease; }
.blog2026-modal-t--hidden   { opacity: 0; transform: scale(0.96); }
.blog2026-modal-t--visible  { opacity: 1; transform: scale(1); }

/* ==========================================================================
   BARRA DE PROGRESSO DE LEITURA
   ========================================================================== */
.blog2026-progress {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9998;
    width: var(--progress, 0%);
    height: 3px;
    background: var(--blog-link);
    transition: width 0.12s linear;
    pointer-events: none;
}

/* ==========================================================================
   HEADER
   ========================================================================== */
.blog2026-header {
    position: sticky;
    top: 0;
    z-index: 900;
    background: var(--blog-header-bg);
    border-bottom: 1px solid var(--blog-header-border);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.blog2026-header--compact {
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

[data-theme="dark"] .blog2026-header--compact {
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
}

.blog2026-header__inner {
    display: flex;
    align-items: center;
    gap: 1rem;
    max-width: none;
    margin: 0 auto;
    padding: 0 1.75rem;
    height: 60px;
}

.blog2026-header__brand {
    display: inline-flex;
    align-items: center;
    color: var(--blog-text);
    font-family: var(--font-heading);
    font-size: 1.65rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0;
    text-decoration: none;
    white-space: nowrap;
}

[data-theme="dark"] .blog2026-header__brand {
    color: var(--color-neutral-0);
}

.blog2026-header__blog-link {
    font-family: var(--font-body);
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--blog-text-muted);
    text-decoration: none;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    transition: color 0.15s ease;
    white-space: nowrap;
}
.blog2026-header__blog-link:hover,
.blog2026-header__blog-link[aria-current="page"] {
    color: var(--blog-link);
}

.blog2026-header__actions {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    margin-left: auto;
}

.blog2026-header-search {
    position: relative;
    display: flex;
    align-items: center;
    width: min(300px, 30vw);
    height: 42px;
    padding: 0 1rem;
    gap: 0.65rem;
    border-radius: 999px;
    background: var(--blog-surface);
    color: var(--blog-text-muted);
    transition: background 0.15s ease, box-shadow 0.15s ease, color 0.15s ease;
}

.blog2026-header-search:focus-within {
    background: var(--blog-bg);
    box-shadow: inset 0 0 0 1px var(--blog-border);
    color: var(--blog-text);
}

.blog2026-header-search__submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 22px;
    height: 22px;
    border: 0;
    padding: 0;
    background: transparent;
    color: inherit;
    cursor: pointer;
}

.blog2026-header-search__submit:focus-visible {
    outline: 2px solid var(--blog-link);
    outline-offset: 3px;
    border-radius: 999px;
}

.blog2026-header-search input[type="search"] {
    width: 100%;
    min-width: 0;
    border: 0;
    outline: 0;
    background: transparent;
    color: var(--blog-text);
    font-family: var(--font-body);
    font-size: 0.95rem;
    -webkit-appearance: none;
    appearance: none;
}

.blog2026-header-search input[type="search"]::placeholder {
    color: var(--blog-text-muted);
}

.blog2026-sidebar-toggle {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    gap: 4px;
    width: 36px;
    height: 36px;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--blog-text-muted);
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
}

.blog2026-sidebar-toggle:hover {
    background: var(--blog-surface);
    color: var(--blog-text);
}

.blog2026-sidebar-toggle:focus-visible {
    outline: 2px solid var(--blog-link);
    outline-offset: 2px;
}

.blog2026-sidebar-toggle span {
    display: block;
    width: 20px;
    height: 1.5px;
    margin: 0 auto;
    border-radius: 999px;
    background: currentColor;
}

/* ── Botão de ícone ──────────────────────────────────────────────────────── */
.blog2026-icon-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: var(--blog-text-muted);
    cursor: pointer;
    font-size: 0.9rem;
    transition: background 0.15s ease, color 0.15s ease;
}
.blog2026-icon-btn:hover {
    background: var(--blog-surface-strong);
    color: var(--blog-text);
}
.blog2026-icon-btn:focus-visible {
    outline: 2px solid var(--blog-link);
    outline-offset: 2px;
}

/* ── Controles de fonte ──────────────────────────────────────────────────── */
.blog2026-font-controls {
    display: flex;
    align-items: center;
    gap: 2px;
    padding: 0 0.25rem;
    border-left: 1px solid var(--blog-border);
    border-right: 1px solid var(--blog-border);
    margin: 0 0.25rem;
}

.blog2026-font-btn {
    border: none;
    background: transparent;
    color: var(--blog-text-muted);
    cursor: pointer;
    padding: 4px 6px;
    border-radius: 4px;
    font-family: var(--font-body);
    font-weight: 600;
    line-height: 1;
    transition: background 0.15s ease, color 0.15s ease;
}
.blog2026-font-btn--sm  { font-size: 0.75rem; }
.blog2026-font-btn--md  { font-size: 0.9rem;  }
.blog2026-font-btn--lg  { font-size: 1.05rem; }
.blog2026-font-btn:hover { background: var(--blog-surface-strong); color: var(--blog-text); }
.blog2026-font-btn--active { color: var(--blog-link); background: var(--color-primary-50); }
[data-theme="dark"] .blog2026-font-btn--active { background: var(--color-primary-900); }
.blog2026-font-btn:focus-visible {
    outline: 2px solid var(--blog-link);
    outline-offset: 1px;
}

/* ── Mobile toggle: visível apenas em telas pequenas ────────────────────── */
.blog2026-mobile-toggle { display: none; }

/* ── Painel de busca ─────────────────────────────────────────────────────── */
.blog2026-search-panel {
    border-top: 1px solid var(--blog-border);
    background: var(--blog-header-bg);
    padding: 0.75rem 0;
}

.blog2026-search-form {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1.25rem;
}

.blog2026-search-form input[type="search"] {
    flex: 1;
    padding: 0.6rem 1rem;
    border: 1px solid var(--blog-border);
    border-radius: 8px;
    background: var(--blog-bg);
    color: var(--blog-text);
    font-family: var(--font-body);
    font-size: 0.9rem;
    outline: none;
    transition: border-color 0.15s ease;
    -webkit-appearance: none;
    appearance: none;
}
.blog2026-search-form input[type="search"]:focus {
    border-color: var(--blog-link);
}
.blog2026-search-form input[type="search"]::placeholder {
    color: var(--blog-text-subtle);
}

.blog2026-search-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 8px;
    background: var(--blog-link);
    color: #fff;
    cursor: pointer;
    font-size: 0.9rem;
    flex-shrink: 0;
    transition: background 0.15s ease;
}
.blog2026-search-btn:hover { background: var(--blog-link-hover); }

/* ── Menu mobile ─────────────────────────────────────────────────────────── */
.blog2026-mobile-menu {
    background: var(--blog-surface);
    border-top: 1px solid var(--blog-border);
    padding: 1rem 1.25rem;
}

.blog2026-mobile-menu__link {
    display: block;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--blog-border);
    color: var(--blog-text);
    text-decoration: none;
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 500;
    transition: color 0.15s ease;
}
.blog2026-mobile-menu__link:last-of-type { border-bottom: none; }
.blog2026-mobile-menu__link:hover { color: var(--blog-link); }

.blog2026-mobile-menu__cta {
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px solid var(--blog-border);
}

/* ==========================================================================
   MAIN
   ========================================================================== */
.blog2026-main {
    flex: 1;
    background: var(--blog-bg);
    transition: background 0.2s ease;
}

.blog2026-shell {
    display: grid;
    grid-template-columns: 216px minmax(48px, 1fr) 760px minmax(48px, 1fr) 248px;
    min-height: calc(100vh - 60px);
    background: var(--blog-bg);
    transition: grid-template-columns 0.2s ease;
}

.blog2026-shell--left-collapsed {
    grid-template-columns: 0 minmax(72px, 1fr) 760px minmax(48px, 1fr) 248px;
}

.blog2026-sidebar {
    position: sticky;
    top: 60px;
    align-self: start;
    height: calc(100vh - 60px);
    overflow-y: auto;
    background: var(--blog-bg);
}

.blog2026-sidebar--left {
    grid-column: 1;
    border-right: 1px solid var(--blog-border);
    padding: 2.5rem 1.5rem;
}

.blog2026-sidebar--right {
    grid-column: 5;
    border-left: 1px solid var(--blog-border);
    padding: 2.5rem 1.5rem;
}

.blog2026--listing .blog2026-main,
.blog2026--article .blog2026-main {
    grid-column: 3;
    min-width: 0;
}

.blog2026-side-nav {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    max-width: 168px;
}

.blog2026-side-nav__link {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-height: 40px;
    color: var(--blog-text-muted);
    font-size: 1rem;
    font-weight: 500;
    text-decoration: none;
    transition: color 0.15s ease;
}

.blog2026-side-nav__link::before {
    content: '';
    position: absolute;
    left: -1.5rem;
    width: 3px;
    height: 28px;
    border-radius: 0 999px 999px 0;
    background: transparent;
}

.blog2026-side-nav__link img {
    width: 24px;
    height: 24px;
    opacity: 0.75;
}

[data-theme="dark"] .blog2026-side-nav__link img {
    filter: invert(1);
}

.blog2026-side-nav__link:hover,
.blog2026-side-nav__link--active {
    color: var(--blog-text);
}

.blog2026-side-nav__link--active::before {
    background: var(--blog-text);
}

.blog2026-side-nav__link--active img,
.blog2026-side-nav__link:hover img {
    opacity: 1;
}

.blog2026-topics {
    max-width: 200px;
}

.blog2026-topics__title {
    margin-bottom: 1.25rem;
    color: var(--blog-text);
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.3;
}

.blog2026-topics__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.blog2026-topic {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0.45rem 1rem;
    border-radius: 999px;
    background: var(--blog-surface);
    color: var(--blog-text);
    font-size: 0.9rem;
    font-weight: 500;
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease;
}

.blog2026-topic:hover {
    background: var(--blog-surface-strong);
    color: var(--blog-link);
}

.blog2026-share-panel {
    max-width: 200px;
    margin-bottom: 2.25rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--blog-border);
}

.blog2026-share-panel__title {
    margin-bottom: 1rem;
    color: var(--blog-text);
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.3;
}

.blog2026-share-panel__actions {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.blog2026-share-link {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    min-height: 36px;
    border: 0;
    padding: 0;
    background: transparent;
    color: var(--blog-text-muted);
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 500;
    text-align: left;
    text-decoration: none;
    cursor: pointer;
    transition: color 0.15s ease;
}

.blog2026-share-link:hover,
.blog2026-share-link:focus-visible {
    color: var(--blog-link);
}

.blog2026-share-link i {
    width: 18px;
    text-align: center;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.blog2026-footer {
    background: var(--color-neutral-900);
    color: var(--color-neutral-300);
    margin-top: auto;
}

.blog2026-footer__inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 3rem 1.25rem 2rem;
    display: flex;
    gap: 3rem;
    align-items: flex-start;
}

.blog2026-footer__brand img {
    display: block;
    height: 32px;
    width: auto;
    margin-bottom: 0.75rem;
}
.blog2026-footer__brand p {
    font-size: 0.85rem;
    line-height: 1.6;
    max-width: 280px;
}

.blog2026-footer__links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1.5rem;
    margin-left: auto;
    align-items: flex-start;
    padding-top: 0.25rem;
}
.blog2026-footer__links a {
    color: var(--color-neutral-400);
    text-decoration: none;
    font-size: 0.85rem;
    transition: color 0.15s ease;
}
.blog2026-footer__links a:hover { color: var(--color-primary-300); }

.blog2026-footer__bar {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1rem 1.25rem 1.5rem;
    border-top: 1px solid var(--color-neutral-800);
}
.blog2026-footer__bar p {
    font-size: 0.8rem;
    color: var(--color-neutral-600);
}

/* ==========================================================================
   BOTÕES
   ========================================================================== */
.blog2026-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.65rem 1.5rem;
    border: none;
    border-radius: 8px;
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
    white-space: nowrap;
}
.blog2026-btn:focus-visible {
    outline: 2px solid var(--blog-link);
    outline-offset: 2px;
}
.blog2026-btn:disabled,
.blog2026-btn[aria-disabled="true"] {
    opacity: 0.52;
    cursor: not-allowed;
    box-shadow: none;
}

.blog2026-btn--primary {
    background: var(--color-primary-500);
    color: #fff;
}
.blog2026-btn--primary:hover { background: var(--color-primary-600); }

.blog2026-btn--accent {
    background: var(--color-accent-500);
    color: #fff;
}
.blog2026-btn--accent:hover { background: var(--color-accent-600); }

.blog2026-btn--ghost {
    background: transparent;
    color: var(--blog-link);
    border: 1.5px solid var(--blog-link);
}
.blog2026-btn--ghost:hover {
    background: var(--color-primary-50);
}
[data-theme="dark"] .blog2026-btn--ghost:hover {
    background: var(--color-primary-900);
}

.blog2026-btn--full { width: 100%; }

/* ==========================================================================
   LEAD MODAL
   ========================================================================== */
.blog2026-lead-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(20, 26, 29, 0.62);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 1000;
    cursor: pointer;
    transition: opacity 0.22s ease;
}

.blog2026-lead-modal {
    position: fixed;
    inset: 0;
    z-index: 1001;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
    pointer-events: none;
}
.blog2026-lead-modal[x-show]:not([style*="display: none"]) {
    pointer-events: auto;
}

.blog2026-lead-modal__surface {
    position: relative;
    background: #fff;
    color: var(--color-neutral-900);
    border-radius: 16px;
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.25);
    width: 100%;
    max-width: 820px;
    max-height: 90vh;
    overflow-y: auto;
    pointer-events: auto;
}

.blog2026-lead-modal__body {
    position: relative;
    display: grid;
    grid-template-columns: minmax(240px, 0.92fr) minmax(320px, 1fr);
    width: min(920px, calc(100vw - 2.5rem));
    max-height: min(720px, calc(100vh - 2.5rem));
    overflow: hidden;
    background: #fff;
    color: var(--color-neutral-900);
    border-radius: 16px;
    border: 1px solid rgba(20, 26, 29, 0.08);
    box-shadow: 0 28px 90px rgba(0, 0, 0, 0.32);
    pointer-events: auto;
}

.blog2026-lead-modal__close {
    position: absolute;
    top: 0.85rem;
    right: 0.85rem;
    z-index: 20;
    width: 44px;
    height: 44px;
    border: 2px solid #fff;
    border-radius: 50%;
    background: var(--color-neutral-900);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    box-shadow: 0 12px 30px rgba(20, 26, 29, 0.28);
    transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
}
.blog2026-lead-modal__close:hover {
    background: var(--color-accent-500);
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 16px 36px rgba(217, 83, 79, 0.34);
}
.blog2026-lead-modal__close:focus-visible {
    outline: 3px solid rgba(29, 138, 156, 0.42);
    outline-offset: 3px;
}

.blog2026-lead-modal__image {
    border-radius: 16px 0 0 16px;
    overflow: hidden;
    background: var(--color-primary-50);
    min-height: 100%;
}
.blog2026-lead-modal__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.blog2026-lead-modal__form {
    max-height: min(720px, calc(100vh - 2.5rem));
    overflow-y: auto;
    padding: 2.5rem 2.5rem 2.25rem;
    background: #fff;
}

.blog2026-lead-modal__form h2 {
    font-family: var(--font-heading);
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--blog-text);
    margin-bottom: 0.75rem;
    line-height: 1.3;
}

.blog2026-lead-modal__form ul {
    list-style: none;
    margin-bottom: 1.25rem;
}
.blog2026-lead-modal__form ul li {
    font-size: 0.875rem;
    color: var(--blog-text-muted);
    padding: 0.2rem 0;
}
.blog2026-lead-modal__form ul li::before {
    content: '→ ';
    color: var(--blog-accent);
    font-weight: 700;
}

/* ── Campos do formulário ────────────────────────────────────────────────── */
.blog2026-field {
    margin-bottom: 0.75rem;
}
.blog2026-field label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--blog-text-muted);
    margin-bottom: 0.3rem;
}
.blog2026-field input {
    width: 100%;
    padding: 0.6rem 0.875rem;
    border: 1px solid var(--blog-border);
    border-radius: 8px;
    background: var(--blog-bg);
    color: var(--blog-text);
    font-family: var(--font-body);
    font-size: 0.9rem;
    outline: none;
    transition: border-color 0.15s ease;
    -webkit-appearance: none;
    appearance: none;
}
.blog2026-field input:focus {
    border-color: var(--blog-link);
}
.blog2026-field input::placeholder {
    color: var(--blog-text-subtle);
}

.blog2026-lgpd {
    margin-bottom: 1rem;
}
.blog2026-lgpd label {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.78rem;
    color: var(--blog-text-muted);
    line-height: 1.4;
    cursor: pointer;
}
.blog2026-lgpd input[type="checkbox"] {
    margin-top: 2px;
    flex-shrink: 0;
    accent-color: var(--blog-link);
}
.blog2026-lgpd a {
    color: var(--blog-link);
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* Ajuste visual do modal de eBooks */
.blog2026-lead-modal__body {
    background: #fff;
    color: var(--color-neutral-900);
    border: 1px solid rgba(20, 26, 29, 0.08);
    box-shadow: 0 28px 90px rgba(0, 0, 0, 0.32);
}

.blog2026-lead-modal__close {
    width: 44px;
    height: 44px;
    background: var(--color-neutral-900);
    color: #fff;
}

.blog2026-lead-modal__close:hover {
    background: var(--color-accent-500);
    color: #fff;
}

.blog2026-lead-modal__form {
    background: #fff;
    color: var(--color-neutral-900);
}

.blog2026-lead-modal__form h2 {
    font-size: clamp(1.45rem, 3vw, 2rem);
    font-weight: 800;
    color: var(--color-neutral-900);
    margin-bottom: 1rem;
    line-height: 1.12;
    letter-spacing: 0;
}

.blog2026-lead-modal__form ul {
    margin-bottom: 1.5rem;
}

.blog2026-lead-modal__form ul li {
    font-size: 0.92rem;
    color: var(--color-neutral-600);
    padding: 0.25rem 0;
}

.blog2026-lead-modal__form ul li::before {
    content: '→ ';
    color: var(--color-accent-500);
    font-weight: 700;
}

.blog2026-lead-modal__form .blog2026-field label,
.blog2026-lead-modal__form .blog2026-lgpd label {
    color: var(--color-neutral-600);
}

.blog2026-lead-modal__form .blog2026-field input {
    border-color: var(--color-neutral-200);
    background: #fff;
    color: var(--color-neutral-900);
}

.blog2026-lead-modal__form .blog2026-field input:focus {
    border-color: var(--color-primary-500);
    box-shadow: 0 0 0 3px rgba(29, 138, 156, 0.12);
}

.blog2026-lead-modal__form .blog2026-lgpd a {
    color: var(--color-primary-600);
}

/* ==========================================================================
   WHATSAPP FLUTUANTE
   (mantido idêntico ao site2026 para reutilização sem conflito)
   ========================================================================== */
.wa-float {
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: 800;
}

@media (max-width: 767px) {
    .wa-float { display: none; }
}

.wa-float__btn {
    position: relative;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    border: none;
    background: #25d366;
    cursor: pointer;
    box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    overflow: hidden;
}
.wa-float__btn:hover { transform: scale(1.08); box-shadow: 0 6px 28px rgba(37, 211, 102, 0.5); }
.wa-float__btn--open { transform: scale(1.05); }

.wa-float__avatar {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
    display: block;
}

.wa-float__badge {
    position: absolute;
    bottom: -2px;
    right: -2px;
    width: 22px;
    height: 22px;
    background: #25d366;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid var(--blog-bg);
    color: #fff;
}
.wa-float__badge svg { width: 12px; height: 12px; }

.wa-float__tooltip {
    position: absolute;
    right: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%);
    background: var(--color-neutral-900);
    color: #fff;
    font-size: 0.78rem;
    font-weight: 600;
    white-space: nowrap;
    padding: 5px 10px;
    border-radius: 6px;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s ease;
}
.wa-float__btn:hover .wa-float__tooltip { opacity: 1; }

.wa-float__modal {
    position: absolute;
    bottom: calc(100% + 12px);
    right: 0;
    width: 280px;
    background: var(--blog-modal-bg);
    border-radius: 14px;
    padding: 1.25rem;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.18);
    border: 1px solid var(--blog-border);
}

.wa-float__modal-header {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 0.6rem;
}
.wa-float__modal-icon {
    width: 32px;
    height: 32px;
    background: #25d366;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    flex-shrink: 0;
}
.wa-float__modal-icon svg { width: 16px; height: 16px; }
.wa-float__modal-title {
    font-family: var(--font-heading);
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--blog-text);
}
.wa-float__modal-body {
    font-size: 0.8rem;
    color: var(--blog-text-muted);
    line-height: 1.5;
    margin-bottom: 1rem;
}
.wa-float__modal-cta {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    width: 100%;
    padding: 0.65rem 1rem;
    background: #25d366;
    color: #fff;
    border-radius: 8px;
    font-size: 0.875rem;
    font-weight: 700;
    text-decoration: none;
    transition: background 0.15s ease;
}
.wa-float__modal-cta:hover { background: #1db858; }
.wa-float__modal-close {
    position: absolute;
    top: 0.6rem;
    right: 0.6rem;
    border: none;
    background: transparent;
    color: var(--blog-text-subtle);
    cursor: pointer;
    padding: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    transition: color 0.15s ease;
}
.wa-float__modal-close:hover { color: var(--blog-text); }

/* Alpine transitions para WA float */
.wa-enter { transition: opacity 0.2s ease, transform 0.2s ease; }
.wa-enter-start { opacity: 0; transform: scale(0.95) translateY(6px); }
.wa-enter-end { opacity: 1; transform: scale(1) translateY(0); }

/* ==========================================================================
   RESPONSIVO
   ========================================================================== */
@media (max-width: 767px) {
    .blog2026-header__inner {
        height: auto;
        min-height: 58px;
        flex-wrap: wrap;
        padding: 0.75rem 1rem;
        gap: 0.75rem;
    }
    .blog2026-header__brand { font-size: 1.45rem; }
    .blog2026-sidebar-toggle { display: none; }
    .blog2026-header-search {
        order: 3;
        width: 100%;
    }
    .blog2026-header__blog-link { display: none; }
    .blog2026-mobile-toggle     { display: flex; }
    .blog2026-font-controls     { display: none; }
    .blog2026-shell {
        display: block;
        min-height: auto;
    }
    .blog2026-sidebar {
        display: none;
    }

    .blog2026-footer__inner {
        flex-direction: column;
        gap: 1.5rem;
    }
    .blog2026-footer__links {
        margin-left: 0;
    }

    .blog2026-lead-modal__body {
        grid-template-columns: 1fr;
    }
    .blog2026-lead-modal__image {
        display: none;
    }
    .blog2026-lead-modal__form {
        padding: 2rem 1.5rem;
    }
    .blog2026-lead-modal__body {
        border-radius: 12px;
    }
}

@media (min-width: 768px) {
    .blog2026-mobile-menu { display: none !important; }
}

@media (max-width: 1180px) {
    .blog2026-shell {
        grid-template-columns: 76px minmax(32px, 1fr) minmax(0, 760px) minmax(32px, 1fr) 220px;
    }
    .blog2026-shell--left-collapsed {
        grid-template-columns: 0 minmax(48px, 1fr) minmax(0, 760px) minmax(32px, 1fr) 220px;
    }
    .blog2026-sidebar--left {
        padding-inline: 1rem;
    }
    .blog2026-side-nav__link {
        justify-content: center;
    }
    .blog2026-side-nav__link span {
        position: absolute;
        width: 1px;
        height: 1px;
        overflow: hidden;
        clip: rect(0 0 0 0);
        white-space: nowrap;
    }
    .blog2026-side-nav__link::before {
        left: -1rem;
    }
}

@media (max-width: 1020px) {
    .blog2026-shell {
        grid-template-columns: 76px minmax(32px, 1fr) minmax(0, 760px) minmax(32px, 1fr);
    }
    .blog2026-shell--left-collapsed {
        grid-template-columns: 0 minmax(48px, 1fr) minmax(0, 760px) minmax(32px, 1fr);
    }
    .blog2026-sidebar--right {
        display: none;
    }
}

/* ==========================================================================
   VIEW-SPECIFIC — adicionar ao final conforme as views forem construídas

   Prefixos recomendados:
     .blog-list-*    → list.blade.php (listagem)
     .blog-show-*    → show.blade.php (artigo)
     .blog-cat-*     → categories.blade.php (categoria)
     .blog-search-*  → search.blade.php (busca)
   ========================================================================== */

/* ==========================================================================
   LISTAGEM — list.blade.php (.blog-list-*)
   ========================================================================== */

/* ── Container da listagem ───────────────────────────────────────────────── */
.blog-list-container {
    max-width: 760px;
    margin: 0 auto;
    padding: 0 2rem;
}

/* ── Hero ────────────────────────────────────────────────────────────────── */
.blog-list-hero {
    padding: 2.8rem 0 2rem;
    border-bottom: 1px solid var(--blog-border);
}

.blog-list-hero__eyebrow {
    font-family: var(--font-body);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--blog-link);
    margin-bottom: 0.75rem;
}

.blog-list-hero__title {
    font-family: var(--font-heading);
    font-size: clamp(1.65rem, 3vw, 2.35rem);
    font-weight: 700;
    line-height: 1.2;
    color: var(--blog-text);
    margin-bottom: 0.875rem;
}

.blog-list-hero__lead {
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--blog-text-muted);
    max-width: 580px;
}

.blog-cat-summary {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.25rem;
    color: var(--blog-text-subtle);
    font-size: 0.85rem;
}

.blog-cat-summary a {
    color: var(--blog-link);
    font-weight: 600;
    text-decoration: none;
}

.blog-cat-summary a:hover {
    color: var(--blog-link-hover);
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* ── Seção de posts ──────────────────────────────────────────────────────── */
.blog-list-posts {
    padding: 2.25rem 0 4rem;
}

/* ── Divider ─────────────────────────────────────────────────────────────── */
.blog-list-divider {
    height: 1px;
    background: var(--blog-border);
    margin: 2.5rem 0;
}

/* ── Badge de categoria ──────────────────────────────────────────────────── */
.blog-list-badge {
    display: inline-block;
    font-family: var(--font-body);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--blog-accent);
    text-decoration: none;
    transition: color 0.15s ease;
}
.blog-list-badge:hover { color: var(--color-accent-600); }
[data-theme="dark"] .blog-list-badge:hover { color: var(--color-accent-300); }

/* ── Meta (data, tempo) ──────────────────────────────────────────────────── */
.blog-list-item__meta,
.blog-list-featured__meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.35rem;
    font-size: 0.8rem;
    color: var(--blog-text-subtle);
    margin-bottom: 0.6rem;
}
.blog-list-meta-sep { opacity: 0.5; }

/* ── Post em destaque ────────────────────────────────────────────────────── */
.blog-list-featured {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 200px;
    gap: 1.5rem;
    align-items: center;
    margin-bottom: 0;
}

.blog-list-featured__img-link {
    grid-column: 2;
    grid-row: 1;
    display: block;
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 0;
    background: var(--blog-surface);
}
.blog-list-featured__img {
    width: 100%;
    height: 134px;
    aspect-ratio: 3 / 2;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}
.blog-list-featured__img-link:hover .blog-list-featured__img {
    transform: scale(1.02);
}

.blog-list-featured__body {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
}

.blog-list-featured__title {
    font-family: var(--font-heading);
    font-size: clamp(1.35rem, 2.2vw, 1.7rem);
    font-weight: 700;
    line-height: 1.25;
    margin-bottom: 0.75rem;
}
.blog-list-featured__title a {
    color: var(--blog-text);
    text-decoration: none;
    transition: color 0.15s ease;
}
.blog-list-featured__title a:hover { color: var(--blog-link); }

.blog-list-featured__desc {
    font-size: 1rem;
    line-height: 1.65;
    color: var(--blog-text-muted);
    margin-bottom: 1rem;
}

.blog-list-featured__read {
    display: none;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--blog-link);
    text-decoration: none;
    transition: gap 0.2s ease, color 0.15s ease;
}
.blog-list-featured__read:hover {
    gap: 0.55rem;
    color: var(--blog-link-hover);
}

/* ── Post regular (list item) ────────────────────────────────────────────── */
.blog-list-item {
    display: flex;
    align-items: flex-start;
    gap: 1.5rem;
    padding: 2rem 0;
    border-top: 1px solid var(--blog-border);
}

.blog-list-item__body {
    flex: 1;
    min-width: 0;
}

.blog-list-item__title {
    font-family: var(--font-heading);
    font-size: 1.15rem;
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: 0.4rem;
}
.blog-list-item__title a {
    color: var(--blog-text);
    text-decoration: none;
    transition: color 0.15s ease;
}
.blog-list-item__title a:hover { color: var(--blog-link); }

.blog-list-item__desc {
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--blog-text-muted);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.blog-list-item__thumb {
    flex-shrink: 0;
    width: 200px;
    height: 134px;
    border-radius: 4px;
    overflow: hidden;
    background: var(--blog-surface);
    display: block;
}
.blog-list-item__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}
.blog-list-item__thumb:hover img { transform: scale(1.04); }

/* ── Estado vazio ────────────────────────────────────────────────────────── */
.blog-list-empty {
    text-align: center;
    padding: 3rem 0;
    color: var(--blog-text-muted);
    font-size: 1rem;
}

/* ── Paginação ───────────────────────────────────────────────────────────── */
.blog-list-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--blog-border);
}

.blog-list-pagination__btn {
    display: inline-flex;
    align-items: center;
    padding: 0.55rem 1.1rem;
    border: 1.5px solid var(--blog-border);
    border-radius: 8px;
    font-family: var(--font-body);
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--blog-text);
    text-decoration: none;
    background: transparent;
    transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease;
}
.blog-list-pagination__btn:not(.blog-list-pagination__btn--disabled):hover {
    border-color: var(--blog-link);
    color: var(--blog-link);
    background: var(--color-primary-50);
}
[data-theme="dark"] .blog-list-pagination__btn:not(.blog-list-pagination__btn--disabled):hover {
    background: var(--color-primary-900);
}
.blog-list-pagination__btn--disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.blog-list-pagination__info {
    font-size: 0.85rem;
    color: var(--blog-text-muted);
    white-space: nowrap;
}

/* ── Responsivo — listagem ───────────────────────────────────────────────── */
@media (max-width: 600px) {
    .blog-list-container { padding: 0 1.25rem; }
    .blog-list-hero { padding: 2rem 0 1.75rem; }

    .blog-list-featured {
        display: flex;
        flex-direction: column;
        align-items: stretch;
    }
    .blog-list-featured__img-link {
        order: -1;
        margin-bottom: 0.25rem;
    }
    .blog-list-featured__img {
        height: auto;
        aspect-ratio: 16 / 9;
    }

    .blog-list-item { gap: 1rem; }
    .blog-list-item__thumb {
        width: 96px;
        height: 64px;
        border-radius: 6px;
    }
    .blog-list-item__desc { display: none; }

    .blog-list-pagination {
        flex-direction: column;
        gap: 0.75rem;
        text-align: center;
    }
}

/* ==========================================================================
   ARTIGO — show.blade.php (.blog-show-*)
   ========================================================================== */

/* ── Container estreito (Medium-style 680px) ─────────────────────────────── */
.blog-show-container {
    max-width: 680px;
    margin: 0 auto;
    padding: 0 1.25rem;
}

/* ── Header do artigo ────────────────────────────────────────────────────── */
.blog-show-hero {
    padding: 3rem 0 2.5rem;
}

.blog-show-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.35rem;
    font-size: 0.8rem;
    color: var(--blog-text-muted);
    margin-bottom: 1.5rem;
}
.blog-show-breadcrumb a {
    color: var(--blog-text-muted);
    text-decoration: none;
    transition: color 0.15s ease;
}
.blog-show-breadcrumb a:hover { color: var(--blog-link); }
.blog-show-breadcrumb span[aria-hidden] { opacity: 0.5; }

.blog-show-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.35rem;
    font-size: 0.82rem;
    color: var(--blog-text-subtle);
    margin-bottom: 1.25rem;
}

.blog-show-title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 5vw, 2.75rem);
    font-weight: 800;
    line-height: 1.15;
    color: var(--blog-text);
    margin-bottom: 1.25rem;
    letter-spacing: -0.02em;
}

.blog-show-lead {
    font-family: var(--font-body);
    font-size: clamp(1.05rem, 2.5vw, 1.2rem);
    line-height: 1.7;
    color: var(--blog-text-muted);
}

.blog-show-share {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1.5rem;
}

.blog-show-share__link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 34px;
    padding: 0.35rem 0.75rem;
    border: 1px solid var(--blog-border);
    border-radius: 999px;
    background: transparent;
    color: var(--blog-text-muted);
    font-family: var(--font-body);
    font-size: 0.82rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease;
}

.blog-show-share__link:hover,
.blog-show-share__link:focus-visible {
    border-color: var(--blog-link);
    color: var(--blog-link);
    background: var(--blog-surface);
}

.blog-show-share__link--button {
    appearance: none;
}

/* ── Imagem de capa ──────────────────────────────────────────────────────── */
.blog-show-cover {
    max-width: 760px;
    margin: 0 auto 2.5rem;
    padding: 0 2rem;
}
.blog-show-cover__img {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-radius: 12px;
    display: block;
}

/* ── Conteúdo do artigo (tipografia editorial) ───────────────────────────── */
.blog-show-content {
    font-family: var(--font-body);
    font-size: var(--blog-body-size, 1.125rem);
    line-height: var(--blog-body-lh, 1.8);
    color: var(--blog-text);
    padding-bottom: 2rem;
}

.blog-show-content h1,
.blog-show-content h2,
.blog-show-content h3,
.blog-show-content h4,
.blog-show-content h5,
.blog-show-content h6 {
    font-family: var(--font-heading);
    font-weight: 700;
    color: var(--blog-text);
    margin-top: 2.25em;
    margin-bottom: 0.6em;
    line-height: 1.25;
    letter-spacing: -0.015em;
}
.blog-show-content h1 { font-size: 1.85em; }
.blog-show-content h2 { font-size: 1.5em; }
.blog-show-content h3 { font-size: 1.25em; }
.blog-show-content h4 { font-size: 1.1em; }
.blog-show-content h5,
.blog-show-content h6 { font-size: 1em; }

.blog-show-content p { margin-bottom: 1.5em; }

.blog-show-content a {
    color: var(--blog-link);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    transition: color 0.15s ease;
}
.blog-show-content a:hover { color: var(--blog-link-hover); }

.blog-show-content ul,
.blog-show-content ol {
    margin-bottom: 1.5em;
    padding-left: 1.75em;
}
.blog-show-content li { margin-bottom: 0.4em; }
.blog-show-content li::marker { color: var(--blog-link); }

.blog-show-content blockquote {
    border-left: 4px solid var(--blog-blockquote-border);
    margin: 2em 0;
    padding: 0.75em 1.25em;
    background: var(--blog-surface);
    border-radius: 0 8px 8px 0;
    font-style: italic;
    color: var(--blog-text-muted);
}
.blog-show-content blockquote p:last-child { margin-bottom: 0; }

.blog-show-content code {
    font-family: 'Fira Code', 'Cascadia Code', 'Courier New', monospace;
    font-size: 0.875em;
    background: var(--blog-code-bg);
    padding: 0.15em 0.4em;
    border-radius: 4px;
    color: var(--color-accent-600);
}
[data-theme="dark"] .blog-show-content code { color: var(--color-accent-300); }

.blog-show-content pre {
    background: var(--blog-code-bg);
    border: 1px solid var(--blog-border);
    border-radius: 10px;
    padding: 1.25em 1.5em;
    overflow-x: auto;
    margin-bottom: 1.5em;
    tab-size: 4;
}
.blog-show-content pre code {
    background: transparent;
    padding: 0;
    font-size: 0.875rem;
    color: var(--blog-text);
}

.blog-show-content table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1.5em;
    font-size: 0.9em;
}
.blog-show-content th,
.blog-show-content td {
    border: 1px solid var(--blog-border);
    padding: 0.6em 0.875em;
    text-align: left;
}
.blog-show-content th {
    background: var(--blog-surface);
    font-weight: 700;
    color: var(--blog-text);
}
.blog-show-content tr:nth-child(even) td { background: var(--blog-surface); }

.blog-show-content figure,
.blog-show-figure {
    margin: 2em 0;
    text-align: center;
}
.blog-show-content img,
.blog-show-img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    display: block;
    margin: 0 auto;
}
.blog-show-content figcaption {
    margin-top: 0.6em;
    font-size: 0.8rem;
    color: var(--blog-text-muted);
    font-style: italic;
}

.blog-show-content hr {
    border: none;
    border-top: 1px solid var(--blog-border);
    margin: 2.5em 0;
}

.blog-show-content strong { font-weight: 700; }
.blog-show-content em { font-style: italic; }
.blog-show-content u { text-decoration: underline; text-underline-offset: 3px; }
.blog-show-content s { text-decoration: line-through; opacity: 0.7; }

.blog-show-content mark {
    background: rgba(255, 237, 0, 0.35);
    color: inherit;
    border-radius: 2px;
    padding: 0 0.15em;
}
[data-theme="dark"] .blog-show-content mark { background: rgba(255, 237, 0, 0.18); }

.blog-show-content small { font-size: 0.85em; }
.blog-show-content sup   { font-size: 0.75em; vertical-align: super; }
.blog-show-content sub   { font-size: 0.75em; vertical-align: sub; }

.blog-show-content dl { margin-bottom: 1.5em; }
.blog-show-content dt {
    font-weight: 700;
    color: var(--blog-text);
    margin-top: 1em;
}
.blog-show-content dd {
    margin-left: 1.5em;
    color: var(--blog-text-muted);
}

.blog-show-content details {
    border: 1px solid var(--blog-border);
    border-radius: 8px;
    padding: 0.75em 1em;
    margin-bottom: 1.5em;
    background: var(--blog-surface);
}
.blog-show-content summary {
    cursor: pointer;
    font-weight: 600;
    color: var(--blog-text);
    list-style: none;
    display: flex;
    align-items: center;
    gap: 0.5em;
}
.blog-show-content summary::-webkit-details-marker { display: none; }
.blog-show-content summary::before {
    content: '▶';
    font-size: 0.7em;
    transition: transform 0.2s ease;
    flex-shrink: 0;
}
.blog-show-content details[open] summary::before { transform: rotate(90deg); }
.blog-show-content details > *:not(summary) { margin-top: 0.75em; }

/* CTA container criado pelo editor de conteúdo */
.blog-show-content .cta-container {
    background: var(--color-primary-50);
    border: 1px solid var(--color-primary-200);
    border-radius: 10px;
    padding: 1.5em;
    margin: 2em 0;
    text-align: center;
}
[data-theme="dark"] .blog-show-content .cta-container {
    background: var(--color-primary-900);
    border-color: var(--color-primary-700);
}
.blog-show-content .cta-container a {
    display: inline-flex;
    padding: 0.65em 1.5em;
    background: var(--color-primary-500);
    color: #fff;
    border-radius: 8px;
    font-weight: 700;
    text-decoration: none;
    transition: background 0.15s ease;
}
.blog-show-content .cta-container a:hover {
    background: var(--color-primary-600);
    color: #fff;
}

/* ── Divider ─────────────────────────────────────────────────────────────── */
.blog-show-divider {
    border: none;
    border-top: 1px solid var(--blog-border);
    margin: 2.5rem 0;
}

/* ── CTA inline após artigo ──────────────────────────────────────────────── */
.blog-show-cta { margin: 2.5rem 0; }
.blog-show-cta__inner {
    background: var(--blog-surface);
    border: 1px solid var(--blog-border);
    border-left: 4px solid var(--blog-link);
    border-radius: 0 10px 10px 0;
    padding: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
    flex-wrap: wrap;
}
.blog-show-cta__title {
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 600;
    color: var(--blog-text);
    margin: 0;
    flex: 1;
    min-width: 200px;
}

/* ── Autor ───────────────────────────────────────────────────────────────── */
.blog-show-author {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: var(--blog-text-muted);
    margin-bottom: 3rem;
}
.blog-show-author__label { color: var(--blog-text-subtle); }
.blog-show-author__name {
    color: var(--blog-link);
    text-decoration: none;
    font-weight: 600;
}
.blog-show-author__name:hover { text-decoration: underline; }

/* ── Posts relacionados ──────────────────────────────────────────────────── */
.blog-show-related {
    border-top: 1px solid var(--blog-border);
    padding: 3rem 0 4rem;
}

.blog-show-related__title {
    font-family: var(--font-heading);
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--blog-text);
    margin-bottom: 2rem;
}

.blog-show-related__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1.5rem;
}

.blog-show-related__img-link {
    display: block;
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 0.75rem;
    background: var(--blog-surface-strong);
    aspect-ratio: 16 / 9;
}
.blog-show-related__img-link img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}
.blog-show-related__img-link:hover img { transform: scale(1.04); }

.blog-show-related__body {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.blog-show-related__item-title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.3;
    margin: 0;
}
.blog-show-related__item-title a {
    color: var(--blog-text);
    text-decoration: none;
    transition: color 0.15s ease;
}
.blog-show-related__item-title a:hover { color: var(--blog-link); }

.blog-show-related__date {
    font-size: 0.78rem;
    color: var(--blog-text-subtle);
}

/* ── Responsivo — artigo ─────────────────────────────────────────────────── */
@media (max-width: 720px) {
    .blog-show-hero  { padding: 2rem 0 1.75rem; }
    .blog-show-cover { margin-bottom: 1.75rem; }
    .blog-show-cover__img { border-radius: 0; }
    .blog-show-cta__inner { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 600px) {
    .blog-show-related__grid { grid-template-columns: 1fr 1fr; gap: 1rem; }
}

@media (max-width: 400px) {
    .blog-show-related__grid { grid-template-columns: 1fr; }
}

/* Overflow para tabelas em telas pequenas */
@media (max-width: 680px) {
    .blog-show-content table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}
