/* ═══════════════════════════════════════════════════════════════════════
   Acervo CM Child — paleta terrosa elegante
   Base: terracota oxidado RGB(171,65,15) = #AB410F
   ═══════════════════════════════════════════════════════════════════════ */

:root {
    /* ── Terracota (família base) ──────────────────────────────────── */
    --acm-terracota:        #AB410F;   /* base — RGB 171,65,15 */
    --acm-terracota-escuro: #7A2D08;   /* hover, links em estado ativo */
    --acm-terracota-fundo:  #6E2706;   /* texto sobre fundo claro com peso */
    --acm-terracota-claro:  #C4623A;   /* decorativo, ícones */
    --acm-terracota-suave:  #E8C9B6;   /* highlights muito suaves */

    /* ── Papel e fundos (cremes envelhecidos) ──────────────────────── */
    --acm-creme:        #FAF6EF;   /* fundo principal */
    --acm-papel:        #F4ECDD;   /* fundo de cards e sidebars */
    --acm-papel-fundo:  #EDE3CF;   /* tonal mais escuro */
    --acm-areia:        #DED2B7;   /* destaque sutil */

    /* ── Bordas ─────────────────────────────────────────────────────── */
    --acm-borda:        #D4C8B0;   /* borda padrão (bege) */
    --acm-borda-forte:  #B8AB8E;   /* borda enfatizada */
    --acm-borda-suave:  #E5DBC4;   /* divisores tênues */

    /* ── Texto ──────────────────────────────────────────────────────── */
    --acm-tinta:        #2A1F14;   /* preto-quase, warm */
    --acm-texto:        #3D2E1F;   /* texto corpo */
    --acm-texto-suave:  #6E5B43;   /* texto secundário */
    --acm-texto-mudo:   #9C8B6E;   /* labels uppercase, captions */

    /* ── Acentos da família terrosa (callouts) ─────────────────────── */
    --acm-ocre:         #B58C2C;   /* dourado-mostarda — sem-fonte */
    --acm-musgo:        #6F7B42;   /* verde-oliva — a-pesquisar */
    --acm-ardosia:      #4E6B74;   /* azul-ardósia — note */
    --acm-borgonha:     #6E2706;   /* vinho/terracota escuro — disputa, warning */

    /* ── Tipografia ─────────────────────────────────────────────────── */
    --acm-serif:  'Source Serif Pro', 'Source Serif', 'Crimson Pro', Georgia, 'Times New Roman', serif;
    --acm-sans:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
    --acm-mono:   ui-monospace, 'SF Mono', SFMono-Regular, 'Cascadia Mono', Consolas, 'Liberation Mono', monospace;

    /* ── Métricas ───────────────────────────────────────────────────── */
    --acm-header-offset: 80px;
    --acm-raio: 3px;                                    /* livro/papel, não app */
    --acm-sombra-suave: 0 1px 3px rgba(42, 31, 20, .06);
    --acm-sombra-media: 0 2px 8px rgba(42, 31, 20, .10);
}

/* ── Reset estrutural mínimo + base do tema-filho ───────────────────── */
body.single-pessoa, body.single-povo-indigena, body.single-lugar,
body.single-instituicao, body.single-evento, body.single-tema,
body.single-conceito, body.single-publicacao, body.single-periodo,
body.single-documento,
body.post-type-archive-pessoa, body.post-type-archive-povo-indigena,
body.post-type-archive-lugar, body.post-type-archive-instituicao,
body.post-type-archive-evento, body.post-type-archive-tema,
body.post-type-archive-conceito, body.post-type-archive-publicacao,
body.post-type-archive-periodo, body.post-type-archive-documento {
    background: var(--acm-creme);
    color: var(--acm-texto);
}
.margin-two-column { margin: 0 !important; }

/* Tipografia base — quando o conteúdo da entidade for renderizado */
.acm-pagina ::selection { background: var(--acm-terracota-suave); color: var(--acm-tinta); }


/* ═══════════════════════════════════════════════════════════════════════
   LAYOUT — single (3 colunas: TOC | conteúdo | sidebar)
   ═══════════════════════════════════════════════════════════════════════ */

.acm-pagina {
    max-width: 1340px;
    margin: 0 auto;
    padding: 0 2rem;
}
.acm-main {
    display: grid;
    grid-template-columns: 230px 1fr 290px;
    gap: 3rem;
    margin-top: 2rem;
    align-items: start;
}
@media (max-width: 1100px) {
    .acm-main { grid-template-columns: 1fr 270px; gap: 2rem; }
    .acm-toc-col { display: none; }
}
@media (max-width: 800px) {
    .acm-pagina { padding: 0 1.25rem; }
    .acm-main { grid-template-columns: 1fr; gap: 1.5rem; }
    .acm-sidebar { order: 2; }
}


/* ── TOC (coluna esquerda) ─────────────────────────────────────────── */

.acm-toc-col {
    position: sticky;
    top: calc(var(--acm-header-offset) + 1.25rem);
}
.acm-toc-inner {
    font-family: var(--acm-sans);
    font-size: .82rem;
    max-height: calc(100vh - var(--acm-header-offset) - 2.5rem);
    overflow-y: auto;
    padding-right: .5rem;
}
.acm-toc-inner::-webkit-scrollbar       { width: 5px; }
.acm-toc-inner::-webkit-scrollbar-thumb { background: var(--acm-borda); border-radius: 3px; }

.acm-toc-inner h4 {
    font-family: var(--acm-sans);
    font-size: .68rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    margin: 0 0 .85rem 0;
    color: var(--acm-texto-mudo);
    font-weight: 600;
}
.acm-toc { list-style: none; margin: 0; padding: 0; }
.acm-toc-item a {
    display: block;
    padding: .35rem .5rem .35rem .9rem;
    color: var(--acm-texto-suave);
    text-decoration: none;
    border-left: 1.5px solid transparent;
    line-height: 1.4;
    transition: color .15s, border-color .15s, padding-left .15s;
}
.acm-toc-item a:hover {
    color: var(--acm-terracota);
    border-left-color: var(--acm-borda-forte);
}
.acm-toc-item-ativo a {
    color: var(--acm-terracota);
    border-left-color: var(--acm-terracota);
    font-weight: 600;
}
.acm-toc-h3 a {
    padding-left: 1.8rem;
    font-size: .94em;
    color: var(--acm-texto-mudo);
}


