/**
 * Single: Bolsa e Financiamento — Layout Editorial Cream
 * Theme: portalv3.0
 */

body.single-bolsa-financiamento #fone-vendas{ display:none !important; }

/* Breadcrumb colado logo abaixo do menu fixo. O body tem padding-top:80px global
 * (header-v2.css) que já reserva a altura do header fixo, então a barra fica
 * naturalmente embaixo do menu com margin-top:0. (O margin-top:-30px da 28A
 * empurrava a barra pra trás do menu fixo e a deixava invisível — corrigido na
 * Frente 28B fix-breadcrumb-visivel, 2026-05-29.) Escopado no post type — este
 * CSS só carrega nas singles modelo-1/modelo-2 e aliases. */
body.single-bolsa-financiamento .breadcrumb-bar{ margin-top:0; }

.bfs{
    --bfs-cream:#f4ede0;
    --bfs-cream-2:#ebe2d0;
    --bfs-cream-3:#f9f4ea;
    --bfs-gold:#b8902e;
    --bfs-gold-dark:#9c7a24;
    --bfs-crimson:#A51C30;
    --bfs-black:#1a1a1a;
    --bfs-ink:#2a2a2a;
    --bfs-body:#4a4a4a;
    --bfs-muted:#6a6a6a;
    --bfs-line:#d8cfb8;
    --bfs-serif:'Source Serif 4', Georgia, serif;
    --bfs-sans:'Inter', system-ui, sans-serif;

    font-family:var(--bfs-sans);
    background:var(--bfs-cream);
    color:var(--bfs-ink);
    line-height:1.6;
    font-size:16px;
    -webkit-font-smoothing:antialiased;
}
.bfs *{box-sizing:border-box}
.bfs a{color:inherit;text-decoration:none}

.bfs .bfs-container{
    max-width:1280px;
    margin:0 auto;
    padding:0 32px;
}

/* Animação de entrada — só ativa quando JS marca o body */
.bfs-anim .bfs .bfs-fade{
    opacity:0;
    transform:translateY(20px);
    transition:opacity .8s ease, transform .8s ease;
}
.bfs-anim .bfs .bfs-fade.is-visible{
    opacity:1;
    transform:none;
}

/* ========== BANNER ========== */
.bfs .bfs-banner{
    background:var(--bfs-cream-2);
    border-bottom:1px solid var(--bfs-line);
    padding:56px 0;
    position:relative;
    overflow:hidden;
}
.bfs .bfs-banner-content{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:48px;
}
.bfs .bfs-banner-left{flex:1}
.bfs .bfs-banner-eyebrow{
    font-family:var(--bfs-sans);
    font-size:11px;
    letter-spacing:.22em;
    text-transform:uppercase;
    font-weight:700;
    color:var(--bfs-gold);
    margin-bottom:16px;
}
.bfs .bfs-banner-title{
    font-family:var(--bfs-serif);
    font-size:clamp(56px,8vw,96px);
    font-weight:500;
    line-height:.95;
    letter-spacing:-.035em;
    color:var(--bfs-black);
    margin:0;
}
.bfs .bfs-banner-title .bfs-italic{
    font-style:italic;
    font-weight:400;
    color:var(--bfs-gold);
}
.bfs .bfs-banner-right{text-align:right}
.bfs .bfs-banner-mark{
    font-family:var(--bfs-serif);
    font-style:italic;
    font-size:18px;
    color:var(--bfs-muted);
    margin-bottom:8px;
}
.bfs .bfs-banner-section{
    font-family:var(--bfs-sans);
    font-size:11px;
    letter-spacing:.22em;
    text-transform:uppercase;
    font-weight:700;
    color:var(--bfs-ink);
}

/* ========== SUBNAV ========== */
.bfs .bfs-subnav{
    background:var(--bfs-cream);
    border-bottom:1px solid var(--bfs-line);
    position:sticky;
    top:0;
    z-index:10;
}
.bfs .bfs-subnav-list{
    display:flex;
    list-style:none;
    overflow-x:auto;
    scrollbar-width:none;
    margin:0;
    padding:0;
}
.bfs .bfs-subnav-list::-webkit-scrollbar{display:none}
.bfs .bfs-subnav-list li{flex-shrink:0}
.bfs .bfs-subnav-list a{
    display:block;
    padding:20px 24px;
    font-family:var(--bfs-sans);
    font-size:11px;
    letter-spacing:.18em;
    text-transform:uppercase;
    font-weight:600;
    color:var(--bfs-muted);
    border-bottom:2px solid transparent;
    transition:color .2s, border-color .2s;
    white-space:nowrap;
}
.bfs .bfs-subnav-list a:hover{color:var(--bfs-black)}
.bfs .bfs-subnav-list a.active{
    color:var(--bfs-gold);
    border-bottom-color:var(--bfs-gold);
}

