/* Matchup Page Specific Styles */

.matchup-header {
	background: var(--color-surface-1);
	color: var(--color-gold-200);
	padding: 3rem 0;
	border-bottom: 1px solid var(--color-border);
}

.champion-showdown {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 3rem;
	flex-wrap: wrap;
}

.champion-info {
	text-align: center;
	flex: 1;
	min-width: 200px;
}

.champion-splash {
	width: 96px;
	height: 96px;
	border-radius: 50%;
	border: 2px solid var(--color-gold);
	box-shadow: 0 0 0 3px rgba(200,170,110,.15);
	margin-bottom: 1rem;
	object-fit: cover;
}

.champion-info h2 {
	font-size: 2rem;
	margin-bottom: 0.5rem;
	font-weight: 700;
	font-family: var(--font-display);
	color: var(--color-gold-200);
}

.champion-role {
	color: var(--color-text-muted);
	font-size: 1.1rem;
	margin-bottom: 0.5rem;
}

.champion-desc {
	font-size: 0.9rem;
	opacity: 0.9;
	max-width: 250px;
	margin: 0 auto;
	color: var(--color-text);
}

.vs-divider {
	font-size: 2rem;
	font-weight: bold;
	color: var(--color-gold);
	text-shadow: 0 0 12px rgba(200,170,110,.25);
}

.matchup-content {
	padding: 3rem 0;
	background: var(--color-bg);
}

.content-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
	margin-bottom: 3rem;
}

.champion-column h3 {
	font-size: 1.5rem;
	margin-bottom: 1.5rem;
	color: var(--color-gold-200);
	border-bottom: 2px solid var(--color-gold);
	padding-bottom: 0.5rem;
	font-family: var(--font-display);
}

.section {
	background: var(--color-surface-2);
	border-radius: var(--radius-lg);
	padding: 1.5rem;
	margin-bottom: 2rem;
	border: 1px solid var(--color-border);
	box-shadow: var(--shadow-1);
}

.section.full-width {
	grid-column: 1 / -1;
	background: var(--color-surface-1);
}

.section h4 {
	color: var(--color-gold-200);
	margin-bottom: 1rem;
	font-size: 1.2rem;
	font-family: var(--font-display);
}

.section ul {
	list-style: none;
	padding: 0;
}

.section li {
	padding: 0.5rem 0;
	border-bottom: 1px solid var(--color-line);
	position: relative;
	padding-left: 1.5rem;
	color: var(--color-text);
}

.section li:last-child {
	border-bottom: none;
}

.section li:before {
	content: "•";
	color: var(--color-gold);
	font-weight: bold;
	position: absolute;
	left: 0;
}

.power-curve {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 1.5rem;
}

.power-stage {
	background: var(--color-surface-2);
	border-radius: var(--radius-md);
	padding: var(--space-4);
	border: 1px solid var(--color-border);
	text-align: center;
	flex: 1;
}

