/* ════════════════════════════════════════════════
   Braz Turismo — Ônibus · Horários (vitrine interativa)
   ════════════════════════════════════════════════ */

.brt-onibus {
	--bo-cream: #F2ECE0;
	--bo-paper: #FFFDF9;
	--bo-ink: #2A2018;
	--bo-verde: #046929;
	--bo-verde-d: #023D18;
	--bo-coral: #E0613A;
	--bo-gold: #D9A94E;
	--bo-linha: #E3DFD4;
	--bo-muted: #8A8276;
	--bo-past-bg: #ECE6D9;
	--bo-serif: "Zilla Slab", "Iowan Old Style", Georgia, serif;
	--bo-sans: "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

	background-color: var(--bo-cream);
	color: var(--bo-ink);
	font-family: var(--bo-sans);
	padding: 40px 24px;
}
.brt-onibus *,
.brt-onibus *::before,
.brt-onibus *::after { box-sizing: border-box; }

/* ── Layout ─────────────────────────────────────── */
.brt-onibus__layout {
	--bo-sidebar: 290px;
	max-width: 1180px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: var(--bo-sidebar) 1fr;
	grid-template-areas:
		"clock main"
		"rodo  main";
	align-items: start;
	gap: 22px 30px;
}
.brt-onibus__clock { grid-area: clock; }
.brt-onibus__rodo  { grid-area: rodo; }
.brt-onibus__main  { grid-area: main; min-width: 0; }

/* ── Relógio ────────────────────────────────────── */
.brt-onibus__clock {
	background: var(--bo-paper);
	border: 1px solid var(--bo-linha);
	border-radius: 16px;
	padding: 18px 18px 20px;
}
.brt-onibus__now {
	display: flex;
	align-items: center;
	gap: 9px;
	font-size: 0.92rem;
	font-weight: 600;
}
.brt-onibus__now-dot {
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: var(--bo-verde);
	flex: 0 0 auto;
	box-shadow: 0 0 0 4px rgba(4, 105, 41, 0.14);
}
.brt-onibus__now-time { font-weight: 700; }
.brt-onibus__now-date {
	margin-top: 4px;
	font-size: 0.84rem;
	color: var(--bo-muted);
}
.brt-onibus__dia-label {
	margin-top: 18px;
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--bo-muted);
}
.brt-onibus__toggle {
	margin-top: 10px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.brt-onibus__tab {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	width: 100%;
	padding: 11px 14px;
	border: 1px solid var(--bo-linha);
	border-radius: 11px;
	background: #fff;
	color: var(--bo-ink);
	font: inherit;
	font-size: 0.9rem;
	font-weight: 600;
	cursor: pointer;
	transition: border-color 0.16s ease, background 0.16s ease, color 0.16s ease;
	-webkit-appearance: none;
	appearance: none;
}
.brt-onibus__tab:hover { border-color: var(--bo-verde); background-color: #FAF6EE; }
.brt-onibus__tab:focus-visible { outline: 3px solid rgba(4, 105, 41, 0.4); outline-offset: 2px; }
.brt-onibus__tab-badge {
	min-width: 26px;
	padding: 2px 8px;
	border-radius: 99px;
	background: var(--bo-past-bg);
	color: var(--bo-muted);
	font-size: 0.76rem;
	font-weight: 700;
	text-align: center;
}
.brt-onibus__tab.is-active {
	background: var(--bo-verde);
	border-color: var(--bo-verde);
	color: #fff;
}
.brt-onibus__tab.is-active .brt-onibus__tab-badge {
	background: rgba(255, 255, 255, 0.22);
	color: #fff;
}

/* ── Rodoviária ─────────────────────────────────── */
.brt-onibus__rodo {
	background: var(--bo-verde-d);
	border-radius: 16px;
	padding: 18px;
	color: #fff;
}
.brt-onibus__rodo-head {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.7);
}
.brt-onibus__rodo-head svg { width: 15px; height: 15px; flex: 0 0 auto; color: rgba(255, 255, 255, 0.7); }
.brt-onibus__rodo-end {
	margin: 12px 0 16px;
	font-size: 0.9rem;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.84);
}
.brt-onibus__rodo-acoes {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.brt-onibus__rodo-tel {
	font-size: 1.05rem;
	font-weight: 700;
	color: #fff;
	text-decoration: none;
}
.brt-onibus__rodo-tel:hover { text-decoration: underline; }
.brt-onibus__rodo-tel-pre { display: none; }
.brt-onibus__rodo-map {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 11px 18px;
	border-radius: 10px;
	background: var(--bo-gold);
	color: #3a2a10;
	font-size: 0.9rem;
	font-weight: 700;
	text-decoration: none;
	transition: filter 0.16s ease;
}
.brt-onibus__rodo-map:hover { filter: brightness(1.06); }

/* ── Cabeçalho da lista ─────────────────────────── */
.brt-onibus__head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 14px;
	margin-bottom: 16px;
}
.brt-onibus__titulo {
	margin: 0;
	font-family: var(--bo-serif);
	font-size: clamp(1.4rem, 2.4vw, 1.8rem);
	font-weight: 700;
	color: var(--bo-verde);
	line-height: 1.1;
}
.brt-onibus__meta {
	flex: 0 0 auto;
	font-size: 0.84rem;
	color: var(--bo-muted);
	white-space: nowrap;
}

