/* ============================================================
   Portal Matrix — Public Styles
   Variáveis injetadas via wp_add_inline_style:
   --pm-accent     (cor de destaque)
   --pm-secondary  (cor secundária/escura)
   ============================================================ */

:root {
    --pm-accent:     #e91e63;
    --pm-secondary:  #1a1a2e;
    --pm-text:       #222;
    --pm-text-light: #666;
    --pm-bg:         #f5f5f5;
    --pm-white:      #fff;
    --pm-radius:     8px;
    --pm-shadow:     0 2px 12px rgba(0,0,0,.08);
    --pm-gap:        20px;
    --pm-max-width:  1200px;
}

/* ---- Base ---- */
.pm-container {
    max-width: var(--pm-max-width);
    margin: 0 auto;
    padding: 0 20px;
}

.pm-section { padding: 48px 0; }

.pm-section__title {
    font-size: 22px;
    font-weight: 700;
    color: var(--pm-secondary);
    margin: 0 0 24px;
    padding-bottom: 10px;
    border-bottom: 3px solid var(--pm-accent);
    display: inline-block;
}

/* ---- Button ---- */
.pm-btn {
    display: inline-block;
    background: var(--pm-accent);
    color: #fff !important;
    padding: 10px 22px;
    border-radius: 5px;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    transition: opacity .2s, transform .15s;
}
.pm-btn:hover { opacity: .88; transform: translateY(-1px); }
.pm-btn--outline {
    background: transparent;
    border: 2px solid currentColor;
    color: inherit !important;
}
.pm-btn--outline:hover { background: rgba(255,255,255,.15); }

/* ==============================================================
   NEWS BAR
   ============================================================== */
.pm-news-bar {
    background: var(--pm-secondary);
    color: #fff;
    padding: 10px 0;
    overflow: hidden;
}
.pm-news-bar .pm-container {
    display: flex;
    align-items: center;
    gap: 16px;
}
.pm-news-bar__label {
    background: var(--pm-accent);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .6px;
    padding: 4px 10px;
    border-radius: 3px;
    white-space: nowrap;
    flex-shrink: 0;
}
.pm-news-bar__track-wrap {
    flex: 1;
    overflow: hidden;
    position: relative;
}
.pm-news-bar__track {
    display: flex;
    gap: 40px;
    list-style: none;
    margin: 0;
    padding: 0;
    animation: pm-ticker 30s linear infinite;
    white-space: nowrap;
    width: max-content;
}
.pm-news-bar__track:hover { animation-play-state: paused; }
.pm-news-bar__item a {
    color: rgba(255,255,255,.85);
    text-decoration: none;
    font-size: 13px;
    transition: color .2s;
}
.pm-news-bar__item a:hover { color: var(--pm-accent); }
.pm-news-bar__item::after {
    content: '•';
    margin-left: 40px;
    color: rgba(255,255,255,.3);
}

@keyframes pm-ticker {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* ==============================================================
   HERO / CARROSSEL
   ============================================================== */
.pm-hero {
    position: relative;
    background: #111;
    overflow: hidden;
    border-radius: 0;
}
.pm-hero__slides { position: relative; height: 480px; }

@media (max-width: 768px) {
    .pm-hero__slides { height: 300px; }
}

.pm-hero__slide {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-color: var(--pm-secondary);
    opacity: 0;
    transition: opacity .5s ease;
    display: flex;
    align-items: flex-end;
}
.pm-hero__slide.is-active { opacity: 1; z-index: 1; }

.pm-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.75) 0%, rgba(0,0,0,.1) 60%, transparent 100%);
}

.pm-hero__content {
    position: relative;
    z-index: 2;
    padding-bottom: 48px;
    padding-top: 32px;
}

.pm-hero__cat {
    display: inline-block;
    background: var(--pm-accent);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    padding: 3px 10px;
    border-radius: 3px;
    margin-bottom: 10px;
}