/* ── Conteúdo (coluna central) ─────────────────────────────────────── */

.acm-content {
    font-family: var(--acm-serif);
    font-size: 1.06rem;
    line-height: 1.78;
    color: var(--acm-texto);
    min-width: 0;
}

.acm-content h2, .acm-content h3, .acm-content h4 {
    font-family: var(--acm-serif);
    scroll-margin-top: var(--acm-header-offset);
    color: var(--acm-tinta);
    font-weight: 600;
    line-height: 1.3;
}
.acm-content h2 {
    margin: 2.5rem 0 .9rem;
    padding-bottom: .4rem;
    border-bottom: 1px solid var(--acm-borda);
    font-size: 1.55rem;
    letter-spacing: -.01em;
}
.acm-content h2:first-child { margin-top: 0; }
.acm-content h3 {
    margin: 1.8rem 0 .65rem;
    font-size: 1.22rem;
    color: var(--acm-terracota-escuro);
}
.acm-content h4 {
    margin: 1.3rem 0 .5rem;
    font-size: 1.05rem;
    font-style: italic;
    color: var(--acm-texto);
}

.acm-content p {
    margin: .75rem 0;
    text-align: justify;
    hyphens: auto;
}
.acm-content p:first-child { margin-top: 0; }

/* Drop cap sutil no primeiro parágrafo após h2 — opcional, elegante */
.acm-content h2 + p::first-letter {
    font-family: var(--acm-serif);
    font-size: 2.6em;
    line-height: .9;
    float: left;
    padding: .12em .12em 0 0;
    color: var(--acm-terracota);
    font-weight: 500;
}

.acm-content blockquote {
    border-left: 3px solid var(--acm-terracota);
    margin: 1.2rem 0;
    padding: .25rem 1.2rem;
    background: var(--acm-papel);
    color: var(--acm-texto-suave);
    font-style: italic;
    border-radius: 0 var(--acm-raio) var(--acm-raio) 0;
}
.acm-content blockquote p { margin: .5rem 0; }

.acm-content code {
    font-family: var(--acm-mono);
    font-size: .88em;
    background: var(--acm-papel-fundo);
    padding: .08em .42em;
    border-radius: 2px;
    color: var(--acm-terracota-fundo);
}
.acm-content pre {
    background: var(--acm-papel);
    border: 1px solid var(--acm-borda-suave);
    padding: .9rem 1.1rem;
    border-radius: var(--acm-raio);
    overflow-x: auto;
    font-size: .9em;
}

.acm-content table {
    border-collapse: collapse;
    margin: 1.2rem 0;
    font-size: .94em;
    width: 100%;
    background: var(--acm-creme);
}
.acm-content th, .acm-content td {
    border: 1px solid var(--acm-borda);
    padding: .55rem .8rem;
    text-align: left;
    vertical-align: top;
}
.acm-content th {
    background: var(--acm-papel);
    font-family: var(--acm-sans);
    font-weight: 600;
    font-size: .85em;
    color: var(--acm-tinta);
    letter-spacing: .01em;
}

.acm-content hr {
    border: none;
    border-top: 1px solid var(--acm-borda);
    margin: 2rem auto;
    width: 30%;
    text-align: center;
}
.acm-content hr::after {
    content: "✦";
    display: inline-block;
    position: relative;
    top: -.7em;
    padding: 0 .5em;
    background: var(--acm-creme);
    color: var(--acm-terracota-claro);
    font-size: .85em;
}


/* ── Sidebar (coluna direita) ──────────────────────────────────────── */

.acm-sidebar {
    position: sticky;
    top: calc(var(--acm-header-offset) + 1.25rem);
    font-family: var(--acm-sans);
    font-size: .86rem;
}
.acm-sidebar-inner {
    background: var(--acm-papel);
    border: 1px solid var(--acm-borda);
    border-left: 3px solid var(--acm-terracota);
    padding: 1.1rem 1.2rem;
    border-radius: var(--acm-raio);
    box-shadow: var(--acm-sombra-suave);
}
.acm-info { margin: 0; }
.acm-info dt {
    font-family: var(--acm-sans);
    font-size: .68rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--acm-texto-mudo);
    font-weight: 600;
    margin-top: .85rem;
}
.acm-info dt:first-child { margin-top: 0; }
.acm-info dd {
    margin: .2rem 0 0 0;
    line-height: 1.45;
    color: var(--acm-texto);
}
.acm-info a {
    color: var(--acm-terracota);
    text-decoration: none;
    border-bottom: 1px solid var(--acm-terracota-suave);
    transition: border-color .15s;
}
.acm-info a:hover {
    border-bottom-color: var(--acm-terracota);
}


/* ═══════════════════════════════════════════════════════════════════════
   META-STRIP — faixa horizontal abaixo do breadcrumb
   ═══════════════════════════════════════════════════════════════════════ */

.acm-meta-strip {
    border-top: 1px solid var(--acm-borda);
    border-bottom: 1px solid var(--acm-borda);
    background: var(--acm-papel);
    margin: 0 0 1.25rem 0;
    padding: .75rem 0;
    font-family: var(--acm-sans);
}
.acm-meta-strip-inner {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
    max-width: 1340px;
    margin: 0 auto;
    padding: 0 2rem;
    font-size: .87rem;
    align-items: flex-end;
}
.acm-meta-item {
    display: flex;
    flex-direction: column;
    gap: .12rem;
    position: relative;
}
.acm-meta-label {
    font-size: .65rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--acm-texto-mudo);
    font-weight: 600;
}
.acm-meta-val {
    color: var(--acm-texto);
    font-weight: 500;
}
.acm-meta-vazio .acm-meta-val {
    color: var(--acm-texto-mudo);
    font-style: italic;
    font-weight: 400;
}


