/**
 * Mundial Plugin - Frontend stylesheet.
 *
 * Branding Loteria del Huila:
 *   --mh-green:  #206c23
 *   --mh-yellow: #ffc412
 *   --mh-black:  #000
 *   --mh-white:  #fff
 *
 * Convenciones:
 *  - Prefijo `mh-` para evitar colisiones con clases del tema.
 *  - Variables CSS para permitir override desde el tema.
 *  - Mobile-first, breakpoint a 640px.
 */

:root {
	--mh-green: #206c23;
	--mh-green-dark: #154916;
	--mh-yellow: #ffc412;
	--mh-yellow-dark: #d9a700;
	--mh-black: #111;
	--mh-white: #fff;
	--mh-gray-50: #f8fafc;
	--mh-gray-100: #f1f5f9;
	--mh-gray-200: #e2e8f0;
	--mh-gray-500: #64748b;
	--mh-gray-700: #334155;
	--mh-gray-900: #0f172a;
	--mh-radius: 10px;
	--mh-shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);
	--mh-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* ============================================================
 * RESET LOCAL — solo dentro de contenedores .mh-*
 * ============================================================ */
.mh-root,
.mh-root * {
	box-sizing: border-box;
}

.mh-root {
	font-family: var(--mh-font);
	color: var(--mh-gray-900);
	line-height: 1.5;
}

.mh-root h2,
.mh-root h3,
.mh-root h4 {
	margin: 0 0 .75em;
	font-weight: 700;
}

/* ============================================================
 * BANDERAS — la clase la pone FlagRenderer
 * ============================================================ */
.mundial-flag {
	display: inline-block;
	vertical-align: middle;
	border-radius: 2px;
	box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .08);
}

.mundial-flag--placeholder svg {
	border-radius: 50%;
}

/* ============================================================
 * CARD DE PARTIDO (reutilizable)
 * ============================================================ */
.mh-fixture {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: .75rem 1rem;
	padding: 1rem;
	background: var(--mh-white);
	border: 1px solid var(--mh-gray-200);
	border-radius: var(--mh-radius);
	box-shadow: var(--mh-shadow);
	margin-bottom: .75rem;
}

.mh-fixture--colombia {
	border-color: var(--mh-yellow);
	box-shadow: 0 0 0 2px rgba(255, 196, 18, .25), var(--mh-shadow);
}

.mh-fixture__team {
	display: flex;
	align-items: center;
	gap: .6rem;
	font-weight: 600;
}

.mh-fixture__team--home {
	justify-content: flex-end;
	text-align: right;
}

.mh-fixture__team--away {
	justify-content: flex-start;
	text-align: left;
}

.mh-fixture__team-name {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 14ch;
}

.mh-fixture__meta {
	display: flex;
	flex-direction: column;
	align-items: center;
	min-width: 90px;
}

.mh-fixture__score {
	font-size: 1.4rem;
	font-weight: 800;
	color: var(--mh-green);
	letter-spacing: .05em;
}

.mh-fixture__vs {
	font-size: .85rem;
	color: var(--mh-gray-500);
	font-weight: 700;
	letter-spacing: .15em;
}

.mh-fixture__time {
	font-size: .85rem;
	color: var(--mh-gray-700);
	margin-top: .1rem;
}

.mh-fixture__footer {
	grid-column: 1 / -1;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: .5rem;
	padding-top: .5rem;
	margin-top: .25rem;
	border-top: 1px dashed var(--mh-gray-200);
	font-size: .8rem;
	color: var(--mh-gray-500);
}

/* ============================================================
 * CRONOGRAMA — agrupado por dia
 * ============================================================ */
.mh-cronograma__day {
	margin-bottom: 1.5rem;
}

.mh-cronograma__day-header {
	background: var(--mh-green);
	color: var(--mh-white);
	padding: .5rem .75rem;
	border-radius: var(--mh-radius);
	margin-bottom: .5rem;
	font-weight: 700;
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: .05em;
}

.mh-cronograma__empty {
	padding: 2rem;
	text-align: center;
	background: var(--mh-gray-50);
	border: 1px dashed var(--mh-gray-200);
	border-radius: var(--mh-radius);
	color: var(--mh-gray-500);
}

/* ============================================================
 * PROXIMO PARTIDO — card grande con countdown
 * ============================================================ */
.mh-next {
	background: linear-gradient(135deg, var(--mh-green) 0%, var(--mh-green-dark) 100%);
	color: var(--mh-white);
	border-radius: var(--mh-radius);
	padding: 1.5rem;
	box-shadow: var(--mh-shadow);
}

