/* Mundial 2026 - Bracket plugin styles
   Palette: deep purple to red gradient (template image), gold trophy accents.
   Scoped under .wc2026 to avoid clashing with theme CSS. */

.wc2026 {
	--wc-purple: #2a1d6e;
	--wc-purple-2: #4a1f7c;
	--wc-red: #b81d2e;
	--wc-red-2: #6e1620;
	--wc-gold: #f5b400;
	--wc-gold-2: #ffe27a;
	--wc-text: #ffffff;
	--wc-text-dim: rgba(255, 255, 255, 0.72);
	--wc-card-bg: rgba(255, 255, 255, 0.06);
	--wc-card-border: rgba(255, 255, 255, 0.12);
	--wc-pill-bg: #c81e2f;
	--wc-live: #00d26a;

	position: relative;
	color: var(--wc-text);
	background: radial-gradient(ellipse at center, var(--wc-purple-2) 0%, var(--wc-purple) 65%, var(--wc-red-2) 92%, var(--wc-red) 100%);
	background-attachment: fixed;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	border-radius: 0;
	padding: 24px;
	overflow: hidden;
	isolation: isolate;
}

.wc2026::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 20% 20%, rgba(255,255,255,0.06) 1px, transparent 2px),
		radial-gradient(circle at 80% 50%, rgba(255,255,255,0.06) 1px, transparent 2px),
		radial-gradient(circle at 40% 80%, rgba(255,255,255,0.05) 1px, transparent 2px);
	background-size: 60px 60px, 90px 90px, 120px 120px;
	pointer-events: none;
	z-index: 0;
}

.wc2026 > * { position: relative; z-index: 1; }

/* ---------- HERO ---------- */