.pm-hero__title {
    font-size: clamp(20px, 3vw, 32px);
    font-weight: 800;
    line-height: 1.25;
    margin: 0 0 10px;
    max-width: 680px;
}
.pm-hero__title a { color: #fff; text-decoration: none; }
.pm-hero__title a:hover { text-decoration: underline; }

.pm-hero__excerpt {
    color: rgba(255,255,255,.8);
    font-size: 15px;
    max-width: 560px;
    margin: 0 0 18px;
}

.pm-hero__controls {
    position: absolute;
    bottom: 16px;
    right: 24px;
    z-index: 3;
    display: flex;
    align-items: center;
    gap: 10px;
}

.pm-hero__prev,
.pm-hero__next {
    background: rgba(255,255,255,.2);
    border: none;
    color: #fff;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    font-size: 22px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .2s;
    line-height: 1;
}
.pm-hero__prev:hover,
.pm-hero__next:hover { background: var(--pm-accent); }

.pm-hero__dots { display: flex; gap: 6px; }
.pm-hero__dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    border: none;
    background: rgba(255,255,255,.4);
    cursor: pointer;
    padding: 0;
    transition: background .2s, transform .2s;
}
.pm-hero__dot.is-active {
    background: var(--pm-accent);
    transform: scale(1.3);
}

/* ==============================================================
   RECENT CARDS
   ============================================================== */
.pm-recent-cards { background: var(--pm-bg); }

.pm-cards-grid {
    display: grid;
    gap: var(--pm-gap);
}
.pm-cards-grid--2col { grid-template-columns: repeat(2, 1fr); }
.pm-cards-grid--3col { grid-template-columns: repeat(3, 1fr); }
.pm-cards-grid--4col { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
    .pm-cards-grid--4col,
    .pm-cards-grid--3col { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .pm-cards-grid { grid-template-columns: 1fr !important; }
}

.pm-card-post {
    background: var(--pm-white);
    border-radius: var(--pm-radius);
    overflow: hidden;
    box-shadow: var(--pm-shadow);
    transition: transform .2s, box-shadow .2s;
    display: flex;
    flex-direction: column;
}
.pm-card-post:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 24px rgba(0,0,0,.12);
}

.pm-card-post__thumb-link { display: block; overflow: hidden; }
.pm-card-post__thumb {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display: block;
    transition: transform .3s;
}
.pm-card-post:hover .pm-card-post__thumb { transform: scale(1.04); }

.pm-card-post__body { padding: 16px; flex: 1; display: flex; flex-direction: column; }

.pm-card-post__meta {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}
.pm-card-post__cat {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--pm-accent);
    text-decoration: none;
    letter-spacing: .4px;
}
.pm-card-post__date { font-size: 12px; color: var(--pm-text-light); }

.pm-card-post__title {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.4;
    margin: 0 0 8px;
    flex: 1;
}
.pm-card-post__title a { color: var(--pm-text); text-decoration: none; }
.pm-card-post__title a:hover { color: var(--pm-accent); }

.pm-card-post__excerpt { font-size: 13px; color: var(--pm-text-light); line-height: 1.55; margin: 0; }

/* Placeholder: fundo cinza quando post não tem imagem */
.pm-card-post__thumb--placeholder {
    width: 100%; aspect-ratio: 16/9;
    background: linear-gradient(135deg, #e5e7eb, #d1d5db);
    display: block;
}

/* Botão "Leia mais" dentro do card */
.pm-card-post__read-more {
    display: inline-block; margin-top: 10px;
    font-size: 13px; font-weight: 700; color: var(--pm-accent);
    text-decoration: none;
}
.pm-card-post__read-more:hover { text-decoration: underline; }

/* Grid — alinhar ao topo para evitar espaço vazio em cards com pouco texto */
.pm-cards-grid { align-items: start; }

/* ==============================================================
   RECENT CARDS — Layout Misto e Lista
   ============================================================== */

/* Layout Misto: 1º card grande + secundários horizontais */
.pm-recent-cards--mixed .pm-mixed-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--pm-gap);
    align-items: start;
}
@media (max-width: 700px) {
    .pm-recent-cards--mixed .pm-mixed-layout { grid-template-columns: 1fr; }
}

