/*!
 * League Data Engine — Public stylesheet
 * Professional sports-site design language. All rules scoped to .lde
 * to avoid bleeding into the parent theme. Supports both LTR and RTL.
 */

/* =========================================================================
 * 1. Design tokens
 * ========================================================================= */
.lde {
	--lde-bg:           #ffffff;
	--lde-bg-soft:      #f5f7fb;
	--lde-bg-alt:       #fafbfd;
	--lde-surface:      #ffffff;
	--lde-border:       #e4e7ee;
	--lde-border-soft:  #eef1f6;
	--lde-text:         #0f172a;
	--lde-text-muted:   #64748b;
	--lde-text-soft:    #94a3b8;

	--lde-primary:      #0b8043;     /* sports green */
	--lde-primary-dark: #066a36;
	--lde-accent:       #f4b400;     /* trophy gold */
	--lde-navy:         #0f1e3d;     /* deep navy heading bar */
	--lde-danger:       #dc2626;
	--lde-warn:         #f59e0b;
	--lde-ok:           #16a34a;

	--lde-zone-champion:    #f4b400;
	--lde-zone-continental: #0b8043;
	--lde-zone-cont-qual:   #14b8a6;
	--lde-zone-relegation:  #dc2626;

	--lde-shadow-sm: 0 1px 2px rgba(15,30,61,.06);
	--lde-shadow:    0 4px 14px rgba(15,30,61,.08);
	--lde-shadow-lg: 0 12px 32px rgba(15,30,61,.12);

	--lde-radius-sm: 6px;
	--lde-radius:    12px;
	--lde-radius-lg: 18px;

	color: var(--lde-text);
	font-family: "Tajawal", "IBM Plex Sans Arabic", "Segoe UI", system-ui,
	             -apple-system, "Helvetica Neue", Arial, sans-serif;
	line-height: 1.55;
	font-feature-settings: "ss01" on, "tnum" on;
}

/* =========================================================================
 * 2. Generic helpers
 * ========================================================================= */
.lde-muted  { color: var(--lde-text-muted); font-size: .9em; }
.lde-empty  { color: var(--lde-text-muted); font-style: italic; padding: 1em 0; }
.lde-scroll-x { overflow-x: auto; width: 100%; -webkit-overflow-scrolling: touch; }
.lde-scroll-x::-webkit-scrollbar { height: 6px; }
.lde-scroll-x::-webkit-scrollbar-thumb { background: var(--lde-border); border-radius: 3px; }

/* =========================================================================
 * 3. Section heading bar
 * ========================================================================= */
.lde-table-head {
	background: linear-gradient(135deg, var(--lde-navy) 0%, #1e3a8a 100%);
	color: #fff;
	padding: 14px 20px;
	border-radius: var(--lde-radius) var(--lde-radius) 0 0;
	box-shadow: var(--lde-shadow-sm);
	position: relative;
	overflow: hidden;
}
.lde-table-head::after {
	content: "";
	position: absolute;
	inset-inline-end: -40px;
	top: -40px;
	width: 120px;
	height: 120px;
	background: radial-gradient(circle, rgba(244,180,0,.25) 0%, transparent 70%);
	pointer-events: none;
}
.lde-table-head h3 {
	margin: 0;
	color: #fff;
	font-size: 1.15em;
	font-weight: 700;
	letter-spacing: .01em;
	display: flex;
	align-items: center;
	gap: 10px;
}
.lde-table-head h3 small {
	font-weight: 400;
	color: rgba(255,255,255,.7);
	font-size: .85em;
}
.lde-table-head-icon {
	display: inline-block;
	width: 6px;
	height: 22px;
	background: var(--lde-accent);
	border-radius: 3px;
	flex: 0 0 6px;
}

/* =========================================================================
 * 4. Data table base
 * ========================================================================= */
.lde-data-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	font-size: 14px;
	background: var(--lde-surface);
	border: 1px solid var(--lde-border);
	border-top: none;
	border-radius: 0 0 var(--lde-radius) var(--lde-radius);
	overflow: hidden;
	box-shadow: var(--lde-shadow);
}
.lde-data-table th,
.lde-data-table td {
	padding: 12px 10px;
	text-align: center;
	border-bottom: 1px solid var(--lde-border-soft);
	vertical-align: middle;
}
.lde-data-table thead th {
	background: var(--lde-bg-soft);
	color: var(--lde-text-muted);
	font-weight: 700;
	font-size: 12px;
	letter-spacing: .04em;
	text-transform: uppercase;
	padding: 11px 8px;
	border-bottom: 2px solid var(--lde-border);
	position: sticky;
	top: 0;
	z-index: 1;
}
.lde-data-table tbody tr {
	transition: background .15s ease;
}
.lde-data-table tbody tr:nth-child(even) { background: var(--lde-bg-alt); }
.lde-data-table tbody tr:hover           { background: #eef5ff; }
.lde-data-table tbody tr:last-child td   { border-bottom: none; }

.lde-data-table .lde-num    { width: 44px; }
.lde-data-table .lde-stat   { width: 42px; font-variant-numeric: tabular-nums; color: var(--lde-text); font-weight: 500; }
.lde-data-table .lde-points { width: 56px; }
.lde-data-table .lde-points strong {
	display: inline-block;
	min-width: 32px;
	padding: 5px 10px;
	border-radius: 6px;
	background: var(--lde-navy);
	color: #fff;
	font-weight: 800;
	font-size: 14px;
}

.lde-data-table .lde-club,
.lde-data-table .lde-player {
	text-align: start;
	font-weight: 600;
	min-width: 160px;
}
.lde-data-table .lde-club a,
.lde-data-table .lde-player a {
	text-decoration: none;
	color: var(--lde-text);
	transition: color .15s;
}
.lde-data-table .lde-club a:hover,
.lde-data-table .lde-player a:hover { color: var(--lde-primary); }

.lde-club-logo {
	width: 26px;
	height: 26px;
	object-fit: contain;
	vertical-align: middle;
	margin-inline-end: 10px;
	border-radius: 3px;
}
.lde-club-logo-lg { width: 72px;  height: 72px; }
.lde-club-logo-xl { width: 128px; height: 128px; }

/* =========================================================================
 * 5. Standings table — zones + position badge
 * ========================================================================= */
.lde-standings-table .lde-pos-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: var(--lde-bg-soft);
	color: var(--lde-text-muted);
	font-weight: 700;
	font-size: 13px;
	font-variant-numeric: tabular-nums;
}

