/* ════════════════════════════════════════════════
   Braz Posts Cards — Página do evento (single)
   Design "Portal Brazópolis": serif + verde + cartaz
   ════════════════════════════════════════════════ */

/* Escopo das variáveis: vale para a página inteira (.bpc-ev, template PHP)
   e para cada widget avulso do Theme Builder (.bpc-ev-w). */
.bpc-ev,
.bpc-ev-w {
	--ev-green: #1f6b3f;
	--ev-green-dark: #14502f;
	--ev-accent: #d8543a;
	--ev-gold: #a8761f;
	--ev-ink: #2b2b26;
	--ev-muted: #7a766d;
	--ev-card: #ffffff;
	--ev-line: #e9e2d8;
	--ev-soft: #f3ece3;
	--ev-serif: "Georgia", "Iowan Old Style", "Times New Roman", serif;

	color: var(--ev-ink);
}
/* Layout de página cheia — só no template PHP, não nos widgets. */
.bpc-ev {
	max-width: 1160px;
	margin: 0 auto;
	padding: 28px clamp(16px, 4vw, 40px) 64px;
}
.bpc-ev *,
.bpc-ev *::before,
.bpc-ev *::after,
.bpc-ev-w *,
.bpc-ev-w *::before,
.bpc-ev-w *::after { box-sizing: border-box; }

/* Nos widgets avulsos as seções não precisam de margem-topo herdada. */
.bpc-ev-w .bpc-ev-secao { margin-bottom: 0; }

/* Placeholder do editor (quando não há evento em contexto / campo vazio). */
.bpc-ev-ph {
	border: 2px dashed var(--ev-line);
	border-radius: 12px;
	padding: 22px 18px;
	text-align: center;
	color: var(--ev-muted);
	font-size: 0.9rem;
}

/* ── Breadcrumb ── */
.bpc-ev-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	font-size: 0.82rem;
	color: var(--ev-muted);
	margin-bottom: 22px;
}
.bpc-ev-breadcrumb a {
	color: var(--ev-muted);
	text-decoration: none;
}
.bpc-ev-breadcrumb a:hover { color: var(--ev-green); }
.bpc-ev-breadcrumb__atual { color: var(--ev-ink); font-weight: 600; }

/* ── Grid principal ── */
.bpc-ev-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 340px;
	gap: 44px;
	align-items: start;
}

/* ════════════════════════════════════════════════
   Coluna principal
   ════════════════════════════════════════════════ */
.bpc-ev-tags {
	font-size: 0.74rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ev-gold);
	margin: 0 0 12px;
}
.bpc-ev-titulo {
	font-family: var(--ev-serif);
	font-size: clamp(1.9rem, 3.4vw, 2.7rem);
	font-weight: 700;
	line-height: 1.12;
	margin: 0 0 14px;
	color: var(--ev-ink);
}
.bpc-ev-resumo {
	font-size: 1.08rem;
	line-height: 1.55;
	color: #55524b;
	margin: 0 0 22px;
	max-width: 60ch;
}

.bpc-ev-status {
	display: inline-block;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 5px 12px;
	border-radius: 99px;
	margin-bottom: 18px;
}
.bpc-ev-status--agora { background: var(--ev-accent); color: #fff; }
.bpc-ev-status--off { background: #e5e5e5; color: #777; }

/* ── Cartaz ── */
.bpc-ev-cartaz {
	margin: 0 0 22px;
	border-radius: 16px;
	overflow: hidden;
}
.bpc-ev-cartaz img {
	display: block;
	width: 100%;
	height: auto;
}
.bpc-ev-cartaz--placeholder {
	position: relative;
	min-height: 320px;
	background-size: cover;
}
.bpc-ev-cartaz--placeholder::after {
	content: "";
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.06) 0 2px, transparent 2px 22px);
}
.bpc-ev-cartaz__tag {
	position: absolute;
	top: 16px;
	left: 16px;
	z-index: 1;
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	color: rgba(255, 255, 255, 0.92);
	background: rgba(0, 0, 0, 0.28);
	padding: 6px 12px;
	border-radius: 8px;
}

