/**
 * Cleatz Golf Widget — frontend styles
 * Scoped under .cleatz-golf-widget so nothing bleeds into the host site.
 */

.cleatz-golf-widget {
	/* Tokens */
	--cgw-bg: #ffffff;
	--cgw-bg-alt: #f6f7f9;
	--cgw-bg-row-hover: #f1f5f9;
	--cgw-border: #e5e7eb;
	--cgw-border-strong: #d1d5db;
	--cgw-text: #111827;
	--cgw-text-muted: #6b7280;
	--cgw-text-soft: #9ca3af;
	--cgw-accent: #0f3a3a;
	--cgw-accent-soft: #ecfdf5;
	--cgw-live: #dc2626;
	--cgw-live-soft: #fef2f2;
	--cgw-pre: #475569;
	--cgw-pre-soft: #f1f5f9;
	--cgw-positive: #059669;
	--cgw-negative: #dc2626;
	--cgw-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 4px 12px rgba(15, 23, 42, 0.04);
	--cgw-radius: 10px;
	--cgw-radius-sm: 6px;
	--cgw-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;
	--cgw-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

	font-family: var(--cgw-sans);
	color: var(--cgw-text);
	background: var(--cgw-bg);
	border: 1px solid var(--cgw-border);
	border-radius: var(--cgw-radius);
	box-shadow: var(--cgw-shadow);
	overflow: hidden;
	margin: 1.5em 0;
	-webkit-font-smoothing: antialiased;
	box-sizing: border-box;
}

.cleatz-golf-widget *,
.cleatz-golf-widget *::before,
.cleatz-golf-widget *::after {
	box-sizing: border-box;
}

/* ============================================================
 * Loading state
 * ========================================================== */

.cleatz-golf-widget .cgw-loading {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 24px 20px;
	color: var(--cgw-text-muted);
	font-size: 14px;
}

.cleatz-golf-widget .cgw-loading__spinner {
	width: 16px;
	height: 16px;
	border: 2px solid var(--cgw-border);
	border-top-color: var(--cgw-accent);
	border-radius: 50%;
	animation: cgw-spin 0.7s linear infinite;
}

@keyframes cgw-spin {
	to { transform: rotate(360deg); }
}

.cleatz-golf-widget .cgw-noscript {
	padding: 16px 20px;
	color: var(--cgw-text-muted);
	font-size: 14px;
}

/* ============================================================
 * Error state
 * ========================================================== */

.cleatz-golf-widget .cgw-error {
	padding: 20px;
	background: var(--cgw-live-soft);
	color: var(--cgw-live);
	font-size: 14px;
	line-height: 1.5;
}

/* ============================================================
 * Header
 * ========================================================== */

.cleatz-golf-widget .cgw-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	padding: 16px 20px;
	border-bottom: 1px solid var(--cgw-border);
	background: var(--cgw-bg);
}

.cleatz-golf-widget .cgw-header__title {
	min-width: 0;
}

.cleatz-golf-widget .cgw-header__event {
	font-size: 17px;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--cgw-text);
	margin: 0 0 4px;
	line-height: 1.2;
}

.cleatz-golf-widget .cgw-header__meta {
	font-size: 13px;
	color: var(--cgw-text-muted);
	line-height: 1.4;
}

.cleatz-golf-widget .cgw-header__meta-sep {
	display: inline-block;
	margin: 0 6px;
	color: var(--cgw-text-soft);
}

.cleatz-golf-widget .cgw-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	white-space: nowrap;
	flex-shrink: 0;
}

.cleatz-golf-widget .cgw-pill--live {
	background: var(--cgw-live-soft);
	color: var(--cgw-live);
}

.cleatz-golf-widget .cgw-pill--live::before {
	content: "";
	display: inline-block;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--cgw-live);
	animation: cgw-pulse 1.6s ease-in-out infinite;
}

@keyframes cgw-pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.35; }
}

.cleatz-golf-widget .cgw-pill--pre {
	background: var(--cgw-pre-soft);
	color: var(--cgw-pre);
}