/* ========== MAIN ========== */
.bfs .bfs-main{padding:64px 0}
.bfs .bfs-main-grid{
    display:grid;
    grid-template-columns:280px 1fr;
    gap:80px;
    align-items:start;
}

.bfs .bfs-main-icon{
    position:sticky;
    top:120px;
}
.bfs .bfs-icon-wrap{
    width:200px;
    height:200px;
    background:var(--bfs-cream-3);
    border:1px solid var(--bfs-line);
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    margin-bottom:24px;
    padding:36px;
    overflow:hidden;
}
.bfs .bfs-icon-img{
    max-width:100%;
    max-height:100%;
    width:auto;
    height:auto;
    object-fit:contain;
    filter:none;
}
.bfs .bfs-icon-label{
    font-family:var(--bfs-serif);
    font-style:italic;
    font-size:14px;
    color:var(--bfs-muted);
    text-align:center;
}

/* ========== CONTENT ========== */
.bfs .bfs-content h1{
    font-family:var(--bfs-serif);
    font-style:italic;
    font-size:48px;
    font-weight:500;
    color:var(--bfs-gold);
    letter-spacing:-.02em;
    margin:0 0 16px;
    line-height:1;
}
.bfs .bfs-content .bfs-lead{
    font-family:var(--bfs-serif);
    font-size:20px;
    line-height:1.55;
    color:var(--bfs-ink);
    margin:0 0 32px;
}

/* Rich text vindo do WYSIWYG: <p><strong>X</strong></p> já foi convertido em <h3> no PHP */
.bfs .bfs-rich h3{
    font-family:var(--bfs-serif);
    font-size:24px;
    font-weight:600;
    color:var(--bfs-black);
    letter-spacing:-.012em;
    margin:24px 0 16px;
    padding-top:24px;
    position:relative;
}
.bfs .bfs-rich h3::before{
    content:"";
    display:block;
    width:48px;
    height:2px;
    background:var(--bfs-gold);
    margin-bottom:16px;
}
.bfs .bfs-rich p{
    font-family:var(--bfs-serif);
    font-size:18px;
    line-height:1.6;
    color:var(--bfs-ink);
    margin:0 0 8px;
}
.bfs .bfs-rich p strong{color:var(--bfs-black);font-weight:600}
.bfs .bfs-rich a{
    color:var(--bfs-gold);
    text-decoration:underline;
    font-weight:600;
}
.bfs .bfs-rich a:hover{color:var(--bfs-gold-dark)}

/* Lista ordenada estilizada como steps */
.bfs .bfs-rich ol{
    list-style:none;
    padding-left:0;
    margin:8px 0 16px;
    counter-reset:bfs-step;
}
.bfs .bfs-rich ol li{
    padding:14px 0 14px 44px;
    border-bottom:1px solid var(--bfs-line);
    font-family:var(--bfs-serif);
    font-size:18px;
    line-height:1.5;
    color:var(--bfs-ink);
    position:relative;
    counter-increment:bfs-step;
}
.bfs .bfs-rich ol li:first-child{border-top:1px solid var(--bfs-line)}
.bfs .bfs-rich ol li::before{
    content:counter(bfs-step,decimal-leading-zero);
    position:absolute;
    left:0;
    top:14px;
    font-family:var(--bfs-sans);
    font-size:11px;
    letter-spacing:.18em;
    font-weight:700;
    color:var(--bfs-gold);
}
.bfs .bfs-rich ol li strong{color:var(--bfs-black);font-weight:600}

.bfs .bfs-rich ul{
    margin:8px 0 16px;
    padding-left:20px;
}
.bfs .bfs-rich ul li{
    font-family:var(--bfs-serif);
    font-size:18px;
    line-height:1.6;
    color:var(--bfs-ink);
    margin-bottom:6px;
}