.mh-next__label {
	font-size: .8rem;
	text-transform: uppercase;
	letter-spacing: .12em;
	opacity: .85;
	margin-bottom: .5rem;
}

.mh-next__matchup {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 1rem;
	align-items: center;
	margin: 1rem 0;
}

.mh-next__team {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .5rem;
}

.mh-next__team .mundial-flag {
	width: 64px;
	height: 48px;
}

.mh-next__team-name {
	font-size: 1.1rem;
	font-weight: 700;
}

.mh-next__vs {
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--mh-yellow);
}

.mh-next__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	font-size: .9rem;
	margin: 1rem 0;
	opacity: .9;
}

.mh-next__countdown {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: .5rem;
	padding: 1rem;
	background: rgba(0, 0, 0, .25);
	border-radius: var(--mh-radius);
}

.mh-next__cd-block {
	text-align: center;
}

.mh-next__cd-value {
	font-size: 1.8rem;
	font-weight: 800;
	color: var(--mh-yellow);
	line-height: 1;
}

.mh-next__cd-label {
	font-size: .7rem;
	text-transform: uppercase;
	letter-spacing: .1em;
	opacity: .8;
}

.mh-next__countdown--live {
	background: var(--mh-yellow);
	color: var(--mh-black);
}

.mh-next__countdown--live .mh-next__cd-value,
.mh-next__countdown--live .mh-next__cd-label {
	color: var(--mh-black);
}

/* ============================================================
 * GRUPOS — tablas de posiciones
 * ============================================================ */
.mh-groups {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.mh-groups--all {
		grid-template-columns: 1fr 1fr;
	}
}

.mh-group {
	background: var(--mh-white);
	border: 1px solid var(--mh-gray-200);
	border-radius: var(--mh-radius);
	overflow: hidden;
	box-shadow: var(--mh-shadow);
}

.mh-group__header {
	background: var(--mh-green);
	color: var(--mh-white);
	padding: .6rem 1rem;
	font-weight: 700;
}

.mh-group table {
	width: 100%;
	border-collapse: collapse;
	font-size: .9rem;
}

.mh-group th,
.mh-group td {
	padding: .5rem .6rem;
	text-align: center;
	border-bottom: 1px solid var(--mh-gray-100);
}

.mh-group th {
	background: var(--mh-gray-50);
	font-size: .75rem;
	text-transform: uppercase;
	color: var(--mh-gray-500);
	font-weight: 700;
}

.mh-group td:nth-child(2) {
	text-align: left;
	display: flex;
	align-items: center;
	gap: .5rem;
}

.mh-group__pos {
	font-weight: 700;
	color: var(--mh-gray-500);
}

.mh-group__pts {
	font-weight: 800;
	color: var(--mh-green);
}

.mh-group__qualify {
	background: linear-gradient(90deg, rgba(32, 108, 35, .08) 0%, transparent 100%);
}

/* ============================================================
 * BRACKET — eliminatorias en formato ACORDEON (una ronda visible por vez)
 * ============================================================ */

/* Acordeon principal. */
.mh-acc {
	display: flex;
	flex-direction: column;
	gap: .75rem;
	width: 100%;
}

/* Cada ronda es un <details>. */
.mh-acc__round {
	background: var(--mh-white);
	border: 1px solid var(--mh-gray-200);
	border-radius: 14px;
	overflow: hidden;
	box-shadow: 0 1px 3px rgba(15, 23, 42, .05);
	transition: box-shadow .2s, transform .15s;
}

.mh-acc__round[open] {
	box-shadow: 0 8px 22px rgba(32, 108, 35, .1);
}

.mh-acc__round--final {
	border-color: #ffc412;
}

.mh-acc__round--final[open] {
	box-shadow: 0 8px 22px rgba(255, 196, 18, .25);
}

/* Quitar el marker default del <summary> en todos los navegadores. */
.mh-acc__round summary {
	list-style: none;
	cursor: pointer;
}

.mh-acc__round summary::-webkit-details-marker {
	display: none;
}

.mh-acc__round summary::marker {
	display: none;
}