/* ── 4 infos ── */
.bpc-ev-facts {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 12px;
	margin-bottom: 34px;
}
.bpc-ev-fact {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 14px 16px;
	background: var(--ev-card);
	border: 1px solid var(--ev-line);
	border-radius: 12px;
}
.bpc-ev-fact--free {
	background: #eaf5ec;
	border-color: #cfe7d4;
}
.bpc-ev-fact__rotulo {
	font-size: 0.66rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ev-muted);
}
.bpc-ev-fact__valor {
	font-family: var(--ev-serif);
	font-size: 1.08rem;
	font-weight: 700;
	color: var(--ev-ink);
}
.bpc-ev-fact--free .bpc-ev-fact__valor { color: var(--ev-green); }

/* ── Seções ── */
.bpc-ev-secao { margin-bottom: 38px; }
.bpc-ev-secao__titulo {
	font-family: var(--ev-serif);
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--ev-green);
	margin: 0 0 16px;
}
.bpc-ev-conteudo {
	font-size: 1rem;
	line-height: 1.7;
	color: #45423c;
}
.bpc-ev-conteudo > * { margin: 0 0 1em; }
.bpc-ev-conteudo img { max-width: 100%; height: auto; border-radius: 10px; }

/* ── Citação ── */
.bpc-ev-citacao {
	margin: 0 0 38px;
	padding: 4px 0 4px 22px;
	border-left: 4px solid var(--ev-accent);
}
.bpc-ev-citacao p {
	font-family: var(--ev-serif);
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1.35;
	color: var(--ev-ink);
	margin: 0 0 8px;
}
.bpc-ev-citacao cite {
	font-style: normal;
	font-size: 0.86rem;
	color: var(--ev-muted);
}

/* ── Programação ── */
.bpc-ev-prog {
	list-style: none;
	margin: 0;
	padding: 0;
}
.bpc-ev-prog__item {
	display: grid;
	grid-template-columns: 110px 1fr;
	gap: 18px;
	padding: 14px 0;
	border-bottom: 1px solid var(--ev-line);
}
.bpc-ev-prog__item:first-child { border-top: 1px solid var(--ev-line); }
.bpc-ev-prog__quando { display: flex; flex-direction: column; gap: 2px; }
.bpc-ev-prog__dia {
	font-size: 0.64rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--ev-gold);
}
.bpc-ev-prog__hora {
	font-family: var(--ev-serif);
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--ev-ink);
}
.bpc-ev-prog__oque { display: flex; flex-direction: column; gap: 3px; }
.bpc-ev-prog__titulo {
	font-family: var(--ev-serif);
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--ev-ink);
}
.bpc-ev-prog__local { font-size: 0.84rem; color: var(--ev-muted); }

/* ── Como chegar ── */
.bpc-ev-mapa {
	position: relative;
	border-radius: 16px;
	overflow: hidden;
	border: 1px solid var(--ev-line);
}
.bpc-ev-mapa iframe {
	display: block;
	width: 100%;
	height: 340px;
	border: 0;
	filter: saturate(0.9);
}
.bpc-ev-mapa__card {
	position: absolute;
	left: 18px;
	bottom: 18px;
	display: flex;
	flex-direction: column;
	gap: 3px;
	max-width: 320px;
	padding: 14px 18px;
	background: #fff;
	border-radius: 12px;
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.16);
}
.bpc-ev-mapa__card strong {
	font-family: var(--ev-serif);
	font-size: 1rem;
	color: var(--ev-ink);
}
.bpc-ev-mapa__card span { font-size: 0.82rem; color: var(--ev-muted); }
.bpc-ev-mapa__card a {
	margin-top: 4px;
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--ev-green);
	text-decoration: none;
}

