/* ============================================================
   Casinos Directory Page Template
   
   Primary money page — wider 1280px container vs careers/contact
   (920px). Premium licences in 2-col grid, other licences in
   4-col grid. Hero pattern matches careers/contact (badge with
   pulse dot + horizontal stat ticker).
   
   No flag emojis — clean acronym-led typography matches the
   editorial brand voice and avoids the Anjouan/Mwali (both KM)
   and Kahnawake/Tobique (both CA) visual ambiguity.
   
   Font sizes follow theme baseline: body 14-15px, h2 22-26px,
   card acronyms 26px (premium) / 17px (other), headings weight 700.
   ============================================================ */

.gc-casinos {
	background: var(--gc-bg);
}

.gc-casinos__container {
	max-width: 1280px;
	margin: 0 auto;
	padding: 36px 32px 80px;
}

/* ============================================================
   HERO (matches careers/contact pattern)
   ============================================================ */

.gc-casinos__hero {
	background: var(--gc-bg);
	border-bottom: 0.5px solid var(--gc-border, #e5e7eb);
	position: relative;
	overflow: hidden;
}

.gc-casinos__hero::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 50%;
	height: 100%;
	background: radial-gradient(ellipse 60% 80% at 100% 50%, rgba(0, 198, 174, 0.05) 0%, transparent 60%);
	pointer-events: none;
}

.gc-casinos__hero-content {
	max-width: 1280px;
	margin: 0 auto;
	padding: 56px 32px 36px;
	position: relative;
	z-index: 1;
}

.gc-casinos__hero-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 5px 14px;
	background: var(--gc-primary-soft, #E6FAF7);
	border: 0.5px solid rgba(0, 198, 174, .3);
	color: var(--gc-primary-dark, #00A894);
	border-radius: 999px;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.4px;
	text-transform: uppercase;
	margin-bottom: 22px;
}

.gc-casinos__hero-badge-dot {
	width: 6px;
	height: 6px;
	background: #00A894;
	border-radius: 50%;
	flex-shrink: 0;
	animation: gc-casinos-pulse 2s ease-in-out infinite;
}

@keyframes gc-casinos-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%      { opacity: 0.5; transform: scale(0.85); }
}

.gc-casinos__hero-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: clamp(32px, 4.5vw, 44px);
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.025em;
	line-height: 1.1;
	margin: 0 0 16px;
	max-width: 720px;
}

