/* ==========================================================================
   Blog Article Hero — Banner verde com badge, data, título e subtítulo
   ========================================================================== */

.blog-article-hero {
    position: relative;
    background-color: #AECA37;
    padding: var(--hero-banner-pad-top) 0 var(--hero-banner-pad-bottom);
    overflow: hidden;
    isolation: isolate;
}

/* Grid pattern de fundo, fade radial — desenhado com gradientes lineares
   e mascarado para suavizar nas bordas. Não usa imagem externa. */
.blog-article-hero__pattern {
    position: absolute;
    inset: 0;
    z-index: -1;
    background-image:
        linear-gradient(to right, rgba(255, 255, 255, 0.18) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255, 255, 255, 0.18) 1px, transparent 1px);
    background-size: clamp(56px, 5vw, 80px) clamp(56px, 5vw, 80px);
    -webkit-mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, #000 0%, rgba(0, 0, 0, 0.6) 50%, transparent 100%);
            mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, #000 0%, rgba(0, 0, 0, 0.6) 50%, transparent 100%);
    pointer-events: none;
}

.blog-article-hero__container {
    width: 100%;
    max-width: 1216px;
    margin: 0 auto;
    padding: 0 var(--container-padding);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--hero-gap-content);
}

/* ===== Badge ===== */

.blog-article-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: clamp(6px, 0.5vw, 8px);
    padding: clamp(5px, 0.4vw, 6px) clamp(12px, calc(8px + 0.5vw), 16px);
    background-color: var(--color-white);
    border-radius: 100px;
    font-family: var(--font-body);
    font-size: var(--hero-badge-size);
    font-weight: 500;
    line-height: 1.4;
    color: #252B37;
}

.blog-article-hero__badge img {
    width: clamp(14px, calc(12px + 0.25vw), 16px);
    height: clamp(14px, calc(12px + 0.25vw), 16px);
}

/* ===== Data de publicação ===== */

.blog-article-hero__published {
    margin: 0;
    font-family: var(--font-body);
    font-size: var(--hero-caption-size);
    font-weight: 400;
    line-height: 1.6;
    letter-spacing: -0.01em;
    color: #252B37;
    text-transform: uppercase;
}

.blog-article-hero__published time {
    font-weight: 500;
}

/* ===== Título + subtítulo ===== */

.blog-article-hero__title {
    margin: 0;
    font-family: var(--font-heading);
    font-weight: 500;
    font-size: var(--hero-banner-article-title-size);
    line-height: 1.1;
    letter-spacing: -0.01em;
    color: #252B37;
    max-width: 720px;
}

.blog-article-hero__desc {
    margin: 0;
    font-size: var(--hero-body-size);
    line-height: 1.5;
    color: #414651;
    max-width: 602px;
}

/* ===== Mobile ===== */

@media (max-width: 768px) {
    .blog-article-hero__container {
        padding: 0 var(--hero-pad-inline);
        gap: clamp(12px, 2vw, 14px);
    }
}
