/**
 * Estilos das pieces renderizadas pelos shortcodes do child theme e
 * pelo template-part `post-card-thumbnail.php`.
 *
 * - .post-tag / .post-meta-time: do shortcode [atys_post_tag] e [atys_read_time]
 * - .featured-media / .featured-illu: variant=featured do template-part
 * - .post-card-media / .media-glyph: variant=card do template-part
 * - .avatar: do filtro get_avatar em inc/avatars.php
 *
 * Tudo que dependeria do markup do mockup (`.featured`, `.featured-body`,
 * `.post-card`, `.post-card-body`, headings, footer do card etc.) vive em
 * blog-elementor-overrides.css porque o Elementor envolve cada widget em
 * `.elementor-widget-...` + `.e-con-inner` e os seletores diretos não
 * pegam.
 */

/* ── Tag de categoria (shortcode [atys_post_tag]) ─────────────────── */
.post-tag {
    display: inline-flex;
    align-items: center;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.25rem 0.625rem;
    border-radius: 9999px;
    background: var(--blue-50);
    color: var(--blue);
    border: 1px solid var(--blue-100);
}
.post-tag--purple { background: var(--accent-purple-bg); color: var(--accent-purple); border-color: var(--accent-purple-bd); }
.post-tag--amber  { background: var(--accent-amber-bg);  color: var(--accent-amber);  border-color: var(--accent-amber-bd); }
.post-tag--green  { background: var(--accent-green-bg);  color: var(--accent-green);  border-color: var(--accent-green-bd); }
.post-tag--pink   { background: var(--accent-pink-bg);   color: var(--accent-pink);   border-color: var(--accent-pink-bd); }
.post-tag--teal   { background: var(--accent-teal-bg);   color: var(--accent-teal);   border-color: var(--accent-teal-bd); }

/* ── Tempo de leitura (shortcode [atys_read_time]) ────────────────── */
.post-meta-time {
    font-size: 0.75rem;
    color: var(--slate-500);
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
}
.post-meta-time::before {
    content: '';
    width: 3px; height: 3px;
    border-radius: 9999px;
    background: var(--slate-300);
}

/* ── Capa do featured (template-part, variant=featured) ───────────── */
.featured-media {
    position: relative;
    background:
        radial-gradient(ellipse at 30% 20%, rgba(52, 132, 196, 0.18), transparent 60%),
        radial-gradient(ellipse at 80% 80%, rgba(109, 40, 217, 0.14), transparent 60%),
        linear-gradient(135deg, #EFF6FF 0%, #F5F3FF 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.featured-media::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(52, 132, 196, 0.12) 1px, transparent 1px),
        linear-gradient(90deg, rgba(52, 132, 196, 0.12) 1px, transparent 1px);
    background-size: 28px 28px;
    mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, #000 40%, transparent 75%);
    -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, #000 40%, transparent 75%);
    pointer-events: none;
}
.featured-media:has(img)::after { display: none; }
.featured-illu {
    position: relative;
    z-index: 1;
    font-size: 4.5rem;
    font-weight: 900;
    color: var(--blue);
    letter-spacing: -0.05em;
    opacity: 0.92;
    text-align: center;
}
.featured-illu small {
    display: block;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--slate-500);
    margin-top: 0.5rem;
}

/* ── Capa do card do grid (template-part, variant=card) ───────────── */
.post-card-media {
    position: relative;
    aspect-ratio: 16 / 9;
    background: var(--slate-50);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.post-card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.post-card-media::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(15, 23, 42, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(15, 23, 42, 0.05) 1px, transparent 1px);
    background-size: 22px 22px;
    opacity: 0.6;
    mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, #000 40%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, #000 40%, transparent 80%);
    pointer-events: none;
}
.post-card-media:has(img)::after { display: none; }
.media-glyph {
    position: relative;
    z-index: 1;
    font-size: 2.5rem;
    font-weight: 900;
    letter-spacing: -0.04em;
    color: var(--slate-700);
    opacity: 0.85;
}
.post-card-media--blue   { background: linear-gradient(135deg, #EFF6FF, #DBEAFE); }
.post-card-media--blue   .media-glyph { color: var(--blue); }
.post-card-media--purple { background: linear-gradient(135deg, #F5F3FF, #EDE9FE); }
.post-card-media--purple .media-glyph { color: var(--accent-purple); }
.post-card-media--amber  { background: linear-gradient(135deg, #FFFBEB, #FEF3C7); }
.post-card-media--amber  .media-glyph { color: var(--accent-amber); }
.post-card-media--green  { background: linear-gradient(135deg, #F0FDF4, #DCFCE7); }
.post-card-media--green  .media-glyph { color: var(--accent-green); }
.post-card-media--pink   { background: linear-gradient(135deg, #FDF2F8, #FCE7F3); }
.post-card-media--pink   .media-glyph { color: var(--accent-pink); }
.post-card-media--teal   { background: linear-gradient(135deg, #F0FDFA, #CCFBF1); }
.post-card-media--teal   .media-glyph { color: var(--accent-teal); }

/* ── Avatar (filtro get_avatar em inc/avatars.php) ────────────────── */
.avatar {
    border-radius: 9999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.6875rem;
    font-weight: 800;
    color: #fff;
    flex-shrink: 0;
    letter-spacing: 0.02em;
}
.avatar--blue   { background: var(--blue); }
.avatar--purple { background: #7C3AED; }
.avatar--green  { background: #16A34A; }
.avatar--pink   { background: #DB2777; }
.avatar--amber  { background: #D97706; }
.avatar--teal   { background: var(--accent-teal); }
.avatar--xs {
    width: 1.625rem;
    height: 1.625rem;
    font-size: 0.5625rem;
}
