/* ================================================================
   AG ENTERTAINMENT — EVENT TEMPLATE
   Shared backbone + 3 variants (After Dark / Golden Hour / Signal)
   Per-event accent via --ag-accent CSS var (set by event-meta.php).
   ================================================================ */

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

/* ---------- CANVAS RESET — kill theme chrome around the event ---------- */
.ag-canvas-body {
	margin: 0;
	padding: 0;
	background: #050508;
}
.ag-canvas-body > *:not(.ag-event):not(script):not(style):not(iframe) {
	display: none !important;
}

/* ---------- DEFAULTS (overridden per variant) ---------- */
.ag-event {
	--ag-bg: #050508;
	--ag-bg-2: #0a0a12;
	--ag-ink: #ffffff;
	--ag-ink-dim: rgba(255, 255, 255, 0.85);
	--ag-ink-faint: rgba(255, 255, 255, 0.55);
	--ag-line: rgba(255, 255, 255, 0.14);
	--ag-accent: #ff2d8a;
	--ag-accent-hot: #ff5fa3;
	--ag-gold: #f0cc8a;
	--ag-secondary: #7c3aed;
	--ag-cyan: #5eead4;

	--display-font: 'Syncopate', 'Helvetica Neue', sans-serif;
	--serif-font:   'Cormorant Garamond', Georgia, serif;
	--ui-font:      'Inter', system-ui, sans-serif;
	--mono-font:    'Space Mono', 'Courier New', monospace;
}

/* ---------- SCOPED RESET ---------- */
.ag-event,
.ag-event *,
.ag-event *::before,
.ag-event *::after {
	box-sizing: border-box;
}

/* ---------- FULL-BLEED CONTAINER ---------- */
.ag-event {
	position: relative;
	width: 100vw;
	margin-left: calc(-50vw + 50%);
	margin-right: calc(-50vw + 50%);
	min-height: 100vh;
	background: var(--ag-bg);
	color: var(--ag-ink);
	font-family: var(--serif-font);
	overflow: hidden;
	isolation: isolate;
}

.ag-event .ag-grain { display: none; }

.ag-event .ag-wrap {
	position: relative;
	z-index: 2;
	max-width: 1320px;
	margin: 0 auto;
	padding: 18px 16px 60px;
}
@media (min-width: 768px) {
	.ag-event .ag-wrap { padding: 28px 32px 80px; }
}

/* ---------- HEADER ---------- */
.ag-event .ag-nav {
	display: flex; align-items: center; justify-content: space-between;
	padding: 8px 0 18px;
	border-bottom: 1px solid var(--ag-line);
	gap: 12px;
}
.ag-event .ag-nav-home { display: inline-flex; text-decoration: none; }
.ag-event .ag-nav-back {
	color: var(--ag-ink-dim); text-decoration: none;
	border-bottom: 1px dotted var(--ag-ink-faint);
	transition: color 0.2s, border-color 0.2s;
}
.ag-event .ag-nav-back:hover { color: var(--ag-accent); border-color: var(--ag-accent); }
.ag-event .ag-logo { height: 34px; width: auto; }
.ag-event .ag-logo-text {
	font-family: var(--display-font); font-weight: 700;
	font-size: 14px; letter-spacing: 0.2em; text-transform: uppercase;
	color: var(--ag-ink);
}
@media (min-width: 768px) { .ag-event .ag-logo { height: 42px; } }
.ag-event .ag-nav-meta {
	font-family: var(--mono-font);
	font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase;
	color: var(--ag-ink-dim);
	display: flex; gap: 10px; align-items: center;
}
.ag-event .ag-footer a {
	color: var(--ag-ink-dim);
	text-decoration: none;
	transition: color 0.2s;
}
.ag-event .ag-footer a:hover { color: var(--ag-accent); }
.ag-event .ag-footer-sep { margin: 0 6px; opacity: 0.5; }
@media (min-width: 768px) { .ag-event .ag-nav-meta { font-size: 10px; gap: 14px; } }
.ag-event .ag-nav-meta .ag-dot {
	width: 6px; height: 6px; border-radius: 50%;
	background: var(--ag-accent);
	box-shadow: 0 0 12px var(--ag-accent);
	animation: ag-pulse-dot 1.4s ease-in-out infinite;
}
@keyframes ag-pulse-dot {
	0%, 100% { opacity: 0.4; transform: scale(1); }
	50%      { opacity: 1;   transform: scale(1.35); }
}