/* 1º card: vertical, imagem grande */
.pm-card-post--hero-card { height: 100%; }
.pm-card-post--hero-card .pm-card-post__thumb {
    width: 100%; aspect-ratio: 3/2; object-fit: cover; display: block;
}
.pm-card-post--hero-card .pm-card-post__body { padding: 16px; }

/* Secundários: layout horizontal com miniatura */
.pm-mixed-secondary { display: flex; flex-direction: column; gap: 12px; }

.pm-card-mini {
    display: flex; gap: 12px; align-items: flex-start;
    padding-bottom: 12px; border-bottom: 1px solid #eee;
}
.pm-card-mini:last-child { border-bottom: none; padding-bottom: 0; }

.pm-card-mini__thumb-link { flex-shrink: 0; }
.pm-card-mini__thumb {
    width: 80px; height: 60px; object-fit: cover;
    border-radius: 6px; display: block;
}
.pm-card-mini__thumb--placeholder {
    width: 80px; height: 60px; border-radius: 6px;
    background: linear-gradient(135deg, #e5e7eb, #d1d5db);
    display: block; flex-shrink: 0;
}

.pm-card-mini__body { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.pm-card-mini__title { font-size: 14px; font-weight: 600; line-height: 1.4; margin: 0; }
.pm-card-mini__title a { color: var(--pm-text); text-decoration: none; }
.pm-card-mini__title a:hover { color: var(--pm-accent); }
.pm-card-mini__cat { font-size: 10px; }
.pm-card-mini__date { font-size: 11px; color: var(--pm-text-light); }

/* Layout Lista: todos horizontais */
.pm-recent-cards--list .pm-cards-list {
    display: flex; flex-direction: column; gap: 0;
}
.pm-card-mini--list { padding: 12px 0; border-bottom: 1px solid #eee; }
.pm-card-mini--list:last-child { border-bottom: none; }
.pm-card-mini--list .pm-card-mini__thumb { width: 100px; height: 70px; }
.pm-card-mini--list .pm-card-mini__thumb--placeholder { width: 100px; height: 70px; }

/* ==============================================================
   INSPIRATION CARD — Card Destaque Inspiracional
   ============================================================== */
.pm-inspiration-card {
    position: relative;
    background-size: cover;
    background-position: center;
    background-color: var(--pm-secondary);
    display: flex;
    align-items: center;
}

.pm-inspiration-card__overlay {
    position: absolute; inset: 0;
    pointer-events: none;
}

.pm-inspiration-card__inner {
    position: relative; z-index: 1;
    padding: 48px 24px;
    display: flex; flex-direction: column; gap: 14px;
}

.pm-inspiration-card--center .pm-inspiration-card__inner { align-items: center; text-align: center; }
.pm-inspiration-card--left   .pm-inspiration-card__inner { align-items: flex-start; text-align: left; }
.pm-inspiration-card--right  .pm-inspiration-card__inner { align-items: flex-end; text-align: right; }

.pm-inspiration-card__divider {
    width: 48px; height: 3px; border-radius: 2px;
    opacity: .6; margin-bottom: 4px;
}

.pm-inspiration-card__icon {
    font-size: 36px; line-height: 1;
    text-shadow: 0 2px 8px rgba(0,0,0,.3);
}

.pm-inspiration-card__phrase {
    font-size: clamp(18px, 2.4vw, 28px);
    font-weight: 800;
    line-height: 1.3;
    letter-spacing: -.2px;
    margin: 0;
    text-shadow: 0 2px 12px rgba(0,0,0,.4);
    quotes: none;
    max-width: 700px;
}

.pm-inspiration-card__subtext {
    font-size: 15px;
    opacity: .85;
    margin: 0;
    max-width: 560px;
    line-height: 1.6;
}

.pm-inspiration-card__btn {
    margin-top: 6px;
    font-size: 14px; font-weight: 700;
    padding: 10px 24px;
    backdrop-filter: blur(4px);
    background: rgba(255,255,255,.1);
}
.pm-inspiration-card__btn:hover {
    background: rgba(255,255,255,.2);
    transform: translateY(-1px);
}

/* ---- Responsivo (mobile) -------------------------------------
   Reduz a altura mínima, centraliza melhor o conteúdo verticalmente,
   diminui frase/subtexto e suaviza o overlay para telas pequenas.
   `!important` é necessário pois min-height/background-position vêm
   como inline-style (controlados pelas configurações do módulo). */
@media (max-width: 768px) {
    .pm-inspiration-card {
        min-height: 360px !important;
        background-position: center center !important;
        justify-content: center;
    }

    /* Overlay levemente mais denso para aumentar contraste do texto */
    .pm-inspiration-card__overlay {
        opacity: .6;
    }

    .pm-inspiration-card__inner {
        width: 85%;          /* limita o bloco de conteúdo a 85% da tela */
        padding: 28px 0;     /* padding lateral zero — a largura já controla */
        gap: 6px;            /* menos espaço entre frase e subtítulo */
        justify-content: center;
    }

    .pm-inspiration-card__divider {
        margin-bottom: 0;
    }

    .pm-inspiration-card__icon {
        font-size: 28px;
        margin-bottom: 2px;
    }

    /* Frase ~28px — fixed para garantir o tamanho pedido em telas < 768px */
    .pm-inspiration-card__phrase {
        font-size: 28px;
        max-width: 100%;     /* já controlado pelo __inner width: 85% */
        line-height: 1.25;
        text-shadow: 0 2px 16px rgba(0,0,0,.55); /* contraste reforçado */
    }

    .pm-inspiration-card__subtext {
        font-size: 14px;
        max-width: 100%;
        line-height: 1.5;
        opacity: .9;         /* levemente mais visível que o .85 do desktop */
        margin-top: 2px;
    }

    /* Botão abaixo do subtítulo com espaço mínimo para respirar */
    .pm-inspiration-card__btn {
        font-size: 13px;
        padding: 9px 22px;
        margin-top: 10px;    /* separa claramente do subtítulo */
    }
}

/* ==============================================================
   FEATURED — Compartilhados (todos os layouts)
   ============================================================== */
.pm-featured { background: var(--pm-white); }

/* Badge / Selo Visual */
.pm-featured__badge {
    display: inline-block;
    background: var(--pm-accent);
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .5px;
    padding: 3px 9px;
    border-radius: 4px;
    margin-bottom: 6px;
}

/* ---- Classic layout ---- */
.pm-featured--classic .pm-featured__classic {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: var(--pm-gap);
}
@media (max-width: 900px) {
    .pm-featured--classic .pm-featured__classic { grid-template-columns: 1fr; }
}

.pm-featured__main { position: relative; border-radius: var(--pm-radius); overflow: hidden; }
.pm-featured__main-link { display: block; height: 400px; position: relative; }
.pm-featured__main-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.pm-featured__main-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.75) 0%, transparent 55%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 24px;
}
.pm-featured__cat {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: #fff;
    background: var(--pm-accent);
    padding: 3px 9px;
    border-radius: 3px;
    text-decoration: none;
    display: inline-block;
    margin-bottom: 8px;
    letter-spacing: .4px;
}
.pm-featured__main-title {
    font-size: 22px;
    font-weight: 800;
    color: #fff;
    line-height: 1.3;
    margin: 0 0 6px;
}
.pm-featured__date { font-size: 12px; color: rgba(255,255,255,.7); }

/* Side posts */
.pm-featured__side { display: flex; flex-direction: column; gap: 16px; }
.pm-featured__side-item {
    display: flex;
    gap: 12px;
    padding-bottom: 16px;
    border-bottom: 1px solid #eee;
}
.pm-featured__side-item:last-child { border-bottom: none; padding-bottom: 0; }

.pm-featured__side-thumb { flex-shrink: 0; width: 90px; height: 70px; border-radius: 6px; overflow: hidden; display: block; }
.pm-featured__side-thumb img { width: 100%; height: 100%; object-fit: cover; }

.pm-featured__side-body { flex: 1; }
.pm-featured__side-title { font-size: 14px; font-weight: 600; line-height: 1.4; margin: 0 0 4px; }
.pm-featured__side-title a { color: var(--pm-text); text-decoration: none; }
.pm-featured__side-title a:hover { color: var(--pm-accent); }

/* ---- Grid layout ---- */
.pm-featured--grid .pm-featured__grid-equal {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--pm-gap);
}
.pm-featured__grid-card {
    background: var(--pm-white);
    border: 1px solid #eee;
    border-radius: var(--pm-radius);
    overflow: hidden;
    transition: transform .2s, box-shadow .2s;
}
.pm-featured__grid-card:hover { transform: translateY(-3px); box-shadow: var(--pm-shadow); }
.pm-featured__grid-img-link { display: block; aspect-ratio: 16/9; overflow: hidden; }
.pm-featured__grid-img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .3s; }
.pm-featured__grid-card:hover .pm-featured__grid-img { transform: scale(1.04); }
.pm-featured__grid-body { padding: 14px; }
.pm-featured__grid-title { font-size: 15px; font-weight: 700; line-height: 1.4; margin: 4px 0 6px; }
.pm-featured__grid-title a { color: var(--pm-text); text-decoration: none; }
.pm-featured__grid-title a:hover { color: var(--pm-accent); }
.pm-featured__grid-excerpt { font-size: 13px; color: var(--pm-text-light); margin: 0 0 6px; }