/* ============================================================
 * AI narrative (Phase 2 / v3.3 multi-section)
 * Sits between the header and the leaderboard. 3 stacked sections,
 * each with a small uppercase label and 50-80 words of prose.
 * ========================================================== */

.cleatz-golf-widget .cgw-narrative {
	padding: 18px 20px 14px;
	border-bottom: 1px solid var(--cgw-border);
	background: var(--cgw-bg);
}

.cleatz-golf-widget .cgw-narrative__section {
	padding-top: 12px;
	margin-top: 12px;
	border-top: 1px dashed var(--cgw-border);
}

.cleatz-golf-widget .cgw-narrative__section:first-child {
	padding-top: 0;
	margin-top: 0;
	border-top: 0;
}

.cleatz-golf-widget .cgw-narrative__label {
	font-size: 11px;
	font-weight: 700;
	color: var(--cgw-accent);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin: 0 0 6px;
}

.cleatz-golf-widget .cgw-narrative__p {
	margin: 0 0 8px;
	font-size: 14.5px;
	line-height: 1.55;
	color: var(--cgw-text);
	font-family: var(--cgw-sans);
}

.cleatz-golf-widget .cgw-narrative__section .cgw-narrative__p:last-of-type {
	margin-bottom: 0;
}

.cleatz-golf-widget .cgw-narrative__attr {
	font-size: 10.5px;
	color: var(--cgw-text-soft);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin-top: 14px;
	padding-top: 10px;
	border-top: 1px solid var(--cgw-border);
}

/* ============================================================
 * Leaderboard table (live state)
 * ========================================================== */

.cleatz-golf-widget .cgw-table-wrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.cleatz-golf-widget .cgw-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
	background: var(--cgw-bg);
}

.cleatz-golf-widget .cgw-table thead th {
	background: var(--cgw-bg-alt);
	color: var(--cgw-text-muted);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 9px 12px;
	text-align: right;
	border-bottom: 1px solid var(--cgw-border);
	white-space: nowrap;
}

.cleatz-golf-widget .cgw-table thead th.cgw-th-pos,
.cleatz-golf-widget .cgw-table thead th.cgw-th-player {
	text-align: left;
}

.cleatz-golf-widget .cgw-table tbody td {
	padding: 10px 12px;
	border-bottom: 1px solid var(--cgw-border);
	text-align: right;
	white-space: nowrap;
	font-variant-numeric: tabular-nums;
	font-family: var(--cgw-mono);
}

.cleatz-golf-widget .cgw-table tbody tr:last-child td {
	border-bottom: 0;
}

.cleatz-golf-widget .cgw-table tbody tr:hover td {
	background: var(--cgw-bg-row-hover);
}

.cleatz-golf-widget .cgw-table .cgw-td-pos {
	text-align: left;
	color: var(--cgw-text-muted);
	font-weight: 600;
	width: 1%;
	padding-left: 20px;
}

.cleatz-golf-widget .cgw-table .cgw-td-player {
	text-align: left;
	font-family: var(--cgw-sans);
	font-weight: 600;
	color: var(--cgw-text);
}

.cleatz-golf-widget .cgw-table .cgw-td-score {
	font-weight: 700;
	color: var(--cgw-text);
}

.cleatz-golf-widget .cgw-table .cgw-td-score--negative {
	color: var(--cgw-negative);
}

.cleatz-golf-widget .cgw-table .cgw-td-score--positive {
	color: var(--cgw-text);
}

.cleatz-golf-widget .cgw-table .cgw-td-thru {
	color: var(--cgw-text-muted);
}

.cleatz-golf-widget .cgw-table .cgw-td-today--negative {
	color: var(--cgw-negative);
}

.cleatz-golf-widget .cgw-table .cgw-td-win {
	font-weight: 600;
	color: var(--cgw-text);
}

.cleatz-golf-widget .cgw-table .cgw-td-odds {
	color: var(--cgw-accent);
	font-weight: 600;
	padding-right: 20px;
}