/* ---------- HERO ---------- */
.ag-event .ag-hero { position: relative; padding: 24px 0 20px; }
@media (min-width: 960px) {
	.ag-event .ag-hero {
		padding: 40px 0 28px;
		display: grid; grid-template-columns: 1.05fr 1fr;
		gap: 50px; align-items: center;
	}
}

.ag-event .ag-flyer-wrap {
	position: relative; margin-bottom: 28px;
	max-width: 360px; margin-left: auto; margin-right: auto;
}
@media (min-width: 960px) {
	.ag-event .ag-flyer-wrap {
		margin-bottom: 0; max-width: 420px;
		margin-left: auto; margin-right: 0; order: 2;
	}
}
.ag-event .ag-flyer-frame {
	position: relative; aspect-ratio: 1080 / 1920;
	overflow: hidden; background: #000;
	border: 1px solid var(--ag-line);
}
.ag-event .ag-flyer-frame img {
	width: 100%; height: 100%; object-fit: contain; display: block;
}
.ag-event .ag-corner {
	position: absolute; width: 28px; height: 28px;
	border: 2px solid var(--ag-accent); pointer-events: none; z-index: 2;
}
.ag-event .ag-corner.tl { top: -1px; left: -1px;  border-right: none; border-bottom: none; }
.ag-event .ag-corner.tr { top: -1px; right: -1px; border-left: none;  border-bottom: none; }
.ag-event .ag-corner.bl { bottom: -1px; left: -1px;  border-right: none; border-top: none; }
.ag-event .ag-corner.br { bottom: -1px; right: -1px; border-left: none;  border-top: none; }
@media (min-width: 768px) { .ag-event .ag-corner { width: 36px; height: 36px; } }

.ag-event .ag-flyer-meta {
	display: flex; justify-content: space-between;
	margin-top: 14px; padding: 0 4px;
	font-family: var(--mono-font);
	font-size: 9px; letter-spacing: 0.25em; text-transform: uppercase;
	color: var(--ag-ink-faint);
}
@media (min-width: 768px) { .ag-event .ag-flyer-meta { font-size: 10px; letter-spacing: 0.3em; } }

.ag-event .ag-info { text-align: center; }
@media (min-width: 960px) { .ag-event .ag-info { text-align: left; order: 1; } }

.ag-event .ag-presents {
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--mono-font);
	font-size: 10px; letter-spacing: 0.35em; text-transform: uppercase;
	color: var(--ag-gold); margin-bottom: 14px;
}
.ag-event .ag-presents .ag-line-accent {
	width: 24px; height: 1px; background: var(--ag-gold);
}

.ag-event .ag-headline {
	font-family: var(--display-font); font-weight: 700;
	font-size: clamp(40px, 9vw, 88px); line-height: 0.92;
	letter-spacing: -0.01em; text-transform: uppercase;
	margin: 0 0 12px;
	color: var(--ag-ink);
}

.ag-event .ag-sub-italic {
	font-family: var(--serif-font); font-style: italic; font-weight: 400;
	font-size: clamp(19px, 3vw, 26px);
	color: var(--ag-ink-dim); margin: 0 0 22px; line-height: 1.35;
}

.ag-event .ag-info-grid {
	display: grid; grid-template-columns: repeat(2, 1fr);
	gap: 14px; margin-bottom: 22px;
	max-width: 480px; margin-left: auto; margin-right: auto;
}
@media (min-width: 960px) {
	.ag-event .ag-info-grid { margin-left: 0; margin-right: 0; }
}
.ag-event .ag-info-cell {
	padding: 14px 14px;
	border: 1px solid var(--ag-line);
	background: rgba(246, 245, 240, 0.03);
	text-align: left;
}
.ag-event .ag-info-cell .label {
	font-family: var(--mono-font);
	font-size: 8px; letter-spacing: 0.3em; text-transform: uppercase;
	color: var(--ag-ink-faint); margin-bottom: 4px;
}
.ag-event .ag-info-cell .value {
	font-family: var(--display-font);
	font-size: 13px; font-weight: 700; letter-spacing: 0.05em;
	text-transform: uppercase; color: var(--ag-ink); line-height: 1.2;
}
.ag-event .ag-info-cell .value.gold { color: var(--ag-gold); }
@media (min-width: 768px) {
	.ag-event .ag-info-cell { padding: 16px 18px; }
	.ag-event .ag-info-cell .label { font-size: 9px; }
	.ag-event .ag-info-cell .value { font-size: 15px; }
}