.gc-casinos__hero-accent {
	color: var(--gc-primary, #00C6AE);
}

.gc-casinos__hero-sub {
	font-size: 17px;
	line-height: 1.7;
	color: var(--gc-muted, #6b7280);
	max-width: 720px;
	margin: 0 0 22px;
}

.gc-casinos__hero-trust {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 9px 14px;
	background: rgba(13, 27, 62, 0.04);
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 8px;
	font-size: 13px;
	color: var(--gc-navy, #0D1B3E);
	font-weight: 500;
}

.gc-casinos__hero-trust svg {
	color: var(--gc-primary-dark, #00A894);
	flex-shrink: 0;
}

/* ===== Hero ticker ===== */

.gc-casinos__hero-ticker {
	background: var(--gc-bg-soft);
	border-top: 0.5px solid var(--gc-border, #e5e7eb);
}

.gc-casinos__hero-ticker-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 16px 32px;
	display: flex;
	align-items: center;
	gap: 36px;
	flex-wrap: wrap;
}

.gc-casinos__hero-ticker-item {
	display: flex;
	align-items: center;
	gap: 10px;
}

.gc-casinos__hero-ticker-label {
	font-size: 11px;
	color: #9ca3af;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-weight: 500;
}

.gc-casinos__hero-ticker-value {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 15px;
	font-weight: 600;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.01em;
}

.gc-casinos__hero-ticker-value--accent {
	color: var(--gc-primary-dark, #00A894);
}

/* ============================================================
   SECTION HEADERS
   ============================================================ */

.gc-casinos__section {
	margin-bottom: 40px;
}

.gc-casinos__section-head {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 18px;
	padding-bottom: 12px;
	border-bottom: 0.5px solid var(--gc-border, #e5e7eb);
}

.gc-casinos__section-icon {
	width: 38px;
	height: 38px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.gc-casinos__section-icon--teal {
	background: rgba(0, 198, 174, 0.12);
	color: var(--gc-primary-dark, #00A894);
}

.gc-casinos__section-icon--navy {
	background: rgba(13, 27, 62, 0.08);
	color: var(--gc-navy, #0D1B3E);
}

.gc-casinos__section-text {
	flex: 1;
	min-width: 0;
}

.gc-casinos__section-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 22px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	margin: 0;
	letter-spacing: -0.01em;
}

.gc-casinos__section-desc {
	font-size: 13px;
	color: var(--gc-muted, #6b7280);
	margin: 2px 0 0;
}

.gc-casinos__section-count {
	font-size: 11px;
	color: var(--gc-muted, #6b7280);
	background: rgba(13, 27, 62, 0.06);
	padding: 4px 10px;
	border-radius: 999px;
	font-weight: 600;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	flex-shrink: 0;
}

.gc-casinos__section-count--teal {
	color: var(--gc-primary-dark, #00A894);
	background: rgba(0, 198, 174, 0.1);
}

/* ============================================================
   PREMIUM CARDS GRID (2-col)
   ============================================================ */

.gc-casinos__premium-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.gc-casinos__premium-card {
	background: var(--gc-bg-soft);
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 12px;
	padding: 26px;
	text-decoration: none;
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: all 180ms ease;
}

.gc-casinos__premium-card:hover {
	border-color: rgba(0, 198, 174, 0.4);
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(13, 27, 62, 0.06);
}

.gc-casinos__premium-tag {
	position: absolute;
	top: 14px;
	right: 14px;
	background: rgba(0, 198, 174, 0.12);
	color: #04342C;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.5px;
	text-transform: uppercase;
}

.gc-casinos__premium-acronym {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 26px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.02em;
	margin-bottom: 6px;
	margin-top: 4px;
	line-height: 1.2;
}

.gc-casinos__premium-authority {
	font-size: 12px;
	color: var(--gc-primary-dark, #00A894);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 14px;
}

.gc-casinos__premium-desc {
	font-size: 15px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.65;
	margin: 0 0 16px;
	flex: 1;
}

.gc-casinos__premium-foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-top: 12px;
	border-top: 0.5px solid var(--gc-border, #e5e7eb);
	gap: 10px;
}

.gc-casinos__premium-region {
	font-size: 11px;
	color: var(--gc-primary-dark, #00A894);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-weight: 600;
}

.gc-casinos__premium-cta {
	font-size: 13px;
	color: var(--gc-primary-dark, #00A894);
	font-weight: 600;
	flex-shrink: 0;
}

/* ============================================================
   OTHER CARDS GRID (4-col)
   ============================================================ */

.gc-casinos__other-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
}

.gc-casinos__other-card {
	background: var(--gc-bg-soft);
	border: 0.5px solid var(--gc-border, #e5e7eb);
	border-radius: 10px;
	padding: 18px;
	text-decoration: none;
	display: flex;
	flex-direction: column;
	transition: all 180ms ease;
}

.gc-casinos__other-card:hover {
	border-color: rgba(0, 198, 174, 0.4);
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(13, 27, 62, 0.05);
}

.gc-casinos__other-head {
	margin-bottom: 12px;
}

.gc-casinos__other-acronym {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 17px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.01em;
	margin-bottom: 4px;
	line-height: 1.2;
}

.gc-casinos__other-authority {
	font-size: 11px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.4;
}

.gc-casinos__other-desc {
	font-size: 13px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.6;
	margin: 0 0 12px;
	flex: 1;
}

.gc-casinos__other-foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-top: 10px;
	border-top: 0.5px solid var(--gc-border, #e5e7eb);
}

.gc-casinos__other-region {
	font-size: 10px;
	color: var(--gc-primary-dark, #00A894);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-weight: 600;
}

.gc-casinos__other-arrow {
	font-size: 13px;
	color: var(--gc-navy, #0D1B3E);
	font-weight: 600;
}

/* ============================================================
   OPERATOR CTA (dark navy banner)
   ============================================================ */

.gc-casinos__operator-cta {
	background: #0D1B3E;
	border-radius: 12px;
	padding: 28px 30px;
	display: flex;
	align-items: center;
	gap: 24px;
	margin-bottom: 40px;
	flex-wrap: wrap;
}

.gc-casinos__operator-cta-text {
	flex: 1;
	min-width: 280px;
}

.gc-casinos__operator-cta-label {
	font-size: 10px;
	color: var(--gc-primary, #00C6AE);
	font-weight: 600;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	margin-bottom: 8px;
}

.gc-casinos__operator-cta-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 20px;
	font-weight: 700;
	color: #ffffff;
	letter-spacing: -0.01em;
	margin-bottom: 6px;
}

.gc-casinos__operator-cta-desc {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.7);
	line-height: 1.65;
	margin: 0;
}

.gc-casinos__operator-cta-btn {
	background: var(--gc-primary, #00C6AE);
	color: #ffffff;
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-weight: 600;
	font-size: 13px;
	padding: 11px 22px;
	border-radius: 7px;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	flex-shrink: 0;
	transition: all 150ms ease;
}

.gc-casinos__operator-cta-btn:hover {
	background: var(--gc-primary-dark, #00A894);
	color: #ffffff;
	transform: translateY(-1px);
}

/* ============================================================
   ABOUT SECTION
   ============================================================ */

.gc-casinos__about {
	margin-bottom: 36px;
}

.gc-casinos__about-pill {
	display: inline-flex;
	align-items: center;
	padding: 4px 12px;
	background: rgba(0, 198, 174, 0.12);
	color: #04342C;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	margin-bottom: 14px;
}

.gc-casinos__about-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 26px;
	font-weight: 700;
	color: var(--gc-navy, #0D1B3E);
	letter-spacing: -0.02em;
	line-height: 1.25;
	margin: 0 0 14px;
}

.gc-casinos__about-accent {
	color: var(--gc-primary, #00C6AE);
}

.gc-casinos__about-text {
	font-size: 15px;
	line-height: 1.75;
	color: var(--gc-muted, #6b7280);
	margin: 0 0 12px;
}

.gc-casinos__about-text strong {
	color: var(--gc-navy, #0D1B3E);
	font-weight: 600;
}

.gc-casinos__about-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	margin-top: 18px;
}

.gc-casinos__about-tile {
	background: var(--gc-bg-soft);
	border-radius: 8px;
	padding: 18px;
}

.gc-casinos__about-tile--accent {
	background: rgba(0, 198, 174, 0.08);
}

.gc-casinos__about-tile-icon {
	color: var(--gc-navy, #0D1B3E);
	display: block;
	margin-bottom: 8px;
}

.gc-casinos__about-tile--accent .gc-casinos__about-tile-icon {
	color: var(--gc-primary-dark, #00A894);
}

.gc-casinos__about-tile-title {
	font-family: var(--gc-font-display, 'Sora', sans-serif);
	font-size: 14px;
	font-weight: 600;
	color: var(--gc-navy, #0D1B3E);
	margin-bottom: 4px;
}

.gc-casinos__about-tile-desc {
	font-size: 12px;
	color: var(--gc-muted, #6b7280);
	line-height: 1.55;
}

/* ============================================================
   DISCLAIMER
   ============================================================ */

.gc-casinos__disclaimer {
	background: rgba(245, 158, 11, 0.08);
	border: 0.5px solid rgba(245, 158, 11, 0.25);
	border-radius: 10px;
	padding: 16px 20px;
	display: flex;
	align-items: flex-start;
	gap: 12px;
	font-size: 13px;
	line-height: 1.65;
	color: #92400E;
}

.gc-casinos__disclaimer strong {
	font-weight: 600;
	color: #78350F;
	display: block;
	margin-bottom: 4px;
}

.gc-casinos__disclaimer svg {
	color: #B45309;
	flex-shrink: 0;
	margin-top: 1px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1100px) {
	.gc-casinos__container {
		padding: 32px 24px 60px;
	}
	.gc-casinos__other-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 900px) {
	.gc-casinos__hero-content {
		padding: 48px 24px 32px;
	}
	.gc-casinos__hero-ticker-inner {
		padding: 14px 24px;
		gap: 24px;
	}
	.gc-casinos__container {
		padding: 28px 20px 56px;
	}
	.gc-casinos__premium-grid,
	.gc-casinos__other-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.gc-casinos__about-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 700px) {
	.gc-casinos__hero-content {
		padding: 40px 20px 28px;
	}
	.gc-casinos__hero-ticker-inner {
		padding: 14px 20px;
		gap: 18px 24px;
	}
	.gc-casinos__container {
		padding: 24px 16px 56px;
	}
	.gc-casinos__premium-grid,
	.gc-casinos__other-grid {
		grid-template-columns: 1fr;
	}
	.gc-casinos__operator-cta {
		flex-direction: column;
		align-items: flex-start;
		padding: 22px;
	}
	.gc-casinos__operator-cta-btn {
		width: 100%;
		justify-content: center;
	}
}

/* ============================================================
   DARK MODE
   ============================================================ */

[data-theme="dark"] .gc-casinos,
[data-theme="dark"] .gc-casinos__hero {
	background: var(--gc-bg);
}

[data-theme="dark"] .gc-casinos__hero {
	border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .gc-casinos__hero-ticker {
	background: rgba(255, 255, 255, 0.02);
	border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .gc-casinos__hero-title,
[data-theme="dark"] .gc-casinos__hero-trust,
[data-theme="dark"] .gc-casinos__section-title,
[data-theme="dark"] .gc-casinos__premium-acronym,
[data-theme="dark"] .gc-casinos__other-acronym,
[data-theme="dark"] .gc-casinos__hero-ticker-value,
[data-theme="dark"] .gc-casinos__about-title,
[data-theme="dark"] .gc-casinos__about-tile-title {
	color: #ffffff;
}

[data-theme="dark"] .gc-casinos__hero-sub,
[data-theme="dark"] .gc-casinos__section-desc,
[data-theme="dark"] .gc-casinos__premium-desc,
[data-theme="dark"] .gc-casinos__other-desc,
[data-theme="dark"] .gc-casinos__other-authority,
[data-theme="dark"] .gc-casinos__about-text,
[data-theme="dark"] .gc-casinos__about-tile-desc,
[data-theme="dark"] .gc-casinos__hero-ticker-label {
	color: rgba(255, 255, 255, 0.6);
}

[data-theme="dark"] .gc-casinos__about-text strong {
	color: #ffffff;
}

[data-theme="dark"] .gc-casinos__premium-card,
[data-theme="dark"] .gc-casinos__other-card {
	background: var(--gc-bg-soft);
	border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .gc-casinos__about-tile {
	background: var(--gc-bg-soft);
}

[data-theme="dark"] .gc-casinos__hero-trust {
	background: var(--gc-bg-soft);
	border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .gc-casinos__premium-foot,
[data-theme="dark"] .gc-casinos__other-foot,
[data-theme="dark"] .gc-casinos__section-head {
	border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .gc-casinos__operator-cta {
	background: #0a1530;
}

[data-theme="dark"] .gc-casinos__premium-tag {
	background: rgba(0, 198, 174, 0.08);
	color: #7DD3C8;
}

[data-theme="dark"] .gc-casinos__about-pill {
	background: rgba(0, 198, 174, 0.08);
	color: #7DD3C8;
}

/* ── Dark mode: hero eyebrow badge — match iHub (subtle teal pill) ── */
[data-theme="dark"] .gc-casinos__hero-badge {
	background: rgba(0, 198, 174, 0.08);
	border-color: rgba(0, 198, 174, 0.20);
	color: #7DD3C8;
}
[data-theme="dark"] .gc-casinos__hero-badge-dot {
	background: #7DD3C8;
}

/* ── Dark mode: amber disclaimer — muted amber accent, neutral body ── */
[data-theme="dark"] .gc-casinos__disclaimer {
	background: rgba(245, 158, 11, 0.06);
	border-color: rgba(245, 158, 11, 0.20);
	color: rgba(255, 255, 255, 0.78);
}
[data-theme="dark"] .gc-casinos__disclaimer strong {
	color: #FCD34D;
}
[data-theme="dark"] .gc-casinos__disclaimer svg {
	color: #FCD34D;
}