/* PhilPress PCSO Lotto Results — frontend styles */

:root {
	--pcso-accent: #1a56a0;
	--pcso-accent-soft: rgba(26, 86, 160, 0.08);
	--pcso-radius: 10px;
	--pcso-shadow: 0 1px 3px rgba(15, 23, 42, 0.08), 0 1px 2px rgba(15, 23, 42, 0.04);
	--pcso-border: #e5e7eb;
	--pcso-muted: #64748b;
	--pcso-bg: #ffffff;
}

.pcso-container {
	max-width: 1160px;
	margin: 0 auto;
	padding: 24px 16px 64px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 32px;
}

@media (max-width: 900px) {
	.pcso-container { grid-template-columns: 1fr; }
}

/* --- Breadcrumbs --- */
.pcso-breadcrumbs ol {
	list-style: none;
	margin: 0 0 18px;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	font-size: 13px;
	color: var(--pcso-muted);
}
.pcso-breadcrumbs li + li::before {
	content: "›";
	margin-right: 6px;
	opacity: 0.6;
}
.pcso-breadcrumbs a {
	color: var(--pcso-accent);
	text-decoration: none;
}
.pcso-breadcrumbs a:hover { text-decoration: underline; }

/* --- Single header --- */
.pcso-single__header {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding-bottom: 18px;
	margin-bottom: 24px;
	border-bottom: 1px solid var(--pcso-border);
}
.pcso-single__badge {
	display: inline-block;
	background: var(--pcso-accent);
	color: #fff;
	font-weight: 700;
	font-size: 13px;
	padding: 6px 10px;
	border-radius: 999px;
	letter-spacing: 0.02em;
	flex-shrink: 0;
}
.pcso-single__title {
	font-size: 30px;
	line-height: 1.2;
	margin: 0 0 6px;
	color: #0f172a;
}
.pcso-single__meta {
	color: var(--pcso-muted);
	font-size: 14px;
	margin: 0;
}

/* --- Balls --- */
.pcso-balls {
	list-style: none;
	padding: 0;
	margin: 16px 0;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}