/* CTA inline (só renderiza se houver link-do-edital) */
.bfs .bfs-cta-row{
    margin-top:32px;
    padding-top:24px;
    border-top:1px solid var(--bfs-line);
    display:flex;
    align-items:center;
    gap:24px;
    flex-wrap:wrap;
}
.bfs .bfs-cta-btn{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:14px 28px;
    background:var(--bfs-black);
    color:#fff !important;
    border-radius:999px;
    font-family:var(--bfs-sans);
    font-size:13px;
    font-weight:600;
    letter-spacing:.02em;
    transition:background .2s;
}
.bfs .bfs-cta-btn:hover{background:#000;color:#fff !important}
.bfs .bfs-cta-btn-alt{
    background:transparent;
    color:var(--bfs-black) !important;
    border:1px solid var(--bfs-black);
}
.bfs .bfs-cta-btn-alt:hover{
    background:var(--bfs-black);
    color:#fff !important;
}
.bfs .bfs-cta-meta{
    font-family:var(--bfs-serif);
    font-style:italic;
    font-size:14px;
    color:var(--bfs-muted);
}

/* ========== CRONOGRAMA (Toolset Views) ==========
   As Views renderizam classes Bootstrap (.nav-tabs, .tab-content, .tab-pane).
   Reestilizamos dentro de .bfs-cronograma pra ficar coerente com o editorial. */
.bfs .bfs-cronograma{
    margin-top:32px;
    padding-top:24px;
    border-top:1px solid var(--bfs-line);
}
.bfs .bfs-cronograma > h3{
    font-family:var(--bfs-serif);
    font-size:24px;
    font-weight:600;
    color:var(--bfs-black);
    letter-spacing:-.012em;
    margin:0 0 16px;
    padding-top:24px;
    position:relative;
}
.bfs .bfs-cronograma > h3::before{
    content:"";
    display:block;
    width:48px;
    height:2px;
    background:var(--bfs-gold);
    margin-bottom:16px;
}
.bfs .bfs-cronograma .nav-tabs{
    display:flex !important;
    flex-wrap:wrap !important;
    gap:8px !important;
    list-style:none !important;
    padding:0 !important;
    margin:0 0 24px !important;
    border:0 !important;
    background:transparent !important;
}
.bfs .bfs-cronograma .nav-tabs > li,
.bfs .bfs-cronograma .nav-tabs .nav-item{margin:0 !important;padding:0 !important;background:transparent !important;list-style:none !important}
.bfs .bfs-cronograma .nav-tabs a,
.bfs .bfs-cronograma .nav-tabs .nav-link{
    display:inline-block !important;
    background:transparent !important;
    border:1px solid var(--bfs-line) !important;
    border-radius:999px !important;
    padding:8px 16px !important;
    margin:0 !important;
    font-family:var(--bfs-sans) !important;
    font-size:13px !important;
    font-weight:600 !important;
    color:var(--bfs-muted) !important;
    line-height:1.2 !important;
    text-decoration:none !important;
    transition:background .2s, border-color .2s, color .2s;
}
.bfs .bfs-cronograma .nav-tabs a:hover,
.bfs .bfs-cronograma .nav-tabs .nav-link:hover,
.bfs .bfs-cronograma .nav-tabs a:focus,
.bfs .bfs-cronograma .nav-tabs .nav-link:focus{
    border-color:var(--bfs-black) !important;
    color:var(--bfs-black) !important;
    background:transparent !important;
    text-decoration:none !important;
}
.bfs .bfs-cronograma .nav-tabs .active a,
.bfs .bfs-cronograma .nav-tabs a.active,
.bfs .bfs-cronograma .nav-tabs .nav-link.active,
.bfs .bfs-cronograma .nav-tabs .nav-item.show .nav-link{
    background:var(--bfs-black) !important;
    border-color:var(--bfs-black) !important;
    color:#fff !important;
}
.bfs .bfs-cronograma .tab-content{
    font-family:var(--bfs-serif);
    color:var(--bfs-ink);
}
.bfs .bfs-cronograma .tab-pane{display:none}
.bfs .bfs-cronograma .tab-pane.active,
.bfs .bfs-cronograma .tab-pane.in{display:block}
.bfs .bfs-cronograma .tab-pane h4,
.bfs .bfs-cronograma .tab-pane h5{
    font-family:var(--bfs-serif);
    font-size:18px;
    font-weight:600;
    color:var(--bfs-black);
    margin:20px 0 10px;
}
.bfs .bfs-cronograma .tab-pane p{
    font-family:var(--bfs-serif);
    font-size:17px;
    line-height:1.6;
    color:var(--bfs-ink);
    margin:0 0 10px;
}
.bfs .bfs-cronograma .tab-pane ul,
.bfs .bfs-cronograma .tab-pane ol{
    margin:8px 0 16px;
    padding-left:20px;
}
.bfs .bfs-cronograma .tab-pane li{
    font-family:var(--bfs-serif);
    font-size:17px;
    line-height:1.55;
    color:var(--bfs-ink);
    margin-bottom:6px;
}
.bfs .bfs-cronograma .tab-pane a{
    color:var(--bfs-gold);
    text-decoration:underline;
    font-weight:600;
}
.bfs .bfs-cronograma .tab-pane a:hover{color:var(--bfs-gold-dark)}

/* ========== TABS NAV (sidebar) ========== */
.bfs .bfs-tabs-nav{
    list-style:none;
    margin:0;
    padding:0;
    border-top:1px solid var(--bfs-line);
}
.bfs .bfs-tabs-nav li{
    border-bottom:1px solid var(--bfs-line);
    margin:0;
}
.bfs .bfs-tabs-nav button{
    width:100%;
    background:transparent;
    border:0;
    text-align:left;
    padding:14px 0;
    font-family:var(--bfs-serif);
    font-size:18px;
    color:var(--bfs-ink);
    cursor:pointer;
    position:relative;
    transition:color .2s;
    letter-spacing:-.005em;
}
.bfs .bfs-tabs-nav button:hover{color:var(--bfs-gold)}
.bfs .bfs-tabs-nav button.active{
    color:var(--bfs-gold);
    font-style:italic;
    font-weight:500;
}
.bfs .bfs-tabs-nav button.active::before{
    content:"→";
    position:absolute;
    left:-20px;
    color:var(--bfs-gold);
    font-style:normal;
}
.bfs .bfs-tabs-nav .bfs-tab-external{
    display:block;
    padding:14px 0;
    font-family:var(--bfs-serif);
    font-size:18px;
    color:var(--bfs-ink);
    text-decoration:none;
    transition:color .2s;
    letter-spacing:-.005em;
}
.bfs .bfs-tabs-nav .bfs-tab-external:hover{color:var(--bfs-gold)}

/* ========== NOTÍCIAS (grid de cards) ========== */
.bfs .bfs-news-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));
    gap:20px;
    margin-top:24px;
}
.bfs .bfs-news-card{
    display:flex;
    flex-direction:column;
    background:var(--bfs-cream-3);
    border:1px solid var(--bfs-line);
    color:inherit;
    text-decoration:none;
    overflow:hidden;
    transition:transform .2s, box-shadow .2s;
}
.bfs .bfs-news-card:hover{
    transform:translateY(-3px);
    box-shadow:0 14px 40px rgba(0,0,0,.08);
}
.bfs .bfs-news-thumb{
    width:100%;
    aspect-ratio:16/10;
    background-size:cover;
    background-position:center;
    background-color:var(--bfs-cream-2);
}
.bfs .bfs-news-body{padding:16px 18px 20px}
.bfs .bfs-news-tag{
    font-family:var(--bfs-sans);
    font-size:10px;
    letter-spacing:.22em;
    text-transform:uppercase;
    font-weight:700;
    color:var(--bfs-gold);
    margin-bottom:8px;
}
.bfs .bfs-news-title{
    font-family:var(--bfs-serif);
    font-size:17px;
    font-weight:500;
    line-height:1.3;
    color:var(--bfs-black);
    margin:0;
}