/* ---------- COUNTDOWN ---------- */
.ag-event .ag-countdown {
	display: flex; justify-content: center; gap: 10px;
	margin-bottom: 24px; flex-wrap: wrap;
}
@media (min-width: 960px) { .ag-event .ag-countdown { justify-content: flex-start; } }
.ag-event .ag-cd-cell {
	min-width: 64px; padding: 10px 8px;
	background: rgba(246, 245, 240, 0.04);
	border: 1px solid var(--ag-line);
	text-align: center;
}
@media (min-width: 768px) { .ag-event .ag-cd-cell { min-width: 78px; padding: 12px 10px; } }
.ag-event .ag-cd-num {
	font-family: var(--display-font); font-weight: 700;
	font-size: 22px; color: var(--ag-ink);
	letter-spacing: 0.02em; line-height: 1; margin-bottom: 4px;
}
@media (min-width: 768px) { .ag-event .ag-cd-num { font-size: 28px; } }
.ag-event .ag-cd-lbl {
	font-family: var(--mono-font);
	font-size: 8px; letter-spacing: 0.25em; text-transform: uppercase;
	color: var(--ag-accent);
}
@media (min-width: 768px) { .ag-event .ag-cd-lbl { font-size: 9px; } }

/* ---------- CTA BUTTONS ---------- */
.ag-event .ag-cta-row {
	display: flex; gap: 10px; flex-wrap: wrap;
	justify-content: center; margin-bottom: 12px;
}
@media (min-width: 960px) { .ag-event .ag-cta-row { justify-content: flex-start; } }
.ag-event .ag-cta {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 14px 22px;
	font-family: var(--mono-font); font-weight: 700;
	font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase;
	text-decoration: none;
	border: 1px solid var(--ag-gold);
	color: var(--ag-gold); background: transparent;
	transition: all 0.3s; cursor: pointer; min-height: 46px;
}
@media (min-width: 768px) {
	.ag-event .ag-cta { padding: 16px 28px; font-size: 11px; letter-spacing: 0.3em; }
}
.ag-event .ag-cta:hover, .ag-event .ag-cta:active {
	background: var(--ag-gold); color: #000;
}
.ag-event .ag-cta.primary {
	background: var(--ag-accent); color: #fff;
	border-color: var(--ag-accent); position: relative; overflow: hidden;
}
.ag-event .ag-cta.primary::before {
	content: ''; position: absolute; inset: 0;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
	transform: translateX(-100%);
	animation: ag-cta-sheen 2.5s ease-in-out infinite;
}
@keyframes ag-cta-sheen {
	0%, 40%   { transform: translateX(-100%); }
	60%, 100% { transform: translateX(100%); }
}
.ag-event .ag-cta.primary:hover, .ag-event .ag-cta.primary:active {
	background: var(--ag-accent-hot);
}
.ag-event .ag-cta .ag-arrow-r { transition: transform 0.3s; }
.ag-event .ag-cta:hover .ag-arrow-r { transform: translateX(4px); }

/* ---------- TICKET CARDS ---------- */
.ag-event .ag-tickets-section {
	margin-top: 48px;
	padding-top: 28px;
	border-top: 1px solid var(--ag-line);
}
.ag-event .ag-section-head { margin-bottom: 22px; text-align: center; }
@media (min-width: 768px) { .ag-event .ag-section-head { text-align: left; } }
.ag-event .ag-section-title {
	font-family: var(--display-font); font-weight: 700;
	font-size: clamp(24px, 4vw, 36px); letter-spacing: 0.01em;
	text-transform: uppercase; margin: 6px 0 0; color: var(--ag-ink);
}