/* ── Outros eventos ── */
.bpc-ev-outros__titulo {
	position: relative;
	padding-left: 16px;
}
.bpc-ev-outros__titulo::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 5px;
	height: 1.05em;
	border-radius: 2px;
	background: var(--ev-accent);
}
.bpc-ev-outros__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 14px;
}
.bpc-ev-mini {
	display: flex;
	background: #fff;
	border: 1px solid var(--ev-line);
	border-radius: 12px;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: transform 0.16s ease, box-shadow 0.16s ease;
}
.bpc-ev-mini:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 18px rgba(40, 40, 30, 0.1);
}
.bpc-ev-mini__date {
	flex: 0 0 54px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1px;
	color: #fff;
	line-height: 1;
}
.bpc-ev-mini__date strong { font-family: var(--ev-serif); font-size: 1.3rem; font-weight: 800; }
.bpc-ev-mini__date small { font-size: 0.55rem; font-weight: 700; letter-spacing: 0.08em; opacity: 0.92; }
.bpc-ev-mini__body { display: flex; flex-direction: column; gap: 3px; padding: 11px 13px; min-width: 0; }
.bpc-ev-mini__tipo {
	font-size: 0.58rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--ev-green-dark);
	background: #eef4ef;
	align-self: flex-start;
	padding: 2px 7px;
	border-radius: 5px;
}
.bpc-ev-mini__title { font-family: var(--ev-serif); font-size: 0.95rem; font-weight: 700; line-height: 1.2; }
.bpc-ev-mini__meta { font-size: 0.76rem; color: var(--ev-muted); }

/* ════════════════════════════════════════════════
   Coluna lateral
   ════════════════════════════════════════════════ */