/* ── Grade de cartões ───────────────────────────── */
.brt-onibus__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 18px;
}

/* ── Cartão ─────────────────────────────────────── */
.brt-onibus-card {
	--bo-card: var(--bo-verde);
	display: flex;
	flex-direction: column;
	background: var(--bo-paper);
	border: 1px solid var(--bo-linha);
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 4px 14px rgba(40, 25, 10, 0.05);
	transition: border-color 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease;
}
.brt-onibus-card:hover {
	border-color: var(--bo-verde);
	box-shadow: 0 10px 26px rgba(40, 25, 10, 0.12);
}
.brt-onibus-card--verde { --bo-card: #046929; }
.brt-onibus-card--navy  { --bo-card: #243C54; }
.brt-onibus-card--cafe  { --bo-card: #6B4A2B; }
.brt-onibus-card--gold  { --bo-card: #B07A2A; }
.brt-onibus-card--slate { --bo-card: #4A5560; }
.brt-onibus-card--coral { --bo-card: #E0613A; }

.brt-onibus-card__head {
	display: flex;
	align-items: center;
	gap: 13px;
	width: 100%;
	padding: 16px 18px;
	border: 0;
	background: transparent;
	text-align: left;
	font: inherit;
	color: inherit;
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
}
.brt-onibus-card__head:focus-visible { outline: 3px solid rgba(4, 105, 41, 0.4); outline-offset: -3px; }
/* Neutraliza estilos de button:hover herdados do tema (evita "rosa" no topo). */
.brt-onibus-card__head:hover,
.brt-onibus-card__head:focus,
.brt-onibus-card__head:active {
	background-color: transparent;
	color: inherit;
	box-shadow: none;
}

.brt-onibus-card__icon {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 11px;
	background: var(--bo-card);
	color: #fff;
}
.brt-onibus-card__icon svg { width: 22px; height: 22px; }

.brt-onibus-card__id {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.brt-onibus-card__cidade {
	font-family: var(--bo-serif);
	font-size: 1.16rem;
	font-weight: 700;
	line-height: 1.15;
	color: var(--bo-ink);
}
.brt-onibus-card__meta {
	font-size: 0.8rem;
	color: var(--bo-muted);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.brt-onibus-card__proximo {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 1px;
	text-align: right;
}
.brt-onibus-card__proximo-label {
	font-size: 0.6rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--bo-muted);
}
.brt-onibus-card__proximo-time {
	font-size: 1.18rem;
	font-weight: 700;
	color: var(--bo-verde);
	font-variant-numeric: tabular-nums;
}

.brt-onibus-card__chev {
	flex: 0 0 auto;
	display: none; /* só aparece no mobile (acordeão) */
	color: var(--bo-muted);
}
.brt-onibus-card__chev svg { width: 18px; height: 18px; transition: transform 0.2s ease; }

/* ── Painel ─────────────────────────────────────── */
.brt-onibus-card__panel {
	padding: 0 18px 16px;
}

/* Linha "Saídas · Seg a Sex" — escondida no desktop (os horários falam por si) */
.brt-onibus-card__saidas {
	display: none;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 12px;
}
.brt-onibus-card__saidas-label {
	font-size: 0.66rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--bo-muted);
}

/* Grade de horários */
.brt-onibus-card__times {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px;
}
.brt-onibus-card__time {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 9px 4px;
	border: 1px solid var(--bo-linha);
	border-radius: 9px;
	background: #fff;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--bo-ink);
	font-variant-numeric: tabular-nums;
	letter-spacing: 0.01em;
	transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.brt-onibus-card__time:not(.is-next):not(.is-past):hover {
	border-color: var(--bo-verde);
	color: var(--bo-verde);
}
.brt-onibus-card__time.is-past {
	background: var(--bo-past-bg);
	border-color: transparent;
	color: #A89F8E;
}
.brt-onibus-card__time.is-next {
	background: var(--bo-verde);
	border-color: var(--bo-verde);
	color: #fff;
	box-shadow: 0 4px 10px rgba(4, 105, 41, 0.28);
}
.brt-onibus-card__vazio {
	font-size: 0.86rem;
	color: var(--bo-muted);
	padding: 4px 0;
}

/* Rodapé do cartão */
.brt-onibus-card__foot {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	margin-top: 14px;
	padding-top: 13px;
	border-top: 1px solid var(--bo-linha);
}
.brt-onibus-card__nota {
	display: flex;
	align-items: baseline;
	gap: 7px;
	font-size: 0.8rem;
	line-height: 1.4;
	color: #6E665B;
}
.brt-onibus-card__nota-dot {
	flex: 0 0 auto;
	width: 6px;
	height: 6px;
	margin-top: 5px;
	border-radius: 50%;
	background: var(--bo-gold);
}
.brt-onibus-card__preco {
	font-size: 0.92rem;
	font-weight: 700;
	color: var(--bo-coral);
	white-space: nowrap;
}
.brt-onibus-card__preco--top { color: var(--bo-coral); }

/* ── Aviso ──────────────────────────────────────── */
.brt-onibus__aviso {
	display: flex;
	align-items: flex-start;
	gap: 11px;
	margin-top: 18px;
	padding: 15px 18px;
	border-radius: 13px;
	background: #FBF1DC;
	border: 1px solid #EBDCBC;
	font-size: 0.88rem;
	line-height: 1.5;
	color: #7A6A48;
}
.brt-onibus__aviso-icon {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	margin-top: 1px;
	color: var(--bo-gold);
}

/* ════════════════════════════════════════════════
   Mobile / Acordeão
   ════════════════════════════════════════════════ */
@media (max-width: 880px) {
	.brt-onibus__layout {
		grid-template-columns: 1fr;
		grid-template-areas:
			"clock"
			"main"
			"rodo";
		gap: 18px;
	}
	/* Relógio em linha (hora à esquerda, data à direita) + abas horizontais */
	.brt-onibus__clock {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		gap: 6px 14px;
		background: transparent;
		border: 0;
		padding: 4px 2px;
	}
	.brt-onibus__now { flex: 1 1 auto; }
	.brt-onibus__now-date { margin-top: 0; margin-left: auto; }
	.brt-onibus__dia-label { display: none; }
	.brt-onibus__toggle {
		flex: 1 1 100%;
		flex-direction: row;
		margin-top: 10px;
		padding-top: 14px;
		border-top: 1px solid var(--bo-linha);
	}
	.brt-onibus__tab { flex: 1 1 0; }
	.brt-onibus__rodo-acoes { flex-direction: row; flex-wrap: wrap; }
	.brt-onibus__rodo-tel {
		flex: 1 1 auto;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		padding: 11px 16px;
		border-radius: 10px;
		background: rgba(255, 255, 255, 0.12);
		font-size: 0.92rem;
	}
	.brt-onibus__rodo-tel-pre { display: inline; }
	.brt-onibus__rodo-map { flex: 1 1 auto; }
}

@media (max-width: 720px) {
	.brt-onibus { padding: 28px 16px; }
	.brt-onibus__grid { grid-template-columns: 1fr; gap: 12px; }

	/* Cartões viram acordeão: o painel só abre quando data-open="1" */
	.brt-onibus-card__chev { display: inline-flex; }
	.brt-onibus-card__head { padding: 14px 16px; }
	.brt-onibus-card__panel {
		display: none;
		padding: 0 16px 16px;
	}
	.brt-onibus-card[data-open="1"] .brt-onibus-card__panel { display: block; }
	.brt-onibus-card[data-open="1"] .brt-onibus-card__chev svg { transform: rotate(180deg); }

	/* No mobile aberto: mostra o cabeçalho "Saídas" + preço; some o preço do rodapé */
	.brt-onibus-card__saidas { display: flex; }
	.brt-onibus-card__preco--foot { display: none; }
	.brt-onibus-card__foot {
		margin-top: 12px;
		padding-top: 11px;
	}
}

@media (max-width: 380px) {
	.brt-onibus-card__times { grid-template-columns: repeat(3, 1fr); }
}

@media (prefers-reduced-motion: reduce) {
	.brt-onibus-card__chev svg,
	.brt-onibus__tab,
	.brt-onibus-card,
	.brt-onibus-card__time { transition: none; }
}
