/**
 * Arca Investe - Widget Ibovespa
 * Cores via CSS variables do projeto. Não usar hex diretamente.
 */

.arca-ibov-wrap {
	font-family: inherit;
	color: var(--contrast);
	margin: 24px 0;
}

.arca-ibov-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr;
	gap: 16px;
	align-items: stretch;
}

.arca-ibov-wrap[data-movers="0"] .arca-ibov-grid {
	grid-template-columns: 1fr;
}

/* ===== Cartões ===== */
.arca-ibov-chart-card,
.arca-ibov-movers-card {
	background: var(--base-3);
	border: 1px solid var(--base);
	border-radius: 12px;
	padding: 20px;
	display: flex;
	flex-direction: column;
	box-shadow: 0 1px 2px rgba(28, 42, 58, 0.04);
}

/* ===== Cabeçalho do gráfico ===== */
.arca-ibov-chart-head {
	margin-bottom: 16px;
}

.arca-ibov-title {
	font-size: 18px;
	font-weight: 700;
	color: var(--contrast);
	margin-bottom: 8px;
}

.arca-ibov-quote {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}

.arca-ibov-points {
	font-size: 22px;
	font-weight: 700;
	color: var(--contrast);
	font-variant-numeric: tabular-nums;
}

.arca-ibov-pill {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 600;
	background: var(--contrast-3);
	color: var(--contrast-2);
	font-variant-numeric: tabular-nums;
}

.arca-ibov-pill.is-up {
	background: rgba(45, 125, 98, 0.12);
	color: var(--global-color-10);
}

.arca-ibov-pill.is-down {
	background: var(--global-color-15);
	color: var(--global-color-14);
}

.arca-ibov-pill::before {
	content: "";
	display: inline-block;
	width: 0;
	height: 0;
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
}

.arca-ibov-pill.is-up::before {
	border-bottom: 5px solid var(--global-color-10);
}

.arca-ibov-pill.is-down::before {
	border-top: 5px solid var(--global-color-14);
}

.arca-ibov-meta {
	margin-top: 8px;
	font-size: 12px;
	color: var(--contrast-2);
	font-variant-numeric: tabular-nums;
}

/* ===== Botões de faixa ===== */
.arca-ibov-ranges {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
	margin-bottom: 12px;
}

.arca-ibov-range-btn {
	appearance: none;
	border: 1px solid var(--base);
	background: var(--base-3);
	color: var(--contrast-2);
	font-size: 12px;
	font-weight: 600;
	padding: 6px 12px;
	border-radius: 999px;
	cursor: pointer;
	transition: all 0.15s ease;
	font-family: inherit;
	letter-spacing: 0.02em;
}

.arca-ibov-range-btn:hover {
	border-color: var(--contrast-2);
	color: var(--contrast);
}

.arca-ibov-range-btn.is-active {
	background: var(--contrast);
	border-color: var(--contrast);
	color: var(--base-3);
}

/* ===== Caixa do gráfico ===== */
.arca-ibov-chart-box {
	position: relative;
	flex: 1;
	min-height: 240px;
}

.arca-ibov-chart-box canvas {
	width: 100% !important;
	height: 100% !important;
	max-height: 280px;
}

.arca-ibov-loading {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: rgba(255, 255, 255, 0.7);
	color: var(--contrast-2);
	font-size: 13px;
	border-radius: 8px;
	z-index: 2;
}

.arca-ibov-loading.is-hidden {
	display: none;
}

.arca-ibov-spinner {
	width: 16px;
	height: 16px;
	border: 2px solid var(--base);
	border-top-color: var(--accent);
	border-radius: 50%;
	animation: arcaIbovSpin 0.7s linear infinite;
}

@keyframes arcaIbovSpin {
	to { transform: rotate(360deg); }
}

/* ===== Rodapé ===== */
.arca-ibov-footer {
	margin-top: 12px;
	padding-top: 10px;
	border-top: 1px solid var(--contrast-3);
	display: flex;
	justify-content: space-between;
	gap: 8px;
	font-size: 11px;
	color: var(--contrast-2);
	flex-wrap: wrap;
}

.arca-ibov-source {
	opacity: 0.8;
}

/* ===== Colunas de altas/baixas ===== */
.arca-ibov-movers-head {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 15px;
	font-weight: 700;
	color: var(--contrast);
	margin-bottom: 10px;
}