/* ── Tags ──────────────────────────────────────────────────────────── */

.acm-tags {
    display: inline-flex;
    gap: .4rem;
    flex-wrap: wrap;
}
.acm-tag {
    display: inline-block;
    padding: .14rem .65rem;
    background: var(--acm-creme);
    border: 1px solid var(--acm-borda);
    border-radius: 999px;
    font-size: .76rem;
    color: var(--acm-terracota-fundo);
    text-decoration: none;
    line-height: 1.45;
    transition: background .15s, color .15s, border-color .15s;
}
.acm-tag:hover {
    background: var(--acm-terracota);
    border-color: var(--acm-terracota);
    color: var(--acm-creme);
}


/* ═══════════════════════════════════════════════════════════════════════
   CALLOUTS (Obsidian → família terrosa)
   ═══════════════════════════════════════════════════════════════════════ */

.acm-callout {
    border-left: 3px solid var(--acm-texto-mudo);
    background: var(--acm-papel);
    padding: .9rem 1.15rem;
    margin: 1.25rem 0;
    border-radius: 0 var(--acm-raio) var(--acm-raio) 0;
    box-shadow: var(--acm-sombra-suave);
}
.acm-callout-title {
    font-family: var(--acm-sans);
    font-weight: 600;
    text-transform: uppercase;
    font-size: .72rem;
    letter-spacing: .12em;
    margin-bottom: .35rem;
    color: var(--acm-texto-suave);
}
.acm-callout-body { color: var(--acm-texto); line-height: 1.6; }
.acm-callout-body > *:first-child { margin-top: 0; }
.acm-callout-body > *:last-child  { margin-bottom: 0; }
.acm-callout-body p { text-align: left; }

.acm-callout-disputa     { border-color: var(--acm-borgonha); }
.acm-callout-disputa .acm-callout-title { color: var(--acm-borgonha); }
.acm-callout-sem-fonte   { border-color: var(--acm-ocre); }
.acm-callout-sem-fonte .acm-callout-title { color: var(--acm-ocre); }
.acm-callout-a-pesquisar { border-color: var(--acm-musgo); }
.acm-callout-a-pesquisar .acm-callout-title { color: var(--acm-musgo); }
.acm-callout-note        { border-color: var(--acm-ardosia); }
.acm-callout-note .acm-callout-title { color: var(--acm-ardosia); }
.acm-callout-warning     { border-color: var(--acm-terracota); }
.acm-callout-warning .acm-callout-title { color: var(--acm-terracota); }


/* ═══════════════════════════════════════════════════════════════════════
   WIKILINKS & código CM-NNNN
   ═══════════════════════════════════════════════════════════════════════ */

.acm-content a {
    color: var(--acm-terracota);
    text-decoration: none;
    border-bottom: 1px solid var(--acm-terracota-suave);
    transition: border-color .15s, color .15s;
}
.acm-content a:hover {
    color: var(--acm-terracota-escuro);
    border-bottom-color: var(--acm-terracota);
}
.acm-link-ausente {
    color: var(--acm-texto-mudo);
    text-decoration: line-through;
    text-decoration-style: dotted;
    cursor: help;
}
.acm-codigo {
    font-family: var(--acm-mono);
    font-size: .9em;
    color: var(--acm-terracota-fundo) !important;
    background: var(--acm-papel-fundo);
    padding: .05em .42em;
    border-radius: 2px;
    border-bottom: 0 !important;
}
.acm-codigo:hover {
    background: var(--acm-terracota-suave);
}


/* ═══════════════════════════════════════════════════════════════════════
   DOCUMENTOS DIGITAIS (grid de CM-NNNN ao final do conteúdo)
   ═══════════════════════════════════════════════════════════════════════ */

.acm-fontes {
    margin-top: 3rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--acm-borda);
}
.acm-fontes h2 {
    font-family: var(--acm-sans);
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--acm-texto-mudo);
    margin: 0 0 1rem 0;
    border-bottom: 0;
    padding-bottom: 0;
    font-weight: 600;
}
.acm-fontes ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: .5rem;
}
.acm-fontes li a {
    display: block;
    padding: .45rem .7rem;
    background: var(--acm-papel);
    border: 1px solid var(--acm-borda);
    border-left: 3px solid var(--acm-terracota);
    color: var(--acm-terracota-fundo);
    font-family: var(--acm-mono);
    font-size: .82rem;
    text-decoration: none;
    border-radius: var(--acm-raio);
    transition: background .15s, transform .15s;
}
.acm-fontes li a:hover {
    background: var(--acm-creme);
    transform: translateX(2px);
}


/* ═══════════════════════════════════════════════════════════════════════
   NOTA CURATORIAL (aside após .acm-content)
   ═══════════════════════════════════════════════════════════════════════ */

.acm-nota-curatorial {
    margin: 2.5rem 0 1rem;
    padding: 1.2rem 1.4rem;
    background: var(--acm-papel);
    border: 1px solid var(--acm-borda);
    border-left: 4px solid var(--acm-ocre);
    border-radius: 0 var(--acm-raio) var(--acm-raio) 0;
    font-family: var(--acm-serif);
    box-shadow: var(--acm-sombra-suave);
}
.acm-nota-curatorial-titulo {
    font-family: var(--acm-sans);
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--acm-ocre);
    margin: 0 0 .6rem 0;
    font-weight: 600;
}
.acm-nota-curatorial-corpo {
    color: var(--acm-texto);
    line-height: 1.7;
}
.acm-nota-curatorial-corpo > *:first-child { margin-top: 0; }
.acm-nota-curatorial-corpo > *:last-child  { margin-bottom: 0; }