.pcso-ball {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background: linear-gradient(180deg, #ffffff 0%, #f1f5f9 100%);
	border: 2px solid var(--pcso-accent);
	color: #0f172a;
	font-weight: 800;
	font-size: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: inset 0 -3px 0 rgba(0, 0, 0, 0.05), 0 1px 2px rgba(0, 0, 0, 0.06);
}
.pcso-balls--sm .pcso-ball {
	width: 36px;
	height: 36px;
	font-size: 14px;
	border-width: 1.5px;
}
.pcso-ordered {
	font-size: 14px;
	color: var(--pcso-muted);
}

/* --- Summary table --- */
.pcso-summary-table {
	width: 100%;
	border-collapse: collapse;
	margin: 18px 0 24px;
	background: #fff;
	border: 1px solid var(--pcso-border);
	border-radius: var(--pcso-radius);
	overflow: hidden;
	font-size: 15px;
}
.pcso-summary-table th,
.pcso-summary-table td {
	padding: 12px 14px;
	text-align: left;
	border-bottom: 1px solid var(--pcso-border);
}
.pcso-summary-table th {
	background: var(--pcso-accent-soft);
	width: 40%;
	color: #0f172a;
	font-weight: 600;
}
.pcso-summary-table tr:last-child th,
.pcso-summary-table tr:last-child td { border-bottom: 0; }

/* --- Jackpot box --- */
.pcso-jackpot-box {
	background: linear-gradient(135deg, var(--pcso-accent) 0%, #0f3d82 100%);
	color: #fff;
	padding: 24px;
	border-radius: var(--pcso-radius);
	text-align: center;
	margin: 18px 0 28px;
	box-shadow: var(--pcso-shadow);
}
.pcso-jackpot-label {
	text-transform: uppercase;
	font-size: 12px;
	letter-spacing: 0.08em;
	opacity: 0.9;
	margin-bottom: 6px;
}
.pcso-jackpot-amount {
	font-size: 34px;
	font-weight: 800;
}
.pcso-jackpot-winners {
	margin-top: 8px;
	opacity: 0.9;
	font-size: 14px;
}

/* --- FAQ --- */
.pcso-faq-item {
	background: #fff;
	border: 1px solid var(--pcso-border);
	border-radius: var(--pcso-radius);
	padding: 14px 16px;
	margin-bottom: 10px;
}
.pcso-faq-item summary {
	font-weight: 600;
	cursor: pointer;
	color: #0f172a;
}
.pcso-faq-item[open] summary { margin-bottom: 6px; }

/* --- Related --- */
.pcso-related-list,
.pcso-sibling-list {
	list-style: none;
	padding: 0;
	margin: 10px 0 22px;
}
.pcso-related-list li,
.pcso-sibling-list li {
	padding: 8px 0;
	border-bottom: 1px dashed var(--pcso-border);
}
.pcso-view-all {
	display: inline-block;
	margin: 6px 0 18px;
	font-weight: 600;
	color: var(--pcso-accent);
	text-decoration: none;
}
.pcso-view-all:hover { text-decoration: underline; }

/* --- Disclaimer --- */
.pcso-disclaimer {
	background: #fef3c7;
	border-left: 4px solid #f59e0b;
	padding: 12px 16px;
	border-radius: 6px;
	color: #78350f;
	font-size: 14px;
}
.pcso-updated {
	color: var(--pcso-muted);
	font-size: 13px;
	margin-top: 24px;
}

/* --- Archive / grid --- */
.pcso-archive__header {
	margin-bottom: 28px;
	padding-bottom: 20px;
	border-bottom: 2px solid var(--pcso-accent);
}
.pcso-archive__title {
	font-size: 32px;
	margin: 8px 0 8px;
	color: #0f172a;
}
.pcso-archive__description {
	color: var(--pcso-muted);
	font-size: 15px;
	margin: 0;
}
.pcso-archive__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 18px;
	margin-bottom: 28px;
}
.pcso-card,
.pcso-game-card {
	background: #fff;
	border: 1px solid var(--pcso-border);
	border-radius: var(--pcso-radius);
	/* Defer rendering of off-screen cards in long grids/lists. */
	content-visibility: auto;
	contain-intrinsic-size: 240px 320px;
	padding: 16px;
	box-shadow: var(--pcso-shadow);
	border-top: 3px solid var(--pcso-accent);
	transition: transform 120ms ease, box-shadow 120ms ease;
}
.pcso-card:hover,
.pcso-game-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 16px rgba(15, 23, 42, 0.08);
}
.pcso-card__head,
.pcso-game-card__head {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 8px;
}
.pcso-card__badge,
.pcso-game-card__badge {
	background: var(--pcso-accent);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	padding: 3px 8px;
	border-radius: 999px;
	letter-spacing: 0.02em;
}
.pcso-card__title,
.pcso-game-card__title {
	margin: 0;
	font-size: 16px;
	line-height: 1.3;
	color: #0f172a;
}
.pcso-card__titlelink { text-decoration: none; color: inherit; }
.pcso-card__meta,
.pcso-game-card__date {
	font-size: 13px;
	color: var(--pcso-muted);
	margin-bottom: 8px;
}
.pcso-card__jackpot,
.pcso-game-card__jackpot {
	margin-top: 8px;
	font-weight: 700;
	color: #16a34a;
	font-size: 15px;
}
.pcso-card__more,
.pcso-game-card__link {
	display: inline-block;
	margin-top: 8px;
	font-size: 13px;
	font-weight: 600;
	color: var(--pcso-accent);
	text-decoration: none;
}