.bfs .bfs-tab-content{display:none}
.bfs .bfs-tab-content.active{display:block}

/* ========== SEMESTRES (toggle) ========== */
.bfs .bfs-semesters{
    margin-top:16px;
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-bottom:24px;
    padding-bottom:16px;
    border-bottom:1px solid var(--bfs-line);
}
.bfs .bfs-semester-btn{
    background:transparent;
    border:1px solid var(--bfs-line);
    padding:8px 16px;
    font-family:var(--bfs-sans);
    font-size:13px;
    font-weight:600;
    color:var(--bfs-muted);
    cursor:pointer;
    border-radius:999px;
    transition:background .2s, border-color .2s, color .2s;
}
.bfs .bfs-semester-btn:hover{
    border-color:var(--bfs-black);
    color:var(--bfs-black);
}
.bfs .bfs-semester-btn.active{
    background:var(--bfs-black);
    border-color:var(--bfs-black);
    color:#fff;
}
.bfs .bfs-semester-content{display:none}
.bfs .bfs-semester-content.active{display:block}


/* h4 dentro do rich (subsections de semestre) */
.bfs .bfs-rich h4{
    font-family:var(--bfs-serif);
    font-size:20px;
    font-weight:600;
    color:var(--bfs-black);
    margin:24px 0 12px;
    letter-spacing:-.005em;
}