/* ═══════════════════════════════════════════════════════════════════════
   AUDIT FOOTER (curadores logados)
   ═══════════════════════════════════════════════════════════════════════ */

.acm-audit-footer {
    display: flex;
    gap: .8rem;
    align-items: center;
    margin: 2rem 0 0 0;
    padding: .6rem .9rem;
    background: var(--acm-papel-fundo);
    border: 1px dashed var(--acm-borda-forte);
    border-radius: var(--acm-raio);
    font-family: var(--acm-sans);
    font-size: .78rem;
    color: var(--acm-texto-suave);
}
.acm-audit-ico  { font-size: 1.1em; opacity: .7; }
.acm-audit-texto { flex: 1; }
.acm-audit-user { color: var(--acm-tinta); font-weight: 600; }
.acm-audit-date { color: var(--acm-tinta); }
.acm-audit-revs { color: var(--acm-texto-mudo); }
.acm-audit-link {
    color: var(--acm-terracota);
    text-decoration: none;
    white-space: nowrap;
    border-bottom: 1px solid transparent;
    transition: border-color .15s;
}
.acm-audit-link:hover { border-bottom-color: var(--acm-terracota); }


/* ═══════════════════════════════════════════════════════════════════════
   INLINE EDITOR — lápis, setas, lixeira, +
   ═══════════════════════════════════════════════════════════════════════ */

.acm-bloco-editavel { position: relative; }
.acm-bloco-editavel:hover .acm-edit-pencil,
.acm-bloco-editavel:hover .acm-edit-trash,
.acm-bloco-editavel:hover .acm-edit-move,
.acm-bloco-editavel:hover .acm-edit-insert {
    opacity: 1;
}
.acm-edit-pencil, .acm-edit-trash, .acm-edit-move, .acm-edit-insert {
    background: transparent;
    border: 1px solid transparent;
    color: var(--acm-texto-mudo);
    cursor: pointer;
    font-size: .9em;
    padding: 0 .3em;
    margin-left: .2em;
    opacity: 0;
    transition: opacity .15s, color .15s, background .15s;
    vertical-align: baseline;
    line-height: 1;
    border-radius: 2px;
}
.acm-edit-pencil:hover { color: var(--acm-terracota); background: var(--acm-terracota-suave); }
.acm-edit-trash:hover  { color: var(--acm-borgonha); background: var(--acm-terracota-suave); }
.acm-edit-move:hover   { color: var(--acm-terracota); background: var(--acm-papel-fundo); }
.acm-edit-insert:hover { color: var(--acm-musgo); background: var(--acm-papel-fundo); }
.acm-edit-move[disabled] { opacity: .25 !important; cursor: not-allowed; }

.acm-bloco-editando {
    outline: 1.5px dashed var(--acm-terracota);
    outline-offset: 6px;
    background: #FFFBF4;
    padding: .3rem;
    border-radius: var(--acm-raio);
}
.acm-bloco-editando [contenteditable="true"] {
    outline: none;
    min-height: 1.4em;
}
.acm-edit-actions {
    margin-top: .5rem;
    display: flex;
    gap: .55rem;
    align-items: center;
    flex-wrap: wrap;
    font-size: .85rem;
}
.acm-edit-save, .acm-edit-cancel {
    padding: .3rem .85rem;
    border: 1px solid var(--acm-borda-forte);
    background: var(--acm-creme);
    border-radius: var(--acm-raio);
    cursor: pointer;
    font-family: var(--acm-sans);
    font-size: .85rem;
    color: var(--acm-texto);
    transition: background .15s, transform .1s;
}
.acm-edit-save {
    background: var(--acm-terracota);
    color: #FFF7EE;
    border-color: var(--acm-terracota);
}
.acm-edit-save:hover  { background: var(--acm-terracota-escuro); transform: translateY(-1px); }
.acm-edit-cancel:hover { background: var(--acm-papel); }
.acm-edit-save[disabled], .acm-edit-cancel[disabled] { opacity: .5; cursor: not-allowed; transform: none; }
.acm-edit-hint { color: var(--acm-texto-mudo); font-size: .78em; }
.acm-edit-status { font-size: .8em; }
.acm-edit-status-info { color: var(--acm-ardosia); }
.acm-edit-status-erro { color: var(--acm-borgonha); }
.acm-edit-flash {
    position: absolute;
    top: -1.5em;
    right: 0;
    background: var(--acm-musgo);
    color: var(--acm-creme);
    padding: .18rem .6rem;
    font-size: .73rem;
    border-radius: var(--acm-raio);
    opacity: 0;
    transform: translateY(4px);
    transition: opacity .25s, transform .25s;
    pointer-events: none;
    font-family: var(--acm-sans);
}
.acm-edit-flash-show { opacity: 1; transform: translateY(0); }
.acm-bloco-recem-movido {
    background: var(--acm-terracota-suave);
    transition: background 1.2s;
}


/* ═══════════════════════════════════════════════════════════════════════
   SIDEBAR INLINE EDIT (tags + meta)
   ═══════════════════════════════════════════════════════════════════════ */

