/**
 * Frontend Stylesheet for 7er Rugby Tabellen
 *
 * Implements a premium, modern, sporty layout optimized for high-end look
 * and fully responsive mobile card grids.
 */

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

:root {
	--r7t-font: 'Outfit', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	--r7t-primary: #101c37; /* Dark navy header background */
	--r7t-primary-light: #1c2c54; /* Row hover background */
	--r7t-accent: #3b82f6; /* Sporty royal blue */
	
	--r7t-text-main: #ffffff;
	--r7t-text-muted: #94a3b8; /* Light gray text */
	--r7t-bg-main: #0c152b; /* Deep navy container background */
	--r7t-bg-zebra: #111d38; /* Alternate zebra row background */
	--r7t-border-color: #243356; /* Subtle blue-gray borders */
	--r7t-card-shadow: 0 12px 30px rgba(0, 0, 0, 0.4), 0 4px 10px rgba(0, 0, 0, 0.2);
	
	/* Dark mode podium colors */
	--r7t-gold-bg: #17254d;
	--r7t-gold-border: rgba(245, 158, 11, 0.35);
	--r7t-gold-badge: rgba(245, 158, 11, 0.15);
	--r7t-gold-text: #fbbf24;

	--r7t-silver-bg: #17254d;
	--r7t-silver-border: rgba(148, 163, 184, 0.3);
	--r7t-silver-badge: rgba(148, 163, 184, 0.12);
	--r7t-silver-text: #cbd5e1;

	--r7t-bronze-bg: #17254d;
	--r7t-bronze-border: rgba(180, 83, 9, 0.35);
	--r7t-bronze-badge: rgba(180, 83, 9, 0.15);
	--r7t-bronze-text: #f97316;

	--r7t-highlight-bg: rgba(16, 185, 129, 0.04);
	--r7t-highlight-border: rgba(16, 185, 129, 0.3);
	--r7t-highlight-text: #34d399;
}

/* 1. Outer Container */
.r7t-table-container {
	font-family: var(--r7t-font);
	color: var(--r7t-text-main);
	background: var(--r7t-bg-main);
	border: 1px solid var(--r7t-border-color);
	border-radius: 16px;
	padding: 36px;
	margin: 32px 0;
	box-shadow: var(--r7t-card-shadow);
	box-sizing: border-box;
	max-width: 100%;
	overflow: hidden;
}

.r7t-table-container.r7t-compact {
	padding: 24px;
	border-radius: 12px;
}

/* 2. Header and Meta block */
.r7t-table-header-block {
	margin-bottom: 28px;
	border-bottom: 2px solid var(--r7t-primary-light);
	padding-bottom: 22px;
}

.r7t-table-title {
	font-size: 3.2rem;
	font-weight: 800;
	margin: 0 0 12px 0;
	color: var(--r7t-text-main);
	letter-spacing: -0.02em;
	text-transform: uppercase;
}

.r7t-compact .r7t-table-title {
	font-size: 2.2rem;
}

.r7t-table-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 24px;
}

.r7t-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	font-size: 1.3rem;
	font-weight: 600;
	color: var(--r7t-text-muted);
}

.r7t-meta-item .dashicons {
	font-size: 24px;
	width: 24px;
	height: 24px;
	color: var(--r7t-accent);
}

/* 3. HTML Table */
.r7t-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	margin: 15px 0;
	text-align: left;
	border: 1px solid var(--r7t-border-color);
	border-radius: 8px;
	overflow: hidden;
}

