@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800&display=swap');

.vsjp-app,
.viacaosjp-app,
.viacaosjp-routes {
	--vsjp-fundo: #FFFDFA;
	--vsjp-primaria: #E95010;
	--vsjp-hover: #F9DA94;
	--vsjp-titulo: #384885;
	--vsjp-texto: #12568F;
	--vsjp-borda: rgba(18, 86, 143, 0.14);
	--vsjp-sombra: 0 2px 8px rgba(0, 0, 0, 0.08);
	background: var(--vsjp-fundo);
	box-sizing: border-box;
	color: var(--vsjp-texto);
	font-family: 'Inter', sans-serif;
	margin: 0 auto;
	max-width: 100%;
	padding: 0 16px;
	width: 100%;
}

.vsjp-app *,
.viacaosjp-app *,
.viacaosjp-routes * {
	box-sizing: border-box;
	font-family: 'Inter', sans-serif;
}

.vsjp-app .screen-reader-text,
.viacaosjp-routes .screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
}

.vsjp-busca,
.viacaosjp-routes-form,
.vsjp-resultados,
.viacaosjp-routes-results,
.viacaosjp-routes-list,
.vsjp-detalhes,
.viacaosjp-routes-detail,
.viacaosjp-routes-events,
.vsjp-tabs-shell,
.viacaosjp-routes-schedule-shell,
.viacaosjp-routes-schedule-panels {
	display: grid;
	gap: 16px;
	max-width: 100%;
	width: 100%;
}

.vsjp-resultados,
.viacaosjp-routes-results,
.viacaosjp-routes-list {
	margin: 0 auto;
}

.vsjp-cabecalho,
.viacaosjp-routes-hero,
.vsjp-card-linha,
.viacaosjp-routes-card,
.vsjp-card-detalhe,
.viacaosjp-routes-detail__card,
.vsjp-bloco-tabela,
.viacaosjp-routes-table-card,
.viacaosjp-routes-event-card,
.viacaosjp-routes-empty {
	background: #ffffff;
	border: 1px solid var(--vsjp-borda);
	border-radius: 4px;
	box-shadow: var(--vsjp-sombra);
	max-width: 100%;
	width: 100%;
}

.vsjp-cabecalho,
.viacaosjp-routes-hero {
	padding: 24px 18px;
	text-align: center;
}

.vsjp-cabecalho,
.viacaosjp-routes-hero {
	background: transparent;
	border: 0;
	box-shadow: none;
	padding: 0;
}

.vsjp-cabecalho__chamada,
.viacaosjp-routes-hero__eyebrow {
	color: var(--vsjp-primaria);
	display: block;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.12em;
	margin-bottom: 10px;
	text-transform: uppercase;
}

.vsjp-cabecalho__chamada,
.viacaosjp-routes-hero__eyebrow,
.vsjp-cabecalho h2,
.viacaosjp-routes-hero h2,
.vsjp-cabecalho p,
.viacaosjp-routes-hero p {
	display: none;
}

.vsjp-cabecalho h2,
.viacaosjp-routes-hero h2,
.vsjp-card-detalhe h3,
.viacaosjp-routes-detail__card h3,
.vsjp-bloco-tabela h4,
.viacaosjp-routes-table-card h4,
.viacaosjp-routes-event-card__header strong,
.vsjp-card-linha__titulo,
.viacaosjp-routes-card__title {
	color: var(--vsjp-titulo);
	font-size: 28px;
	font-weight: 700;
	line-height: 1.2;
	margin: 0;
}

.vsjp-app p,
.vsjp-app label,
.viacaosjp-routes-hero p,
.viacaosjp-routes-detail__heading p,
.viacaosjp-routes-detail__section p,
.viacaosjp-routes-empty,
.viacaosjp-routes-detail__empty,
.viacaosjp-routes-event-card__header span,
.viacaosjp-routes-terminal-pill span,
.viacaosjp-routes-table td,
.viacaosjp-routes-table th {
	color: var(--vsjp-texto);
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	margin: 0;
}

.vsjp-busca__campo,
.viacaosjp-routes-search-wrap {
	margin-bottom: 32px;
	max-width: 100%;
	position: relative;
	width: 100%;
}

.vsjp-card-linha h2,
.vsjp-card-linha .vsjp-card-linha__titulo,
.vsjp-card-linha .viacaosjp-routes-card__title {
	font-size: 18px;
	word-break: break-word;
}