[data-acm-edit]:hover .acm-sb-pencil { opacity: 1; }
.acm-sb-pencil {
    background: transparent;
    border: none;
    color: var(--acm-texto-mudo);
    cursor: pointer;
    font-size: .85em;
    opacity: 0;
    margin-left: .4em;
    transition: opacity .15s, color .15s;
}
.acm-sb-pencil:hover { color: var(--acm-terracota); }
.acm-sb-editing {
    padding: .35rem;
    background: #FFFBF4;
    outline: 1px dashed var(--acm-terracota);
    border-radius: var(--acm-raio);
}
.acm-sb-editor {
    display: flex;
    flex-direction: column;
    gap: .4rem;
    margin-top: .3rem;
}
.acm-sb-input, .acm-sb-tag-input {
    padding: .3rem .55rem;
    border: 1px solid var(--acm-borda);
    border-radius: var(--acm-raio);
    font-family: var(--acm-sans);
    font-size: .85rem;
    width: 100%;
    box-sizing: border-box;
    background: var(--acm-creme);
    color: var(--acm-texto);
}
.acm-sb-input:focus, .acm-sb-tag-input:focus {
    outline: none;
    border-color: var(--acm-terracota);
    box-shadow: 0 0 0 2px var(--acm-terracota-suave);
}
.acm-sb-actions { display: flex; gap: .4rem; align-items: center; }
.acm-sb-save, .acm-sb-cancel {
    padding: .18rem .6rem;
    border: 1px solid var(--acm-borda);
    background: var(--acm-creme);
    border-radius: var(--acm-raio);
    cursor: pointer;
    font-size: .85rem;
    color: var(--acm-texto);
}
.acm-sb-save {
    background: var(--acm-terracota);
    color: var(--acm-creme);
    border-color: var(--acm-terracota);
}
.acm-sb-save:hover { background: var(--acm-terracota-escuro); }
.acm-sb-empty { color: var(--acm-texto-mudo); font-style: italic; font-size: .85em; }
.acm-sb-status-info { color: var(--acm-ardosia); font-size: .8em; }
.acm-sb-status-erro { color: var(--acm-borgonha); font-size: .8em; }
.acm-sb-help { color: var(--acm-texto-mudo); font-size: .74rem; }
.acm-sb-tags-chips { display: flex; flex-wrap: wrap; gap: .3rem; min-height: 1.4em; }
.acm-sb-tag-chip {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .12rem .5rem;
    background: var(--acm-creme);
    border: 1px solid var(--acm-borda);
    border-radius: 999px;
    font-size: .75rem;
    color: var(--acm-terracota-fundo);
}
.acm-sb-chip-remove {
    background: transparent;
    border: none;
    color: var(--acm-texto-mudo);
    cursor: pointer;
    font-size: 1em;
    line-height: 1;
    padding: 0 .2em;
}
.acm-sb-chip-remove:hover { color: var(--acm-borgonha); }
.acm-sb-tag-input-wrap { position: relative; }
.acm-sb-tags-suggest {
    position: absolute;
    top: 100%; left: 0; right: 0;
    background: var(--acm-creme);
    border: 1px solid var(--acm-borda);
    border-top: none;
    max-height: 200px;
    overflow-y: auto;
    z-index: 10;
    box-shadow: var(--acm-sombra-media);
    border-radius: 0 0 var(--acm-raio) var(--acm-raio);
}
.acm-sb-suggest-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .3rem .6rem;
    background: transparent;
    border: none;
    width: 100%;
    text-align: left;
    cursor: pointer;
    font-size: .85rem;
    color: var(--acm-texto);
    font-family: var(--acm-sans);
}
.acm-sb-suggest-item:hover, .acm-sb-suggest-ativo {
    background: var(--acm-papel);
    color: var(--acm-terracota-fundo);
}
.acm-sb-suggest-count { color: var(--acm-texto-mudo); font-size: .8em; }
.acm-sb-flash {
    position: absolute;
    top: -1.4em;
    right: 0;
    background: var(--acm-musgo);
    color: var(--acm-creme);
    padding: .12rem .5rem;
    font-size: .72rem;
    border-radius: var(--acm-raio);
    opacity: 0;
    transition: opacity .2s;
}
.acm-sb-flash-show { opacity: 1; }


/* ═══════════════════════════════════════════════════════════════════════
   ARCHIVE — barra A-Z, busca, tags cumulativas
   ═══════════════════════════════════════════════════════════════════════ */

.acm-archive-wrapper {
    max-width: 1340px;
    margin: 0 auto;
    padding: 2rem;
    font-family: var(--acm-sans);
}
.acm-archive-titulo {
    font-family: var(--acm-serif);
    font-size: 2.1rem;
    margin: 0 0 1.5rem 0;
    color: var(--acm-terracota);
    font-weight: 600;
    letter-spacing: -.01em;
}
.acm-archive-bar {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .3rem;
    padding: .75rem 0;
    border-top: 1px solid var(--acm-borda);
    border-bottom: 1px solid var(--acm-borda);
    margin: 1.5rem 0;
    font-size: .92rem;
    font-family: var(--acm-serif);
}
.acm-letra {
    display: inline-block;
    min-width: 1.9em;
    height: 1.9em;
    line-height: 1.9em;
    text-align: center;
    color: var(--acm-texto-mudo);
    text-decoration: none;
    border-radius: var(--acm-raio);
    transition: background .15s, color .15s;
    padding: 0 .3em;
}
.acm-letra-com-conteudo {
    color: var(--acm-tinta);
    font-weight: 600;
}
.acm-letra-com-conteudo:hover {
    background: var(--acm-papel);
    color: var(--acm-terracota);
}
.acm-letra-ativa, .acm-letra-ativa.acm-letra-com-conteudo {
    background: var(--acm-terracota);
    color: var(--acm-creme);
}
.acm-archive-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 2.5rem;
    margin-top: 1.5rem;
}
@media (max-width: 900px) {
    .acm-archive-grid { grid-template-columns: 1fr; gap: 1.5rem; }
}
.acm-archive-lista {
    columns: 2;
    column-gap: 2.5rem;
    list-style: none;
    margin: 0;
    padding: 0;
    font-family: var(--acm-serif);
    font-size: 1.02rem;
    line-height: 1.65;
}
@media (max-width: 700px) {
    .acm-archive-lista { columns: 1; }
}
.acm-archive-lista li {
    break-inside: avoid;
    padding: .15rem 0;
}
.acm-archive-lista a {
    color: var(--acm-tinta);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: color .15s, border-color .15s;
}
.acm-archive-lista a:hover {
    color: var(--acm-terracota);
    border-bottom-color: var(--acm-terracota-suave);
}
.acm-archive-tags-card {
    background: var(--acm-papel);
    border: 1px solid var(--acm-borda);
    border-left: 3px solid var(--acm-terracota);
    padding: 1.1rem 1.2rem;
    border-radius: var(--acm-raio);
    align-self: start;
    box-shadow: var(--acm-sombra-suave);
}
.acm-archive-tags-card h3 {
    margin: 0 0 .7rem 0;
    font-family: var(--acm-sans);
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--acm-texto-mudo);
    font-weight: 600;
}
.acm-tags-busca {
    width: 100%;
    padding: .35rem .65rem;
    margin-bottom: .65rem;
    border: 1px solid var(--acm-borda);
    border-radius: var(--acm-raio);
    box-sizing: border-box;
    background: var(--acm-creme);
    color: var(--acm-texto);
    font-family: var(--acm-sans);
    font-size: .85rem;
}
.acm-tags-busca:focus {
    outline: none;
    border-color: var(--acm-terracota);
    box-shadow: 0 0 0 2px var(--acm-terracota-suave);
}
.acm-tag-chips { display: flex; flex-wrap: wrap; gap: .35rem; }
.acm-tag-chip {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .18rem .65rem;
    background: var(--acm-creme);
    border: 1px solid var(--acm-borda);
    border-radius: 999px;
    font-size: .78rem;
    color: var(--acm-terracota-fundo);
    text-decoration: none;
    transition: background .15s, color .15s, border-color .15s;
}
.acm-tag-chip:hover {
    background: var(--acm-terracota);
    color: var(--acm-creme);
    border-color: var(--acm-terracota);
}
.acm-tag-chip-ativa {
    background: var(--acm-terracota);
    color: var(--acm-creme);
    border-color: var(--acm-terracota);
}
.acm-tag-chip-escondido { display: none; }
.acm-tag-chip-count {
    color: inherit;
    opacity: .65;
    font-size: .85em;
}
.acm-tags-busca-vazio {
    color: var(--acm-texto-mudo);
    font-style: italic;
    font-size: .82rem;
    margin: .35rem 0 0 0;
}