/* --- Shortcode lists --- */
.pcso-latest-list {
	list-style: none;
	padding: 0;
	margin: 0;
	border: 1px solid var(--pcso-border);
	border-radius: var(--pcso-radius);
	overflow: hidden;
	background: #fff;
}
.pcso-latest-item {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	border-bottom: 1px solid var(--pcso-border);
	font-size: 14px;
}
.pcso-latest-item:last-child { border-bottom: 0; }
.pcso-badge {
	display: inline-block;
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	padding: 3px 8px;
	border-radius: 999px;
}
.pcso-latest-title { font-weight: 600; color: #0f172a; text-decoration: none; display: block; }
.pcso-latest-title:hover { color: var(--pcso-accent); }
.pcso-latest-date { display: block; font-size: 12px; color: var(--pcso-muted); }
.pcso-latest-numbers { font-weight: 700; color: #0f172a; white-space: nowrap; }

.pcso-archive-table {
	width: 100%;
	border-collapse: collapse;
	background: #fff;
	border: 1px solid var(--pcso-border);
	border-radius: var(--pcso-radius);
	overflow: hidden;
	font-size: 14px;
}
.pcso-archive-table th,
.pcso-archive-table td {
	padding: 10px 12px;
	text-align: left;
	border-bottom: 1px solid var(--pcso-border);
}
.pcso-archive-table thead th {
	background: var(--pcso-accent-soft);
	color: #0f172a;
}
.pcso-archive-table tr:last-child td { border-bottom: 0; }

/* --- All games grid --- */
.pcso-allgames-block { margin: 0; }
.pcso-allgames-block > .pcso-block-title { display: none; } /* heading is provided by theme section-header */
.pcso-allgames-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 16px;
}

/* --- Homepage PCSO section: matches editorial layout --- */
.home-pcso-section { padding: 40px 0; background: #f8fafc; }
.home-pcso-section .pcso-allgames-grid {
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 18px;
}
.home-pcso-section .pcso-game-card {
	padding: 14px 16px 16px;
	border-top-width: 4px;
	border-top-color: var(--pcso-accent);
}
.home-pcso-section .pcso-game-card__head {
	margin-bottom: 6px;
}
.home-pcso-section .pcso-game-card__title {
	font-size: 15px;
	font-weight: 700;
}
.home-pcso-section .pcso-game-card__date {
	font-size: 12px;
	margin-bottom: 10px;
}
.home-pcso-section .pcso-balls--sm { gap: 6px; margin: 6px 0 10px; }
.home-pcso-section .pcso-balls--sm .pcso-ball {
	width: 32px;
	height: 32px;
	font-size: 13px;
	border-color: var(--pcso-accent);
}
.home-pcso-section .pcso-game-card__jackpot {
	font-size: 14px;
	margin-top: 4px;
}
.home-pcso-section .pcso-game-card__link {
	margin-top: 6px;
	font-size: 12px;
}

/* --- Sidebar --- */
.pcso-sidebar {
	position: sticky;
	top: 90px;
	align-self: start;
	display: flex;
	flex-direction: column;
	gap: 20px;
}
@media (max-width: 900px) {
	.pcso-sidebar { position: static; }
}

.pcso-block-title {
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--pcso-muted);
	margin: 0 0 10px;
}
.pcso-empty {
	color: var(--pcso-muted);
	font-style: italic;
	padding: 16px;
	background: #f8fafc;
	border: 1px dashed var(--pcso-border);
	border-radius: var(--pcso-radius);
}

/* --- Pagination --- */
.pcso-pagination {
	text-align: center;
	margin-top: 28px;
	display: flex;
	gap: 6px;
	justify-content: center;
	flex-wrap: wrap;
}
.pcso-pagination .page-numbers {
	display: inline-block;
	padding: 7px 12px;
	border: 1px solid var(--pcso-border);
	border-radius: 6px;
	color: var(--pcso-accent);
	text-decoration: none;
	background: #fff;
	font-size: 14px;
}
.pcso-pagination .page-numbers.current {
	background: var(--pcso-accent);
	color: #fff;
	border-color: var(--pcso-accent);
}

/* --- Archive layout: header + game chips + sidebar widgets --- */
.pcso-archive-main { min-width: 0; }

.pcso-archive__header {
	background: #fff;
	border: 1px solid var(--pcso-border);
	border-top: 4px solid var(--pcso-accent);
	border-radius: var(--pcso-radius);
	padding: 24px 24px 22px;
	margin-bottom: 22px;
	box-shadow: var(--pcso-shadow);
}
.pcso-archive__header .pcso-breadcrumbs ol { margin-bottom: 10px; }
.pcso-archive__title {
	font-size: 30px;
	font-weight: 800;
	margin: 4px 0 10px;
	line-height: 1.15;
	color: #0f172a;
	border-bottom: none;
	padding-bottom: 0;
}
.pcso-archive__description {
	color: var(--pcso-muted);
	font-size: 15px;
	line-height: 1.55;
	margin: 0;
}

/* Game chips: pill-shaped quick-jumps */
.pcso-game-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0 0 22px;
	padding: 14px;
	background: #fff;
	border: 1px solid var(--pcso-border);
	border-radius: var(--pcso-radius);
}
.pcso-game-chip {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 12px 6px 6px;
	background: #f8fafc;
	border: 1px solid var(--pcso-border);
	border-radius: 999px;
	text-decoration: none;
	color: #0f172a;
	font-size: 13px;
	font-weight: 600;
	transition: transform 120ms ease, border-color 120ms ease, background 120ms ease;
}
.pcso-game-chip:hover {
	transform: translateY(-1px);
	border-color: var(--chip-color);
	background: #fff;
}
.pcso-game-chip__short {
	display: inline-block;
	min-width: 36px;
	text-align: center;
	background: var(--chip-color);
	color: #fff;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.02em;
	padding: 3px 8px;
	border-radius: 999px;
}
.pcso-game-chip__name { white-space: nowrap; }
@media (max-width: 600px) {
	.pcso-game-chip__name { display: none; }
	.pcso-game-chip { padding: 4px; }
}