/* ---- Carousel layout ---- */
.pm-featured--carousel .pm-featured-carousel { position: relative; border-radius: var(--pm-radius); overflow: hidden; }
.pm-featured-carousel__track { position: relative; }
.pm-featured-carousel__slide {
    display: none;
    position: relative;
    min-height: 320px;
    background: var(--pm-secondary);
}
.pm-featured-carousel__slide.is-active { display: flex; align-items: flex-end; }
.pm-featured-carousel__img {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
}
.pm-featured-carousel__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.75) 0%, transparent 60%);
}
.pm-featured-carousel__content {
    position: relative; z-index: 1;
    padding: 24px; width: 100%;
}
.pm-featured-carousel__title { font-size: 18px; font-weight: 800; color: #fff; margin: 6px 0; line-height: 1.3; }
.pm-featured-carousel__title a { color: #fff; text-decoration: none; }
.pm-featured-carousel__title a:hover { text-decoration: underline; }
.pm-featured-carousel__nav {
    display: flex; align-items: center; justify-content: center; gap: 12px;
    padding: 10px; background: #f8f8f8; border-top: 1px solid #eee;
}
.pm-featured-carousel__prev,
.pm-featured-carousel__next {
    background: none; border: 1px solid #ddd; border-radius: 50%;
    width: 28px; height: 28px; cursor: pointer; font-size: 16px; color: #555;
    display: flex; align-items: center; justify-content: center;
    transition: background .2s, color .2s;
}
.pm-featured-carousel__prev:hover,
.pm-featured-carousel__next:hover { background: var(--pm-accent); color: #fff; border-color: var(--pm-accent); }
.pm-featured-carousel__dots { display: flex; gap: 6px; }
.pm-featured-carousel__dot {
    width: 8px; height: 8px; border-radius: 50%; border: none;
    background: #ccc; cursor: pointer; padding: 0; transition: background .2s, transform .2s;
}
.pm-featured-carousel__dot.is-active { background: var(--pm-accent); transform: scale(1.3); }

/* ---- Hero Secundário layout ---- */
.pm-featured--hero-secondary .pm-featured__hero-sec { display: flex; flex-direction: column; gap: 0; }
.pm-featured__hero-sec-main {
    height: 380px; position: relative;
    background-size: cover; background-position: center; background-color: var(--pm-secondary);
    border-radius: var(--pm-radius) var(--pm-radius) 0 0;
    overflow: hidden;
}
@media (max-width: 768px) { .pm-featured__hero-sec-main { height: 260px; } }
.pm-featured__hero-sec-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.8) 0%, rgba(0,0,0,.1) 60%, transparent 100%);
    display: flex; align-items: flex-end;
}
.pm-featured__hero-sec-content { padding: 28px; }
.pm-featured__hero-sec-title { font-size: clamp(18px, 2.5vw, 26px); font-weight: 800; color: #fff; margin: 8px 0 10px; line-height: 1.3; }
.pm-featured__hero-sec-title a { color: #fff; text-decoration: none; }
.pm-featured__hero-sec-title a:hover { text-decoration: underline; }
.pm-featured__hero-sec-excerpt { color: rgba(255,255,255,.8); font-size: 14px; margin: 0 0 14px; }

.pm-featured__hero-sec-strip {
    display: flex; gap: 0; background: #fff;
    border: 1px solid #eee; border-top: none;
    border-radius: 0 0 var(--pm-radius) var(--pm-radius); overflow: hidden;
}
.pm-featured__hero-sec-item { flex: 1; display: flex; gap: 10px; padding: 12px; border-right: 1px solid #eee; }
.pm-featured__hero-sec-item:last-child { border-right: none; }
@media (max-width: 700px) { .pm-featured__hero-sec-strip { flex-direction: column; } }
.pm-featured__hero-sec-thumb { flex-shrink: 0; width: 60px; height: 48px; border-radius: 4px; overflow: hidden; display: block; }
.pm-featured__hero-sec-thumb img { width: 100%; height: 100%; object-fit: cover; }
.pm-featured__hero-sec-item-body { flex: 1; }

/* ==============================================================
   LIST THUMB
   ============================================================== */
.pm-list-thumb { background: var(--pm-bg); }

.pm-list-thumb__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0; }
.pm-list-thumb__item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid #e8e8e8;
}
.pm-list-thumb__item:last-child { border-bottom: none; }

.pm-list-thumb__num {
    font-size: 28px;
    font-weight: 900;
    color: var(--pm-accent);
    opacity: .3;
    line-height: 1;
    flex-shrink: 0;
    width: 32px;
    text-align: right;
}

.pm-list-thumb__img-link { flex-shrink: 0; width: 80px; height: 60px; border-radius: 6px; overflow: hidden; display: block; }
.pm-list-thumb__img { width: 100%; height: 100%; object-fit: cover; }

.pm-list-thumb__body { flex: 1; }
.pm-list-thumb__title { font-size: 15px; font-weight: 600; margin: 0 0 4px; line-height: 1.4; }
.pm-list-thumb__title a { color: var(--pm-text); text-decoration: none; }
.pm-list-thumb__title a:hover { color: var(--pm-accent); }

.pm-list-thumb__meta { display: flex; gap: 12px; font-size: 12px; color: var(--pm-text-light); }

/* ==============================================================
   CTA BLOCK
   ============================================================== */
.pm-cta-block {
    padding: 60px 0;
    position: relative;
    overflow: hidden;
    text-align: center;
}
.pm-cta-block__img {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: .12;
}
.pm-cta-block__inner { position: relative; z-index: 1; max-width: 620px; }
.pm-cta-block__title { font-size: 28px; font-weight: 800; margin: 0 0 12px; }
.pm-cta-block__desc { font-size: 16px; opacity: .85; margin: 0 0 24px; line-height: 1.6; }

/* ==============================================================
   MORE PORTAL
   ============================================================== */
.pm-more-portal { background: var(--pm-white); }

.pm-more-portal__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 32px;
}