/* ═══════════════════════════════════════════════════════════════════════
   BUSCA
   ═══════════════════════════════════════════════════════════════════════ */

.acm-busca-form { margin-bottom: .75rem; max-width: 420px; }
.acm-busca-wrap {
    display: flex;
    align-items: center;
    background: var(--acm-creme);
    border: 1px solid var(--acm-borda);
    border-radius: var(--acm-raio);
    padding: 0 .65rem;
    transition: border-color .15s, box-shadow .15s;
}
.acm-busca-wrap:focus-within {
    border-color: var(--acm-terracota);
    box-shadow: 0 0 0 2px var(--acm-terracota-suave);
}
.acm-busca-input {
    flex: 1;
    border: none;
    background: transparent;
    padding: .5rem .25rem;
    outline: none;
    font-family: var(--acm-sans);
    font-size: .92rem;
    color: var(--acm-texto);
}
.acm-busca-input::placeholder { color: var(--acm-texto-mudo); }
.acm-busca-btn {
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--acm-texto-mudo);
    padding: .35rem .5rem;
    transition: color .15s;
}
.acm-busca-btn:hover { color: var(--acm-terracota); }
.acm-busca-limpar {
    color: var(--acm-texto-mudo);
    text-decoration: none;
    padding: .3rem .45rem;
    transition: color .15s;
}
.acm-busca-limpar:hover { color: var(--acm-borgonha); }


/* ═══════════════════════════════════════════════════════════════════════
   PAGINAÇÃO (output do the_posts_pagination)
   ═══════════════════════════════════════════════════════════════════════ */

.acm-archive-wrapper .pagination,
.acm-archive-wrapper nav.navigation {
    margin-top: 2.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--acm-borda);
    text-align: center;
    font-family: var(--acm-sans);
}
.acm-archive-wrapper .page-numbers {
    display: inline-block;
    padding: .35rem .7rem;
    margin: 0 .15rem;
    background: var(--acm-creme);
    border: 1px solid var(--acm-borda);
    border-radius: var(--acm-raio);
    color: var(--acm-texto);
    text-decoration: none;
    font-size: .9rem;
    transition: background .15s, color .15s;
}
.acm-archive-wrapper .page-numbers:hover {
    background: var(--acm-papel);
    color: var(--acm-terracota);
}
.acm-archive-wrapper .page-numbers.current {
    background: var(--acm-terracota);
    color: var(--acm-creme);
    border-color: var(--acm-terracota);
}


/* ═══════════════════════════════════════════════════════════════════════
   MODO EMBED (?acervo_embed=1)
   ═══════════════════════════════════════════════════════════════════════ */

body.acm-embed-mode #wpadminbar,
body.acm-embed-mode header.site-header,
body.acm-embed-mode #masthead,
body.acm-embed-mode .tainacan-header,
body.acm-embed-mode .breadcrumbs,
body.acm-embed-mode .breadcrumb,
body.acm-embed-mode footer.site-footer,
body.acm-embed-mode #colophon,
body.acm-embed-mode .acm-toc-col,
body.acm-embed-mode .acm-sidebar,
body.acm-embed-mode .acm-meta-strip,
body.acm-embed-mode .acm-audit-footer,
body.acm-embed-mode .acm-edit-pencil,
body.acm-embed-mode .acm-edit-trash,
body.acm-embed-mode .acm-edit-move,
body.acm-embed-mode .acm-edit-actions {
    display: none !important;
}
body.acm-embed-mode .acm-main { grid-template-columns: 1fr; }


/* ═══════════════════════════════════════════════════════════════════════
   EMBED INLINE de CM-NNNN (iframe expandido sob o parágrafo)
   ═══════════════════════════════════════════════════════════════════════ */