.cleatz-golf-widget .cgw-table .cgw-td-odds--empty {
	color: var(--cgw-text-soft);
	font-weight: 400;
}

/* ============================================================
 * Kalshi column (Phase 3)
 * Brighter green than the teal accent so it reads as a separate
 * data source — Kalshi-brand-adjacent without copying the logo color.
 * ========================================================== */

.cleatz-golf-widget {
	--cgw-kalshi: #00a86b;
	--cgw-kalshi-soft: #e6f7ef;
	--cgw-poly: #2D9CDB;
	--cgw-poly-soft: #e7f3fb;
}

.cleatz-golf-widget .cgw-table .cgw-th-kalshi {
	color: var(--cgw-kalshi);
}

.cleatz-golf-widget .cgw-table .cgw-td-kalshi {
	color: var(--cgw-kalshi);
	font-weight: 700;
}

.cleatz-golf-widget .cgw-table .cgw-td-kalshi--empty {
	color: var(--cgw-text-soft);
	font-weight: 400;
}

.cleatz-golf-widget .cgw-table .cgw-th-poly {
	color: var(--cgw-poly);
}

.cleatz-golf-widget .cgw-table .cgw-td-poly {
	color: var(--cgw-poly);
	font-weight: 700;
}

.cleatz-golf-widget .cgw-table .cgw-td-poly--empty {
	color: var(--cgw-text-soft);
	font-weight: 400;
}

/* ============================================================
 * Trade CTAs — two-tile row above the event header.
 * Each tile is a single clickable card with brand color, heading,
 * tagline, and a "Trade on X →" affordance. On mobile, tiles stack.
 * ========================================================== */
.cleatz-golf-widget .cgw-ctas {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	padding: 16px 20px 0;
}

.cleatz-golf-widget .cgw-cta-tile {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 16px;
	border-radius: var(--cgw-radius-md);
	text-decoration: none;
	transition: transform 0.12s ease, box-shadow 0.12s ease, filter 0.12s ease;
	color: #fff;
	min-height: 64px;
}

.cleatz-golf-widget .cgw-cta-tile:hover,
.cleatz-golf-widget .cgw-cta-tile:focus {
	text-decoration: none;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
	filter: brightness(1.05);
	color: #fff;
}

