/* ================================================================
   AG ENTERTAINMENT — AFFILIATE PORTAL OVERRIDES
   Targets affiliatewp-affiliate-portal SPA (Tailwind + Alpine).
   Loads after affwp-affiliate-portal CSS — wins on specificity + order.
   Aesthetic match: Skyy Banks landing page.
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Cormorant+Garamond:ital,wght@0,400;0,600;1,300&family=Inter:wght@300;400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

/* ---------- DESIGN TOKENS ---------- */
:root,
body.antialiased {
	--ag-bg:        #050508;
	--ag-bg-2:      #0a0a12;
	--ag-bg-3:      #11111c;
	--ag-panel:     #0d0d14;
	--ag-ink:       #ffffff;
	--ag-ink-dim:   rgba(255,255,255,0.78);
	--ag-ink-faint: rgba(255,255,255,0.50);
	--ag-line:      rgba(200,169,100,0.18);
	--ag-line-soft: rgba(255,255,255,0.08);
	--ag-gold:      #C8A964;
	--ag-gold-2:    #B43627;
	--ag-gold-glow: rgba(200,169,100,0.35);
	--ag-amber:     #f6b94a;

	--ag-display: 'Bebas Neue', 'Helvetica Neue', sans-serif;
	--ag-serif:   'Cormorant Garamond', Georgia, serif;
	--ag-ui:      'Inter', system-ui, -apple-system, sans-serif;
	--ag-mono:    'Space Mono', ui-monospace, 'SF Mono', Menlo, monospace;
}

/* ---------- BODY / SHELL ---------- */
body.antialiased.font-sans {
	background: var(--ag-bg) !important;
	color: var(--ag-ink) !important;
	font-family: var(--ag-ui) !important;
	-webkit-font-smoothing: antialiased;
}