/* Cabecera del item: icono + titulo + meta + chevron. */
.mh-acc__head {
	display: flex !important;
	align-items: center;
	gap: 1rem;
	padding: 1rem 1.25rem;
	background: linear-gradient(135deg, var(--mh-green) 0%, #2d8531 100%);
	color: #fff;
	transition: background .2s;
}

.mh-acc__round--final .mh-acc__head {
	background: linear-gradient(135deg, #d9a700 0%, #ffc412 100%);
	color: #154916;
}

.mh-acc__head:hover {
	filter: brightness(1.08);
}

.mh-acc__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	background: rgba(255, 255, 255, .18);
	border-radius: 12px;
	color: #ffc412;
	flex-shrink: 0;
}

.mh-acc__round--final .mh-acc__icon {
	background: rgba(21, 73, 22, .15);
	color: #154916;
}

.mh-acc__icon svg {
	width: 22px;
	height: 22px;
}

.mh-acc__titles {
	display: flex;
	flex-direction: column;
	flex: 1;
	min-width: 0;
	line-height: 1.2;
}

.mh-acc__title {
	font-size: 1.05rem;
	font-weight: 800;
	letter-spacing: .01em;
}

.mh-acc__meta {
	font-size: .72rem;
	font-weight: 600;
	opacity: .85;
	letter-spacing: .06em;
	text-transform: uppercase;
}

.mh-acc__chevron {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: inherit;
	transition: transform .25s;
	flex-shrink: 0;
}

.mh-acc__round[open] .mh-acc__chevron {
	transform: rotate(180deg);
}

/* Body: contiene la grilla de partidos. */
.mh-acc__body {
	padding: 1rem 1.25rem 1.25rem;
	background:
		radial-gradient(circle at 1px 1px, rgba(32, 108, 35, .05) 1px, transparent 0) 0 0 / 16px 16px,
		linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

/* Grilla de partidos dentro del body. */
.mh-acc__matches {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: .85rem;
}

/* La final es UN solo partido: lo centramos y agrandamos. */
.mh-acc__matches--single {
	grid-template-columns: 1fr;
	max-width: 480px;
	margin: 0 auto;
}

.mh-acc__matches--single .mh-acc__match {
	padding: 1.25rem 1.5rem;
}

/* Tarjeta de partido. */
.mh-acc__match {
	background: var(--mh-white);
	border: 1px solid var(--mh-gray-200);
	border-radius: 12px;
	padding: .8rem .95rem;
	box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
	transition: transform .15s, box-shadow .2s, border-color .2s;
	display: flex;
	flex-direction: column;
	gap: .4rem;
}

.mh-acc__match:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 14px rgba(15, 23, 42, .08);
	border-color: var(--mh-green);
}

.mh-acc__match.is-played {
	background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

.mh-acc__match--special {
	border: 2px solid #ffc412;
	box-shadow: 0 4px 14px rgba(255, 196, 18, .2);
	background: linear-gradient(180deg, #fffbeb 0%, #fff 100%);
}

.mh-acc__match-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: .72rem;
	color: var(--mh-gray-500);
	font-weight: 600;
	letter-spacing: .05em;
	padding-bottom: .4rem;
	border-bottom: 1px dashed var(--mh-gray-100);
	margin-bottom: .15rem;
}

.mh-acc__match-num {
	color: var(--mh-green);
	font-weight: 800;
}

.mh-acc__match--special .mh-acc__match-num {
	color: #b88600;
}

.mh-acc__match-when {
	font-weight: 600;
}

.mh-acc__match-when--played {
	color: var(--mh-green);
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .1em;
	font-size: .65rem;
}

/* Fila de equipo. */
.mh-acc__team {
	display: flex;
	align-items: center;
	gap: .6rem;
	padding: .45rem .25rem;
	border-radius: 6px;
}

.mh-acc__team .mundial-flag {
	width: 24px;
	height: 18px;
	border-radius: 2px;
	box-shadow: 0 1px 2px rgba(0, 0, 0, .12);
	flex-shrink: 0;
}

.mh-acc__flag-placeholder {
	display: inline-block;
	width: 24px;
	height: 18px;
	background: var(--mh-gray-100);
	border-radius: 2px;
	flex-shrink: 0;
}

.mh-acc__team-name {
	flex: 1;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	font-size: .95rem;
	font-weight: 600;
	color: var(--mh-gray-900);
}

.mh-acc__team-score {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 30px;
	height: 30px;
	background: var(--mh-gray-100);
	color: var(--mh-gray-700);
	border-radius: 6px;
	font-size: 1rem;
	font-weight: 800;
}

.mh-acc__team.is-winner {
	background: rgba(32, 108, 35, .08);
}

.mh-acc__team.is-winner .mh-acc__team-name {
	font-weight: 800;
	color: var(--mh-green);
}

.mh-acc__team.is-winner .mh-acc__team-score {
	background: var(--mh-green);
	color: #fff;
}

.mh-acc__team.is-loser {
	opacity: .5;
}

.mh-acc__team.is-loser .mh-acc__team-name {
	text-decoration: line-through;
	text-decoration-thickness: 1px;
	text-decoration-color: var(--mh-gray-500);
}

.mh-acc__match-foot {
	margin-top: .35rem;
	padding-top: .4rem;
	border-top: 1px dashed var(--mh-gray-100);
	font-size: .72rem;
	color: var(--mh-gray-500);
	text-align: center;
	font-weight: 600;
	letter-spacing: .03em;
}

/* Animacion suave al abrir (interpolacion del body en navegadores modernos). */
.mh-acc__round[open] .mh-acc__body {
	animation: mh-acc-slide-in .25s ease-out;
}

@keyframes mh-acc-slide-in {
	from {
		opacity: 0;
		transform: translateY(-6px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* ============================================================
 * BRACKET LEGACY — clases viejas para compat (eliminables despues)
 * ============================================================ */

/* Contenedor principal con campeon arriba si aplica. */
.mh-bracket-wrap {
	display: block;
	width: 100%;
}

/* Banner del campeon (si ya se conoce). */
.mh-bracket-champion {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1.25rem;
	margin: 0 0 1.5rem;
	padding: 1.25rem 1.75rem;
	background: linear-gradient(135deg, #ffc412 0%, #d9a700 100%);
	border-radius: var(--mh-radius);
	box-shadow: 0 8px 22px rgba(255, 196, 18, .35);
	color: #154916;
	text-align: left;
}

.mh-bracket-champion__trophy {
	flex-shrink: 0;
	width: 64px;
	height: 64px;
	background: #154916;
	color: #ffc412;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mh-bracket-champion__text {
	display: flex;
	flex-direction: column;
	gap: .15rem;
}

.mh-bracket-champion__label {
	display: inline-block;
	font-size: .72rem;
	font-weight: 800;
	letter-spacing: .18em;
	text-transform: uppercase;
	opacity: .8;
}

.mh-bracket-champion__name {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	font-size: 1.5rem;
	font-weight: 800;
	color: #154916;
}

/* Container del bracket: scroll horizontal con snap. */
.mh-bracket {
	display: flex;
	gap: 2rem;
	overflow-x: auto;
	padding: 1.5rem;
	scroll-snap-type: x proximity;
	background:
		radial-gradient(circle at 1px 1px, rgba(32, 108, 35, .06) 1px, transparent 0) 0 0 / 18px 18px,
		linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
	border: 1px solid var(--mh-gray-200);
	border-radius: 18px;
	scrollbar-color: #cbd5e1 transparent;
	scrollbar-width: thin;
}

.mh-bracket::-webkit-scrollbar {
	height: 10px;
}

.mh-bracket::-webkit-scrollbar-track {
	background: transparent;
}

.mh-bracket::-webkit-scrollbar-thumb {
	background: #cbd5e1;
	border-radius: 999px;
}

.mh-bracket::-webkit-scrollbar-thumb:hover {
	background: #94a3b8;
}

/* Cada ronda es una columna. */
.mh-bracket__round {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	min-width: 280px;
	max-width: 280px;
	scroll-snap-align: start;
}

@media (max-width: 600px) {
	.mh-bracket__round {
		min-width: 250px;
		max-width: 250px;
	}
}

/* Header de cada ronda. */
.mh-bracket__round-header {
	display: flex;
	align-items: center;
	gap: .75rem;
	padding: .85rem 1rem;
	background: linear-gradient(135deg, var(--mh-green) 0%, #2d8531 100%);
	color: #fff;
	border-radius: 12px;
	box-shadow: 0 4px 10px rgba(32, 108, 35, .2);
	position: sticky;
	top: 0;
	z-index: 2;
}

.mh-bracket__round--final .mh-bracket__round-header {
	background: linear-gradient(135deg, #d9a700 0%, #ffc412 100%);
	color: #154916;
}

.mh-bracket__round-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	background: rgba(255, 255, 255, .18);
	border-radius: 10px;
	color: #ffc412;
	flex-shrink: 0;
}

.mh-bracket__round--final .mh-bracket__round-icon {
	background: rgba(21, 73, 22, .15);
	color: #154916;
}

.mh-bracket__round-titles {
	display: flex;
	flex-direction: column;
	gap: 0;
	line-height: 1.2;
	min-width: 0;
}

.mh-bracket__round-title {
	font-size: 1rem;
	font-weight: 800;
	letter-spacing: .01em;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.mh-bracket__round-meta {
	font-size: .7rem;
	font-weight: 600;
	opacity: .85;
	letter-spacing: .08em;
	text-transform: uppercase;
}

/* Wrapper de los matches dentro de una ronda. */
.mh-bracket__matches {
	display: flex;
	flex-direction: column;
	gap: .85rem;
	flex: 1;
	justify-content: space-around;
}

/* Card de partido. */
.mh-bracket__match {
	background: var(--mh-white);
	border: 1px solid var(--mh-gray-200);
	border-radius: 12px;
	padding: .7rem .85rem;
	box-shadow: 0 1px 3px rgba(15, 23, 42, .06);
	transition: transform .15s, box-shadow .2s, border-color .2s;
	display: flex;
	flex-direction: column;
	gap: .35rem;
}

.mh-bracket__match:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 14px rgba(15, 23, 42, .1);
	border-color: var(--mh-green);
}

.mh-bracket__match.is-played {
	background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

.mh-bracket__match--special {
	border: 2px solid #ffc412;
	box-shadow: 0 4px 14px rgba(255, 196, 18, .2);
}

.mh-bracket__match-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: .7rem;
	color: var(--mh-gray-500);
	font-weight: 600;
	letter-spacing: .05em;
	padding-bottom: .35rem;
	border-bottom: 1px dashed var(--mh-gray-100);
	margin-bottom: .1rem;
}

.mh-bracket__match-num {
	color: var(--mh-green);
	font-weight: 800;
}

.mh-bracket__match-when {
	font-weight: 600;
}

.mh-bracket__match-when--played {
	color: var(--mh-green);
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .12em;
	font-size: .65rem;
}

/* Filas de equipo. */
.mh-bracket__team {
	display: flex;
	align-items: center;
	gap: .55rem;
	padding: .4rem .15rem;
	border-radius: 6px;
	transition: background .15s;
}

.mh-bracket__team .mundial-flag {
	width: 22px;
	height: 16px;
	border-radius: 2px;
	box-shadow: 0 1px 2px rgba(0, 0, 0, .15);
	flex-shrink: 0;
}

.mh-bracket__flag-placeholder {
	display: inline-block;
	width: 22px;
	height: 16px;
	background: var(--mh-gray-100);
	border-radius: 2px;
	flex-shrink: 0;
}

.mh-bracket__team-name {
	flex: 1;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	font-size: .9rem;
	font-weight: 600;
	color: var(--mh-gray-900);
}

.mh-bracket__team-score {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 28px;
	height: 28px;
	background: var(--mh-gray-100);
	color: var(--mh-gray-700);
	border-radius: 6px;
	font-size: .95rem;
	font-weight: 800;
}

.mh-bracket__team.is-winner {
	background: rgba(32, 108, 35, .08);
}

.mh-bracket__team.is-winner .mh-bracket__team-name {
	font-weight: 800;
	color: var(--mh-green);
}

.mh-bracket__team.is-winner .mh-bracket__team-score {
	background: var(--mh-green);
	color: #fff;
}

.mh-bracket__team.is-loser {
	opacity: .5;
}

.mh-bracket__team.is-loser .mh-bracket__team-name {
	text-decoration: line-through;
	text-decoration-thickness: 1px;
	text-decoration-color: var(--mh-gray-500);
}

/* Footer del match con info extra (penales, tiempo extra). */
.mh-bracket__match-foot {
	margin-top: .25rem;
	padding-top: .35rem;
	border-top: 1px dashed var(--mh-gray-100);
	font-size: .72rem;
	color: var(--mh-gray-500);
	text-align: center;
	font-weight: 600;
	letter-spacing: .03em;
}

/* ============================================================
 * RESPONSIVE
 * ============================================================ */
@media (max-width: 480px) {
	.mh-fixture {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.mh-fixture__team {
		justify-content: center !important;
		text-align: center !important;
	}

	.mh-fixture__meta {
		order: -1;
	}

	.mh-next__matchup {
		grid-template-columns: 1fr;
	}
}

/* Estilos del shortcode [mundial_polla] viven en polla.css
   (cargado por separado por AssetManager para mayor especificidad
   contra los estilos del tema). */