/* Left/right accent bar marking qualification zones */
.lde-standings-table tbody tr {
	box-shadow: inset 4px 0 0 0 transparent;
}
.lde-standings-table tbody tr.lde-zone-champion         { box-shadow: inset 4px 0 0 0 var(--lde-zone-champion); }
.lde-standings-table tbody tr.lde-zone-continental      { box-shadow: inset 4px 0 0 0 var(--lde-zone-continental); }
.lde-standings-table tbody tr.lde-zone-continental-qual { box-shadow: inset 4px 0 0 0 var(--lde-zone-cont-qual); }
.lde-standings-table tbody tr.lde-zone-relegation       { box-shadow: inset 4px 0 0 0 var(--lde-zone-relegation); }

[dir="rtl"] .lde-standings-table tbody tr                           { box-shadow: inset -4px 0 0 0 transparent; }
[dir="rtl"] .lde-standings-table tbody tr.lde-zone-champion         { box-shadow: inset -4px 0 0 0 var(--lde-zone-champion); }
[dir="rtl"] .lde-standings-table tbody tr.lde-zone-continental      { box-shadow: inset -4px 0 0 0 var(--lde-zone-continental); }
[dir="rtl"] .lde-standings-table tbody tr.lde-zone-continental-qual { box-shadow: inset -4px 0 0 0 var(--lde-zone-cont-qual); }
[dir="rtl"] .lde-standings-table tbody tr.lde-zone-relegation       { box-shadow: inset -4px 0 0 0 var(--lde-zone-relegation); }

.lde-standings-table tr.lde-zone-champion .lde-pos-badge {
	background: var(--lde-zone-champion); color: #2a1d00;
}
.lde-standings-table tr.lde-zone-continental .lde-pos-badge,
.lde-standings-table tr.lde-zone-continental-qual .lde-pos-badge {
	background: rgba(11,128,67,.12); color: var(--lde-primary-dark);
}
.lde-standings-table tr.lde-zone-relegation .lde-pos-badge {
	background: rgba(220,38,38,.12); color: var(--lde-danger);
}

.lde-gd-pos { color: var(--lde-ok);     font-weight: 700; }
.lde-gd-neg { color: var(--lde-danger); font-weight: 700; }