/* Sidebar widgets */
.pcso-sidebar__widget {
	background: #fff;
	border: 1px solid var(--pcso-border);
	border-radius: var(--pcso-radius);
	padding: 18px;
	box-shadow: var(--pcso-shadow);
}
.pcso-sidebar__title {
	font-family: inherit;
	font-size: 16px;
	font-weight: 800;
	color: #0f172a;
	margin: 0 0 4px;
	padding-bottom: 8px;
	border-bottom: 2px solid var(--pcso-accent);
}
.pcso-sidebar__sub {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--pcso-muted);
	margin: 0 0 14px;
}
.pcso-sidebar__widget p {
	font-size: 14px;
	color: #334155;
	line-height: 1.55;
	margin: 0 0 10px;
}
.pcso-sidebar__widget p:last-child { margin-bottom: 0; }

/* In sidebar context, condense the all-games grid to a vertical stack */
.pcso-sidebar .pcso-allgames-grid {
	grid-template-columns: 1fr;
	gap: 10px;
}
.pcso-sidebar .pcso-game-card {
	padding: 12px 14px;
	border-top-width: 3px;
}
.pcso-sidebar .pcso-game-card__title { font-size: 14px; }
.pcso-sidebar .pcso-game-card__date { font-size: 12px; margin-bottom: 6px; }
.pcso-sidebar .pcso-balls--sm .pcso-ball {
	width: 28px;
	height: 28px;
	font-size: 12px;
	border-width: 1.5px;
}
.pcso-sidebar .pcso-game-card__jackpot { font-size: 13px; }
.pcso-sidebar .pcso-game-card__link { font-size: 12px; }

/* --- Tags --- */
.pcso-tags {
	margin-top: 28px;
	padding-top: 18px;
	border-top: 1px solid var(--pcso-border);
	font-size: 13px;
	color: var(--pcso-muted);
}
.pcso-tags a {
	display: inline-block;
	padding: 3px 9px;
	margin: 2px 4px 2px 0;
	background: #f1f5f9;
	border-radius: 999px;
	text-decoration: none;
	color: #334155;
	font-size: 12px;
}
.pcso-tags a:hover { background: var(--pcso-accent); color: #fff; }

/* --- Performance: respect reduced motion --- */
@media (prefers-reduced-motion: reduce) {
	.pcso-card, .pcso-game-card { transition: none; }
}