/* ========== FAQ (accordion) ========== */
.bfs .bfs-faq{margin-top:24px}
.bfs .bfs-faq-item{
    border-bottom:1px solid var(--bfs-line);
}
.bfs .bfs-faq-item:first-child{border-top:1px solid var(--bfs-line)}
.bfs .bfs-faq-q{
    width:100%;
    text-align:left;
    background:transparent;
    border:0;
    padding:18px 32px 18px 0;
    cursor:pointer;
    font-family:var(--bfs-serif);
    font-size:18px;
    color:var(--bfs-black);
    font-weight:500;
    position:relative;
    line-height:1.3;
}
.bfs .bfs-faq-q:hover{color:var(--bfs-gold)}
.bfs .bfs-faq-q::after{
    content:"+";
    position:absolute;
    right:8px;
    top:50%;
    transform:translateY(-50%);
    font-size:22px;
    color:var(--bfs-gold);
    font-weight:300;
    transition:transform .2s;
}
.bfs .bfs-faq-item.open .bfs-faq-q::after{transform:translateY(-50%) rotate(45deg)}
.bfs .bfs-faq-a{
    max-height:0;
    overflow:hidden;
    transition:max-height .3s ease;
}
.bfs .bfs-faq-a-inner{
    padding:0 0 18px;
    font-family:var(--bfs-serif);
    font-size:16px;
    line-height:1.6;
    color:var(--bfs-ink);
}
.bfs .bfs-faq-a-inner p{margin-bottom:8px}
.bfs .bfs-faq-item.open .bfs-faq-a{max-height:600px}

/* ========== DOCS LIST (PDFs com seta ↓) ========== */
.bfs .bfs-docs-list{
    list-style:none;
    padding:0;
    margin:16px 0;
}
.bfs .bfs-docs-list li{
    padding:0;
    border:0;
    margin:0;
}
.bfs .bfs-docs-list li::before{display:none}
.bfs .bfs-docs-list a{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:16px;
    padding:14px 0;
    border-bottom:1px solid var(--bfs-line);
    text-decoration:none;
    color:var(--bfs-black);
    font-family:var(--bfs-serif);
    font-size:16px;
    font-weight:500;
    transition:color .2s;
}
.bfs .bfs-docs-list a:hover{color:var(--bfs-gold)}
.bfs .bfs-docs-list a::after{
    content:"↓";
    color:var(--bfs-gold);
    font-size:16px;
    flex-shrink:0;
}

/* ========== CONTATOS ========== */
.bfs .bfs-contact-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:24px;
    margin-top:24px;
}
.bfs .bfs-contact-card{
    background:var(--bfs-cream-3);
    border:1px solid var(--bfs-line);
    padding:24px;
}
.bfs .bfs-contact-label{
    font-family:var(--bfs-sans);
    font-size:11px;
    letter-spacing:.22em;
    text-transform:uppercase;
    font-weight:700;
    color:var(--bfs-gold);
    margin-bottom:8px;
}
.bfs .bfs-contact-value{
    font-family:var(--bfs-serif);
    font-size:20px;
    color:var(--bfs-black);
    font-weight:500;
}