.bpc-ev-side {
	position: sticky;
	top: 24px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.bpc-ev-card {
	background: #fff;
	border: 1px solid var(--ev-line);
	border-radius: 16px;
	overflow: hidden;
}
.bpc-ev-card__head {
	display: flex;
	gap: 14px;
	align-items: center;
	padding: 20px;
	background: linear-gradient(135deg, var(--ev-green) 0%, var(--ev-green-dark) 100%);
	color: #fff;
}
.bpc-ev-card__date {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	line-height: 1;
	background: rgba(255, 255, 255, 0.14);
	border-radius: 10px;
	padding: 8px 12px;
	min-width: 56px;
}
.bpc-ev-card__date strong { font-family: var(--ev-serif); font-size: 1.9rem; font-weight: 800; }
.bpc-ev-card__date small { font-size: 0.58rem; font-weight: 700; letter-spacing: 0.1em; opacity: 0.9; }
.bpc-ev-card__when { display: flex; flex-direction: column; gap: 3px; }
.bpc-ev-card__when strong { font-family: var(--ev-serif); font-size: 1.12rem; font-weight: 700; }
.bpc-ev-card__when span { font-size: 0.8rem; opacity: 0.85; }

.bpc-ev-card__rows {
	list-style: none;
	margin: 0;
	padding: 18px 20px;
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.bpc-ev-card__rows li { display: flex; gap: 12px; align-items: flex-start; }
.bpc-ev-card__rows svg { width: 20px; height: 20px; color: var(--ev-green); flex: 0 0 auto; margin-top: 1px; }
.bpc-ev-card__rows span { display: flex; flex-direction: column; }
.bpc-ev-card__rows strong { font-size: 0.92rem; font-weight: 700; color: var(--ev-ink); }
.bpc-ev-card__rows em { font-style: normal; font-size: 0.78rem; color: var(--ev-muted); }

.bpc-ev-btn {
	display: block;
	text-align: center;
	font-size: 0.9rem;
	font-weight: 700;
	padding: 12px 16px;
	border-radius: 99px;
	text-decoration: none;
	cursor: pointer;
	border: none;
	transition: background 0.2s, color 0.2s;
}
.bpc-ev-btn--add {
	margin: 0 20px 10px;
	background: var(--ev-green);
	color: #fff;
}
.bpc-ev-btn--add:hover { background: var(--ev-green-dark); color: #fff; }

.bpc-ev-card__actions {
	display: flex;
	gap: 10px;
	padding: 0 20px 20px;
}
.bpc-ev-btn--ghost,
.bpc-ev-btn--wa {
	flex: 1;
	font-size: 0.84rem;
	padding: 11px 12px;
}
.bpc-ev-btn--ghost {
	background: var(--ev-soft);
	color: var(--ev-ink);
}
.bpc-ev-btn--ghost:hover { background: #e7ded2; }
.bpc-ev-btn--wa {
	background: #e8f6ed;
	color: #1a7a4c;
}
.bpc-ev-btn--wa::before {
	content: "";
	display: inline-block;
	width: 8px;
	height: 8px;
	margin-right: 6px;
	border-radius: 50%;
	background: #25d366;
	vertical-align: middle;
}
.bpc-ev-btn--wa:hover { background: #d8efe0; color: #145e3a; }

/* ── Organização ── */
.bpc-ev-org,
.bpc-ev-patro {
	border-radius: 14px;
	padding: 16px 18px;
	text-decoration: none;
	color: inherit;
	display: block;
}
.bpc-ev-org { background: #fff; border: 1px solid var(--ev-line); }
.bpc-ev-org__rotulo,
.bpc-ev-patro__rotulo {
	display: block;
	font-size: 0.64rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--ev-muted);
	margin-bottom: 12px;
}
.bpc-ev-org__linha,
.bpc-ev-patro__linha { display: flex; align-items: center; gap: 12px; }
.bpc-ev-avatar {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 10px;
	overflow: hidden;
	background: #6b4a2b;
	color: #fff;
	font-size: 0.86rem;
	font-weight: 700;
}
.bpc-ev-avatar img { width: 100%; height: 100%; object-fit: cover; }
.bpc-ev-org__nome strong,
.bpc-ev-patro__nome strong {
	display: block;
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--ev-ink);
}
.bpc-ev-org__nome em,
.bpc-ev-patro__nome em {
	font-style: normal;
	font-size: 0.78rem;
	color: var(--ev-muted);
}

/* ── Patrocínio (escuro) ── */
.bpc-ev-patro {
	background: #3a2a1c;
	transition: transform 0.18s ease;
}
.bpc-ev-patro:hover { transform: translateY(-2px); }
.bpc-ev-patro__rotulo { color: var(--ev-gold); }
.bpc-ev-patro__nome strong { color: #fff; }
.bpc-ev-patro__nome em { color: rgba(255, 255, 255, 0.7); }
.bpc-ev-avatar--patro { background: var(--ev-gold); }

/* ── Toast (compartilhar) ── */
.bpc-ev-toast {
	position: fixed;
	left: 50%;
	bottom: 28px;
	transform: translateX(-50%) translateY(20px);
	background: var(--ev-ink);
	color: #fff;
	font-size: 0.86rem;
	font-weight: 600;
	padding: 11px 20px;
	border-radius: 99px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.25s, transform 0.25s;
	z-index: 9999;
}
.bpc-ev-toast.is-on { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ════════════════════════════════════════════════
   Responsivo
   ════════════════════════════════════════════════ */
@media (max-width: 980px) {
	.bpc-ev-grid { grid-template-columns: 1fr; gap: 32px; }
	.bpc-ev-side { position: static; }
}
@media (max-width: 640px) {
	.bpc-ev-facts { grid-template-columns: repeat(2, 1fr); }
	.bpc-ev-outros__grid { grid-template-columns: 1fr; }
	.bpc-ev-prog__item { grid-template-columns: 84px 1fr; gap: 12px; }
}

@media (prefers-reduced-motion: reduce) {
	.bpc-ev-mini, .bpc-ev-mini:hover,
	.bpc-ev-patro, .bpc-ev-patro:hover { transform: none; transition: none; }
}