.acm-codigo-embed {
    margin: 1.25rem 0;
    border: 1px solid var(--acm-borda);
    background: var(--acm-papel);
    border-radius: var(--acm-raio);
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    transition: max-height .3s ease, opacity .25s;
    position: relative;
    box-shadow: var(--acm-sombra-suave);
}
.acm-codigo-embed-aberto {
    max-height: 900px !important;
    opacity: 1 !important;
}
.acm-codigo-embed-fechar {
    position: absolute;
    top: .4rem; right: .4rem;
    z-index: 2;
    background: var(--acm-creme);
    border: 1px solid var(--acm-borda);
    border-radius: var(--acm-raio);
    width: 1.9em;
    height: 1.9em;
    line-height: 1.9em;
    text-align: center;
    cursor: pointer;
    color: var(--acm-texto-suave);
    font-size: .95em;
    transition: color .15s, background .15s;
}
.acm-codigo-embed-fechar:hover {
    color: var(--acm-borgonha);
    background: var(--acm-terracota-suave);
}
.acm-codigo-embed-loading {
    padding: 1.2rem;
    color: var(--acm-texto-mudo);
    font-style: italic;
    font-family: var(--acm-sans);
    font-size: .9rem;
}
.acm-codigo-embed-iframe {
    width: 100%;
    height: 600px;
    border: none;
    display: block;
    background: var(--acm-creme);
}


/* ═══════════════════════════════════════════════════════════════════════
   COMMAND POPUP (reservado para feature futura)
   ═══════════════════════════════════════════════════════════════════════ */

.acm-cmd-popup {
    position: fixed;
    background: var(--acm-creme);
    border: 1px solid var(--acm-borda);
    border-radius: var(--acm-raio);
    box-shadow: var(--acm-sombra-media);
    min-width: 280px;
    max-width: 380px;
    z-index: 9999;
    font-family: var(--acm-sans);
    font-size: .87rem;
}
.acm-cmd-header {
    padding: .45rem .65rem;
    border-bottom: 1px solid var(--acm-borda-suave);
    color: var(--acm-texto-mudo);
    font-size: .8em;
}
.acm-cmd-list {
    list-style: none;
    margin: 0;
    padding: 0;
    max-height: 280px;
    overflow-y: auto;
}
.acm-cmd-item {
    padding: .35rem .65rem;
    cursor: pointer;
    display: flex;
    gap: .6rem;
    align-items: center;
    color: var(--acm-texto);
}
.acm-cmd-item:hover, .acm-cmd-ativo {
    background: var(--acm-papel);
}
.acm-cmd-cmd {
    font-family: var(--acm-mono);
    color: var(--acm-terracota);
    font-size: .88em;
}
.acm-cmd-label { color: var(--acm-texto-suave); }
.acm-cmd-empty {
    padding: .5rem .65rem;
    color: var(--acm-texto-mudo);
    font-style: italic;
}


/* ═══════════════════════════════════════════════════════════════════════
   LGPD BANNER (rodapé discreto)
   ═══════════════════════════════════════════════════════════════════════ */

.acm-lgpd-banner {
    position: fixed;
    bottom: 1.25rem;
    right: 1.25rem;
    max-width: 440px;
    background: var(--acm-creme);
    border: 1px solid var(--acm-borda);
    border-left: 4px solid var(--acm-terracota);
    box-shadow: var(--acm-sombra-media);
    padding: .95rem 1.1rem;
    border-radius: var(--acm-raio);
    z-index: 9998;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .3s, transform .3s;
    display: flex;
    gap: .9rem;
    align-items: center;
    font-family: var(--acm-sans);
    font-size: .82rem;
    line-height: 1.5;
    color: var(--acm-texto);
}
.acm-lgpd-visivel { opacity: 1; transform: translateY(0); }
.acm-lgpd-fechando { opacity: 0; transform: translateY(20px); }
.acm-lgpd-texto { flex: 1; color: var(--acm-texto-suave); }
.acm-lgpd-texto strong { color: var(--acm-tinta); }
.acm-lgpd-btn {
    background: var(--acm-terracota);
    color: var(--acm-creme);
    border: none;
    padding: .45rem .95rem;
    border-radius: var(--acm-raio);
    cursor: pointer;
    font-family: var(--acm-sans);
    font-size: .82rem;
    font-weight: 500;
    white-space: nowrap;
    letter-spacing: .02em;
    transition: background .15s, transform .1s;
}
.acm-lgpd-btn:hover {
    background: var(--acm-terracota-escuro);
    transform: translateY(-1px);
}


/* ═══════════════════════════════════════════════════════════════════════
   CARDS — [acm_cards] / [acm_sugestoes] / [acm_card]
   ═══════════════════════════════════════════════════════════════════════ */

.acm-cards-wrap { margin: 1.5rem 0 2rem; }

.acm-cards-titulo {
    font-family: var(--acm-sans);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--acm-texto-mudo);
    font-weight: 600;
    margin: 0 0 1rem 0;
    padding-bottom: .5rem;
    border-bottom: 1px solid var(--acm-borda);
}

.acm-card-grid {
    display: grid;
    gap: 1.2rem;
}
.acm-card-cols-1 { grid-template-columns: 1fr; }
.acm-card-cols-2 { grid-template-columns: repeat(2, 1fr); }
.acm-card-cols-3 { grid-template-columns: repeat(3, 1fr); }
.acm-card-cols-4 { grid-template-columns: repeat(4, 1fr); }
.acm-card-cols-5 { grid-template-columns: repeat(5, 1fr); }

@media (max-width: 900px) {
    .acm-card-cols-3, .acm-card-cols-4, .acm-card-cols-5 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .acm-card-cols-2, .acm-card-cols-3, .acm-card-cols-4, .acm-card-cols-5 { grid-template-columns: 1fr; }
}

/* Variante 1 coluna ("solo") — layout horizontal mais largo */
.acm-card-solo .acm-card {
    flex-direction: row;
    max-width: 560px;
}
.acm-card-solo .acm-card-thumb {
    width: 180px;
    min-width: 180px;
    padding-bottom: 0;
    height: auto;
    align-self: stretch;
}

/* ── Card individual ───────────────────────────────────────────────── */