body.antialiased .portal,
body .portal.h-screen {
	background: radial-gradient(ellipse at top left, #0e0d18 0%, var(--ag-bg) 60%) !important;
	color: var(--ag-ink) !important;
}

/* page background swap (Tailwind bg-gray-100) */
body.antialiased .bg-gray-100 {
	background: transparent !important;
}

/* ---------- TYPOGRAPHY ---------- */
body.antialiased h1, body.antialiased h2, body.antialiased h3 {
	font-family: var(--ag-display) !important;
	letter-spacing: 0.04em;
	color: var(--ag-ink);
	font-weight: 400;
}
body.antialiased .text-2xl,
body.antialiased .text-3xl,
body.antialiased .text-4xl {
	font-family: var(--ag-display) !important;
	letter-spacing: 0.04em;
	color: var(--ag-ink) !important;
}
body.antialiased .text-gray-900 { color: var(--ag-ink) !important; }
body.antialiased .text-gray-800 { color: var(--ag-ink) !important; }
body.antialiased .text-gray-700,
body.antialiased .text-gray-600 { color: var(--ag-ink-dim) !important; }
body.antialiased .text-gray-500,
body.antialiased .text-gray-400 { color: var(--ag-ink-faint) !important; }

/* ---------- SIDEBAR (desktop static) ---------- */
body.antialiased .bg-gray-800 {
	background: linear-gradient(180deg, #07070d 0%, #0b0b14 100%) !important;
	border-right: 1px solid var(--ag-line) !important;
	position: relative;
}
body.antialiased .md\:flex-shrink-0 .flex.flex-col.w-64 {
	background: linear-gradient(180deg, #07070d 0%, #0b0b14 100%) !important;
	border-right: 1px solid var(--ag-line) !important;
}

/* Logo strip */
body.antialiased .h-16.flex-shrink-0.flex.px-4.bg-gray-800 {
	background: #07070d !important;
	border-bottom: 1px solid var(--ag-line) !important;
	height: 5rem !important;
}

/* "Back to site" link group */
body.antialiased .bg-gray-800 a.text-gray-400,
body.antialiased .bg-gray-800 a.text-gray-300 {
	font-family: var(--ag-mono) !important;
	font-size: 11px !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase !important;
	color: var(--ag-ink-faint) !important;
	padding: 10px 14px !important;
	border-radius: 2px !important;
	transition: all .18s ease !important;
}
body.antialiased .bg-gray-800 a.text-gray-400:hover,
body.antialiased .bg-gray-800 a.text-gray-300:hover {
	color: var(--ag-gold) !important;
	background: rgba(200,169,100,0.06) !important;
}

/* Nav items: each is a flex anchor inside <nav> */
body.antialiased nav a,
body.antialiased nav button {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	padding: 12px 14px !important;
	margin: 2px 6px !important;
	border-radius: 3px !important;
	font-family: var(--ag-ui) !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	letter-spacing: 0.04em !important;
	color: var(--ag-ink-dim) !important;
	text-decoration: none !important;
	border-left: 2px solid transparent !important;
	transition: background .18s ease, color .18s ease, border-color .18s ease !important;
}
body.antialiased nav a:hover,
body.antialiased nav button:hover {
	background: rgba(200,169,100,0.08) !important;
	color: var(--ag-gold) !important;
	border-left-color: var(--ag-gold) !important;
}
body.antialiased nav a.bg-gray-900,
body.antialiased nav a[aria-current="page"],
body.antialiased nav .bg-gray-900 {
	background: linear-gradient(135deg, rgba(200,169,100,0.18) 0%, rgba(180,54,39,0.12) 100%) !important;
	color: var(--ag-gold) !important;
	border-left: 2px solid var(--ag-gold) !important;
	box-shadow: inset 0 0 0 1px rgba(200,169,100,0.22) !important;
}
body.antialiased nav a svg,
body.antialiased nav button svg {
	width: 20px !important;
	height: 20px !important;
	color: currentColor !important;
	opacity: .85 !important;
}

/* nav section dividers */
body.antialiased nav .border-gray-700,
body.antialiased nav .border-t {
	border-color: var(--ag-line) !important;
	margin: 14px 8px !important;
}

/* ---------- TOP BAR ---------- */
body.antialiased .bg-white {
	background: rgba(10,10,18,0.92) !important;
	border-bottom: 1px solid var(--ag-line) !important;
	color: var(--ag-ink) !important;
	backdrop-filter: blur(8px);
}
body.antialiased .h-16.bg-white {
	background: rgba(10,10,18,0.92) !important;
	border-bottom: 1px solid var(--ag-line) !important;
}
body.antialiased .border-r.border-gray-200 {
	border-color: var(--ag-line) !important;
}

/* breadcrumbs / page title in main */
body.antialiased .pb-5.border-b.border-gray-200,
body.antialiased .border-b.border-gray-200 {
	border-color: var(--ag-line) !important;
}

/* main content area */
body.antialiased main,
body.antialiased main.flex-1 {
	background: transparent !important;
	color: var(--ag-ink) !important;
}
body.antialiased main .max-w-7xl,
body.antialiased main .max-w-6xl {
	color: var(--ag-ink) !important;
}

/* ---------- STAT CARDS (Earnings / Month / Clicks / Referrals) ---------- */
body.antialiased .bg-white.overflow-hidden,
body.antialiased .bg-white.shadow,
body.antialiased .bg-white.shadow.rounded-lg,
body.antialiased .bg-white.rounded-lg {
	background: var(--ag-panel) !important;
	border: 1px solid var(--ag-line) !important;
	border-radius: 2px !important;
	box-shadow: 0 1px 0 rgba(255,255,255,0.02), 0 8px 24px rgba(0,0,0,0.4) !important;
	color: var(--ag-ink) !important;
	position: relative;
	overflow: hidden;
	transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
body.antialiased .bg-white.overflow-hidden::before,
body.antialiased .bg-white.shadow::before,
body.antialiased .bg-white.rounded-lg::before {
	content: "";
	position: absolute; top: 0; left: 0; right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--ag-gold) 30%, var(--ag-gold) 70%, transparent);
	opacity: .8;
}
body.antialiased .bg-white.overflow-hidden:hover,
body.antialiased .bg-white.shadow:hover,
body.antialiased .bg-white.rounded-lg:hover {
	transform: translateY(-2px);
	border-color: rgba(200,169,100,0.45) !important;
	box-shadow: 0 1px 0 rgba(200,169,100,0.1), 0 16px 36px rgba(0,0,0,0.55) !important;
}

/* gold corner brackets on stat cards */
body.antialiased .bg-white.overflow-hidden::after {
	content: "";
	position: absolute; top: 8px; right: 8px;
	width: 14px; height: 14px;
	border-top: 1px solid var(--ag-gold);
	border-right: 1px solid var(--ag-gold);
	opacity: .55;
	pointer-events: none;
}

/* stat card label (mono uppercase) */
body.antialiased .bg-white .text-sm.font-medium.text-gray-500,
body.antialiased .bg-white dt {
	font-family: var(--ag-mono) !important;
	font-size: 10.5px !important;
	letter-spacing: 0.22em !important;
	text-transform: uppercase !important;
	color: var(--ag-ink-faint) !important;
	font-weight: 400 !important;
}
/* stat card big number (display font) */
body.antialiased .bg-white .text-3xl,
body.antialiased .bg-white .text-2xl.font-semibold,
body.antialiased .bg-white dd .text-3xl,
body.antialiased .bg-white dd > div {
	font-family: var(--ag-display) !important;
	font-size: 38px !important;
	letter-spacing: 0.02em !important;
	color: var(--ag-ink) !important;
	font-weight: 400 !important;
	line-height: 1 !important;
	margin-top: 8px !important;
}

/* card padding bump */
body.antialiased .bg-white.overflow-hidden .px-4.py-5,
body.antialiased .bg-white.overflow-hidden .p-5,
body.antialiased .bg-white .px-4.py-5.sm\:p-6 {
	padding: 22px 22px 24px !important;
}

/* card icon accent */
body.antialiased .bg-white .bg-indigo-500,
body.antialiased .bg-white .bg-indigo-600 {
	background: linear-gradient(135deg, var(--ag-gold), var(--ag-gold-2)) !important;
	border-radius: 2px !important;
}
body.antialiased .text-indigo-600,
body.antialiased .text-indigo-500 {
	color: var(--ag-gold) !important;
}
body.antialiased .hover\:text-indigo-500:hover,
body.antialiased .hover\:text-indigo-600:hover {
	color: var(--ag-amber) !important;
}

/* secondary card footer link strip */
body.antialiased .bg-gray-50,
body.antialiased .bg-gray-100.px-5.py-3 {
	background: rgba(200,169,100,0.04) !important;
	border-top: 1px solid var(--ag-line-soft) !important;
}
body.antialiased .bg-gray-50 a,
body.antialiased .bg-gray-50 .text-sm {
	font-family: var(--ag-mono) !important;
	font-size: 11px !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase !important;
	color: var(--ag-gold) !important;
}

/* ---------- TABLES (referrals / payouts / visits) ---------- */
body.antialiased table {
	background: var(--ag-panel) !important;
	color: var(--ag-ink) !important;
	border: 1px solid var(--ag-line) !important;
	border-radius: 2px !important;
}
body.antialiased thead,
body.antialiased thead.bg-gray-50,
body.antialiased thead .bg-gray-50,
body.antialiased table thead tr {
	background: rgba(200,169,100,0.06) !important;
	border-bottom: 1px solid var(--ag-line) !important;
}
body.antialiased th {
	font-family: var(--ag-mono) !important;
	font-size: 10.5px !important;
	letter-spacing: 0.22em !important;
	text-transform: uppercase !important;
	color: var(--ag-gold) !important;
	font-weight: 400 !important;
	padding: 14px 16px !important;
	border: none !important;
}
body.antialiased td {
	color: var(--ag-ink-dim) !important;
	border-top: 1px solid var(--ag-line-soft) !important;
	padding: 14px 16px !important;
	font-size: 13.5px !important;
}
body.antialiased tbody tr:hover,
body.antialiased tbody tr:hover td {
	background: rgba(200,169,100,0.05) !important;
	color: var(--ag-ink) !important;
}
body.antialiased .divide-gray-200 > * + *,
body.antialiased .divide-y > * + * {
	border-color: var(--ag-line-soft) !important;
}

/* ---------- STATUS BADGES (pending / unpaid / paid) ---------- */
body.antialiased .inline-flex.items-center.rounded-full,
body.antialiased .badge,
body.antialiased span.bg-yellow-100,
body.antialiased span.bg-green-100,
body.antialiased span.bg-red-100,
body.antialiased span.bg-gray-100 {
	font-family: var(--ag-mono) !important;
	font-size: 10px !important;
	letter-spacing: 0.20em !important;
	text-transform: uppercase !important;
	font-weight: 700 !important;
	padding: 4px 10px !important;
	border-radius: 2px !important;
	border: 1px solid currentColor !important;
}
body.antialiased span.bg-yellow-100,
body.antialiased .text-yellow-800 {
	background: rgba(246,185,74,0.12) !important;
	color: var(--ag-amber) !important;
	border-color: rgba(246,185,74,0.5) !important;
}
body.antialiased span.bg-green-100,
body.antialiased .text-green-800 {
	background: linear-gradient(135deg, var(--ag-gold), var(--ag-gold-2)) !important;
	color: #050505 !important;
	border-color: var(--ag-gold) !important;
}
body.antialiased span.bg-red-100,
body.antialiased .text-red-800 {
	background: rgba(180,54,39,0.18) !important;
	color: #ff7a63 !important;
	border-color: rgba(180,54,39,0.6) !important;
}
body.antialiased span.bg-gray-100,
body.antialiased .text-gray-800.bg-gray-100 {
	background: transparent !important;
	color: var(--ag-gold) !important;
	border-color: var(--ag-gold) !important;
}

/* ---------- FORMS / INPUTS ---------- */
body.antialiased input[type="text"],
body.antialiased input[type="email"],
body.antialiased input[type="password"],
body.antialiased input[type="url"],
body.antialiased input[type="search"],
body.antialiased input[type="number"],
body.antialiased select,
body.antialiased textarea,
body.antialiased .form-input,
body.antialiased .form-select,
body.antialiased .form-textarea {
	background: var(--ag-bg-2) !important;
	color: var(--ag-ink) !important;
	border: 1px solid var(--ag-line) !important;
	border-radius: 2px !important;
	padding: 10px 14px !important;
	font-family: var(--ag-ui) !important;
	font-size: 14px !important;
	transition: border-color .18s ease, box-shadow .18s ease;
}
body.antialiased input::placeholder,
body.antialiased textarea::placeholder {
	color: var(--ag-ink-faint) !important;
}
body.antialiased input:focus,
body.antialiased select:focus,
body.antialiased textarea:focus,
body.antialiased .form-input:focus {
	outline: none !important;
	border-color: var(--ag-gold) !important;
	box-shadow: 0 0 0 3px rgba(200,169,100,0.18) !important;
}
body.antialiased label,
body.antialiased .block.text-sm.font-medium {
	font-family: var(--ag-mono) !important;
	font-size: 10.5px !important;
	letter-spacing: 0.22em !important;
	text-transform: uppercase !important;
	color: var(--ag-ink-faint) !important;
	font-weight: 400 !important;
	margin-bottom: 8px !important;
}

/* ---------- BUTTONS ---------- */
body.antialiased button.bg-indigo-600,
body.antialiased button.bg-indigo-500,
body.antialiased a.bg-indigo-600,
body.antialiased a.bg-indigo-500,
body.antialiased input[type="submit"],
body.antialiased .button-primary,
body.antialiased button[type="submit"]:not(.bg-gray-100):not(.bg-white) {
	background: linear-gradient(135deg, var(--ag-gold) 0%, var(--ag-gold-2) 100%) !important;
	color: #050505 !important;
	font-family: var(--ag-ui) !important;
	font-weight: 700 !important;
	font-size: 12.5px !important;
	letter-spacing: 0.25em !important;
	text-transform: uppercase !important;
	padding: 12px 22px !important;
	border: none !important;
	border-radius: 2px !important;
	box-shadow: 0 4px 14px rgba(200,169,100,0.25) !important;
	transition: transform .18s ease, box-shadow .18s ease, filter .18s ease !important;
	cursor: pointer;
}
body.antialiased button.bg-indigo-600:hover,
body.antialiased a.bg-indigo-600:hover,
body.antialiased input[type="submit"]:hover,
body.antialiased button[type="submit"]:hover:not(.bg-gray-100):not(.bg-white) {
	transform: translateY(-1px);
	filter: brightness(1.08);
	box-shadow: 0 6px 22px rgba(200,169,100,0.4) !important;
}
body.antialiased button.bg-white,
body.antialiased a.bg-white.border {
	background: transparent !important;
	color: var(--ag-gold) !important;
	border: 1px solid var(--ag-gold) !important;
	font-family: var(--ag-ui) !important;
	font-weight: 600 !important;
	font-size: 12.5px !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase !important;
	border-radius: 2px !important;
}
body.antialiased button.bg-white:hover {
	background: rgba(200,169,100,0.08) !important;
}

/* anchor tags inside content */
body.antialiased main a:not([class*="bg-"]):not(nav a) {
	color: var(--ag-gold);
	text-decoration: none;
	border-bottom: 1px dotted rgba(200,169,100,0.4);
}
body.antialiased main a:not([class*="bg-"]):not(nav a):hover {
	color: var(--ag-amber);
	border-color: var(--ag-amber);
}

/* ---------- EMPTY STATES ---------- */
body.antialiased .text-center.py-12,
body.antialiased .empty-state,
body.antialiased .text-gray-500.text-center {
	color: var(--ag-ink-faint) !important;
	font-family: var(--ag-serif) !important;
	font-style: italic;
	font-size: 16px;
	letter-spacing: 0.02em;
	padding: 48px 16px !important;
}

/* ---------- MODAL / DRAWER ---------- */
body.antialiased .fixed.inset-0.bg-gray-500,
body.antialiased .fixed.inset-0.bg-gray-600,
body.antialiased .fixed.inset-0.bg-black {
	background: rgba(5,5,8,0.78) !important;
	backdrop-filter: blur(6px);
}
body.antialiased .fixed.inset-0 .bg-white,
body.antialiased [role="dialog"] .bg-white,
body.antialiased .modal-content {
	background: rgba(13,13,20,0.96) !important;
	border: 1px solid var(--ag-gold) !important;
	border-radius: 3px !important;
	box-shadow: 0 24px 80px rgba(0,0,0,0.65), 0 0 0 1px rgba(200,169,100,0.3) !important;
	color: var(--ag-ink) !important;
}

/* ---------- NOTIFICATIONS ---------- */
body.antialiased .notification,
body.antialiased [class*="notification"] .bg-white {
	background: var(--ag-panel) !important;
	border-left: 3px solid var(--ag-gold) !important;
	color: var(--ag-ink) !important;
	border-radius: 2px !important;
}

/* ---------- LOGO STRIP TWEAK (use white logo instead of black on dark bg) ---------- */
body.antialiased .h-16.flex-shrink-0.flex.px-4.bg-gray-800 .bg-contain {
	filter: brightness(1.2) contrast(1.05);
}

/* ---------- LINKS IN HEADER (logout / feedback icons) ---------- */
body.antialiased .h-16.bg-white .text-gray-400,
body.antialiased .h-16.bg-white .text-gray-500 {
	color: var(--ag-ink-faint) !important;
}
body.antialiased .h-16.bg-white .text-gray-400:hover,
body.antialiased .h-16.bg-white .text-gray-500:hover {
	color: var(--ag-gold) !important;
}

/* ---------- PAGINATION ---------- */
body.antialiased .pagination a,
body.antialiased .pagination span,
body.antialiased nav.pagination > * {
	background: transparent !important;
	color: var(--ag-ink-dim) !important;
	border: 1px solid var(--ag-line) !important;
	font-family: var(--ag-mono) !important;
	font-size: 11px !important;
	letter-spacing: 0.15em !important;
}
body.antialiased .pagination .current,
body.antialiased nav.pagination .bg-indigo-50 {
	background: var(--ag-gold) !important;
	color: #050505 !important;
	border-color: var(--ag-gold) !important;
}

/* ---------- DIVIDERS ---------- */
body.antialiased hr,
body.antialiased .border-gray-200,
body.antialiased .border-gray-300 {
	border-color: var(--ag-line) !important;
}

/* ---------- SELECT SCROLLBARS (webkit) ---------- */
body.antialiased ::-webkit-scrollbar { width: 10px; height: 10px; }
body.antialiased ::-webkit-scrollbar-track { background: var(--ag-bg); }
body.antialiased ::-webkit-scrollbar-thumb {
	background: rgba(200,169,100,0.25);
	border-radius: 1px;
}
body.antialiased ::-webkit-scrollbar-thumb:hover { background: rgba(200,169,100,0.5); }

/* ---------- CHARTS (alpine-chart canvas wrapper) ---------- */
body.antialiased .chart-container,
body.antialiased canvas {
	background: transparent !important;
}

/* ---------- LOGIN / OPT-IN / REGISTER (when shown inside portal shell) ---------- */
body.antialiased .min-h-screen.bg-gray-50,
body.antialiased .bg-gray-50 {
	background: var(--ag-bg) !important;
}
body.antialiased .max-w-md.bg-white {
	background: var(--ag-panel) !important;
	border: 1px solid var(--ag-gold) !important;
	box-shadow: 0 24px 60px rgba(0,0,0,0.6), 0 0 0 1px rgba(200,169,100,0.18);
}

/* ---------- RESPONSIVE TIGHTEN ---------- */
@media (max-width: 768px) {
	body.antialiased .h-16.flex-shrink-0.flex.px-4.bg-gray-800 { height: 4.5rem !important; }
	body.antialiased .bg-white .text-3xl { font-size: 32px !important; }
}