.pm-more-portal__col-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--pm-accent);
}
.pm-more-portal__col-title { font-size: 16px; font-weight: 700; margin: 0; }
.pm-more-portal__col-title a { color: var(--pm-secondary); text-decoration: none; }
.pm-more-portal__col-title a:hover { color: var(--pm-accent); }
.pm-more-portal__see-all { font-size: 12px; color: var(--pm-accent); text-decoration: none; font-weight: 600; }

.pm-more-portal__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.pm-more-portal__item {
    display: flex;
    gap: 10px;
    align-items: flex-start;
}
.pm-more-portal__thumb-link { flex-shrink: 0; width: 64px; height: 48px; border-radius: 5px; overflow: hidden; display: block; }
.pm-more-portal__thumb { width: 100%; height: 100%; object-fit: cover; }

.pm-more-portal__item-title { font-size: 13px; font-weight: 600; margin: 0; line-height: 1.4; }
.pm-more-portal__item-title a { color: var(--pm-text); text-decoration: none; }
.pm-more-portal__item-title a:hover { color: var(--pm-accent); }

/* ==============================================================
   CONTRIBUTORS (interno: contributors — exibido conforme vocabulário)
   ============================================================== */
.pm-contributors { background: var(--pm-bg); }

.pm-contributors__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--pm-gap);
}