.vsjp-input-busca,
.viacaosjp-routes-search {
	background: #ffffff;
	border: 1px solid var(--vsjp-borda);
	border-radius: 4px;
	color: var(--vsjp-titulo);
	font-size: 16px;
	font-weight: 600;
	min-height: 56px;
	padding: 0 16px;
	width: 100%;
}

.vsjp-input-busca::placeholder,
.viacaosjp-routes-search::placeholder {
	color: rgba(18, 86, 143, 0.58);
	font-size: 16px;
}

.vsjp-input-busca:focus,
.viacaosjp-routes-search:focus {
	border-color: var(--vsjp-primaria);
	outline: none;
}

.vsjp-card-linha__resumo,
.viacaosjp-routes-card__summary {
	align-items: start;
	display: grid;
	gap: 16px;
	padding: 16px;
}

.vsjp-card-linha__meta,
.viacaosjp-routes-card__meta,
.vsjp-card-linha__badges,
.viacaosjp-routes-card__badges,
.vsjp-terminais,
.viacaosjp-routes-terminals {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.vsjp-card-linha__meta,
.viacaosjp-routes-card__meta,
.viacaosjp-routes-detail__intro {
	align-content: start;
	display: grid;
	gap: 8px;
}

.viacaosjp-routes-card__number {
	color: var(--vsjp-primaria);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.viacaosjp-routes-card__badge,
.vsjp-terminal-pill,
.viacaosjp-routes-terminal-pill {
	align-items: center;
	background: rgba(18, 86, 143, 0.08);
	border: 1px solid var(--vsjp-borda);
	border-radius: 4px;
	color: var(--vsjp-texto);
	display: inline-flex;
	font-size: 14px;
	font-weight: 700;
	gap: 8px;
	padding: 8px 10px;
}

.vsjp-terminais__titulo,
.viacaosjp-routes-terminals__label,
.viacaosjp-routes-terminal-pill strong,
.viacaosjp-routes-detail__section h4 {
	color: var(--vsjp-titulo);
	font-size: 16px;
	font-weight: 700;
}

.vsjp-botao,
.viacaosjp-routes-button,
.vsjp-botao--toggle,
.viacaosjp-routes-card__toggle {
	align-items: center;
	background: var(--vsjp-primaria);
	border: 1px solid var(--vsjp-primaria);
	border-radius: 4px;
	color: #ffffff;
	cursor: pointer;
	display: flex;
	font-size: 16px;
	font-weight: 700;
	justify-content: center;
	min-height: 48px;
	padding: 0 18px;
	text-align: center;
	text-decoration: none;
	width: 100%;
}

.vsjp-botao:hover,
.viacaosjp-routes-button:hover,
.vsjp-botao--toggle:hover,
.viacaosjp-routes-card__toggle:hover {
	background: var(--vsjp-hover);
	border-color: var(--vsjp-hover);
	color: var(--vsjp-titulo);
}

.vsjp-botao.vsjp-ativo,
.viacaosjp-routes-card__toggle.is-open {
	background: var(--vsjp-primaria);
	color: #ffffff;
}

.vsjp-card-linha__detalhes,
.viacaosjp-routes-card__details {
	border-top: 1px solid var(--vsjp-borda);
	padding: 0 16px 16px;
	width: 100%;
}

.vsjp-card-detalhe,
.viacaosjp-routes-detail__card,
.viacaosjp-routes-detail__section,
.viacaosjp-routes-event-card {
	align-content: start;
	display: grid;
	gap: 12px;
	padding: 16px;
}

.vsjp-card-detalhe,
.viacaosjp-routes-detail__card {
	background: transparent;
	border: 0;
	box-shadow: none;
	gap: 24px;
	padding: 0;
}

.vsjp-bloco-tabela,
.viacaosjp-routes-table-card,
.viacaosjp-routes-event-card {
	background: transparent;
	border: 0;
	box-shadow: none;
	padding: 0;
}

.vsjp-card-detalhe__cabecalho,
.viacaosjp-routes-detail__heading,
.viacaosjp-routes-detail__grid,
.viacaosjp-routes-detail__columns {
	align-items: start;
	display: grid;
	gap: 16px;
}

.vsjp-card-detalhe__cabecalho,
.viacaosjp-routes-detail__heading {
	gap: 8px;
	grid-template-columns: minmax(0, 1fr);
	margin-top: 16px;
}

.vsjp-terminais,
.viacaosjp-routes-terminals {
	align-items: stretch;
	display: grid;
	gap: 8px;
	width: 100%;
}

.vsjp-terminal-pill,
.viacaosjp-routes-terminal-pill {
	align-items: center;
	justify-content: flex-start;
	width: 100%;
}

.vsjp-tabs,
.viacaosjp-routes-schedule-tabs {
	display: grid;
	gap: 8px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	width: 100%;
}

.vsjp-botao-tab,
.viacaosjp-routes-schedule-tab,
.tab-button {
	align-items: center;
	background: transparent;
	border: 1px solid var(--vsjp-primaria);
	border-radius: 4px;
	color: var(--vsjp-primaria);
	cursor: pointer;
	display: flex;
	font-size: 16px;
	font-weight: 600;
	justify-content: center;
	min-height: 44px;
	padding: 10px 12px;
	text-align: center;
	width: 100%;
}

.vsjp-botao-tab:hover,
.viacaosjp-routes-schedule-tab:hover,
.tab-button:hover,
.vsjp-botao-tab:focus,
.viacaosjp-routes-schedule-tab:focus,
.tab-button:focus {
	background: var(--vsjp-hover);
	border-color: var(--vsjp-hover);
	color: var(--vsjp-titulo);
	outline: none;
}

.vsjp-botao-tab.vsjp-ativo,
.viacaosjp-routes-schedule-tab.vsjp-ativo,
.viacaosjp-routes-schedule-tab.active,
.tab-button.vsjp-ativo,
.tab-button.active {
	background: var(--vsjp-primaria);
	border-color: var(--vsjp-primaria);
	color: #ffffff;
}

.vsjp-painel-tab,
.viacaosjp-routes-schedule-panel,
.tab-content {
	display: none;
}

.vsjp-painel-tab.vsjp-ativo,
.viacaosjp-routes-schedule-panel.vsjp-ativo,
.viacaosjp-routes-schedule-panel.active,
.tab-content.vsjp-ativo,
.tab-content.active {
	display: block;
}

.vsjp-bloco-tabela,
.viacaosjp-routes-table-card {
	padding: 0;
}

.table-wrapper,
.viacaosjp-routes-table-wrap {
	overflow-x: auto;
	width: 100%;
}

.vsjp-tabela-horarios,
.viacaosjp-routes-table {
	border-collapse: collapse;
	table-layout: fixed;
	width: 100%;
}

.vsjp-tabela-horarios th,
.vsjp-tabela-horarios td,
.viacaosjp-routes-table th,
.viacaosjp-routes-table td {
	border: 1px solid var(--vsjp-borda);
	padding: 12px 10px;
	text-align: center;
	vertical-align: middle;
	word-break: break-word;
}

.vsjp-tabela-horarios th,
.viacaosjp-routes-table th {
	background: rgba(18, 86, 143, 0.08);
	color: var(--vsjp-titulo);
	font-weight: 700;
}

.vsjp-tabela-horarios td strong,
.vsjp-tabela-horarios td b,
.viacaosjp-routes-table td strong,
.viacaosjp-routes-table td b {
	color: var(--vsjp-titulo);
}

.viacaosjp-routes :is(h1, h2, h3, h4, h5, h6, p, span, strong, b, mark, button) {
	text-decoration: none;
}

.viacaosjp-routes-table u,
.vsjp-tabela-horarios u {
	text-decoration: underline;
}

.horario-box {
	background: #fff;
	border: 1px solid #000;
	border-radius: 2px;
	display: inline-block;
	line-height: 1;
	padding: 1px 5px;
}

.vsjp-acoes,
.viacaosjp-routes-detail__actions {
	align-items: flex-end;
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 8px;
}

.viacaosjp-routes-detail__actions .btn {
	display: block;
	max-width: 180px;
	text-align: center;
	width: 100%;
}

.btn-itinerarios,
.viacaosjp-routes-detail__actions .btn-itinerarios {
	align-items: center;
	background-color: #12568F;
	border: 1px solid #12568F;
	color: #ffffff;
	display: flex;
	justify-content: center;
	text-align: center;
	transition: all 0.3s ease;
}

.btn-itinerarios:hover,
.viacaosjp-routes-detail__actions .btn-itinerarios:hover {
	background-color: transparent;
	border: 1px solid #12568F;
	color: #12568F;
}

.viacaosjp-routes-detail {
	gap: 24px;
}

.viacaosjp-routes-detail__section {
	gap: 8px;
	padding: 14px;
}

@media (max-width: 767px) {
	.viacaosjp-routes-detail__actions {
		align-items: stretch;
		width: 100%;
	}

	.viacaosjp-routes-detail__actions .btn {
		max-width: 100%;
		width: 100%;
	}
}

@media (min-width: 768px) {
	.vsjp-app,
	.viacaosjp-app,
	.viacaosjp-routes {
		padding: 0 24px;
	}

	.vsjp-resultados,
	.viacaosjp-routes-results,
	.viacaosjp-routes-list {
		max-width: 1080px;
	}

	.vsjp-app p,
	.vsjp-app label,
	.viacaosjp-routes-hero p,
	.viacaosjp-routes-detail__heading p,
	.viacaosjp-routes-detail__section p,
	.viacaosjp-routes-empty,
	.viacaosjp-routes-detail__empty,
	.viacaosjp-routes-event-card__header span,
	.viacaosjp-routes-terminal-pill span,
	.viacaosjp-routes-table td,
	.viacaosjp-routes-table th {
		font-size: 18px;
	}

	.vsjp-cabecalho h2,
	.viacaosjp-routes-hero h2,
	.vsjp-card-detalhe h3,
	.viacaosjp-routes-detail__card h3,
	.vsjp-bloco-tabela h4,
	.viacaosjp-routes-table-card h4,
	.viacaosjp-routes-event-card__header strong,
	.vsjp-card-linha__titulo,
	.viacaosjp-routes-card__title {
		font-size: 34px;
	}

	.vsjp-card-linha h2,
	.vsjp-card-linha .vsjp-card-linha__titulo,
	.vsjp-card-linha .viacaosjp-routes-card__title {
		font-size: 20px;
	}

	.vsjp-card-linha__resumo,
	.viacaosjp-routes-card__summary {
		align-items: start;
		grid-template-columns: minmax(0, 1fr) auto;
	}

	.vsjp-card-detalhe__cabecalho,
	.viacaosjp-routes-detail__heading {
		grid-template-columns: minmax(0, 1fr);
		margin-top: 24px;
	}

	.viacaosjp-routes-detail__grid,
	.viacaosjp-routes-detail__columns {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.vsjp-tabs-shell,
	.viacaosjp-routes-schedule-shell {
		gap: 24px;
	}

	.vsjp-tabs,
	.viacaosjp-routes-schedule-tabs {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.vsjp-terminais,
	.viacaosjp-routes-terminals {
		align-items: center;
		display: flex;
		flex-wrap: nowrap;
		gap: 12px;
	}

	.vsjp-terminais__titulo,
	.viacaosjp-routes-terminals__label {
		flex: 0 0 auto;
		white-space: nowrap;
	}

	.vsjp-terminal-pill,
	.viacaosjp-routes-terminal-pill {
		flex: 0 0 auto;
		gap: 8px;
		white-space: nowrap;
		width: auto;
	}

	.vsjp-botao,
	.viacaosjp-routes-button,
	.vsjp-botao--toggle,
	.viacaosjp-routes-card__toggle {
		width: auto;
	}

	.viacaosjp-routes-card__toggle {
		justify-self: end;
	}
}

@media (min-width: 1200px) {
	.vsjp-app p,
	.vsjp-app label,
	.viacaosjp-routes-hero p,
	.viacaosjp-routes-detail__heading p,
	.viacaosjp-routes-detail__section p,
	.viacaosjp-routes-empty,
	.viacaosjp-routes-detail__empty,
	.viacaosjp-routes-event-card__header span,
	.viacaosjp-routes-terminal-pill span,
	.viacaosjp-routes-table td,
	.viacaosjp-routes-table th {
		font-size: 20px;
	}

	.vsjp-cabecalho h2,
	.viacaosjp-routes-hero h2,
	.vsjp-card-detalhe h3,
	.viacaosjp-routes-detail__card h3,
	.vsjp-bloco-tabela h4,
	.viacaosjp-routes-table-card h4,
	.viacaosjp-routes-event-card__header strong,
	.vsjp-card-linha__titulo,
	.viacaosjp-routes-card__title {
		font-size: 40px;
	}
}