.power-stage h4 {
	color: var(--color-gold);
	margin-bottom: var(--space-3);
	font-size: var(--font-size-md);
	font-family: var(--font-display);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.power-stage p {
	font-size: var(--font-size-sm);
	line-height: var(--line-tight);
	margin: 0;
}

/* Power Curve Graph Styles */
.power-curve-graph {
	margin-top: 2rem;
	background: var(--color-surface-2);
	border-radius: var(--radius-md);
	padding: 1.5rem;
	border: 1px solid var(--color-border);
}

.power-curve {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.power-curve-graph-container {
	width: 100%;
}

.power-curve-graph-container h4 {
	color: var(--color-gold-200);
	font-family: var(--font-display);
	font-size: var(--font-size-md);
	margin-bottom: var(--space-2);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.power-stages {
	display: flex;
	flex-direction: row;
	gap: var(--space-3);
	width: 100%;
}

.graph-container {
	position: relative;
	height: 320px;
	margin: 0;
	background: var(--color-surface-2);
	border-radius: var(--radius-md);
	padding: var(--space-4);
	border: 1px solid var(--color-border);
	overflow: hidden;
}

/* Ensure SVG elements stay within container */
.graph-container svg {
	max-width: 100%;
	max-height: 100%;
	overflow: visible;
}

/* Ensure text labels don't overflow */
.graph-container text {
	font-size: 12px;
}

.graph-svg { width: 100%; height: 100%; }

.graph-axis { stroke: #7b8794; stroke-width: 1; }
.graph-grid { stroke: #2a3a56; stroke-width: 0.5; }

.graph-line { fill: none; stroke-width: 3; stroke-linecap: round; stroke-linejoin: round; }
.graph-line.power-curve { stroke: var(--color-hextech); }

.graph-dot { r: 4; cursor: pointer; transition: r 0.2s; }
.graph-dot:hover { r: 6; }
.graph-dot.champion1 { fill: var(--color-hextech); }
.graph-dot.champion2 { fill: var(--color-danger); }
.graph-dot.neutral { fill: #95a5a6; }

.graph-legend {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	margin-top: 1rem;
	padding: 0 1rem;
}

.legend-item { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9rem; color: var(--color-text); }
.legend-line { width: 24px; height: 3px; background-color: var(--color-hextech); border-radius: 2px; flex-shrink: 0; }
.legend-description { text-align: center; color: var(--color-text-muted); max-width: 100%; }
.legend-description small { font-size: 0.8rem; line-height: 1.3; display: block; }

.graph-tooltip {
	position: absolute;
	background: rgba(0, 0, 0, 0.8);
	color: white;
	padding: 0.5rem;
	border-radius: 4px;
	font-size: 0.8rem;
	pointer-events: none;
	z-index: 1000;
	opacity: 0;
	transition: opacity 0.2s;
}

.graph-tooltip.show { opacity: 1; }

.win-conditions {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
}

.win-condition {
	background: var(--color-surface-2);
	border-radius: var(--radius-md);
	padding: 1.5rem;
	border: 1px solid var(--color-border);
}

.win-condition h4 {
	color: var(--color-gold-200);
	margin-bottom: 1rem;
	font-size: 1.2rem;
	font-family: var(--font-display);
}

.laning-guide {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 1.5rem;
}

.wave {
	background: var(--color-surface-2);
	border-radius: var(--radius-md);
	padding: 1.5rem;
	border: 1px solid var(--color-border);
}

.wave h4 {
	color: var(--color-gold);
	margin-bottom: 1rem;
	font-size: 1.1rem;
	font-family: var(--font-display);
}

.wave p { margin-bottom: 0.5rem; color: var(--color-text); }
.wave p:last-child { margin-bottom: 0; }

.build-section {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 1.5rem;
}

.build-item {
	background: var(--color-surface-2);
	border-radius: var(--radius-md);
	padding: 1.5rem;
	border: 1px solid var(--color-border);
	text-align: center;
}

.build-item h4 {
	color: var(--color-gold);
	margin-bottom: 1rem;
	font-size: 1.1rem;
	font-family: var(--font-display);
}

.build-item p { margin-bottom: 0.5rem; color: var(--color-text); }

.tips-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }

.tip {
	background: var(--color-surface-2);
	border-radius: var(--radius-md);
	padding: 1.5rem;
	border: 1px solid var(--color-border);
}

.tip h4 { color: var(--color-gold-200); margin-bottom: 1rem; font-size: 1.2rem; font-family: var(--font-display); }

.related-matchups { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; }

.matchup-link {
	background: var(--color-gold);
	color: var(--color-text-inverse);
	padding: 0.75rem 1.5rem;
	border-radius: 6px;
	text-decoration: none;
	font-weight: 600;
	transition: all 0.3s;
	border: 1px solid var(--color-gold-700);
}

.matchup-link:hover { filter: brightness(1.05); transform: translateY(-2px); box-shadow: var(--shadow-2); }

/* 2v2 Matchup Specific Styles */
.duo-champions { display: flex; gap: 0.5rem; justify-content: center; margin-bottom: 1rem; }
.duo-champions .champion-splash { width: 80px; height: 80px; }

.synergy-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }

.synergy { background: var(--color-surface-2); border-radius: var(--radius-md); padding: 1.5rem; border: 1px solid var(--color-border); }

.synergy h4 { color: var(--color-gold-200); margin-bottom: 1rem; font-size: 1.2rem; font-family: var(--font-display); }

/* Power Spikes Styles */
.power-spikes-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }

.champion-spikes { background: var(--color-surface-2); border-radius: var(--radius-md); padding: 1.5rem; border: 1px solid var(--color-border); }

.champion-spikes h4 { color: var(--color-gold-200); margin-bottom: 1.5rem; font-size: 1.2rem; border-bottom: 2px solid var(--color-gold); padding-bottom: 0.5rem; font-family: var(--font-display); }

.spike-category { margin-bottom: 1.5rem; }
.spike-category:last-child { margin-bottom: 0; }

.spike-category h5 { color: var(--color-gold); margin-bottom: 0.75rem; font-size: 1rem; font-weight: 600; font-family: var(--font-display); }

.spike-category ul { list-style: none; padding: 0; }

.spike-category li {
	padding: 0.4rem 0;
	border-bottom: 1px solid var(--color-line);
	position: relative;
	padding-left: 1rem;
	font-size: 0.9rem;
	line-height: 1.4;
	color: var(--color-text);
}

.spike-category li:last-child { border-bottom: none; }

.spike-category li:before { content: "⚡"; position: absolute; left: 0; color: var(--color-gold); font-size: 0.8rem; }

.spike-category li strong { color: var(--color-gold-200); font-weight: 600; }

/* Collapsible Sections Styles */
.collapsible-header { cursor: pointer; user-select: none; position: relative; transition: all 0.3s ease; display: flex; align-items: center; justify-content: space-between; }

.collapsible-header:hover { color: var(--color-gold); }

.collapsible-header:focus { outline: none; box-shadow: var(--glow-gold); }

.collapse-icon { font-size: 1.2em; font-weight: bold; color: var(--color-gold); transition: transform 0.3s ease; flex-shrink: 0; margin-left: 0.5rem; }

.collapsible-header.collapsed .collapse-icon { transform: rotate(0deg); }

.collapsible-content { overflow: hidden; transition: max-height 0.3s ease, opacity 0.3s ease; max-height: none; opacity: 1; }

.collapsible-content[aria-hidden="true"] { max-height: 0; opacity: 0; }

/* Section Controls */
.section-controls { background: var(--color-surface-1); border-bottom: 1px solid var(--color-border); padding: 1rem 0; }

.controls-wrapper { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; }

.control-btn {
	background: var(--color-surface-2);
	border: 1px solid var(--color-gold);
	color: var(--color-gold-200);
	padding: 0.5rem 1rem;
	border-radius: 6px;
	font-size: 0.9rem;
	cursor: pointer;
	transition: all 0.3s ease;
	font-weight: 600;
}

.control-btn:hover { background: var(--color-gold); color: var(--color-text-inverse); transform: translateY(-1px); }
.control-btn:active { transform: translateY(0); }

/* Matchup Dynamics Styles */
.matchup-dynamics { background: linear-gradient(135deg, rgba(19,34,56,1) 0%, rgba(15,26,43,1) 100%); border: 1px solid var(--color-border); margin-bottom: 2rem; }

.dynamics-overview { display: grid; gap: 2rem; }

.dynamics-summary { background: var(--color-surface-2); padding: 1.5rem; border-radius: var(--radius-md); border-left: 4px solid var(--color-gold); border: 1px solid var(--color-border); }

.dynamics-summary h4 { color: var(--color-gold-200); margin-bottom: 1rem; font-size: 1.2rem; font-family: var(--font-display); }

.dynamics-summary p { line-height: 1.6; margin: 0; color: var(--color-text); }

.dynamics-phases { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1rem; }

.phase-item { background: var(--color-surface-2); padding: 1rem; border-radius: var(--radius-md); border: 1px solid var(--color-border); text-align: center; }

.phase-item h5 { color: var(--color-gold); margin-bottom: 0.75rem; font-size: 1rem; font-weight: 600; font-family: var(--font-display); }

.phase-item p { font-size: 0.9rem; line-height: 1.4; margin: 0; color: var(--color-text); }

.advantage { display: inline-block; padding: 2px 8px; border-radius: 999px; font-size: 0.8rem; font-weight: 700; text-transform: none; letter-spacing: .2px; border: 1px solid transparent; }
.advantage.champion-a { background: rgba(47,143,237,.15); color: #BFD7FF; border-color: var(--color-hextech); }
.advantage.champion-b { background: rgba(227,76,76,.15); color: #FFD1D1; border-color: var(--color-danger); }
.advantage.skill { background: rgba(200,170,110,.15); color: var(--color-gold-200); border-color: var(--color-gold); }

.key-interactions { background: var(--color-surface-2); padding: 1.5rem; border-radius: var(--radius-md); border-left: 4px solid var(--color-success); border: 1px solid var(--color-border); }

.key-interactions h4 { color: var(--color-gold-200); margin-bottom: 1rem; font-size: 1.2rem; font-family: var(--font-display); }

.key-interactions ul { list-style: none; padding: 0; margin: 0; }

.key-interactions li { padding: 0.75rem 0; border-bottom: 1px solid var(--color-line); position: relative; padding-left: 1.5rem; line-height: 1.5; color: var(--color-text); }

.key-interactions li:last-child { border-bottom: none; }

.key-interactions li:before { content: "🔗"; position: absolute; left: 0; font-size: 0.9rem; }

.key-interactions li strong { color: var(--color-success); font-weight: 600; }

/* Best Build Styles */
.best-build-overview { display: grid; grid-template-columns: 2fr 1fr; gap: 2rem; }

.build-sequence { display: flex; flex-direction: column; gap: 1rem; }

.build-step { display: flex; align-items: flex-start; gap: 1rem; padding: 1rem; background: var(--color-surface-2); border-radius: var(--radius-md); border: 1px solid var(--color-border); }

.step-number { background: var(--color-hextech); color: white; width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: bold; flex-shrink: 0; }

.step-content strong { color: var(--color-gold-200); font-size: 1.1rem; display: block; margin-bottom: 0.25rem; }

.step-content p { margin: 0; color: var(--color-text); font-size: 0.9rem; line-height: 1.4; }

.situational-items { background: var(--color-surface-2); padding: 1.5rem; border-radius: var(--radius-md); border: 1px solid var(--color-border); height: fit-content; }

.situational-items h4 { color: var(--color-gold-200); margin-bottom: 1rem; font-size: 1.1rem; font-family: var(--font-display); }

.situational-items ul { list-style: none; padding: 0; margin: 0; }

.situational-items li { padding: 0.5rem 0; border-bottom: 1px solid var(--color-line); font-size: 0.9rem; line-height: 1.4; color: var(--color-text); }

.situational-items li:last-child { border-bottom: none; }

/* Key Patterns Styles */
.patterns-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.5rem; }

.pattern-category { background: var(--color-surface-2); padding: 1.5rem; border-radius: var(--radius-md); border: 1px solid var(--color-border); }

.pattern-category h4 { color: var(--color-gold-200); margin-bottom: 1rem; font-size: 1.1rem; border-bottom: 2px solid var(--color-gold); padding-bottom: 0.5rem; font-family: var(--font-display); }

.combo-list { display: flex; flex-direction: column; gap: 1rem; }

.combo-item { padding: 1rem; background: var(--color-surface-1); border-radius: 6px; border-left: 3px solid var(--color-gold); border: 1px solid var(--color-border); }

.combo-item strong { color: var(--color-gold-200); display: block; margin-bottom: 0.5rem; font-size: 0.95rem; }

.combo-item p { margin: 0 0 0.5rem 0; font-family: var(--font-mono); background: var(--color-surface-2); padding: 0.5rem; border-radius: 4px; font-size: 0.85rem; color: var(--color-text); }

.damage-note { color: var(--color-danger); font-style: italic; font-size: 0.8rem; }

.threshold-list { list-style: none; padding: 0; margin: 0; }

.threshold-list li { padding: 0.75rem; background: var(--color-surface-1); border-radius: 6px; margin-bottom: 0.5rem; border-left: 3px solid var(--color-success); font-size: 0.9rem; color: var(--color-text); }

.threshold-list li:last-child { margin-bottom: 0; }

/* Game Plan Table Styles */
.game-plan-table-container { overflow-x: auto; background: var(--color-surface-2); border-radius: var(--radius-lg); box-shadow: var(--shadow-1); border: 1px solid var(--color-border); }

.game-plan-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; background: var(--color-surface-2); }

.game-plan-table thead th { background: var(--color-surface-1); color: var(--color-gold-200); padding: 1rem 0.75rem; text-align: left; font-weight: 700; border-bottom: 1px solid var(--color-border); position: sticky; top: 0; font-family: var(--font-display); }

.game-plan-table tbody td { padding: 0.75rem; border-top: 1px solid var(--color-line); vertical-align: top; line-height: 1.4; color: var(--color-text); }

.game-plan-table tbody tr:hover { background: rgba(255,255,255,.02); }

/* First Back Goals Styles */
.back-goals-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.5rem; }

.back-scenario { background: var(--color-surface-2); padding: 1.5rem; border-radius: var(--radius-md); border: 1px solid var(--color-border); }

.back-scenario h4 { color: var(--color-gold-200); margin-bottom: 1rem; font-size: 1.1rem; border-bottom: 2px solid var(--color-success); padding-bottom: 0.5rem; font-family: var(--font-display); }

.back-scenario ul { list-style: none; padding: 0; margin: 0 0 1rem 0; }

.back-scenario li { padding: 0.4rem 0; border-bottom: 1px solid var(--color-line); font-size: 0.9rem; color: var(--color-text); }

.back-scenario li:last-child { border-bottom: none; }

.scenario-note { background: rgba(83,131,232,.12); padding: 0.75rem; border-radius: 6px; margin: 0; font-size: 0.85rem; color: var(--color-hextech); }

/* Common Mistakes Styles */
.mistakes-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }

.mistake-category { background: var(--color-surface-2); padding: 1.5rem; border-radius: var(--radius-md); border: 1px solid var(--color-border); }

.mistake-category h4 { color: var(--color-gold-200); margin-bottom: 1rem; font-size: 1.1rem; border-bottom: 2px solid var(--color-danger); padding-bottom: 0.5rem; font-family: var(--font-display); }

.mistake-list { display: flex; flex-direction: column; gap: 1rem; }

.mistake-item { padding: 1rem; background: rgba(227,76,76,.08); border-radius: 6px; border-left: 3px solid var(--color-danger); }

.mistake-item strong { color: var(--color-danger); display: block; margin-bottom: 0.5rem; font-size: 0.95rem; }

.mistake-item p { margin: 0; font-size: 0.9rem; line-height: 1.4; color: var(--color-text); }

/* Responsive Design for Matchup Pages */
@media (max-width: 768px) {
	.champion-showdown { flex-direction: column; gap: 2rem; }
	.vs-divider { font-size: 1.5rem; }
	.content-grid { grid-template-columns: 1fr; gap: 1.5rem; }
	.win-conditions { grid-template-columns: 1fr; gap: 1.5rem; }
	.tips-grid { grid-template-columns: 1fr; gap: 1.5rem; }
	.power-spikes-grid { grid-template-columns: 1fr; gap: 1.5rem; }
	.dynamics-phases { grid-template-columns: 1fr; gap: 1rem; }
	.dynamics-overview { gap: 1.5rem; }
	.dynamics-summary, .key-interactions { padding: 1rem; }
	.phase-item { padding: 0.8rem; }
	.best-build-overview { grid-template-columns: 1fr; gap: 1.5rem; }
	.patterns-grid { grid-template-columns: 1fr; gap: 1rem; }
	.back-goals-grid { grid-template-columns: 1fr; gap: 1rem; }
	.mistakes-grid { grid-template-columns: 1fr; gap: 1.5rem; }
	.game-plan-table-container { font-size: 0.8rem; }
	.game-plan-table th, .game-plan-table td { padding: 0.5rem 0.4rem; }
	.power-curve { grid-template-columns: 1fr; }
	.laning-guide { grid-template-columns: 1fr; }
	.build-section { grid-template-columns: 1fr; }
	.champion-splash { width: 100px; height: 100px; }
	.champion-info h2 { font-size: 1.5rem; }
}

@media (max-width: 480px) {
	.matchup-header { padding: 2rem 0; }
	.matchup-content { padding: 2rem 0; }
	.section { padding: 1rem; }
	.champion-splash { width: 80px; height: 80px; }
	.champion-info h2 { font-size: 1.3rem; }
	.related-matchups { flex-direction: column; align-items: center; }
	.matchup-link { width: 100%; text-align: center; }
	.synergy-grid { grid-template-columns: 1fr; gap: 1.5rem; }
	.duo-champions { flex-direction: column; gap: 0.25rem; }
	.duo-champions .champion-splash { width: 60px; height: 60px; }
	.graph-container { height: 250px; }
	
	.power-stages {
		flex-direction: column;
		gap: var(--space-2);
	}
	
	.power-stage {
		padding: var(--space-3);
	}
	
	.power-curve {
		gap: var(--space-3);
	}
	.graph-legend { padding: 0 0.5rem; gap: 0.25rem; }
	.legend-item { font-size: 0.8rem; }
	.legend-description small { font-size: 0.7rem; }
	.controls-wrapper { flex-direction: column; align-items: center; gap: 0.5rem; }
	.control-btn { width: 100%; max-width: 200px; font-size: 0.8rem; padding: 0.4rem 0.8rem; }
	.collapse-icon { font-size: 1em; }
}

/* Medium screens */
@media (max-width: 768px) {
	.graph-container { height: 260px; }
	
	.power-stages {
		flex-direction: column;
		gap: var(--space-2);
	}
	
	.power-stage {
		padding: var(--space-3);
	}
	.graph-legend { gap: 1rem; }
}

/* Experimental Tag */
.experimental-tag {
	display: inline-block;
	background: var(--color-warning);
	color: var(--color-surface-1);
	font-size: var(--font-size-xs);
	font-weight: 600;
	padding: 0.25rem 0.5rem;
	border-radius: var(--radius-sm);
	margin-left: var(--space-2);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	vertical-align: middle;
	border: 1px solid rgba(255, 193, 7, 0.3);
}