.r7t-table th {
	background: var(--r7t-primary);
	color: #ffffff !important;
	font-weight: 700;
	font-size: 1.35rem;
	padding: 20px 28px;
	border-bottom: 2px solid var(--r7t-border-color);
	border-right: 1px solid var(--r7t-border-color);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.r7t-table th:last-child {
	border-right: none;
}

.r7t-table td {
	padding: 20px 28px;
	border-bottom: 1px solid var(--r7t-border-color);
	border-right: 1px solid var(--r7t-border-color);
	font-size: 1.5rem;
	vertical-align: middle;
	color: #ffffff !important; /* Ensure contrast on dark navy rows */
	transition: all 0.15s ease-in-out;
}

.r7t-table td:last-child {
	border-right: none;
}

.r7t-table tbody tr:last-child td {
	border-bottom: none;
}

.r7t-compact .r7t-table th {
	padding: 16px 18px;
	font-size: 1.15rem;
}

.r7t-compact .r7t-table td {
	padding: 16px 18px;
	font-size: 1.25rem;
}

.r7t-align-right {
	text-align: right !important;
}

.r7t-table tbody tr {
	background: var(--r7t-bg-main);
	transition: background-color 0.2s ease, transform 0.2s ease;
}

.r7t-table tbody tr:nth-child(even) {
	background: var(--r7t-bg-zebra);
}

/* Row Hover Effect on Desktop */
@media (min-width: 481px) {
	.r7t-table tbody tr:hover {
		background: var(--r7t-primary-light) !important;
		transform: scale(1.002);
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	}
}

/* 4. Column Styles */
.r7t-col-rank {
	width: 80px;
}

.r7t-cell-rank {
	font-weight: 700;
}

.r7t-rank-badge {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 46px;
	height: 46px;
	border-radius: 50%;
	background: #101c37;
	color: #94a3b8;
	font-size: 1.35rem;
	font-weight: 700;
	border: 1px solid var(--r7t-border-color);
}

.r7t-cell-team {
	font-weight: 700;
}

.r7t-team-name-wrapper {
	display: flex;
	align-items: center;
	gap: 14px;
}

.r7t-team-name-text {
	font-size: 1.65rem;
	font-weight: 700;
	color: #ffffff;
}

.r7t-medal-indicator {
	font-size: 1.7rem;
	line-height: 1;
}

/* Points column highlight matching user request (dark blue background, larger text) */
.r7t-col-points,
.r7t-cell-points {
	color: #fbbf24 !important;
	font-weight: 800 !important;
	font-size: 1.85rem !important;
}

.r7t-compact .r7t-cell-points {
	font-size: 1.5rem !important;
}

/* Difference signs and styling */
.r7t-diff-positive {
	color: #34d399 !important;
	font-weight: 700;
}

.r7t-diff-negative {
	color: #f87171 !important;
	font-weight: 700;
}

/* 5. Podium Highlight Classes */
.r7t-rank-gold,
.r7t-rank-silver,
.r7t-rank-bronze {
	background-color: #17254d !important; /* Distinct highlighted blue background for top 3 */
}

.r7t-rank-gold td,
.r7t-rank-gold .r7t-team-name-text,
.r7t-rank-gold .r7t-rank-badge,
.r7t-rank-silver td,
.r7t-rank-silver .r7t-team-name-text,
.r7t-rank-silver .r7t-rank-badge,
.r7t-rank-bronze td,
.r7t-rank-bronze .r7t-team-name-text,
.r7t-rank-bronze .r7t-rank-badge {
	color: #fcd34d !important; /* Gold/yellow text for high contrast on blue background */
}

.r7t-rank-gold .r7t-rank-badge,
.r7t-rank-silver .r7t-rank-badge,
.r7t-rank-bronze .r7t-rank-badge {
	background: rgba(252, 211, 77, 0.12) !important;
	border-color: #fcd34d !important;
}

.r7t-rank-gold td,
.r7t-rank-silver td,
.r7t-rank-bronze td {
	border-bottom-color: var(--r7t-border-color);
}

.r7t-rank-highlight {
	background-color: var(--r7t-highlight-bg) !important;
}
.r7t-rank-highlight .r7t-rank-badge {
	background: var(--r7t-highlight-border);
	color: var(--r7t-highlight-text);
	border: 1px solid var(--r7t-highlight-border);
}
.r7t-rank-highlight td {
	border-bottom-color: var(--r7t-highlight-border);
}
.r7t-table-notes {
	margin-top: 24px;
	background: #101c37;
	border: 1px solid var(--r7t-border-color);
	border-left: 4px solid var(--r7t-accent);
	border-radius: 8px;
	padding: 18px 24px;
	font-size: 1.1rem;
	color: var(--r7t-text-muted);
	display: flex;
	align-items: flex-start;
	gap: 12px;
}

.r7t-table-notes .dashicons {
	font-size: 22px;
	width: 22px;
	height: 22px;
	color: var(--r7t-accent);
	margin-top: 2px;
}

.r7t-notes-content {
	line-height: 1.5;
}


/* =========================================
   7. Mobile Responsive Transformation
   ========================================= */

@media (max-width: 480px) {
	.r7t-table-container {
		padding: 16px;
		border-radius: 12px;
	}

	.r7t-table-header-block {
		margin-bottom: 16px;
		padding-bottom: 12px;
	}

	.r7t-table-title {
		font-size: 1.6rem;
	}

	.r7t-table-meta {
		gap: 10px;
	}

	.r7t-meta-item {
		font-size: 0.9rem;
	}

	/* Collapse HTML Table structure into Cards */
	.r7t-table, 
	.r7t-table thead, 
	.r7t-table tbody, 
	.r7t-table tr, 
	.r7t-table th, 
	.r7t-table td {
		display: block;
	}

	.r7t-table {
		border: none;
		margin: 8px 0;
	}

	.r7t-table thead {
		display: none; /* Hide header completely on mobile */
	}

	/* Each row becomes a card using CSS Grid */
	.r7t-table tbody tr {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		gap: 10px;
		padding: 16px;
		border: 1px solid var(--r7t-border-color);
		border-radius: 12px;
		margin-bottom: 12px;
		box-shadow: 0 2px 4px rgba(0,0,0,0.02);
		background: var(--r7t-bg-main);
		box-sizing: border-box;
	}

	.r7t-table tbody tr:nth-child(even) {
		background: var(--r7t-bg-zebra);
	}

	/* Remove vertical borders on mobile */
	.r7t-table td {
		border-right: none !important;
		border-bottom: none !important;
	}

	/* Placement override for card headers */
	.r7t-cell-rank {
		grid-column: 1 / 2;
		grid-row: 1;
		display: flex;
		align-items: center;
		justify-content: flex-start;
		padding: 0 0 10px 0 !important;
		border: none !important;
		background: transparent !important;
	}

	.r7t-cell-team {
		grid-column: 2 / 5;
		grid-row: 1;
		display: flex;
		align-items: center;
		padding: 0 0 10px 0 !important;
		border: none !important;
		background: transparent !important;
		font-size: 1.3rem !important;
	}

	.r7t-team-name-wrapper {
		display: flex;
		align-items: center;
		flex-wrap: wrap;
		gap: 8px;
	}

	.r7t-team-name-text {
		font-size: 1.25rem;
	}

	.r7t-medal-indicator {
		font-size: 1.25rem;
	}

	/* Grid layout for stats cells (Row 2 of card) */
	.r7t-cell-stat, 
	.r7t-cell-points {
		grid-row: 2;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		background: #101c37;
		border: 1px solid var(--r7t-border-color) !important;
		border-radius: 8px;
		padding: 10px 6px !important;
		font-size: 1.1rem !important;
		text-align: center !important;
	}

	.r7t-cell-points {
		background: #101c37;
		border-color: var(--r7t-border-color) !important;
		font-weight: 700;
	}

	/* Generate Stat Labels dynamically from HTML attribute */
	.r7t-cell-stat::before, 
	.r7t-cell-points::before {
		content: attr(data-label);
		display: block;
		font-size: 0.75rem;
		text-transform: uppercase;
		letter-spacing: 0.05em;
		color: var(--r7t-text-muted);
		margin-bottom: 4px;
		font-weight: 700;
	}

	/* Ensure difference styles remain correct inside card stats */
	.r7t-diff-positive {
		color: #34d399 !important;
		font-weight: 700;
	}

	.r7t-diff-negative {
		color: #f87171 !important;
		font-weight: 700;
	}

	/* Podium highlights for mobile cards - borders indicate podium place */
	.r7t-rank-gold {
		border: 2px solid var(--r7t-gold-border) !important;
		background: var(--r7t-gold-bg) !important;
	}
	.r7t-rank-gold .r7t-cell-stat, 
	.r7t-rank-gold .r7t-cell-points {
		background: rgba(254, 243, 199, 0.04);
		border-color: rgba(254, 240, 138, 0.2) !important;
	}
	
	.r7t-rank-silver {
		border: 2px solid var(--r7t-silver-border) !important;
		background: var(--r7t-silver-bg) !important;
	}
	.r7t-rank-silver .r7t-cell-stat, 
	.r7t-rank-silver .r7t-cell-points {
		background: rgba(245, 245, 244, 0.04);
		border-color: rgba(231, 229, 230, 0.2) !important;
	}

	.r7t-rank-bronze {
		border: 2px solid var(--r7t-bronze-border) !important;
		background: var(--r7t-bronze-bg) !important;
	}
	.r7t-rank-bronze .r7t-cell-stat, 
	.r7t-rank-bronze .r7t-cell-points {
		background: rgba(255, 237, 213, 0.04);
		border-color: rgba(254, 215, 170, 0.2) !important;
	}

	.r7t-table-notes {
		padding: 12px 16px;
		font-size: 0.9rem;
		border-radius: 6px;
	}

	/* Season Standings Overrides (5-column layout on mobile) */
	.r7t-table-season tbody tr {
		grid-template-columns: repeat(5, 1fr) !important;
	}

	.r7t-table-season .r7t-cell-team {
		grid-column: 2 / 6 !important;
	}

	.r7t-table-season .r7t-cell-stat, 
	.r7t-table-season .r7t-cell-points {
		grid-row: 2 !important;
		grid-column: span 1 !important;
		width: 100% !important;
		box-sizing: border-box !important;
	}
}