.cleatz-golf-widget .cgw-cta-tile--kalshi {
	background: linear-gradient(135deg, var(--cgw-kalshi) 0%, #00875a 100%);
}

.cleatz-golf-widget .cgw-cta-tile--poly {
	background: linear-gradient(135deg, var(--cgw-poly) 0%, #1d7bb8 100%);
}

.cleatz-golf-widget .cgw-cta-tile__body {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0; /* let flex children shrink */
}

.cleatz-golf-widget .cgw-cta-tile__head {
	display: flex;
	align-items: center;
	gap: 8px;
}

.cleatz-golf-widget .cgw-cta-tile__heading {
	font-size: 15px;
	font-weight: 800;
	letter-spacing: 0.01em;
	color: #fff;
}

.cleatz-golf-widget .cgw-cta-tile__live {
	display: inline-block;
	padding: 2px 6px;
	background: rgba(255, 255, 255, 0.22);
	color: #fff;
	font-size: 9px;
	font-weight: 700;
	letter-spacing: 0.08em;
	border-radius: 3px;
	text-transform: uppercase;
}

.cleatz-golf-widget .cgw-cta-tile__tagline {
	font-size: 11px;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.85);
	letter-spacing: 0.01em;
}

.cleatz-golf-widget .cgw-cta-tile__arrow {
	font-size: 12px;
	font-weight: 700;
	color: #fff;
	white-space: nowrap;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	flex-shrink: 0;
}

/* ============================================================
 * Pre-tournament probability table
 * Same shell as live, different columns. Win column gets the
 * accent color treatment (like odds in live state).
 * ========================================================== */

.cleatz-golf-widget .cgw-table .cgw-td-mc,
.cleatz-golf-widget .cgw-table .cgw-td-t20,
.cleatz-golf-widget .cgw-table .cgw-td-t10,
.cleatz-golf-widget .cgw-table .cgw-td-t5 {
	color: var(--cgw-text);
	font-weight: 600;
}

.cleatz-golf-widget .cgw-table .cgw-td-win-pre {
	color: var(--cgw-accent);
	font-weight: 700;
	padding-right: 20px;
}

.cleatz-golf-widget .cgw-table .cgw-td-empty {
	color: var(--cgw-text-soft);
	font-weight: 400;
}

/* Unranked rows (in the field but no model probability published yet)
   get a softer treatment so the ranked block reads as the leaderboard. */
.cleatz-golf-widget .cgw-table tbody tr.cgw-row--unranked td {
	color: var(--cgw-text-muted);
	background: var(--cgw-bg-alt);
}
.cleatz-golf-widget .cgw-table tbody tr.cgw-row--unranked .cgw-td-player {
	color: var(--cgw-text-muted);
	font-weight: 500;
}
.cleatz-golf-widget .cgw-table tbody tr.cgw-row--unranked:hover td {
	background: var(--cgw-bg-row-hover);
}

/* Top 5 highlight — subtle treatment so leaders pop */
.cleatz-golf-widget .cgw-table tbody tr.cgw-row--leader td {
	background: var(--cgw-accent-soft);
}
.cleatz-golf-widget .cgw-table tbody tr.cgw-row--leader:hover td {
	background: #d1fae5;
}
.cleatz-golf-widget .cgw-table tbody tr.cgw-row--leader .cgw-td-pos {
	color: var(--cgw-accent);
}

/* ============================================================
 * Footer
 * ========================================================== */

.cleatz-golf-widget .cgw-footer {
	display: flex;
	flex-wrap: wrap;
	gap: 4px 12px;
	padding: 10px 20px;
	font-size: 11px;
	color: var(--cgw-text-soft);
	border-top: 1px solid var(--cgw-border);
	background: var(--cgw-bg-alt);
	letter-spacing: 0.02em;
}

.cleatz-golf-widget .cgw-footer__item {
	display: inline-flex;
	align-items: center;
	gap: 4px;
}

.cleatz-golf-widget .cgw-footer__sep {
	color: var(--cgw-border-strong);
}

/* ============================================================
 * Pre-tournament card
 * ========================================================== */

.cleatz-golf-widget .cgw-pre-card {
	padding: 24px 20px;
}

.cleatz-golf-widget .cgw-pre-card__lead {
	color: var(--cgw-text-muted);
	font-size: 14px;
	line-height: 1.5;
}

.cleatz-golf-widget .cgw-pre-card__stats {
	display: flex;
	flex-wrap: wrap;
	gap: 24px;
}

/* Top divider only when there's a lead paragraph above (i.e. no AI snippet). */
.cleatz-golf-widget .cgw-pre-card__lead + .cgw-pre-card__stats {
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid var(--cgw-border);
}

.cleatz-golf-widget .cgw-stat__label {
	font-size: 11px;
	color: var(--cgw-text-muted);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin-bottom: 4px;
}

.cleatz-golf-widget .cgw-stat__value {
	font-size: 18px;
	font-weight: 700;
	color: var(--cgw-text);
	line-height: 1.2;
}

.cleatz-golf-widget .cgw-pre-field {
	border-top: 1px solid var(--cgw-border);
	padding: 16px 20px;
}

.cleatz-golf-widget .cgw-pre-field__title {
	font-size: 11px;
	font-weight: 600;
	color: var(--cgw-text-muted);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin-bottom: 10px;
}

.cleatz-golf-widget .cgw-pre-field__list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 4px 16px;
	font-size: 13px;
	color: var(--cgw-text);
	margin: 0;
	padding: 0;
	list-style: none;
}