.arca-ibov-arrow {
	width: 0;
	height: 0;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
}

.arca-ibov-arrow--up {
	border-bottom: 6px solid var(--global-color-10);
}

.arca-ibov-arrow--down {
	border-top: 6px solid var(--global-color-14);
}

/* Grid base de 4 colunas, usado pelo cabeçalho e por cada linha */
.arca-ibov-mover-cols {
	display: grid;
	grid-template-columns: minmax(70px, 1.1fr) minmax(70px, 1fr) minmax(80px, 1.1fr) minmax(80px, 1fr);
	column-gap: 8px;
	align-items: center;
}

.arca-ibov-mover-thead {
	padding: 6px 6px 8px;
	border-bottom: 1px solid var(--contrast-3);
	font-size: 10.5px;
	font-weight: 700;
	color: var(--contrast-2);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.arca-ibov-mover-thead .arca-ibov-col {
	color: var(--contrast-2);
}

.arca-ibov-mover-thead .arca-ibov-col--pct,
.arca-ibov-mover-thead .arca-ibov-col--change,
.arca-ibov-mover-thead .arca-ibov-col--price {
	text-align: right;
}

.arca-ibov-movers-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
}

.arca-ibov-mover {
	padding: 9px 6px;
	border-radius: 6px;
	transition: background 0.15s ease;
	font-size: 13px;
	display: grid;
	grid-template-columns: minmax(70px, 1.1fr) minmax(70px, 1fr) minmax(80px, 1.1fr) minmax(80px, 1fr);
	column-gap: 8px;
	align-items: center;
}

.arca-ibov-mover + .arca-ibov-mover {
	border-top: 1px solid var(--contrast-3);
}

.arca-ibov-mover:hover {
	background: var(--contrast-3);
}

.arca-ibov-col {
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.arca-ibov-col--ticker {
	font-weight: 700;
	color: var(--contrast);
	letter-spacing: 0.02em;
}

.arca-ibov-col--pct {
	font-weight: 700;
	text-align: right;
}

.arca-ibov-col--pct.is-up    { color: var(--global-color-10); }
.arca-ibov-col--pct.is-down  { color: var(--global-color-14); }

.arca-ibov-col--change {
	text-align: right;
	font-weight: 500;
	color: var(--contrast-2);
	font-size: 12px;
}

.arca-ibov-col--change.is-up   { color: var(--global-color-9); }
.arca-ibov-col--change.is-down { color: var(--global-color-13); }

.arca-ibov-col--price {
	text-align: right;
	color: var(--contrast);
	font-weight: 500;
}

/* ===== Skeleton ===== */
.arca-ibov-mover--placeholder {
	display: block;
	padding: 10px 6px;
}

.arca-ibov-skeleton {
	display: block;
	height: 24px;
	border-radius: 6px;
	background: linear-gradient(90deg, var(--contrast-3) 0%, var(--base) 50%, var(--contrast-3) 100%);
	background-size: 200% 100%;
	animation: arcaIbovShimmer 1.4s ease-in-out infinite;
}

@keyframes arcaIbovShimmer {
	0%   { background-position: 200% 0; }
	100% { background-position: -200% 0; }
}

/* ===== Erro inline ===== */
.arca-ibov-error {
	padding: 12px;
	background: var(--global-color-15);
	color: var(--global-color-14);
	border-radius: 8px;
	font-size: 13px;
	text-align: center;
}

/* ===== Responsivo ===== */
@media (max-width: 960px) {
	.arca-ibov-grid {
		grid-template-columns: 1fr 1fr;
	}
	.arca-ibov-chart-card {
		grid-column: 1 / -1;
	}
}

@media (max-width: 600px) {
	.arca-ibov-grid {
		grid-template-columns: 1fr;
	}
	.arca-ibov-chart-card,
	.arca-ibov-movers-card {
		padding: 16px;
	}
	.arca-ibov-points { font-size: 18px; }
	.arca-ibov-range-btn { padding: 5px 10px; font-size: 11px; }

	.arca-ibov-mover-cols,
	.arca-ibov-mover {
		grid-template-columns: minmax(60px, 1fr) minmax(60px, 1fr) minmax(70px, 1fr) minmax(70px, 1fr);
		column-gap: 6px;
	}

	.arca-ibov-col,
	.arca-ibov-col--change {
		font-size: 11.5px;
	}
}