.wc2026-hero { text-align: center; padding: 12px 0 28px; }
.wc2026-title {
	font-size: clamp(28px, 4vw, 48px);
	font-weight: 900;
	letter-spacing: 1px;
	margin: 0;
	background: linear-gradient(180deg, #fff 0%, #ffe27a 80%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	text-shadow: 0 2px 8px rgba(0,0,0,0.4);
}
.wc2026-subtitle { margin: 4px 0 16px; color: var(--wc-text-dim); font-size: 14px; letter-spacing: 2px; text-transform: uppercase; }
.wc2026-final-info {
	display: inline-flex; gap: 12px; align-items: center;
	background: var(--wc-pill-bg);
	border-radius: 2px;
	padding: 8px 18px;
	font-size: 13px;
	font-weight: 600;
}
.wc2026-final-label { background: #fff; color: var(--wc-red); padding: 2px 8px; border-radius: 2px; font-weight: 900; }

/* ---------- CHART ---------- */

.wc2026-chart {
	display: grid;
	grid-template-columns: minmax(140px, 16%) 1fr minmax(140px, 16%);
	gap: 12px;
	margin-bottom: 32px;
}

.wc2026-side-title {
	font-size: 14px;
	letter-spacing: 1.5px;
	text-align: center;
	color: var(--wc-gold-2);
	margin: 0 0 8px;
}

.wc2026-group {
	margin-bottom: 8px;
	background: rgba(0,0,0,0.18);
	border: 1px solid var(--wc-card-border);
	border-radius: 2px;
	overflow: hidden;
}
.wc2026-group-header {
	background: var(--wc-pill-bg);
	color: #fff;
	font-weight: 800;
	padding: 4px 8px;
	font-size: 12px;
	text-align: center;
	letter-spacing: 1px;
}
.wc2026-group-teams { list-style: none; margin: 0; padding: 4px 6px; }
.wc2026-team {
	display: grid;
	grid-template-columns: 22px 1fr auto;
	gap: 6px;
	align-items: center;
	font-size: 11px;
	padding: 3px 0;
	border-bottom: 1px solid rgba(255,255,255,0.05);
}
.wc2026-team:last-child { border-bottom: none; }
.wc2026-team-name { color: var(--wc-text); }
.wc2026-team-code { color: var(--wc-text-dim); font-size: 10px; font-weight: 700; }
.wc2026-flag {
	display: inline-block;
	width: 20px; height: 15px;
	border-radius: 2px;
	object-fit: cover;
	box-shadow: 0 0 0 1px rgba(0,0,0,0.25);
	background: #444;
	flex-shrink: 0;
}
.wc2026-flag-tbd {
	width: 20px; height: 15px;
	background: linear-gradient(135deg, #ccc 0%, #888 100%);
	color: #222;
	font-size: 10px;
	font-weight: 800;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.wc2026-slot-team .wc2026-flag { width: 14px; height: 11px; }
.wc2026-slot-team-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; padding: 0 4px; }
.wc2026-slot-team { gap: 4px; }
.wc2026-card-flag {
	width: 32px; height: 24px;
	object-fit: contain;
	border-radius: 2px;
	flex-shrink: 0;
}
.wc2026-table-flag {
	width: 20px; height: 15px;
	object-fit: cover;
	border-radius: 2px;
	margin-right: 6px;
	vertical-align: middle;
	box-shadow: 0 0 0 1px rgba(0,0,0,0.25);
}

/* ---------- CENTER BRACKET ---------- */

.wc2026-center {
	display: flex; flex-direction: column;
}
.wc2026-rounds-header {
	display: grid;
	grid-template-columns: repeat(9, 1fr);
	gap: 4px;
	margin-bottom: 8px;
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--wc-text-dim);
	text-align: center;
}
.wc2026-rounds-header span { padding: 4px 0; background: rgba(0,0,0,0.2); border-radius: 2px; }
.wc2026-rounds-final { color: var(--wc-gold) !important; font-weight: 900; }

.wc2026-bracket-grid {
	display: grid;
	grid-template-columns: repeat(9, 1fr);
	gap: 4px;
	flex: 1;
}

.wc2026-col { display: flex; flex-direction: column; justify-content: space-around; gap: 6px; }

.wc2026-slot {
	background: var(--wc-card-bg);
	border: 1px solid var(--wc-card-border);
	border-radius: 2px;
	padding: 4px 6px;
	font-size: 10px;
	min-height: 36px;
}
.wc2026-slot.is-live { border-color: var(--wc-live); box-shadow: 0 0 0 1px var(--wc-live), 0 0 12px rgba(0,210,106,0.4); animation: wc-live-pulse 2s infinite; }
@keyframes wc-live-pulse { 50% { box-shadow: 0 0 0 1px var(--wc-live), 0 0 18px rgba(0,210,106,0.7); } }
.wc2026-slot-label {
	background: var(--wc-pill-bg);
	font-size: 9px;
	color: #fff;
	padding: 1px 4px;
	border-radius: 2px;
	display: inline-block;
	font-weight: 700;
	margin-bottom: 4px;
	letter-spacing: 0.5px;
}
.wc2026-slot-pair { display: flex; flex-direction: column; gap: 2px; }
.wc2026-slot-team { display: flex; justify-content: space-between; align-items: center; color: var(--wc-text); font-weight: 600; }
.wc2026-slot-score { background: rgba(255,255,255,0.1); padding: 1px 6px; border-radius: 2px; font-weight: 800; min-width: 18px; text-align: center; }

.wc2026-col-final {
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	gap: 12px;
}
.wc2026-trophy { width: 80px; }
.wc2026-trophy svg { width: 100%; height: auto; filter: drop-shadow(0 8px 20px rgba(245,180,0,0.45)); }
.wc2026-final-slot .wc2026-slot { background: rgba(0,0,0,0.35); border-color: var(--wc-gold); }
.wc2026-third-slot {
	font-size: 10px;
	color: var(--wc-text-dim);
	background: rgba(0,0,0,0.2);
	border: 1px dashed var(--wc-card-border);
	border-radius: 2px;
	padding: 4px 8px;
}

/* ---------- TABS ---------- */

.wc2026-tabs {
	display: flex; flex-wrap: wrap; gap: 4px;
	margin-bottom: 16px;
	border-bottom: 1px solid var(--wc-card-border);
}
.wc2026-tab {
	background: transparent;
	color: var(--wc-text-dim);
	border: none;
	border-bottom: 3px solid transparent;
	padding: 10px 16px;
	font-weight: 700;
	letter-spacing: 0.5px;
	cursor: pointer;
	font-size: 14px;
	transition: color 0.15s, border-color 0.15s;
}
.wc2026-tab:hover { color: var(--wc-text); }
.wc2026-tab.is-active { color: var(--wc-gold); border-bottom-color: var(--wc-gold); }

.wc2026-panel { display: none; }
.wc2026-panel.is-active { display: block; }

/* ---------- MATCH CARDS ---------- */

.wc2026-round-filter { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
.wc2026-round-btn {
	background: rgba(0,0,0,0.25);
	color: var(--wc-text-dim);
	border: 1px solid var(--wc-card-border);
	border-radius: 2px;
	padding: 6px 14px;
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.15s;
}
.wc2026-round-btn:hover { color: var(--wc-text); }
.wc2026-round-btn.is-active { background: var(--wc-pill-bg); color: #fff; border-color: var(--wc-pill-bg); }
.wc2026-round-count {
	display: inline-block;
	background: rgba(0,0,0,0.3);
	padding: 1px 6px;
	border-radius: 2px;
	margin-left: 4px;
	font-size: 10px;
}

.wc2026-cards { display: none; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; }
.wc2026-cards.is-active { display: grid; }
.wc2026-card {
	background: var(--wc-card-bg);
	border: 1px solid var(--wc-card-border);
	border-radius: 2px;
	padding: 12px;
	transition: transform 0.15s;
}
.wc2026-card:hover { transform: translateY(-2px); }
.wc2026-card.is-live { border-color: var(--wc-live); box-shadow: 0 0 0 1px var(--wc-live); }
.wc2026-card-head { display: flex; justify-content: space-between; align-items: center; font-size: 11px; color: var(--wc-text-dim); margin-bottom: 8px; }
.wc2026-card-status { font-weight: 700; padding: 2px 8px; border-radius: 2px; }
.wc2026-card.is-live .wc2026-card-status { background: var(--wc-live); color: #000; animation: wc-live-pulse 2s infinite; }
.wc2026-card.is-done .wc2026-card-status { background: rgba(255,255,255,0.1); }
.wc2026-card.is-scheduled .wc2026-card-status { background: rgba(245,180,0,0.2); color: var(--wc-gold); }

.wc2026-card-body { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 8px; margin-bottom: 8px; }
.wc2026-card-team { display: flex; align-items: center; gap: 8px; font-weight: 700; }
.wc2026-card-home { justify-content: flex-end; }
.wc2026-card-away { justify-content: flex-start; }
.wc2026-card-score { background: rgba(0,0,0,0.35); padding: 4px 10px; border-radius: 2px; font-size: 18px; font-weight: 900; min-width: 28px; text-align: center; }
.wc2026-card-vs { color: var(--wc-text-dim); font-size: 11px; text-transform: uppercase; }

.wc2026-card-foot { font-size: 11px; color: var(--wc-text-dim); display: flex; flex-direction: column; gap: 4px; }
.wc2026-card-goals { list-style: none; margin: 6px 0 0; padding: 0; font-size: 11px; }
.wc2026-card-goals li { padding: 2px 0; }
.wc2026-goal-min { color: var(--wc-gold); font-weight: 700; }
.wc2026-goal-team { color: var(--wc-text-dim); }

/* ---------- STANDINGS ---------- */

.wc2026-standings-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
.wc2026-standings-table { background: var(--wc-card-bg); border: 1px solid var(--wc-card-border); border-radius: 2px; padding: 12px; }
.wc2026-standings-table h4 { margin: 0 0 8px; color: var(--wc-gold-2); font-size: 14px; }
.wc2026-standings-table table { width: 100%; border-collapse: collapse; font-size: 12px; }
.wc2026-standings-table th, .wc2026-standings-table td { padding: 4px 6px; text-align: center; color: var(--wc-text); }
.wc2026-standings-table th { color: var(--wc-text-dim); font-weight: 600; border-bottom: 1px solid var(--wc-card-border); }
.wc2026-standings-table td.t-name, .wc2026-standings-table th.t-name { text-align: left; }
.wc2026-standings-table tbody tr { border-bottom: 1px solid rgba(255,255,255,0.05); }
.wc2026-standings-table tbody tr:last-child { border-bottom: none; }
.wc2026-row-qualify td:first-child { box-shadow: inset 3px 0 0 var(--wc-live); }
.wc2026-row-maybe td:first-child { box-shadow: inset 3px 0 0 var(--wc-gold); }
.wc2026-row-out td:first-child { box-shadow: inset 3px 0 0 #777; }

.wc2026-legend { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 12px; font-size: 11px; color: var(--wc-text-dim); }
.wc2026-legend i { display: inline-block; width: 10px; height: 10px; border-radius: 2px; margin-right: 4px; vertical-align: middle; }
.wc2026-dot-qualify { background: var(--wc-live); }
.wc2026-dot-maybe { background: var(--wc-gold); }
.wc2026-dot-out { background: #777; }

/* ---------- SCORERS ---------- */

.wc2026-scorers-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 16px; }
.wc2026-scorers-col { background: var(--wc-card-bg); border: 1px solid var(--wc-card-border); border-radius: 2px; padding: 12px; }
.wc2026-scorers-col h4 { margin: 0 0 12px; color: var(--wc-gold-2); font-size: 15px; }
.wc2026-leaderboard { width: 100%; border-collapse: collapse; font-size: 13px; }
.wc2026-leaderboard th, .wc2026-leaderboard td { padding: 6px; text-align: left; border-bottom: 1px solid rgba(255,255,255,0.05); }
.wc2026-leaderboard th { color: var(--wc-text-dim); font-weight: 600; }
.wc2026-leaderboard td:last-child, .wc2026-leaderboard th:last-child { text-align: center; }
.wc2026-player { display: flex; align-items: center; gap: 8px; }
.wc2026-player img { border-radius: 50%; object-fit: cover; }

/* ---------- NEWS ---------- */

.wc2026-news-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; }
.wc2026-news-card { background: var(--wc-card-bg); border: 1px solid var(--wc-card-border); border-radius: 2px; overflow: hidden; transition: transform 0.15s; }
.wc2026-news-card:hover { transform: translateY(-3px); }
.wc2026-news-thumb { display: block; aspect-ratio: 16/9; background: rgba(0,0,0,0.3); overflow: hidden; }
.wc2026-news-thumb img { width: 100%; height: 100%; object-fit: cover; }
.wc2026-news-body { padding: 12px; }
.wc2026-news-body time { font-size: 11px; color: var(--wc-text-dim); }
.wc2026-news-body h4 { margin: 6px 0 8px; font-size: 15px; line-height: 1.3; }
.wc2026-news-body h4 a { color: var(--wc-text); text-decoration: none; }
.wc2026-news-body h4 a:hover { color: var(--wc-gold); }
.wc2026-news-body p { font-size: 12px; color: var(--wc-text-dim); margin: 0; line-height: 1.5; }

/* ---------- MISC ---------- */

/* ---------- STANDALONE WRAPPERS ([worldcup_standings], [worldcup_scorers]) ---------- */

.wc2026--standalone { padding: 20px 24px; }
.wc2026--standalone .wc2026-panel { display: block; padding: 0; }
.wc2026-standalone-title {
	margin: 0 0 16px;
	font-size: clamp(20px, 2.4vw, 26px);
	font-weight: 800;
	color: var(--wc-gold-2);
	letter-spacing: 0.5px;
}

.wc2026-empty, .wc2026-notice {
	padding: 20px;
	text-align: center;
	background: rgba(0,0,0,0.2);
	border: 1px dashed var(--wc-card-border);
	border-radius: 2px;
	color: var(--wc-text-dim);
	font-size: 13px;
}

/* ---------- RESPONSIVE ---------- */

@media (max-width: 980px) {
	.wc2026-chart {
		grid-template-columns: 1fr;
	}
	.wc2026-side { order: 2; }
	.wc2026-center { order: 1; overflow-x: auto; }
	.wc2026-bracket-grid { min-width: 900px; }
	.wc2026-rounds-header { min-width: 900px; }
}

@media (max-width: 600px) {
	.wc2026 { padding: 14px; }
	.wc2026-tabs { overflow-x: auto; flex-wrap: nowrap; }
	.wc2026-tab { white-space: nowrap; }
	.wc2026-card-body { grid-template-columns: 1fr; gap: 4px; }
	.wc2026-card-home, .wc2026-card-away { justify-content: space-between; }
}
