/* ============================================================
   CBP — Página de detalhes do evento (detalhe.php)
   ============================================================ */

.cbp-detalhe-wrap {
    max-width: var(--cbp-max-width, 720px);
    margin: 32px auto;
    padding: 0 16px;
    font-family: inherit;
    font-size: var(--cbp-font-size, 15px);
    color: var(--cbp-text, #1a1a1a);
    line-height: 1.6;
}

/* Voltar */
.cbp-detalhe-voltar-wrap {
    margin-bottom: 20px;
}
.cbp-detalhe-voltar {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px !important;
    color: var(--cbp-primary, #7a1f1f) !important;
    text-decoration: none !important;
    border: 1px solid var(--cbp-primary, #7a1f1f);
    border-radius: 6px;
    padding: 7px 14px;
    font-family: inherit !important;
    transition: background .15s;
}
.cbp-detalhe-voltar:hover {
    background: #fdf5f5;
    text-decoration: none !important;
}

/* Alerta */
.cbp-detalhe-alerta {
    margin-bottom: 16px;
}

/* Header: datebox + título */
.cbp-detalhe-header {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    margin-bottom: 28px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--cbp-border, #e4e0db);
}
.cbp-detalhe-datebox {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 12px 16px;
    background: var(--cbp-ban-bg, #f3f4f6);
    border: 1px solid var(--cbp-border, #e4e0db);
    border-left: 3px solid var(--cbp-primary, #7a1f1f);
    border-radius: 8px;
    min-width: 60px;
    flex-shrink: 0;
    text-align: center;
}
.cbp-detalhe-dia {
    font-size: 32px !important;
    font-weight: 700 !important;
    color: var(--cbp-primary, #7a1f1f) !important;
    line-height: 1;
    display: block;
    font-family: inherit !important;
}
.cbp-detalhe-mes {
    font-size: 11px !important;
    color: var(--cbp-muted, #777) !important;
    text-transform: uppercase;
    letter-spacing: .07em;
    margin-top: 3px;
    display: block;
    font-family: inherit !important;
}
.cbp-detalhe-header-info {
    flex: 1;
}
.cbp-detalhe-titulo {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--cbp-text, #1a1a1a) !important;
    margin: 0 0 8px !important;
    line-height: 1.3 !important;
    font-family: inherit !important;
}
.cbp-detalhe-badge {
    font-size: 11px !important;
}

/* Layout principal: conteúdo + sidebar */
.cbp-detalhe-corpo {
    display: flex;
    gap: 28px;
    align-items: flex-start;
}
.cbp-detalhe-main {
    flex: 1;
    min-width: 0;
}
.cbp-detalhe-sidebar {
    flex-shrink: 0;
    width: 200px;
}

/* Seções de info */
.cbp-detalhe-secao {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    margin-bottom: 22px;
    padding-bottom: 22px;
    border-bottom: 1px solid var(--cbp-border, #e4e0db);
}
.cbp-detalhe-secao:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}
.cbp-detalhe-secao-icone {
    font-size: 18px;
    line-height: 1.4;
    flex-shrink: 0;
    width: 24px;
    text-align: center;
}
.cbp-detalhe-secao-conteudo {
    flex: 1;
}
.cbp-detalhe-secao-titulo {
    font-size: 11px !important;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--cbp-muted, #777) !important;
    font-weight: 600;
    margin-bottom: 5px;
    font-family: inherit !important;
}
.cbp-detalhe-secao-valor {
    font-size: var(--cbp-font-size, 15px) !important;
    color: var(--cbp-text, #1a1a1a) !important;
    font-family: inherit !important;
}
.cbp-detalhe-hora {
    color: var(--cbp-muted, #777) !important;
    font-size: 14px !important;
}

/* Botões de mapa */
.cbp-detalhe-maps-acoes {
    display: flex;
    gap: 8px;
    margin-top: 10px;
    flex-wrap: wrap;
}
.cbp-detalhe-btn-mapa,
.cbp-detalhe-btn-copiar {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12px !important;
    padding: 5px 12px;
    border-radius: 6px;
    cursor: pointer;
    font-family: inherit !important;
    transition: background .15s, color .15s;
    text-decoration: none !important;
    border: 1px solid var(--cbp-primary, #7a1f1f);
}
.cbp-detalhe-btn-mapa {
    background: var(--cbp-primary, #7a1f1f);
    color: #fff !important;
}
.cbp-detalhe-btn-mapa:hover {
    background: #5e1717;
    color: #fff !important;
    text-decoration: none !important;
}
.cbp-detalhe-btn-copiar {
    background: transparent;
    color: var(--cbp-primary, #7a1f1f) !important;
}
.cbp-detalhe-btn-copiar:hover,
.cbp-detalhe-btn-copiado {
    background: #fdf5f5;
}

/* Miniatura do mapa */
.cbp-detalhe-mapa-wrap {
    margin-bottom: 22px;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--cbp-border, #e4e0db);
}

/* Descrição */
.cbp-detalhe-descricao {
    font-size: var(--cbp-font-size, 15px) !important;
    color: var(--cbp-text, #1a1a1a);
    font-family: inherit !important;
}
.cbp-detalhe-descricao p {
    margin: 0 0 12px;
}
.cbp-detalhe-descricao p:last-child {
    margin-bottom: 0;
}

/* Card de ingresso */
.cbp-detalhe-ingresso-card {
    background: var(--cbp-ban-bg, #f3f4f6);
    border: 1px solid var(--cbp-border, #e4e0db);
    border-left: 3px solid var(--cbp-primary, #7a1f1f);
    border-radius: 8px;
    padding: 18px 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.cbp-detalhe-preco {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.cbp-detalhe-preco-lbl {
    font-size: 11px !important;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--cbp-muted, #777) !important;
    font-weight: 600;
    font-family: inherit !important;
}
.cbp-detalhe-preco-val {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--cbp-text, #1a1a1a) !important;
    font-family: inherit !important;
}
.cbp-detalhe-gratuito {
    color: #166534 !important;
}
.cbp-detalhe-vagas {
    margin-left: 0 !important;
    font-size: 13px !important;
}
.cbp-detalhe-esgotado {
    font-size: 13px !important;
    color: #991b1b !important;
    font-weight: 600;
}
.cbp-detalhe-btn-ingresso {
    display: block;
    width: 100%;
    text-align: center;
    font-size: 14px !important;
    padding: 10px 16px;
    border-radius: var(--cbp-btn-radius, 6px);
    background: var(--cbp-btn-comprar-bg, #166534);
    color: var(--cbp-btn-comprar-txt, #fff) !important;
    border: 1px solid var(--cbp-btn-comprar-b, #166534);
    text-decoration: none !important;
    font-family: inherit !important;
    font-weight: 600;
    transition: opacity .15s;
    cursor: pointer;
}
.cbp-detalhe-btn-ingresso:hover {
    opacity: .88;
    text-decoration: none !important;
    color: var(--cbp-btn-comprar-txt, #fff) !important;
}
.cbp-detalhe-em-breve {
    display: block;
    text-align: center;
    font-size: 13px !important;
    color: var(--cbp-muted, #777) !important;
    padding: 8px;
    background: #f9f9f9;
    border: 1px solid var(--cbp-border, #e4e0db);
    border-radius: 6px;
}

/* Mobile */
@media (max-width: 640px) {
    .cbp-detalhe-corpo {
        flex-direction: column;
    }
    .cbp-detalhe-sidebar {
        width: 100%;
        order: -1; /* card de ingresso aparece antes da descrição no mobile */
    }
    .cbp-detalhe-titulo {
        font-size: 18px !important;
    }
    .cbp-detalhe-dia {
        font-size: 26px !important;
    }
}