.lde-zone-legend {
	list-style: none;
	margin: 12px 0 4px;
	padding: 10px 14px;
	display: flex;
	flex-wrap: wrap;
	gap: 14px 22px;
	font-size: 12.5px;
	color: var(--lde-text-muted);
	background: var(--lde-bg-soft);
	border-radius: var(--lde-radius-sm);
}
.lde-zone-legend li { display: flex; align-items: center; gap: 6px; }
.lde-zone-dot {
	display: inline-block;
	width: 10px; height: 10px;
	border-radius: 50%;
}
.lde-zone-dot.lde-zone-champion    { background: var(--lde-zone-champion); }
.lde-zone-dot.lde-zone-continental { background: var(--lde-zone-continental); }
.lde-zone-dot.lde-zone-relegation  { background: var(--lde-zone-relegation); }

/* =========================================================================
 * 6. Top scorers
 * ========================================================================= */
.lde-scorers-table .lde-rank-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: var(--lde-bg-soft);
	color: var(--lde-text-muted);
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}
.lde-scorers-table tr.lde-rank-gold   .lde-rank-badge { background: #f4b400; color: #2a1d00; box-shadow: 0 0 0 3px rgba(244,180,0,.18); }
.lde-scorers-table tr.lde-rank-silver .lde-rank-badge { background: #c0c5ce; color: #1f2937; }
.lde-scorers-table tr.lde-rank-bronze .lde-rank-badge { background: #c97a35; color: #fff; }

.lde-goal-pill {
	display: inline-block;
	min-width: 36px;
	padding: 5px 12px;
	border-radius: 999px;
	background: linear-gradient(135deg, #ff6b35 0%, #f54952 100%);
	color: #fff;
	font-weight: 800;
	font-size: 14px;
	box-shadow: 0 2px 8px rgba(245,73,82,.25);
}

.lde-player-photo-sm {
	width: 36px !important;
	height: 36px !important;
	border-radius: 50%;
	object-fit: cover;
	margin-inline-end: 10px;
	background: var(--lde-bg-soft);
	vertical-align: middle;
}
.lde-photo-fallback {
	display: inline-block;
	background: var(--lde-bg-soft)
	            url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2394a3b8'><path d='M12 12a4 4 0 100-8 4 4 0 000 8zm0 2c-3.3 0-8 1.7-8 5v1h16v-1c0-3.3-4.7-5-8-5z'/></svg>")
	            center/60% no-repeat;
}

/* =========================================================================
 * 7. Cards (club / player)
 * ========================================================================= */
.lde-club-card,
.lde-player-card {
	background: var(--lde-surface);
	border: 1px solid var(--lde-border);
	border-radius: var(--lde-radius);
	padding: 18px;
	margin: 16px 0;
	box-shadow: var(--lde-shadow-sm);
	transition: box-shadow .2s, transform .2s;
}
.lde-club-card:hover,
.lde-player-card:hover { box-shadow: var(--lde-shadow); transform: translateY(-2px); }

.lde-club-card-head,
.lde-player-card-head {
	display: flex;
	gap: 16px;
	align-items: center;
	margin-bottom: 14px;
	padding-bottom: 12px;
	border-bottom: 3px solid var(--lde-club-color, var(--lde-primary));
}
.lde-club-card-title h3,
.lde-player-card-title h3 {
	margin: 0;
	font-size: 1.25em;
	font-weight: 800;
}
.lde-club-card-title a,
.lde-player-card-title a { text-decoration: none; color: inherit; }

.lde-club-meta,
.lde-player-meta {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 8px 16px;
	margin: 0;
}
.lde-club-meta dt,
.lde-player-meta dt { color: var(--lde-text-muted); font-size: .88em; font-weight: 500; }
.lde-club-meta dd,
.lde-player-meta dd { margin: 0; font-weight: 600; color: var(--lde-text); }

/* =========================================================================
 * 8. Squad grid
 * ========================================================================= */
.lde-club-squad h3 { margin-bottom: 8px; font-weight: 800; }
.lde-squad-bucket { margin: 18px 0; }
.lde-squad-bucket h4 {
	margin: 8px 0;
	font-size: 1em;
	color: var(--lde-text);
	font-weight: 700;
	padding-inline-start: 10px;
	border-inline-start: 4px solid var(--lde-primary);
}
.lde-squad-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.lde-player-tile {
	background: var(--lde-surface);
	border: 1px solid var(--lde-border);
	border-radius: var(--lde-radius-sm);
	padding: 12px;
	display: flex;
	gap: 12px;
	align-items: center;
	transition: border-color .15s, transform .15s, box-shadow .15s;
}
.lde-player-tile:hover {
	border-color: var(--lde-primary);
	transform: translateY(-2px);
	box-shadow: var(--lde-shadow);
}
.lde-player-photo {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	object-fit: cover;
	background: var(--lde-bg-soft);
	flex: 0 0 52px;
}
.lde-player-photo-lg { width: 128px; height: 128px; }
.lde-player-tile-info { display: flex; flex-direction: column; gap: 3px; font-size: .95em; min-width: 0; }
.lde-player-tile-info a { text-decoration: none; color: var(--lde-text); font-weight: 700; }
.lde-player-tile-info a:hover { color: var(--lde-primary); }
.lde-player-tile-info .lde-shirt {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 24px; height: 24px;
	padding: 0 6px;
	border-radius: 4px;
	background: var(--lde-bg-soft);
	color: var(--lde-text-muted);
	font-size: .78em;
	font-weight: 700;
	width: fit-content;
}

/* =========================================================================
 * 9. Single-club hero
 * ========================================================================= */
.lde-club-hero {
	position: relative;
	background: linear-gradient(135deg, var(--lde-club-color, var(--lde-navy)) 0%, #000 100%);
	border-radius: var(--lde-radius-lg);
	overflow: hidden;
	margin-bottom: 18px;
	min-height: 220px;
	box-shadow: var(--lde-shadow-lg);
}
.lde-club-cover {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	opacity: .35;
	z-index: 0;
}
.lde-club-hero-body {
	position: relative; z-index: 1;
	padding: 32px 28px;
	display: flex;
	align-items: center;
	gap: 22px;
	color: #fff;
	text-shadow: 0 2px 6px rgba(0,0,0,.5);
}
.lde-club-hero-body .lde-club-logo-xl {
	background: rgba(255,255,255,.95);
	border-radius: 12px;
	padding: 8px;
	box-shadow: 0 8px 24px rgba(0,0,0,.3);
}
.lde-club-hero-body .entry-title {
	margin: 0;
	color: #fff;
	font-size: 2em;
	font-weight: 800;
	letter-spacing: -.01em;
}

/* =========================================================================
 * 10. News list
 * ========================================================================= */
.lde-news-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 12px;
}
.lde-news-item {
	background: var(--lde-surface);
	border: 1px solid var(--lde-border);
	border-radius: var(--lde-radius-sm);
	overflow: hidden;
	transition: transform .15s, box-shadow .15s;
}
.lde-news-item:hover { transform: translateY(-2px); box-shadow: var(--lde-shadow); }
.lde-news-link {
	display: flex;
	gap: 12px;
	align-items: center;
	padding: 10px;
	text-decoration: none;
	color: inherit;
}
.lde-news-thumb {
	width: 72px;
	height: 72px;
	object-fit: cover;
	border-radius: var(--lde-radius-sm);
	flex: 0 0 72px;
}
.lde-news-body { display: flex; flex-direction: column; gap: 4px; font-size: .93em; min-width: 0; }
.lde-news-title {
	font-weight: 700;
	line-height: 1.4;
	color: var(--lde-text);
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
.lde-news-body time { color: var(--lde-text-muted); font-size: .85em; }

/* =========================================================================
 * 11. Misc / single pages
 * ========================================================================= */
.lde-single .entry-title { margin: .2em 0; font-weight: 800; }
.lde-en-name { color: var(--lde-text-muted); margin: .1em 0 1em; font-size: .95em; }
.lde-club-section,
.lde-player-section { margin: 22px 0; }
.lde-comp-list {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: 8px;
}
.lde-comp-list li {
	background: var(--lde-surface);
	border: 1px solid var(--lde-border);
	border-radius: 999px;
	padding: 5px 14px;
	font-size: .9em;
	font-weight: 500;
	transition: border-color .15s, color .15s;
}
.lde-comp-list li:hover { border-color: var(--lde-primary); color: var(--lde-primary); }
.lde-comp-list a { text-decoration: none; color: inherit; }

/* =========================================================================
 * 12. Mobile
 * ========================================================================= */
@media (max-width: 720px) {
	.lde-club-hero-body  { flex-direction: column; text-align: center; padding: 24px 16px; }
	.lde-club-hero-body .entry-title { font-size: 1.5em; }
	.lde-data-table      { font-size: 13px; }
	.lde-data-table th,
	.lde-data-table td   { padding: 9px 5px; }
	.lde-data-table .lde-club,
	.lde-data-table .lde-player { min-width: 130px; }
	.lde-club-logo       { width: 22px; height: 22px; margin-inline-end: 6px; }
	.lde-player-photo-sm { width: 30px !important; height: 30px !important; }
	.lde-table-head      { padding: 12px 14px; border-radius: var(--lde-radius-sm) var(--lde-radius-sm) 0 0; }
	.lde-table-head h3   { font-size: 1em; }
}