.ag-event .ag-tickets {
	display: grid; gap: 14px;
	grid-template-columns: 1fr;
}
@media (min-width: 600px) {
	.ag-event .ag-tickets { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1000px) {
	.ag-event .ag-tickets { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
}
.ag-event .ag-ticket-card {
	display: flex; flex-direction: column;
	padding: 22px 20px;
	background: rgba(246, 245, 240, 0.04);
	border: 1px solid var(--ag-line);
	transition: all 0.3s;
	position: relative; overflow: hidden;
}
.ag-event .ag-ticket-card::before {
	content: ''; position: absolute; top: 0; left: 0;
	width: 40px; height: 1px; background: var(--ag-accent);
}
.ag-event .ag-ticket-card:hover {
	border-color: var(--ag-accent);
	transform: translateY(-2px);
}
.ag-event .ag-ticket-idx {
	font-family: var(--mono-font);
	font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase;
	color: var(--ag-accent); margin-bottom: 10px;
}
.ag-event .ag-ticket-title {
	font-family: var(--display-font); font-weight: 700;
	font-size: 15px; letter-spacing: 0.04em; text-transform: uppercase;
	color: var(--ag-ink); margin-bottom: 14px; line-height: 1.2;
}
.ag-event .ag-ticket-price {
	font-family: var(--display-font); font-weight: 700;
	font-size: 32px; line-height: 1;
	color: var(--ag-gold); margin-bottom: 18px;
}
.ag-event .ag-ticket-cta {
	margin-top: auto;
	display: inline-flex; align-items: center; justify-content: space-between; gap: 8px;
	padding: 12px 16px;
	font-family: var(--mono-font); font-weight: 700;
	font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase;
	text-decoration: none;
	background: var(--ag-accent); color: #fff;
	border: 1px solid var(--ag-accent);
	transition: all 0.3s; min-height: 42px;
}
.ag-event .ag-ticket-cta:hover, .ag-event .ag-ticket-cta:active {
	background: var(--ag-accent-hot); border-color: var(--ag-accent-hot); color: #fff;
}
.ag-event .ag-ticket-cta.disabled {
	background: transparent; color: var(--ag-ink-faint);
	border-color: var(--ag-line); cursor: not-allowed;
}
.ag-event .ag-tickets-empty {
	padding: 40px 16px; text-align: center;
	font-family: var(--mono-font);
	font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase;
	color: var(--ag-ink-faint);
	border: 1px dashed var(--ag-line);
}

/* ---------- DETAILS ---------- */
.ag-event .ag-details {
	margin-top: 48px;
	display: grid; gap: 18px;
	grid-template-columns: 1fr;
}
@media (min-width: 900px) {
	.ag-event .ag-details { grid-template-columns: repeat(2, 1fr); }
	.ag-event .ag-detail-card--wide { grid-column: span 1; }
}
.ag-event .ag-detail-card {
	padding: 22px 20px;
	background: rgba(246, 245, 240, 0.025);
	border: 1px solid var(--ag-line);
	position: relative; overflow: hidden;
}
.ag-event .ag-detail-card::before {
	content: ''; position: absolute; top: 0; left: 0;
	width: 40px; height: 1px; background: var(--ag-gold);
}
.ag-event .ag-detail-idx {
	font-family: var(--mono-font);
	font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase;
	color: var(--ag-accent); margin-bottom: 10px;
}
.ag-event .ag-detail-title {
	font-family: var(--display-font); font-weight: 700;
	font-size: 15px; letter-spacing: 0.05em; text-transform: uppercase;
	margin-bottom: 10px; color: var(--ag-ink);
}
.ag-event .ag-detail-body {
	font-family: var(--serif-font); font-size: 16px; line-height: 1.55;
	color: var(--ag-ink-dim);
}
.ag-event .ag-detail-body p { margin: 0 0 10px; }

/* ---------- FINAL CTA ---------- */
.ag-event .ag-final-cta {
	margin-top: 48px; padding: 36px 22px; text-align: center;
	background: rgba(246, 245, 240, 0.03);
	border: 1px solid var(--ag-line);
	position: relative; overflow: hidden;
}
@media (min-width: 768px) {
	.ag-event .ag-final-cta { padding: 52px 32px; margin-top: 64px; }
}
.ag-event .ag-final-cta h3 {
	font-family: var(--display-font); font-weight: 700;
	font-size: clamp(24px, 6vw, 42px); letter-spacing: 0.01em;
	text-transform: uppercase; line-height: 1;
	margin: 0 0 14px; color: var(--ag-ink);
}
.ag-event .ag-final-cta p {
	font-family: var(--serif-font); font-style: italic;
	font-size: clamp(14px, 3vw, 18px);
	color: var(--ag-ink-dim);
	max-width: 540px; margin: 0 auto 24px; line-height: 1.5;
}

/* ---------- FOOTER ---------- */
.ag-event .ag-footer {
	margin-top: 50px; padding-top: 24px;
	border-top: 1px solid var(--ag-line);
	display: flex; flex-direction: column; gap: 10px; align-items: center;
	font-family: var(--mono-font);
	font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase;
	color: var(--ag-ink-faint); text-align: center;
}
@media (min-width: 640px) {
	.ag-event .ag-footer {
		flex-direction: row; justify-content: space-between;
		font-size: 10px; letter-spacing: 0.25em;
	}
}

/* ================================================================
   VARIANT 1 — AFTER DARK (club / late-night)
   Black-on-black, magenta + gold + cyan, atmospheric gradients, grain
   ================================================================ */
.ag-event.ag-variant-club {
	--ag-bg: #050508;
	--ag-bg-2: #0a0a12;
	--ag-ink: #ffffff;
	--ag-ink-dim: rgba(255, 255, 255, 0.85);
	--ag-ink-faint: rgba(255, 255, 255, 0.55);
	--ag-line: rgba(255, 255, 255, 0.14);
	--ag-gold: #f0cc8a;
	--ag-cyan: #5eead4;
	--display-font: 'Syncopate', 'Helvetica Neue', sans-serif;
	--serif-font:   'Cormorant Garamond', Georgia, serif;
}
.ag-event.ag-variant-club::before {
	content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 0;
	background:
		radial-gradient(ellipse 100% 70% at 50% 0%, color-mix(in srgb, var(--ag-accent) 28%, transparent), transparent 65%),
		radial-gradient(ellipse 80% 50% at 100% 30%, rgba(225, 29, 72, 0.22), transparent 70%),
		radial-gradient(ellipse 80% 50% at 0% 50%, rgba(124, 58, 237, 0.18), transparent 70%),
		radial-gradient(ellipse 80% 60% at 50% 100%, rgba(212, 175, 110, 0.1), transparent 70%),
		linear-gradient(180deg, #120516 0%, #050508 60%, #0a0512 100%);
}
.ag-event.ag-variant-club::after {
	content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 0;
	background-image:
		linear-gradient(var(--ag-line) 1px, transparent 1px),
		linear-gradient(90deg, var(--ag-line) 1px, transparent 1px);
	background-size: 60px 60px; opacity: 0.22;
	mask-image: radial-gradient(ellipse at center, black 10%, transparent 75%);
	-webkit-mask-image: radial-gradient(ellipse at center, black 10%, transparent 75%);
}
.ag-event.ag-variant-club .ag-grain {
	display: block;
	position: absolute; inset: 0; pointer-events: none; z-index: 1;
	opacity: 0.35; mix-blend-mode: overlay;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.5'/></svg>");
}
.ag-event.ag-variant-club .ag-headline {
	background: linear-gradient(180deg, #fff 0%, #fff 40%, var(--ag-gold) 100%);
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent; color: transparent;
}
.ag-event.ag-variant-club .ag-flyer-frame {
	box-shadow:
		0 0 80px color-mix(in srgb, var(--ag-accent) 25%, transparent),
		0 0 160px rgba(124, 58, 237, 0.15),
		0 30px 80px rgba(0, 0, 0, 0.6);
	border-color: rgba(212, 175, 110, 0.3);
}
.ag-event.ag-variant-club .ag-cd-cell {
	background: linear-gradient(135deg,
		color-mix(in srgb, var(--ag-accent) 8%, transparent),
		rgba(124, 58, 237, 0.08));
	border-color: color-mix(in srgb, var(--ag-accent) 30%, transparent);
}
.ag-event.ag-variant-club .ag-final-cta {
	background: linear-gradient(135deg,
		rgba(124, 58, 237, 0.15),
		color-mix(in srgb, var(--ag-accent) 15%, transparent),
		rgba(212, 175, 110, 0.1));
	border-color: rgba(212, 175, 110, 0.3);
}
.ag-event.ag-variant-club .ag-final-cta h3 {
	background: linear-gradient(180deg, #fff 40%, var(--ag-gold) 100%);
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent;
}

/* ================================================================
   VARIANT 2 — GOLDEN HOUR (chic daytime / urban / rooftop)
   Cream, terracotta, sage, amber. Editorial, sun-washed, no grain.
   ================================================================ */
.ag-event.ag-variant-daytime {
	--ag-bg: #f7f1e6;
	--ag-bg-2: #efe7d4;
	--ag-ink: #2a1f14;
	--ag-ink-dim: rgba(42, 31, 20, 0.7);
	--ag-ink-faint: rgba(42, 31, 20, 0.4);
	--ag-line: rgba(42, 31, 20, 0.12);
	--ag-accent: #c0653d;
	--ag-accent-hot: #d97a4f;
	--ag-gold: #b08642;
	--ag-secondary: #7a8c6a;
	--display-font: 'Cormorant Garamond', Georgia, serif;
	--serif-font:   'Cormorant Garamond', Georgia, serif;
	--ui-font:      'Inter', system-ui, sans-serif;
}
.ag-event.ag-variant-daytime::before {
	content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 0;
	background:
		radial-gradient(ellipse 80% 50% at 80% 10%, rgba(217, 122, 79, 0.12), transparent 65%),
		radial-gradient(ellipse 70% 40% at 10% 60%, rgba(122, 140, 106, 0.08), transparent 70%),
		linear-gradient(180deg, #faf4e8 0%, #f7f1e6 60%, #eee4d0 100%);
}
.ag-event.ag-variant-daytime .ag-headline {
	font-style: italic; font-weight: 600;
	letter-spacing: -0.02em; text-transform: none;
	color: var(--ag-ink);
}
.ag-event.ag-variant-daytime .ag-info-cell { background: rgba(42, 31, 20, 0.025); }
.ag-event.ag-variant-daytime .ag-presents,
.ag-event.ag-variant-daytime .ag-detail-idx,
.ag-event.ag-variant-daytime .ag-ticket-idx { color: var(--ag-accent); }
.ag-event.ag-variant-daytime .ag-presents .ag-line-accent { background: var(--ag-accent); }
.ag-event.ag-variant-daytime .ag-cd-lbl { color: var(--ag-secondary); }
.ag-event.ag-variant-daytime .ag-flyer-frame {
	border-color: rgba(42, 31, 20, 0.15);
	box-shadow: 0 30px 60px rgba(42, 31, 20, 0.15), 0 8px 20px rgba(42, 31, 20, 0.08);
}
.ag-event.ag-variant-daytime .ag-cta { color: var(--ag-ink); border-color: var(--ag-ink); }
.ag-event.ag-variant-daytime .ag-cta:hover { background: var(--ag-ink); color: var(--ag-bg); }
.ag-event.ag-variant-daytime .ag-cta.primary { background: var(--ag-accent); border-color: var(--ag-accent); color: #fff; }
.ag-event.ag-variant-daytime .ag-ticket-price { color: var(--ag-accent); }
.ag-event.ag-variant-daytime .ag-info-cell .value.gold { color: var(--ag-accent); }
.ag-event.ag-variant-daytime .ag-final-cta {
	background: linear-gradient(135deg,
		rgba(192, 101, 61, 0.10),
		rgba(122, 140, 106, 0.08));
	border-color: rgba(42, 31, 20, 0.15);
}

/* ================================================================
   VARIANT 3 — SIGNAL (listening room / conference / panel)
   Off-white slate, single emerald accent, strict grid, restrained.
   ================================================================ */
.ag-event.ag-variant-signal {
	--ag-bg: #f4f1ea;
	--ag-bg-2: #ebe7dd;
	--ag-ink: #1c1c1e;
	--ag-ink-dim: rgba(28, 28, 30, 0.7);
	--ag-ink-faint: rgba(28, 28, 30, 0.45);
	--ag-line: rgba(28, 28, 30, 0.12);
	--ag-accent: #0a6e4d;
	--ag-accent-hot: #0d8a60;
	--ag-gold: #1c1c1e;
	--display-font: 'Manrope', system-ui, sans-serif;
	--serif-font:   'Cormorant Garamond', Georgia, serif;
	--ui-font:      'Inter', system-ui, sans-serif;
}
.ag-event.ag-variant-signal::before {
	content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 0;
	background: linear-gradient(180deg, #faf7f0 0%, var(--ag-bg) 100%);
}
.ag-event.ag-variant-signal .ag-headline {
	letter-spacing: -0.025em; font-weight: 800;
	font-size: clamp(36px, 7vw, 72px);
	color: var(--ag-ink);
}
.ag-event.ag-variant-signal .ag-sub-italic { font-style: normal; font-family: var(--ui-font); font-weight: 400; }
.ag-event.ag-variant-signal .ag-presents,
.ag-event.ag-variant-signal .ag-ticket-idx,
.ag-event.ag-variant-signal .ag-detail-idx { color: var(--ag-accent); }
.ag-event.ag-variant-signal .ag-presents .ag-line-accent { background: var(--ag-accent); }
.ag-event.ag-variant-signal .ag-cd-lbl { color: var(--ag-accent); }
.ag-event.ag-variant-signal .ag-flyer-frame {
	border-color: var(--ag-line);
	box-shadow: 0 20px 50px rgba(28, 28, 30, 0.12);
}
.ag-event.ag-variant-signal .ag-info-cell { background: rgba(28, 28, 30, 0.02); }
.ag-event.ag-variant-signal .ag-cta { color: var(--ag-ink); border-color: var(--ag-ink); }
.ag-event.ag-variant-signal .ag-cta:hover { background: var(--ag-ink); color: var(--ag-bg); }
.ag-event.ag-variant-signal .ag-cta.primary {
	background: var(--ag-accent); border-color: var(--ag-accent); color: #fff;
}
.ag-event.ag-variant-signal .ag-cta.primary::before { display: none; } /* no sheen — too playful */
.ag-event.ag-variant-signal .ag-ticket-card { background: #fff; }
.ag-event.ag-variant-signal .ag-ticket-price { color: var(--ag-ink); }
.ag-event.ag-variant-signal .ag-info-cell .value.gold { color: var(--ag-accent); }
.ag-event.ag-variant-signal .ag-final-cta {
	background: rgba(10, 110, 77, 0.06);
	border-color: var(--ag-line);
}
.ag-event.ag-variant-signal .ag-nav-meta .ag-dot { animation: none; box-shadow: none; }

/* ================================================================
   AG BOTTLE MAP — variant-aware overrides so the plugin's map
   inherits the surrounding event-page palette
   ================================================================ */
.ag-event .ag-bottle-section {
	margin-top: 48px;
	padding-top: 28px;
	border-top: 1px solid var(--ag-line);
}
.ag-event .ag-bottle-map-wrap {
	margin: 0 auto;
}

/* After Dark — re-tint the map to match magenta+gold-on-black */
.ag-event.ag-variant-club .agbm-root {
	--agbm-bg:          var(--ag-bg);
	--agbm-bg-elev:     var(--ag-bg-2);
	--agbm-ink:         var(--ag-ink);
	--agbm-ink-dim:     var(--ag-ink-dim);
	--agbm-ink-faint:   var(--ag-ink-faint);
	--agbm-gold:        var(--ag-gold);
	--agbm-gold-bright: var(--ag-gold);
	--agbm-line:        var(--ag-line);
	/* Keep green/red dot colors — they're functional UX (available/sold) */
}
.ag-event.ag-variant-club .agbm-header { border-color: var(--ag-line); }
.ag-event.ag-variant-club .agbm-reserve-btn {
	background: var(--ag-accent) !important;
	color: #fff !important;
	border-color: var(--ag-accent) !important;
}
.ag-event.ag-variant-club .agbm-reserve-btn:hover { background: var(--ag-accent-hot) !important; }

/* Golden Hour — terracotta on cream */
.ag-event.ag-variant-daytime .agbm-root {
	--agbm-bg:          var(--ag-bg);
	--agbm-bg-elev:     var(--ag-bg-2);
	--agbm-ink:         var(--ag-ink);
	--agbm-ink-dim:     var(--ag-ink-dim);
	--agbm-ink-faint:   var(--ag-ink-faint);
	--agbm-gold:        var(--ag-accent);
	--agbm-gold-bright: var(--ag-accent-hot);
	--agbm-line:        var(--ag-line);
}

/* Signal — restrained graphite + emerald */
.ag-event.ag-variant-signal .agbm-root {
	--agbm-bg:          var(--ag-bg);
	--agbm-bg-elev:     var(--ag-bg-2);
	--agbm-ink:         var(--ag-ink);
	--agbm-ink-dim:     var(--ag-ink-dim);
	--agbm-ink-faint:   var(--ag-ink-faint);
	--agbm-gold:        var(--ag-accent);
	--agbm-gold-bright: var(--ag-accent-hot);
	--agbm-line:        var(--ag-line);
}