.acm-card {
    display: flex;
    flex-direction: column;
    background: var(--acm-papel);
    border: 1px solid var(--acm-borda);
    border-radius: var(--acm-raio);
    overflow: hidden;
    text-decoration: none;
    color: var(--acm-texto);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    box-shadow: var(--acm-sombra-suave);
    position: relative;
}
.acm-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--acm-sombra-media);
    border-color: var(--acm-borda-forte);
    color: var(--acm-texto);
}
.acm-card:hover .acm-card-titulo {
    color: var(--acm-terracota);
}

/* Faixa terracota lateral revelada no hover */
.acm-card::before {
    content: "";
    position: absolute;
    top: 0; left: 0; bottom: 0;
    width: 3px;
    background: var(--acm-terracota);
    transform: scaleY(0);
    transform-origin: top;
    transition: transform .2s ease;
    z-index: 1;
}
.acm-card:hover::before { transform: scaleY(1); }

/* Thumb */
.acm-card-thumb {
    width: 100%;
    padding-bottom: 62%;                         /* aspect-ratio ~16:10 */
    background-color: var(--acm-papel-fundo);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
}
.acm-card-thumb-vazia {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--acm-papel) 0%, var(--acm-papel-fundo) 100%);
}
.acm-card-thumb-inicial {
    font-family: var(--acm-serif);
    font-size: 3.4rem;
    font-weight: 300;
    color: var(--acm-terracota-claro);
    line-height: 1;
    opacity: .65;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    letter-spacing: -.02em;
}

/* Info */
.acm-card-info {
    padding: .85rem 1rem 1rem;
    display: flex;
    flex-direction: column;
    gap: .3rem;
    flex: 1;
    min-width: 0;
}
.acm-card-tipo {
    font-family: var(--acm-sans);
    font-size: .65rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--acm-terracota);
    font-weight: 600;
}
.acm-card-titulo {
    font-family: var(--acm-serif);
    font-size: 1.08rem;
    line-height: 1.3;
    color: var(--acm-tinta);
    font-weight: 600;
    transition: color .15s;
    /* clamp 2 linhas */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.acm-card-meta {
    font-family: var(--acm-sans);
    font-size: .78rem;
    color: var(--acm-texto-suave);
    line-height: 1.4;
}
.acm-card-excerto {
    font-family: var(--acm-serif);
    font-size: .85rem;
    line-height: 1.5;
    color: var(--acm-texto-suave);
    margin-top: .2rem;
    /* clamp 3 linhas */
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ── Rodapé "Ver mais →" ───────────────────────────────────────────── */

.acm-cards-rodape {
    margin-top: 1.25rem;
    text-align: right;
}
.acm-cards-ver-mais {
    font-family: var(--acm-sans);
    font-size: .82rem;
    color: var(--acm-terracota);
    text-decoration: none;
    border-bottom: 1px solid var(--acm-terracota-suave);
    padding-bottom: 1px;
    transition: border-color .15s, color .15s;
    letter-spacing: .01em;
}
.acm-cards-ver-mais:hover {
    color: var(--acm-terracota-escuro);
    border-bottom-color: var(--acm-terracota);
}

/* ── Estado vazio ──────────────────────────────────────────────────── */

.acm-cards-vazio, .acm-card-vazio {
    padding: 1.5rem;
    text-align: center;
    color: var(--acm-texto-mudo);
    font-family: var(--acm-sans);
    font-size: .9rem;
    background: var(--acm-papel);
    border: 1px dashed var(--acm-borda);
    border-radius: var(--acm-raio);
}
.acm-card-vazio code {
    font-family: var(--acm-mono);
    background: var(--acm-papel-fundo);
    color: var(--acm-terracota-fundo);
    padding: .1em .4em;
    border-radius: 2px;
    font-style: normal;
}

/* ── Skeleton loaders ([acm_sugestoes] enquanto JS carrega) ────────── */

.acm-card-skel {
    pointer-events: none;
    cursor: default;
    background: var(--acm-papel);
}
.acm-card-skel:hover {
    transform: none;
    border-color: var(--acm-borda);
    box-shadow: var(--acm-sombra-suave);
}
.acm-card-skel::before { display: none; }
.acm-card-skel-thumb {
    background: linear-gradient(90deg,
        var(--acm-papel-fundo) 0%,
        var(--acm-papel) 50%,
        var(--acm-papel-fundo) 100%);
    background-size: 200% 100%;
    animation: acm-skel-shimmer 1.4s ease-in-out infinite;
}
.acm-card-skel-linha {
    height: .75em;
    background: linear-gradient(90deg,
        var(--acm-papel-fundo) 0%,
        var(--acm-papel) 50%,
        var(--acm-papel-fundo) 100%);
    background-size: 200% 100%;
    animation: acm-skel-shimmer 1.4s ease-in-out infinite;
    border-radius: 2px;
}
.acm-card-skel-linha-pq { width: 25%; height: .55em; }
.acm-card-skel-linha-gr { width: 85%; height: 1em; margin-top: .15em; }
.acm-card-skel-linha-md { width: 60%; height: .65em; margin-top: .1em; }

@keyframes acm-skel-shimmer {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fade-in dos cards reais (sugestoes) substituindo skeletons */
.acm-sug-fade-in .acm-card {
    animation: acm-fade-in .4s ease both;
}
.acm-sug-fade-in .acm-card:nth-child(1) { animation-delay: .00s; }
.acm-sug-fade-in .acm-card:nth-child(2) { animation-delay: .05s; }
.acm-sug-fade-in .acm-card:nth-child(3) { animation-delay: .10s; }
.acm-sug-fade-in .acm-card:nth-child(4) { animation-delay: .15s; }
.acm-sug-fade-in .acm-card:nth-child(5) { animation-delay: .20s; }
.acm-sug-fade-in .acm-card:nth-child(6) { animation-delay: .25s; }
@keyframes acm-fade-in {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}