/* ========== RESPONSIVO ========== */
@media (max-width:900px){
    .bfs .bfs-container{padding:0 20px}
    /* 96px = header fixed 80px + 16px buffer. Substituiu 180px que deixava o conteúdo muito empurrado pra baixo no mobile. */
    .bfs .bfs-banner{padding:96px 0 40px}
    .bfs .bfs-banner-content{flex-direction:column;align-items:flex-start;gap:24px}
    .bfs .bfs-banner-right{text-align:left}
    .bfs .bfs-main{padding:48px 0}
    .bfs .bfs-main-grid{grid-template-columns:1fr;gap:40px}
    .bfs .bfs-main-icon{position:static}
    .bfs .bfs-icon-wrap{width:140px;height:140px;margin:0 auto 16px;padding:24px}
    .bfs .bfs-icon-label{text-align:center}
    .bfs .bfs-content h1{font-size:36px}

    /* Subnav: vira chips em wrap, sem scroll horizontal */
    .bfs .bfs-subnav{position:static}
    .bfs .bfs-subnav .bfs-container{padding:16px 20px}
    .bfs .bfs-subnav-list{
        display:flex;
        flex-wrap:wrap;
        gap:8px;
        overflow:visible;
    }
    .bfs .bfs-subnav-list a{
        display:inline-block;
        padding:8px 14px;
        font-size:10px;
        letter-spacing:.14em;
        border:1px solid var(--bfs-line);
        border-bottom:1px solid var(--bfs-line);
        border-radius:999px;
        background:transparent;
        color:var(--bfs-ink);
        transition:background .2s, color .2s, border-color .2s;
    }
    .bfs .bfs-subnav-list a:hover{
        border-color:var(--bfs-gold);
        color:var(--bfs-gold);
    }
    .bfs .bfs-subnav-list a.active{
        background:var(--bfs-gold);
        border-color:var(--bfs-gold);
        color:#fff;
    }

    /* Tabs nav some o "→" indicador no mobile */
    .bfs .bfs-tabs-nav button.active::before{display:none}

    /* Contatos vira coluna única */
    .bfs .bfs-contact-grid{grid-template-columns:1fr}
}

@media (prefers-reduced-motion: reduce){
    .bfs .bfs-fade{opacity:1;transform:none;transition:none}
}

/* ============================================================
 * FIES (modelo-2 / .bfs-fies-mode) — ajustes Frente 28B fix (2026-05-29)
 * ============================================================ */

/* Tabelas de pagamento IES x CAIXA no FAQ "Coparticipação".
 * Recuperadas do template Bootstrap antigo; as 2 imagens vêm de prod. */
.bfs-fies-mode .bfs-fies-tabelas{
    display:flex;
    flex-wrap:wrap;
    gap:20px;
    margin:20px 0 24px;
    align-items:flex-start;
}
.bfs-fies-mode .bfs-fies-tabelas img{
    max-width:550px;
    width:100%;
    height:auto;
    flex:1 1 280px;
    border:1px solid var(--bfs-line);
    border-radius:6px;
    background:var(--bfs-cream-3);
    padding:8px;
    box-shadow:0 2px 10px rgba(26,26,26,.06);
}
@media (max-width:680px){
    .bfs-fies-mode .bfs-fies-tabelas{flex-direction:column;gap:14px}
    .bfs-fies-mode .bfs-fies-tabelas img{max-width:100%;flex:1 1 auto}
}

/* Espaçamento entre as subsections do FIES — antes os h3/h4 ficavam
 * grudados. Dá respiro vertical + linha separadora dourada sutil. */
/* Inclui o h3 "Como funciona" que fica solto entre os 2 .bfs-rich da aba
 * Inscrição (filho direto de .bfs-tab-content, fora de .bfs-rich) — Frente 28B
 * fix h3 órfão (2026-05-29). */
.bfs-fies-mode .bfs-content > .bfs-tab-content > h3,
.bfs-fies-mode .bfs-rich h3,
.bfs-fies-mode .bfs-rich h4{
    margin-top:2.5rem;
    padding-bottom:.5rem;
    border-bottom:1px solid var(--bfs-line);
}
.bfs-fies-mode .bfs-rich h4{
    border-bottom-color:var(--bfs-gold);
    border-bottom-width:2px;
    display:inline-block;
}
/* Primeiro título do bloco não precisa do respiro extra no topo. */
.bfs-fies-mode .bfs-rich > h3:first-child,
.bfs-fies-mode .bfs-rich > h4:first-child{margin-top:0}