.cleatz-golf-widget .cgw-pre-field__item {
	padding: 3px 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cleatz-golf-widget .cgw-pre-field__toggle {
	background: transparent;
	border: 0;
	padding: 8px 0 0;
	margin-top: 8px;
	color: var(--cgw-accent);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	font-family: inherit;
}

.cleatz-golf-widget .cgw-pre-field__toggle:hover {
	text-decoration: underline;
}

/* ============================================================
 * Mobile
 * ========================================================== */

@media (max-width: 540px) {
	.cleatz-golf-widget .cgw-header {
		padding: 14px 14px;
	}
	.cleatz-golf-widget .cgw-header__event {
		font-size: 15px;
	}
	.cleatz-golf-widget .cgw-table thead th,
	.cleatz-golf-widget .cgw-table tbody td {
		padding: 9px 8px;
		font-size: 13px;
	}
	.cleatz-golf-widget .cgw-table .cgw-td-pos {
		padding-left: 14px;
	}
	.cleatz-golf-widget .cgw-table .cgw-td-odds {
		padding-right: 14px;
	}
	/* Hide today column to make room — total score is the headline number */
	.cleatz-golf-widget .cgw-table .cgw-th-today,
	.cleatz-golf-widget .cgw-table .cgw-td-today {
		display: none;
	}
	/* Pre-tournament: drop Make Cut and Top 20 first (lowest priority) */
	.cleatz-golf-widget .cgw-table .cgw-th-mc,
	.cleatz-golf-widget .cgw-table .cgw-td-mc,
	.cleatz-golf-widget .cgw-table .cgw-th-t20,
	.cleatz-golf-widget .cgw-table .cgw-td-t20 {
		display: none;
	}
	.cleatz-golf-widget .cgw-footer {
		padding: 10px 14px;
		font-size: 10px;
	}
	/* Drop bet365 opening odds on mobile so Kalshi/Poly (more dynamic) survive */
	.cleatz-golf-widget .cgw-table .cgw-th-odds,
	.cleatz-golf-widget .cgw-table .cgw-td-odds {
		display: none;
	}
	/* Stack CTA tiles vertically on mobile */
	.cleatz-golf-widget .cgw-ctas {
		grid-template-columns: 1fr;
		gap: 8px;
		padding: 12px 14px 0;
	}
	.cleatz-golf-widget .cgw-cta-tile {
		padding: 12px 14px;
		min-height: 56px;
	}
	.cleatz-golf-widget .cgw-cta-tile__heading {
		font-size: 14px;
	}
	.cleatz-golf-widget .cgw-cta-tile__tagline {
		font-size: 10px;
	}
	.cleatz-golf-widget .cgw-cta-tile__arrow {
		font-size: 11px;
	}
	.cleatz-golf-widget .cgw-pre-card,
	.cleatz-golf-widget .cgw-pre-field {
		padding: 16px 14px;
	}
	.cleatz-golf-widget .cgw-narrative {
		padding: 14px 14px 12px;
	}
	.cleatz-golf-widget .cgw-narrative__p {
		font-size: 14px;
	}
}

@media (max-width: 380px) {
	/* Drop win% on very narrow screens */
	.cleatz-golf-widget .cgw-table .cgw-th-win,
	.cleatz-golf-widget .cgw-table .cgw-td-win {
		display: none;
	}
	/* Pre-tournament: also drop Top 10 — leave Pos / Player / Top 5 / Win */
	.cleatz-golf-widget .cgw-table .cgw-th-t10,
	.cleatz-golf-widget .cgw-table .cgw-td-t10 {
		display: none;
	}
	/* Drop Poly column on very narrow screens (Kalshi stays since it's
	   typically higher-volume and more granular per-player). The CTA
	   tile still surfaces Polymarket for the trade prompt. */
	.cleatz-golf-widget .cgw-table .cgw-th-poly,
	.cleatz-golf-widget .cgw-table .cgw-td-poly {
		display: none;
	}
}

/* ============================================================
 * Reduced motion
 * ========================================================== */

@media (prefers-reduced-motion: reduce) {
	.cleatz-golf-widget .cgw-loading__spinner,
	.cleatz-golf-widget .cgw-pill--live::before {
		animation: none;
	}
}