.pm-contributor-card {
    background: var(--pm-white);
    border-radius: var(--pm-radius);
    padding: 24px 20px;
    text-align: center;
    box-shadow: var(--pm-shadow);
    transition: transform .2s;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.pm-contributor-card:hover { transform: translateY(-3px); }

.pm-contributor-card__avatar-link { display: inline-block; margin-bottom: 10px; }
.pm-contributor-card__avatar {
    width: 80px; height: 80px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--pm-accent);
}
.pm-contributor-card__role {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--pm-accent);
    margin-bottom: 4px;
}
.pm-contributor-card__name { font-size: 15px; font-weight: 700; margin: 0 0 6px; }
.pm-contributor-card__name a { color: var(--pm-secondary); text-decoration: none; }
.pm-contributor-card__name a:hover { color: var(--pm-accent); }
.pm-contributor-card__bio { font-size: 13px; color: var(--pm-text-light); line-height: 1.5; margin: 0 0 12px; }
.pm-contributor-card__link { font-size: 12px; font-weight: 600; color: var(--pm-accent); text-decoration: none; }
.pm-contributor-card__link:hover { text-decoration: underline; }

/* ---- Widgets ---- */
.pm-widget-posts { list-style: none; margin: 0; padding: 0; }
.pm-widget-posts__item { display: flex; gap: 8px; align-items: flex-start; padding: 8px 0; border-bottom: 1px solid #eee; }
.pm-widget-posts__item:last-child { border-bottom: none; }
.pm-widget-posts__thumb { flex-shrink: 0; }
.pm-widget-posts__thumb img { width: 60px; height: 60px; object-fit: cover; border-radius: 4px; }
.pm-widget-posts__body a { font-size: 13px; font-weight: 600; color: var(--pm-text); text-decoration: none; display: block; line-height: 1.4; }
.pm-widget-posts__body a:hover { color: var(--pm-accent); }
.pm-widget-posts__body time { font-size: 11px; color: var(--pm-text-light); }

.pm-widget-cats { list-style: none; margin: 0; padding: 0; }
.pm-widget-cats__item { padding: 5px 0; border-bottom: 1px solid #eee; font-size: 13px; }
.pm-widget-cats__item:last-child { border-bottom: none; }
.pm-widget-cats__item a { color: var(--pm-text); text-decoration: none; }
.pm-widget-cats__item a:hover { color: var(--pm-accent); }
.pm-widget-cats__count { color: var(--pm-text-light); font-size: 11px; }
