/*
Theme Name: UEG Events
Theme URI: https://urbaneventsglobal.com
Author: Urban Events Global
Author URI: https://urbaneventsglobal.com
Description: Official theme for Urban Events Global — Hybrid A+B: premium Black travel brand meets high-energy events platform. Aspirational, immersive, and alive.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: Proprietary
Text Domain: ueg-events
Tags: event, landing-page, black-owned, travel, community, premium
*/

/* ============================================================
   DESIGN SYSTEM — CSS CUSTOM PROPERTIES (Hybrid A+B)
   ============================================================ */
:root {
  /* ── Core Brand ── */
  --ueg-black:       #0a0a0a;
  --ueg-deep:        #080808;
  --ueg-dark:        #111111;
  --ueg-charcoal:    #1a1a1a;
  --ueg-graphite:    #242424;
  --ueg-mid:         #2e2e2e;
  --ueg-white:       #ffffff;
  --ueg-off-white:   #f8f6f1;
  --ueg-cream:       #f2ede3;
  --ueg-muted:       rgba(255,255,255,0.45);
  --ueg-subtle:      rgba(255,255,255,0.12);

  /* ── Premium Gold (Option A) ── */
  --ueg-gold:        #d4a843;
  --ueg-gold-light:  #e8c46a;
  --ueg-gold-dark:   #a87f2a;
  --ueg-gold-glow:   rgba(212,168,67,0.18);

  /* ── Energy Amber (Option B) ── */
  --ueg-amber:       #F59E0B;
  --ueg-amber-dark:  #D97706;
  --ueg-fire:        #EA580C;
  --ueg-fire-glow:   rgba(234,88,12,0.20);

  /* ── Pillar Colors ── */
  --ueg-events:      #EA580C;    /* Events — fire orange */
  --ueg-community:   #0D9488;    /* Community — teal */
  --ueg-marketing:   #d4a843;    /* Marketing — gold */
  --ueg-content:     #7C3AED;    /* BTT — purple */

  /* ── Borders ── */
  --ueg-border-dark: rgba(255,255,255,0.08);
  --ueg-border-gold: rgba(212,168,67,0.25);
  --ueg-border-mid:  rgba(255,255,255,0.15);

  /* ── Light-mode surfaces (for pages with light bg) ── */
  --ueg-surface:     #f8f6f1;
  --ueg-surface-2:   #f2ede3;
  --ueg-text-dark:   #1a1a1a;
  --ueg-text-mid:    #4a4540;
  --ueg-text-light:  #7a7570;

  /* ── Typography ── */
  --font-display: 'Playfair Display', 'Georgia', serif;
  --font-body:    'DM Sans', 'Helvetica Neue', sans-serif;
  --font-mono:    'DM Mono', 'Courier New', monospace;

  /* ── Spacing ── */
  --space-xs:  0.5rem;
  --space-sm:  1rem;
  --space-md:  1.5rem;
  --space-lg:  2.5rem;
  --space-xl:  4rem;
  --space-2xl: 6rem;
  --space-3xl: 9rem;

  /* ── Layout ── */
  --content-width: 760px;
  --wide-width:    1140px;
  --full-width:    1440px;

  /* ── Radii ── */
  --radius-sm: 4px;
  --radius-md: 10px;
  --radius-lg: 20px;
  --radius-xl: 32px;

  /* ── Motion ── */
  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-in:     cubic-bezier(0.4, 0, 1, 1);
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--ueg-dark);
  background: var(--ueg-black);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* ============================================================
   SITE HEADER
   ============================================================ */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: rgba(10,10,10,0.95);
  border-bottom: 1px solid var(--ueg-border-gold);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: background 0.3s var(--ease-out), border-color 0.3s;
}

.site-header.scrolled {
  background: rgba(8,8,8,0.98);
  border-bottom-color: rgba(212,168,67,0.35);
}

.header-inner {
  max-width: var(--wide-width);
  margin: 0 auto;
  padding: 0 2rem;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}

/* Logo */
.site-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
}

.logo-mark {
  width: 38px; height: 38px;
  background: linear-gradient(135deg, var(--ueg-gold), var(--ueg-amber));
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-weight: 700; font-size: 13px;
  color: var(--ueg-black);
  letter-spacing: -0.02em;
  flex-shrink: 0;
}

.logo-text {
  font-family: var(--font-display);
  font-size: 1.05rem; font-weight: 600;
  color: var(--ueg-white);
  line-height: 1.2;
}

.logo-sub {
  font-family: var(--font-body);
  font-size: 0.62rem; font-weight: 500;
  color: var(--ueg-gold);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  display: block;
  margin-top: 2px;
}

/* Primary Nav */
.site-nav {
  display: flex;
  align-items: center;
  gap: 1.75rem;
}

/* wp_nav_menu outputs a <ul class="nav-menu"> — must be flex for horizontal layout */
.nav-menu {
  display: flex;
  align-items: center;
  gap: 1.75rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.site-nav a {
  font-size: 0.8rem; font-weight: 500;
  color: rgba(255,255,255,0.7);
  text-transform: uppercase;
  letter-spacing: 0.09em;
  transition: color 0.2s;
  white-space: nowrap;
}

.site-nav a:hover { color: var(--ueg-gold); }

.nav-cta {
  background: linear-gradient(135deg, var(--ueg-amber), var(--ueg-fire)) !important;
  color: var(--ueg-white) !important;
  padding: 0.55rem 1.3rem !important;
  border-radius: var(--radius-sm) !important;
  font-weight: 700 !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.08em !important;
  transition: opacity 0.2s, transform 0.2s !important;
  box-shadow: 0 4px 16px rgba(234,88,12,0.35) !important;
}
.nav-cta:hover {
  opacity: 0.92 !important;
  transform: translateY(-1px) !important;
}

/* Mobile-only nav CTA — hidden on desktop, shown in mobile drawer */
.nav-mobile-cta { display: none; }

/* Mobile Menu Toggle */
.mobile-menu-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  width: 40px; height: 40px;
  justify-content: center;
  align-items: center;
  background: transparent;
  border: 1px solid var(--ueg-border-mid);
  border-radius: var(--radius-sm);
  z-index: 1001;
}

.mobile-menu-toggle span {
  display: block;
  width: 20px; height: 2px;
  background: var(--ueg-white);
  border-radius: 2px;
  transition: transform 0.3s var(--ease-out), opacity 0.2s;
  transform-origin: center;
}

.mobile-menu-toggle.is-active span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.mobile-menu-toggle.is-active span:nth-child(2) {
  opacity: 0; transform: scaleX(0);
}
.mobile-menu-toggle.is-active span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ============================================================
   CONTAINER — shared layout utility (used by all templates)
   ============================================================ */
.container {
  max-width: var(--wide-width);
  margin-left: auto;
  margin-right: auto;
  padding-left: 2rem;
  padding-right: 2rem;
  width: 100%;
  box-sizing: border-box;
}

/* ============================================================
   SITE STRUCTURE
   ============================================================ */
/* header.php opens <div class="site"><main class="site-main"> — no .site-content element */
.site-main { padding-top: 72px; min-height: 60vh; }

/* Skip link */
.skip-link {
  position: absolute;
  top: -100px; left: 16px;
  background: var(--ueg-amber);
  color: var(--ueg-black);
  padding: 8px 16px;
  font-weight: 700;
  font-size: 0.85rem;
  border-radius: var(--radius-sm);
  z-index: 9999;
  transition: top 0.2s;
}
.skip-link:focus { top: 16px; }

/* ============================================================
   HOMEPAGE — HERO SECTION
   ============================================================ */
.ueg-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  background: var(--ueg-deep);
  overflow: hidden;
}

.ueg-hero__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 100% at 20% 80%, rgba(212,168,67,0.12) 0%, transparent 55%),
    radial-gradient(ellipse 60% 80% at 85% 15%, rgba(234,88,12,0.09) 0%, transparent 50%),
    radial-gradient(ellipse 40% 60% at 60% 50%, rgba(124,58,237,0.05) 0%, transparent 50%);
}

.ueg-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(8,8,8,0.3) 0%, rgba(8,8,8,0.1) 40%, rgba(8,8,8,0.7) 100%);
}

.ueg-hero__img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.22;
  filter: saturate(1.1);
}

.ueg-hero__inner,
.ueg-hero__content {
  position: relative;
  z-index: 1;
  max-width: var(--wide-width);
  margin: 0 auto;
  padding: var(--space-3xl) 2rem var(--space-2xl);
  width: 100%;
}

.ueg-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ueg-gold);
  margin-bottom: 1.5rem;
}

.ueg-hero__eyebrow::before {
  content: '';
  display: block;
  width: 24px; height: 2px;
  background: var(--ueg-gold);
}

.ueg-hero__headline {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 5.5rem);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--ueg-white);
  max-width: 820px;
  margin-bottom: 1.5rem;
}

.ueg-hero__headline em {
  font-style: italic;
  color: var(--ueg-gold);
}

.ueg-hero__sub {
  font-size: clamp(1rem, 1.8vw, 1.2rem);
  color: rgba(255,255,255,0.7);
  max-width: 560px;
  line-height: 1.65;
  margin-bottom: 2.5rem;
}

.ueg-hero__ctas {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  align-items: center;
}

.ueg-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--ueg-amber), var(--ueg-fire));
  color: var(--ueg-white);
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  padding: 1rem 2rem;
  border-radius: var(--radius-sm);
  border: none;
  cursor: pointer;
  box-shadow: 0 6px 24px rgba(234,88,12,0.40);
  transition: transform 0.2s var(--ease-out), box-shadow 0.2s, opacity 0.15s;
  white-space: nowrap;
}
.ueg-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(234,88,12,0.50);
}

.ueg-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  color: var(--ueg-white);
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  padding: 1rem 2rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--ueg-border-mid);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
  white-space: nowrap;
}
.ueg-btn-secondary:hover {
  border-color: var(--ueg-gold);
  background: rgba(212,168,67,0.08);
  color: var(--ueg-gold);
}

.ueg-btn-gold {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--ueg-gold);
  color: var(--ueg-black);
  font-size: 0.88rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.875rem 1.75rem;
  border-radius: var(--radius-sm);
  border: none;
  cursor: pointer;
  transition: background 0.2s, transform 0.2s var(--ease-out);
}
.ueg-btn-gold:hover {
  background: var(--ueg-gold-light);
  transform: translateY(-2px);
}

.ueg-hero__stats {
  display: flex;
  gap: 2.5rem;
  margin-top: 3.5rem;
  flex-wrap: wrap;
}

.hero-stat__num {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  color: var(--ueg-white);
  line-height: 1;
}

.hero-stat__label {
  font-size: 0.72rem;
  font-weight: 500;
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-top: 4px;
}

.ueg-hero__scroll {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: rgba(255,255,255,0.35);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  animation: scrollBounce 2.5s ease-in-out infinite;
}

.ueg-hero__scroll::after {
  content: '';
  display: block;
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, rgba(255,255,255,0.3), transparent);
}

@keyframes scrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50% { transform: translateX(-50%) translateY(6px); }
}

/* ============================================================
   SOCIAL PROOF TICKER
   ============================================================ */
.ueg-ticker {
  background: var(--ueg-charcoal);
  border-top: 1px solid var(--ueg-border-gold);
  border-bottom: 1px solid var(--ueg-border-gold);
  overflow: hidden;
  height: 48px;
  display: flex;
  align-items: center;
}

.ueg-ticker__track {
  display: flex;
  gap: 0;
  animation: tickerSlide 30s linear infinite;
  white-space: nowrap;
}

.ueg-ticker__track:hover { animation-play-state: paused; }

.ueg-ticker__item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 0 2.5rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: rgba(255,255,255,0.7);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  white-space: nowrap;
}

.ueg-ticker__item .dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--ueg-gold);
  flex-shrink: 0;
}

.ueg-ticker__item strong { color: var(--ueg-gold); }

@keyframes tickerSlide {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ============================================================
   SECTION SHARED STYLES
   ============================================================ */
.ueg-section {
  padding: var(--space-3xl) 2rem;
}

.ueg-section--dark   { background: var(--ueg-deep); }
.ueg-section--black  { background: var(--ueg-black); }
.ueg-section--charcoal { background: var(--ueg-charcoal); }
.ueg-section--light  { background: var(--ueg-off-white); }

.ueg-section__inner {
  max-width: var(--wide-width);
  margin: 0 auto;
}

.ueg-section__header {
  margin-bottom: 3.5rem;
}

.ueg-section__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ueg-gold);
  margin-bottom: 0.875rem;
}

.ueg-section__eyebrow::before {
  content: '';
  display: block;
  width: 20px; height: 2px;
  background: var(--ueg-gold);
}

.ueg-section--light .ueg-section__eyebrow { color: var(--ueg-amber-dark); }
.ueg-section--light .ueg-section__eyebrow::before { background: var(--ueg-amber-dark); }

.ueg-section__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3.5vw, 3rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--ueg-white);
}

.ueg-section--light .ueg-section__title { color: var(--ueg-text-dark); }

.ueg-section__title em { font-style: italic; color: var(--ueg-gold); }

.ueg-section__sub {
  font-size: 1.05rem;
  color: rgba(255,255,255,0.6);
  max-width: 520px;
  line-height: 1.65;
  margin-top: 0.875rem;
}

.ueg-section--light .ueg-section__sub { color: var(--ueg-text-mid); }

/* ============================================================
   4 PILLARS GRID
   ============================================================ */
.ueg-pillars {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--ueg-border-dark);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.ueg-pillar {
  background: var(--ueg-charcoal);
  padding: 2.25rem 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
  transition: background 0.3s;
  cursor: default;
}

.ueg-pillar::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--pillar-color, var(--ueg-gold));
}

.ueg-pillar:hover { background: var(--ueg-graphite); }

.ueg-pillar--events    { --pillar-color: var(--ueg-events); }
.ueg-pillar--community { --pillar-color: var(--ueg-community); }
.ueg-pillar--marketing { --pillar-color: var(--ueg-marketing); }
.ueg-pillar--content   { --pillar-color: var(--ueg-content); }

.ueg-pillar__num {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--pillar-color, var(--ueg-gold));
  line-height: 1;
  opacity: 0.5;
}

.ueg-pillar__name {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--ueg-white);
  line-height: 1.2;
}

.ueg-pillar__sub {
  font-size: 0.83rem;
  color: rgba(255,255,255,0.5);
  line-height: 1.55;
}

.ueg-pillar__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--pillar-color, var(--ueg-gold));
  margin-top: auto;
  padding-top: 0.5rem;
  transition: gap 0.2s;
}

.ueg-pillar__link:hover { gap: 10px; }

/* ============================================================
   EVENTS SECTION
   ============================================================ */
.ueg-events-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

.ueg-event-card {
  background: var(--ueg-charcoal);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: transform 0.3s var(--ease-out), border-color 0.3s;
  display: flex;
  flex-direction: column;
}

.ueg-event-card:hover {
  transform: translateY(-4px);
  border-color: var(--ueg-border-gold);
}

.ueg-event-card__thumb {
  height: 200px;
  background: var(--ueg-graphite);
  position: relative;
  overflow: hidden;
}

.ueg-event-card__thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.5s var(--ease-out);
}
.ueg-event-card:hover .ueg-event-card__thumb img {
  transform: scale(1.04);
}

.ueg-event-card__badge {
  position: absolute;
  top: 12px; left: 12px;
  background: var(--ueg-events);
  color: var(--ueg-white);
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  padding: 4px 10px;
  border-radius: 20px;
}

.ueg-event-card__body {
  padding: 1.25rem 1.5rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  flex: 1;
}

.ueg-event-card__date {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ueg-gold);
}

.ueg-event-card__title {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--ueg-white);
  line-height: 1.3;
}

.ueg-event-card__location {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.5);
  display: flex;
  align-items: center;
  gap: 5px;
}

.ueg-event-card__countdown {
  display: flex;
  gap: 0.625rem;
  margin: 0.5rem 0;
}

.countdown-unit {
  text-align: center;
  background: var(--ueg-graphite);
  border-radius: var(--radius-sm);
  padding: 6px 10px;
  min-width: 44px;
}

.countdown-num {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ueg-amber);
  line-height: 1;
}

.countdown-label {
  font-size: 0.55rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.4);
  margin-top: 3px;
}

.ueg-event-card__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  background: linear-gradient(135deg, var(--ueg-amber), var(--ueg-fire));
  color: var(--ueg-white);
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  padding: 0.75rem;
  border-radius: var(--radius-sm);
  transition: opacity 0.2s;
  margin-top: auto;
}
.ueg-event-card__cta:hover { opacity: 0.88; }

/* ============================================================
   COMMUNITY HUB
   ============================================================ */
/* Section wrapper — NOT the card grid */
.ueg-community-grid {
  display: block;
  padding: 5rem 0;
}

/* 4-card inner grid (inside .ueg-community-grid > .container) */
.community-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  margin-bottom: 2rem;
}

/* Community card — div wrapper */
.community-card {
  background: var(--ueg-charcoal);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: transform 0.3s var(--ease-out), border-color 0.3s, box-shadow 0.3s;
  display: flex;
  flex-direction: column;
  color: inherit;
}

.community-card:hover {
  transform: translateY(-4px);
  border-color: rgba(13,148,136,0.45);
  box-shadow: 0 8px 32px rgba(0,0,0,0.3);
}

/* Inner anchor covers the card body */
.community-card__link {
  display: block;
  text-decoration: none;
  color: inherit;
  flex: 1;
}

/* WhatsApp join button */
.community-card__wa-btn {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.6rem 1.25rem;
  background: rgba(37,211,102,0.1);
  border-top: 1px solid rgba(37,211,102,0.18);
  color: #25d366;
  font-size: 0.75rem;
  font-weight: 600;
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: background 0.2s, color 0.2s;
}
.community-card__wa-btn:hover {
  background: rgba(37,211,102,0.22);
  color: #fff;
}

.community-card__flag {
  font-size: 2.25rem;
  padding: 1.5rem 1.5rem 0.75rem;
  display: block;
  background: linear-gradient(135deg, var(--ueg-graphite), var(--ueg-mid));
}

.community-card__body {
  padding: 1rem 1.5rem 1.5rem;
}

.community-card__region {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--ueg-white);
  margin-bottom: 0.5rem;
}

.community-card__desc {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.55;
  margin-bottom: 1rem;
}

.community-card__stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.community-card__stat strong {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ueg-community);
  line-height: 1;
}

.community-card__stat span {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.4);
}

/* CTA below community grid */
.section-cta-wrap {
  text-align: center;
  margin-top: 1.5rem;
}

/* Legacy BEM card styles (keep for backwards compat) */
.ueg-community-card {
  background: var(--ueg-charcoal);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: transform 0.3s var(--ease-out), border-color 0.3s;
}

.ueg-community-card:hover {
  transform: translateY(-3px);
  border-color: rgba(13,148,136,0.4);
}

.ueg-community-card__header {
  background: linear-gradient(135deg, var(--ueg-graphite), var(--ueg-mid));
  padding: 1.75rem 1.5rem 1.25rem;
  position: relative;
  overflow: hidden;
}

.ueg-community-card__header::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--ueg-community);
}

.ueg-community-card__flag {
  font-size: 2.5rem;
  margin-bottom: 0.5rem;
}

.ueg-community-card__city {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ueg-white);
}

.ueg-community-card__country {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ueg-community);
  margin-top: 2px;
}

.ueg-community-card__body {
  padding: 1.25rem 1.5rem 1.5rem;
}

.ueg-community-card__count {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  color: var(--ueg-white);
  line-height: 1;
}

.ueg-community-card__count-label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.45);
  margin-top: 3px;
  margin-bottom: 1rem;
}

.ueg-community-card__features {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  margin-bottom: 1.25rem;
}

.ueg-community-card__feature {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.6);
  display: flex;
  align-items: center;
  gap: 7px;
}

.ueg-community-card__feature::before {
  content: '';
  display: block;
  width: 14px; height: 14px;
  background: rgba(13,148,136,0.25);
  border-radius: 50%;
  border: 1px solid rgba(13,148,136,0.5);
  flex-shrink: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='8' height='6' viewBox='0 0 8 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 3L3 5L7 1' stroke='%230D9488' stroke-width='1.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}

.ueg-community-card__join {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  background: transparent;
  color: var(--ueg-community);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 0.7rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(13,148,136,0.5);
  transition: background 0.2s, border-color 0.2s;
}
.ueg-community-card__join:hover {
  background: rgba(13,148,136,0.15);
  border-color: var(--ueg-community);
}

/* ============================================================
   BLACK TRAVEL TUBE PREVIEW
   ============================================================ */
.ueg-btt {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}

.ueg-btt__logo-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(124,58,237,0.15);
  border: 1px solid rgba(124,58,237,0.3);
  color: #a78bfa;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  padding: 4px 12px;
  border-radius: 20px;
  margin-bottom: 1.25rem;
}

.ueg-btt__logo-badge::before {
  content: '▶';
  font-size: 0.6rem;
}

.ueg-btt__videos {
  display: grid;
  gap: 0.75rem;
}

.ueg-btt__video-card {
  display: flex;
  gap: 0.875rem;
  align-items: center;
  background: var(--ueg-graphite);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: border-color 0.25s;
  cursor: pointer;
}
.ueg-btt__video-card:hover { border-color: rgba(124,58,237,0.4); }

.ueg-btt__thumb {
  width: 120px; height: 78px;
  background: var(--ueg-mid);
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}
.ueg-btt__thumb img { width: 100%; height: 100%; object-fit: cover; }

.ueg-btt__play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.4);
}

.ueg-btt__play-btn {
  width: 28px; height: 28px;
  background: rgba(124,58,237,0.9);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6rem;
  color: white;
}

.ueg-btt__info { padding: 0.75rem 1rem 0.75rem 0; flex: 1; }
.ueg-btt__info-title {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--ueg-white);
  line-height: 1.4;
  margin-bottom: 4px;
}
.ueg-btt__info-meta { font-size: 0.72rem; color: rgba(255,255,255,0.4); }

/* ============================================================
   EMAIL CAPTURE SECTION
   ============================================================ */
.ueg-capture {
  background: linear-gradient(135deg, #0a0a0a 0%, #111111 50%, #0f0d0a 100%);
  border-top: 1px solid var(--ueg-border-gold);
  border-bottom: 1px solid var(--ueg-border-gold);
  position: relative;
  overflow: hidden;
}

.ueg-capture::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 100% at 10% 50%, rgba(212,168,67,0.06) 0%, transparent 60%),
    radial-gradient(ellipse 40% 80% at 90% 50%, rgba(234,88,12,0.05) 0%, transparent 55%);
  pointer-events: none;
}

.ueg-capture__inner {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
  position: relative;
  z-index: 1;
}

.ueg-capture__form {
  display: flex;
  gap: 0.75rem;
  margin-top: 2rem;
  flex-wrap: wrap;
}

.ueg-capture__input {
  flex: 1;
  min-width: 220px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--ueg-border-mid);
  color: var(--ueg-white);
  font-family: var(--font-body);
  font-size: 0.95rem;
  padding: 0.9rem 1.25rem;
  border-radius: var(--radius-sm);
  outline: none;
  transition: border-color 0.2s;
}
.ueg-capture__input::placeholder { color: rgba(255,255,255,0.35); }
.ueg-capture__input:focus { border-color: var(--ueg-gold); }

.ueg-capture__note {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.3);
  margin-top: 0.875rem;
  letter-spacing: 0.02em;
}

/* ============================================================
   SOCIAL PROOF / STATS STRIP
   ============================================================ */
.ueg-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--ueg-border-dark);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.ueg-stat {
  background: var(--ueg-charcoal);
  padding: 2rem 1.5rem;
  text-align: center;
}

.ueg-stat__num {
  font-family: var(--font-display);
  font-size: 2.75rem;
  font-weight: 800;
  color: var(--ueg-white);
  line-height: 1;
}

.ueg-stat__num--gold { color: var(--ueg-gold); }
.ueg-stat__num--amber { color: var(--ueg-amber); }

.ueg-stat__label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.45);
  margin-top: 6px;
}

/* ============================================================
   EVENTS SECTION — HEADER ENHANCEMENTS
   ============================================================ */

/* Destination strip */
.ueg-dest-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1.25rem;
}
.ueg-dest-item {
  font-size: 0.82rem;
  font-weight: 600;
  color: rgba(255,255,255,0.55);
  letter-spacing: 0.03em;
}
.ueg-dest-sep { color: rgba(255,255,255,0.2); font-size: 0.75rem; }

/* Next-up + affirm row */
.ueg-events-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: var(--space-xl);
  padding: 1rem 1.5rem;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-md);
}
.ueg-next-up {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.ueg-next-up__label {
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ueg-amber);
  background: rgba(245,158,11,0.12);
  border: 1px solid rgba(245,158,11,0.25);
  border-radius: 999px;
  padding: 0.2rem 0.65rem;
  flex-shrink: 0;
}
.ueg-next-up__event {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--ueg-white);
}
.ueg-next-up__date {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.45);
}
.ueg-affirm-note {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.45);
  flex-shrink: 0;
}

/* Tab archived label */
.ueg-tab__archived {
  font-size: 0.62em;
  opacity: 0.5;
  margin-left: 0.3em;
  font-weight: 400;
}

/* ── Card image with real photo ── */
.ueg-card-img--photo {
  background-size: cover;
  background-position: center;
}
.ueg-card-img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.15) 0%,
    rgba(0,0,0,0.45) 100%
  );
  z-index: 1;
}
.ueg-card-img--photo .ueg-badge { z-index: 2; }
.ueg-card-img--photo .ueg-past-badge { z-index: 2; }

/* Gold strip for Essence */
.ueg-strip--gold { background: linear-gradient(90deg, var(--ueg-gold), var(--ueg-gold-light)); }

/* ── International trips banner ── */
.ueg-intl-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  background: rgba(124,58,237,0.07);
  border: 1px solid rgba(124,58,237,0.18);
  border-radius: var(--radius-md);
  padding: 1rem 1.5rem;
  margin-bottom: var(--space-xl);
}
.ueg-intl-banner__copy {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.ueg-intl-banner__copy strong {
  font-size: 0.9rem;
  color: var(--ueg-white);
}
.ueg-intl-banner__copy span {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.55);
}
.ueg-intl-banner__tag {
  font-size: 0.78rem;
  font-weight: 600;
  color: #a78bfa;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── Essence collection header ── */
.ueg-collection-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
  background: linear-gradient(135deg, rgba(212,168,67,0.08) 0%, rgba(212,168,67,0.03) 100%);
  border: 1px solid rgba(212,168,67,0.2);
  border-left: 3px solid var(--ueg-gold);
  border-radius: var(--radius-md);
  padding: 1.5rem 2rem;
  margin-bottom: var(--space-xl);
}
.ueg-collection-badge {
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ueg-gold);
  margin-bottom: 0.5rem;
}
.ueg-collection-title {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--ueg-white);
  margin: 0 0 0.35rem;
  line-height: 1.2;
}
.ueg-collection-sub {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.55);
  margin: 0;
  max-width: 480px;
}
.ueg-collection-header__right {
  display: flex;
  gap: 2rem;
  flex-shrink: 0;
}
.ueg-collection-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  text-align: center;
}
.ueg-collection-stat span:first-child {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 900;
  color: var(--ueg-gold);
  line-height: 1;
}
.ueg-collection-stat {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.4);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Essence events grid — narrower cards, show all 5 */
.ueg-events-grid--essence {
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}

/* Past event notice */
.ueg-past-notice {
  text-align: center;
  padding: var(--space-2xl) 0;
}
.ueg-past-notice h3 {
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--ueg-white);
  margin-bottom: 0.75rem;
}
.ueg-past-notice p {
  color: var(--ueg-muted);
  margin-bottom: var(--space-lg);
}

/* ============================================================
   EMAIL CAPTURE / JOIN CTA — LAYOUT & COMPONENTS
   ============================================================ */

/* Two-column layout: copy left, form right */
.capture-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  padding: 5rem 0;
}

.ueg-capture .container { position: relative; z-index: 1; }

.capture-eyebrow {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--ueg-gold);
  margin-bottom: 0.75rem;
  font-weight: 600;
}

.capture-headline {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 800;
  color: var(--ueg-white);
  line-height: 1.15;
  margin-bottom: 1rem;
}

.capture-sub {
  color: rgba(255,255,255,0.65);
  font-size: 1rem;
  line-height: 1.65;
  margin-bottom: 1.5rem;
}

.capture-perks {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.capture-perks li {
  color: rgba(255,255,255,0.8);
  font-size: 0.95rem;
}

/* Social proof row below form */
.capture-proof {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-top: 0.75rem;
  padding: 0.65rem 1rem;
  background: rgba(255,255,255,0.06);
  border-radius: var(--radius-sm);
}

.capture-proof p {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.6);
  margin: 0;
}

.avatar-stack {
  font-size: 1.1rem;
  letter-spacing: -0.3em;
}

/* ============================================================
   GHL FORM EMBED STYLES
   ============================================================ */

/* White card wrap — matches GHL form's own white background */
.ueg-ghl-form-wrap {
  background: #fff;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 16px 56px rgba(0,0,0,0.4);
}

.ueg-ghl-form-wrap iframe {
  width: 100%;
  border: none;
  display: block;
  min-height: 650px;
  background: transparent;
}

/* Footer form — slightly more height for standalone white card */
.footer-ghl-form iframe {
  min-height: 630px;
}

/* ============================================================
   BRAND PARTNERS / SPONSORS
   ============================================================ */
.ueg-partners {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}

.ueg-partner-logo {
  height: 36px;
  opacity: 0.35;
  filter: brightness(0) invert(1);
  transition: opacity 0.3s;
}
.ueg-partner-logo:hover { opacity: 0.7; }

/* ============================================================
   FOOTER NEWSLETTER CAPTURE SECTION
   ============================================================ */
.ueg-footer-capture {
  background: linear-gradient(135deg, #0d0d0d 0%, #111 50%, #0f0d0a 100%);
  border-top: 1px solid var(--ueg-border-gold);
  padding: 4rem 0;
}

.footer-capture-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: start;
}

.footer-capture-copy h2 {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 800;
  color: var(--ueg-white);
  margin-bottom: 0.75rem;
}

.footer-capture-copy p {
  color: rgba(255,255,255,0.6);
  font-size: 0.95rem;
  line-height: 1.65;
}

/* Footer GHL form — white card, max-width constrained */
.footer-ghl-form {
  max-width: 480px;
}

/* ============================================================
   SITE FOOTER (UPGRADED)
   ============================================================ */
.site-footer {
  background: var(--ueg-deep);
  border-top: 1px solid var(--ueg-border-gold);
}

.footer-newsletter {
  background: var(--ueg-charcoal);
  border-bottom: 1px solid var(--ueg-border-dark);
  padding: var(--space-xl) 2rem;
}

.footer-newsletter__inner {
  max-width: var(--wide-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2rem;
  align-items: center;
}

.footer-newsletter__text h3 {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ueg-white);
  margin-bottom: 4px;
}

.footer-newsletter__text p {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.5);
}

.footer-newsletter__form {
  display: flex;
  gap: 0.75rem;
}

.footer-grid,
.footer-inner {
  max-width: var(--wide-width);
  margin: 0 auto;
  padding: var(--space-xl) 2rem;
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: var(--space-xl);
}

.footer-brand .logo-text { font-size: 1.15rem; }

.footer-brand p {
  font-size: 0.83rem;
  line-height: 1.7;
  color: rgba(255,255,255,0.45);
  margin-top: 0.875rem;
  max-width: 260px;
}

.footer-brand__social {
  display: flex;
  gap: 0.75rem;
  margin-top: 1.25rem;
}

.social-link {
  width: 34px; height: 34px;
  background: var(--ueg-graphite);
  border: 1px solid var(--ueg-border-dark);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.75rem;
  color: rgba(255,255,255,0.5);
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.social-link:hover {
  background: var(--ueg-gold-glow);
  border-color: var(--ueg-border-gold);
  color: var(--ueg-gold);
}

.footer-col h4 {
  font-family: var(--font-body);
  font-size: 0.65rem; font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--ueg-gold);
  margin-bottom: 1.25rem;
}

.footer-col ul li { margin-bottom: 0.6rem; }

.footer-col ul li a {
  font-size: 0.83rem;
  color: rgba(255,255,255,0.45);
  transition: color 0.2s;
}
.footer-col ul li a:hover { color: var(--ueg-white); }

.footer-bottom {
  max-width: var(--wide-width);
  margin: 0 auto;
  padding: var(--space-md) 2rem;
  border-top: 1px solid var(--ueg-border-dark);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.72rem;
  color: rgba(255,255,255,0.25);
  flex-wrap: wrap;
  gap: 0.5rem;
}

.footer-bottom a {
  color: rgba(255,255,255,0.35);
  transition: color 0.2s;
}
.footer-bottom a:hover { color: var(--ueg-white); }

/* ============================================================
   PAGE CONTENT — Event Landing Pages (generic pages)
   ============================================================ */

/* Default title bar for pages without a custom hero */
.page-title-bar {
  padding: var(--space-2xl) 2rem var(--space-xl);
  background: var(--ueg-deep);
}
.page-title-bar h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 700;
  line-height: 1.1;
  color: var(--ueg-white);
  max-width: var(--wide-width);
  margin: 0 auto;
}

/* Featured image hero overlay + title */
.page-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(8,8,8,0.25) 0%, rgba(8,8,8,0.7) 100%);
  z-index: 1;
}
.page-hero-title {
  position: absolute;
  bottom: var(--space-lg);
  left: 0; right: 0;
  z-index: 2;
  padding: 0 2rem;
}
.page-hero-title h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 700;
  line-height: 1.1;
  color: var(--ueg-white);
  max-width: var(--wide-width);
  margin: 0 auto;
}

.page-featured-image {
  position: relative;
  max-height: 420px;
  overflow: hidden;
}

.page-featured-image img {
  width: 100%;
  height: 420px;
  object-fit: cover;
  opacity: 0.6;
}

.page-featured-image::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 30%, var(--ueg-black) 100%);
}

/* Default entry-content for plain text/blog content */
.entry-content {
  max-width: var(--content-width);
  margin: 0 auto;
  padding: var(--space-xl) 2rem;
  color: var(--ueg-white);
  overflow-x: hidden;
}

/* Generated event/page content uses full-width sections — remove constraint */
.ueg-event-page .entry-wrap > .container,
.ueg-event-page .entry-content {
  max-width: none;
  padding: 0;
  margin: 0;
}

.entry-content h1:first-of-type {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--ueg-white);
  margin-bottom: 0.75rem;
}

.entry-content h1:first-of-type::after {
  content: '';
  display: block;
  width: 40px; height: 3px;
  background: var(--ueg-gold);
  margin-top: 1rem;
}

.entry-content h2 {
  font-family: var(--font-body);
  font-size: 0.7rem; font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--ueg-muted);
  margin: var(--space-xl) 0 var(--space-md);
  display: flex;
  align-items: center;
  gap: 1rem;
}

.entry-content h2::before {
  content: '';
  display: block;
  width: 24px; height: 2px;
  background: var(--ueg-gold);
  flex-shrink: 0;
}

.entry-content h2::after {
  content: '';
  flex: 1;
  display: block;
  height: 1px;
  background: var(--ueg-border-dark);
}

.entry-content h3 {
  font-family: var(--font-display);
  font-size: 1.2rem; font-weight: 600;
  color: var(--ueg-white);
  margin: var(--space-md) 0 var(--space-sm);
}

.entry-content p {
  font-size: 1rem;
  line-height: 1.8;
  color: rgba(255,255,255,0.75);
  margin-bottom: var(--space-sm);
}

.entry-content ul:not(.ueg-highlights) {
  margin: var(--space-sm) 0 var(--space-md);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.entry-content ul:not(.ueg-highlights) li {
  display: flex;
  align-items: baseline;
  padding: 0.875rem 1.25rem;
  border-bottom: 1px solid var(--ueg-border-dark);
  font-size: 0.92rem;
  color: rgba(255,255,255,0.7);
  transition: background 0.15s;
}

.entry-content ul:not(.ueg-highlights) li:last-child { border-bottom: none; }
.entry-content ul:not(.ueg-highlights) li:hover { background: var(--ueg-charcoal); }

.entry-content ul:not(.ueg-highlights) li strong {
  font-weight: 600;
  color: var(--ueg-white);
  min-width: 180px;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  flex-shrink: 0;
}

/* Highlights / Feature List */
.entry-content h2 + ul,
.ueg-highlights {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin: var(--space-sm) 0 var(--space-md);
}

.entry-content h2 + ul li,
.ueg-highlights li {
  background: var(--ueg-charcoal);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  padding: 0.875rem 1rem;
  font-size: 0.87rem;
  color: rgba(255,255,255,0.75);
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  transition: border-color 0.2s;
}

.entry-content h2 + ul li:hover,
.ueg-highlights li:hover { border-color: var(--ueg-border-gold); }

.entry-content h2 + ul li::before,
.ueg-highlights li::before {
  content: '';
  display: block;
  width: 16px; height: 16px;
  background: var(--ueg-gold);
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 2px;
  background-image: url("data:image/svg+xml,%3Csvg width='8' height='7' viewBox='0 0 8 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 3.5L3 5.5L7 1' stroke='%230a0a0a' stroke-width='1.3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}

/* Pricing block */
.ueg-pricing,
.entry-content .ueg-pricing {
  background: var(--ueg-charcoal);
  border-left: 3px solid var(--ueg-gold);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: 1.25rem 1.5rem;
  margin-bottom: var(--space-lg);
  color: rgba(255,255,255,0.8);
}

/* CTA links */
.entry-content a[href*="posh"],
.entry-content a[href*="book"],
.entry-content a[href*="ticket"],
.entry-content p > a:only-child {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--ueg-amber), var(--ueg-fire));
  color: var(--ueg-white);
  font-size: 0.88rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 1rem 2.5rem;
  border-radius: var(--radius-sm);
  box-shadow: 0 6px 24px rgba(234,88,12,0.35);
  transition: transform 0.2s var(--ease-out), box-shadow 0.2s, opacity 0.15s;
  margin: 0.5rem 0;
}

.entry-content a[href*="posh"]:hover,
.entry-content a[href*="book"]:hover,
.entry-content a[href*="ticket"]:hover,
.entry-content p > a:only-child:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(234,88,12,0.50);
  opacity: 0.94;
}

/* Tagline */
.ueg-tagline {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.1rem;
  color: var(--ueg-gold);
  margin-bottom: var(--space-md);
}

/* Hashtag / footer text */
.entry-content p:last-child:has(a:first-child) {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.3);
  letter-spacing: 0.08em;
}

/* ============================================================
   COMMUNITY PAGE
   ============================================================ */
.ueg-community-page__hero {
  background: linear-gradient(135deg, #031a16 0%, #051e1a 50%, #021410 100%);
  border-bottom: 1px solid rgba(13,148,136,0.25);
  padding: var(--space-2xl) 2rem;
  position: relative;
  overflow: hidden;
}

.ueg-community-page__hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 120% at 80% 50%, rgba(13,148,136,0.12) 0%, transparent 60%);
}

/* ============================================================
   MARKETING / MEDIA KIT PAGE
   ============================================================ */
.ueg-media-kit-hero {
  background: linear-gradient(135deg, #0d0a02 0%, #1a1200 50%, #0d0a02 100%);
  border-bottom: 1px solid var(--ueg-border-gold);
  padding: var(--space-2xl) 2rem;
  position: relative;
  overflow: hidden;
}

.ueg-media-kit-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 100% at 80% 50%, rgba(212,168,67,0.1) 0%, transparent 60%);
}

.ueg-package-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

.ueg-package-card {
  background: var(--ueg-charcoal);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  padding: 2rem 1.75rem 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: border-color 0.3s, transform 0.3s var(--ease-out);
}

.ueg-package-card:hover {
  border-color: var(--ueg-border-gold);
  transform: translateY(-3px);
}

.ueg-package-card--featured {
  border-color: var(--ueg-gold);
  background: linear-gradient(180deg, rgba(212,168,67,0.06) 0%, var(--ueg-charcoal) 100%);
}

.ueg-package-card__tier {
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ueg-gold);
}

.ueg-package-card__title {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--ueg-white);
}

.ueg-package-card__price {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 800;
  color: var(--ueg-white);
  line-height: 1;
}

.ueg-package-card__price span {
  font-size: 0.85rem;
  font-weight: 400;
  color: rgba(255,255,255,0.45);
  font-family: var(--font-body);
}

.ueg-package-card__features {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--ueg-border-dark);
}

.ueg-package-feature {
  font-size: 0.83rem;
  color: rgba(255,255,255,0.65);
  display: flex;
  align-items: center;
  gap: 8px;
}

.ueg-package-feature::before {
  content: '✓';
  color: var(--ueg-gold);
  font-weight: 700;
  font-size: 0.7rem;
  flex-shrink: 0;
}

/* ============================================================
   AUDIENCE STATS GRID
   ============================================================ */
.ueg-audience-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.875rem;
}

.ueg-audience-stat {
  background: var(--ueg-charcoal);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  padding: 1.25rem 1.5rem;
}

.ueg-audience-stat__num {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 800;
  color: var(--ueg-gold);
  line-height: 1;
}

.ueg-audience-stat__label {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.45);
  margin-top: 5px;
}

/* ============================================================
   SCROLL REVEAL (JS-driven)
   ============================================================ */
.will-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.6s var(--ease-out) var(--reveal-delay, 0ms),
    transform 0.6s var(--ease-out) var(--reveal-delay, 0ms);
}

.is-revealed {
  opacity: 1;
  transform: none;
}

/* ============================================================
   UTILITY CLASSES
   ============================================================ */
.text-gold    { color: var(--ueg-gold); }
.text-amber   { color: var(--ueg-amber); }
.text-muted   { color: rgba(255,255,255,0.5); }
.text-center  { text-align: center; }
.mt-sm        { margin-top: var(--space-sm); }
.mt-md        { margin-top: var(--space-md); }
.mt-lg        { margin-top: var(--space-lg); }
.mt-xl        { margin-top: var(--space-xl); }
.mb-lg        { margin-bottom: var(--space-lg); }

.ueg-divider {
  border: none;
  border-top: 1px solid var(--ueg-border-dark);
  margin: var(--space-xl) 0;
}

/* ============================================================
   SECTION HEADERS — shared pattern across all pages
   ============================================================ */
.section-header {
  text-align: center;
  max-width: 680px;
  margin: 0 auto var(--space-xl);
}

.section-title {
  font-family: var(--font-display);
  font-size: clamp(1.9rem, 3.5vw, 2.75rem);
  font-weight: 800;
  color: var(--ueg-white);
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin-bottom: 0.75rem;
}

.section-sub {
  font-size: 1rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.7;
  max-width: 560px;
  margin: 0 auto;
}

/* ============================================================
   PILL BADGES
   ============================================================ */
.ueg-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.13em;
  padding: 0.4rem 1rem;
  border-radius: 100px;
  border: 1px solid;
  margin-bottom: 1.25rem;
}

.ueg-pill--fire    { color: var(--ueg-amber); border-color: rgba(245,158,11,0.35); background: rgba(245,158,11,0.08); }
.ueg-pill--gold    { color: var(--ueg-gold);  border-color: rgba(212,168,67,0.35); background: rgba(212,168,67,0.08); }
.ueg-pill--community { color: var(--ueg-community); border-color: rgba(13,148,136,0.35); background: rgba(13,148,136,0.08); }
.ueg-pill--marketing { color: var(--ueg-marketing); border-color: rgba(212,168,67,0.35); background: rgba(212,168,67,0.08); }
.ueg-pill--content { color: #a78bfa; border-color: rgba(124,58,237,0.35); background: rgba(124,58,237,0.08); }

/* ============================================================
   HERO — missing pieces
   ============================================================ */
.ueg-hero__actions {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 2.5rem;
}

.ueg-hero__payment-note {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.45);
  margin-top: 1.5rem;
  letter-spacing: 0.01em;
}

.hero-scroll-indicator {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  cursor: pointer;
}

.hero-scroll-indicator span {
  display: block;
  width: 1px;
  height: 48px;
  background: linear-gradient(to bottom, rgba(255,255,255,0.4), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}

@keyframes scrollPulse {
  0%, 100% { opacity: 0.3; transform: scaleY(1); }
  50% { opacity: 0.8; transform: scaleY(1.1); }
}

/* ============================================================
   PILLAR CARDS — non-BEM (home-pillars.php)
   ============================================================ */
.pillars-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  margin-top: var(--space-xl);
}

.pillars-grid--3 {
  grid-template-columns: repeat(3, 1fr);
}

.pillar-card {
  background: var(--ueg-charcoal);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  padding: 2rem 1.75rem 2.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  position: relative;
  overflow: hidden;
  transition: border-color 0.3s, transform 0.3s var(--ease-out), box-shadow 0.3s;
}

.pillar-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--ueg-gold);
  opacity: 0;
  transition: opacity 0.3s;
}

.pillar-card:hover {
  border-color: rgba(212,168,67,0.3);
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.25);
}

.pillar-card:hover::before { opacity: 1; }

.pillar-card.pillar-events::before   { background: var(--ueg-events); }
.pillar-card.pillar-community::before { background: var(--ueg-community); }
.pillar-card.pillar-marketing::before { background: var(--ueg-marketing); }
.pillar-card.pillar-content::before  { background: var(--ueg-content); }

.pillar-icon {
  font-size: 2rem;
  line-height: 1;
  display: block;
  margin-bottom: 0.25rem;
}

.pillar-title {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ueg-white);
  line-height: 1.2;
}

.pillar-desc {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.65;
  flex: 1;
}

.pillar-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ueg-gold);
  text-decoration: none;
  margin-top: 0.5rem;
  transition: gap 0.2s, color 0.2s;
}

.pillar-link:hover { gap: 9px; color: var(--ueg-gold-light); }

/* ============================================================
   EVENT TAB SYSTEM
   ============================================================ */
.ueg-tabs {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: var(--space-xl);
  border-bottom: 1px solid var(--ueg-border-dark);
  padding-bottom: 0;
}

.ueg-tab {
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.5);
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 600;
  padding: 0.85rem 1.35rem;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 0.2s, border-color 0.2s;
  white-space: nowrap;
}

.ueg-tab:hover { color: rgba(255,255,255,0.85); }

.ueg-tab.on {
  color: var(--ueg-white);
  border-bottom-color: var(--ueg-amber);
}

.ueg-panel { display: none; }
.ueg-panel.on { display: block; }

/* Payment banner in events */
.ueg-payment-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  background: rgba(245,158,11,0.06);
  border: 1px solid rgba(245,158,11,0.18);
  border-radius: var(--radius-md);
  padding: 1rem 1.5rem;
  margin-bottom: var(--space-xl);
  flex-wrap: wrap;
}

.ueg-payment-banner p {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.75);
  margin: 0;
}

.ueg-btn-sm {
  padding: 0.55rem 1.25rem;
  font-size: 0.78rem;
}

/* ============================================================
   EVENT CARDS — home-events.php component styles
   ============================================================ */
.ueg-events-grid--4 {
  grid-template-columns: repeat(4, 1fr);
}

/* Card image / placeholder area */
.ueg-card-img {
  position: relative;
  height: 160px;
  background: linear-gradient(135deg, var(--ueg-graphite), var(--ueg-charcoal));
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}

.ueg-card-img-ph {
  font-size: 2.75rem;
  opacity: 0.7;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.5));
}

/* Event badges */
.ueg-badge {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.3rem 0.7rem;
  border-radius: 100px;
  z-index: 2;
}

.b-amber { background: rgba(245,158,11,0.9);  color: #000; }
.b-fire  { background: rgba(234,88,12,0.9);   color: #fff; }
.b-grey  { background: rgba(60,60,60,0.9);    color: rgba(255,255,255,0.85); }
.b-gold  { background: rgba(212,168,67,0.9);  color: #000; }
.b-purple{ background: rgba(124,58,237,0.9);  color: #fff; }

.ueg-past-badge {
  position: absolute;
  bottom: 0.6rem;
  right: 0.6rem;
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  padding: 0.25rem 0.6rem;
  border-radius: var(--radius-sm);
  background: rgba(0,0,0,0.7);
  color: rgba(255,255,255,0.6);
}

/* Colored accent strip */
.ueg-strip {
  height: 3px;
  width: 100%;
  flex-shrink: 0;
}

.ueg-strip--fire   { background: linear-gradient(90deg, var(--ueg-fire), var(--ueg-amber)); }
.ueg-strip--purple { background: linear-gradient(90deg, #7C3AED, #a78bfa); }

/* Card body */
.ueg-card-body {
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  flex: 1;
}

.ueg-ev-date {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ueg-amber);
  display: block;
}

.ueg-ev-title {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--ueg-white);
  line-height: 1.25;
}

.ueg-ev-loc {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.5);
  line-height: 1.4;
  margin: 0;
}

.ueg-ev-desc {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.45);
  line-height: 1.55;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Countdown */
.ueg-countdown {
  display: flex;
  gap: 0.5rem;
  margin: 0.25rem 0;
}

.countdown-unit {
  display: flex;
  align-items: baseline;
  gap: 3px;
}

.countdown-num {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ueg-white);
  line-height: 1;
  min-width: 1.6ch;
  font-variant-numeric: tabular-nums;
}

.countdown-label {
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.4);
}

.ueg-event-completed {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.3);
  font-style: italic;
  margin: 0.25rem 0;
}

/* Card footer */
.ueg-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: auto;
  padding-top: 0.75rem;
  border-top: 1px solid var(--ueg-border-dark);
  flex-wrap: wrap;
}

.ueg-ev-price {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ueg-ev-price strong {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--ueg-white);
}

.ueg-plan-note {
  font-size: 0.65rem;
  color: rgba(255,255,255,0.4);
}

.ueg-event-card--past { opacity: 0.6; }

/* Fire button */
.ueg-btn-fire {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: linear-gradient(135deg, var(--ueg-amber), var(--ueg-fire));
  color: #fff;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.65rem 1.25rem;
  border-radius: var(--radius-sm);
  border: none;
  cursor: pointer;
  transition: transform 0.2s var(--ease-out), box-shadow 0.2s;
  white-space: nowrap;
}

.ueg-btn-fire:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(234,88,12,0.45);
}

.ueg-btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  color: rgba(255,255,255,0.6);
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.65rem 1.25rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--ueg-border-dark);
  cursor: pointer;
  transition: border-color 0.2s, color 0.2s;
  text-decoration: none;
}

.ueg-btn-outline:hover {
  border-color: var(--ueg-border-mid);
  color: var(--ueg-white);
}

.section-cta {
  text-align: center;
  margin-top: var(--space-xl);
}

/* Past event notice */
.ueg-past-notice { padding: var(--space-2xl) 0; text-align: center; }

/* ============================================================
   BTT SECTION — home-btt-preview.php
   ============================================================ */
.btt-inner {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: var(--space-2xl);
  align-items: center;
}

.btt-copy {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.btt-logo-lockup {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}

.btt-logo-icon {
  width: 44px;
  height: 44px;
  background: #7C3AED;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: #fff;
  flex-shrink: 0;
}

.btt-logo-text {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--ueg-white);
  line-height: 1.2;
}

.btt-logo-text span {
  display: block;
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 400;
  color: rgba(255,255,255,0.45);
}

.btt-headline {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 2.8vw, 2.25rem);
  font-weight: 800;
  color: var(--ueg-white);
  line-height: 1.15;
  margin: 0;
}

.btt-desc {
  font-size: 0.95rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.7;
  margin: 0;
}

.btt-stats {
  display: flex;
  gap: 2rem;
}

.btt-stat {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.btt-stat strong {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: #a78bfa;
  line-height: 1;
}

.btt-stat span {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.4);
}

/* Video grid */
.btt-videos {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}

.btt-video-card {
  position: relative;
  background: var(--ueg-graphite);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  aspect-ratio: 16/9;
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.3s, transform 0.3s var(--ease-out);
  display: flex;
  align-items: center;
  justify-content: center;
}

.btt-video-card:hover {
  border-color: rgba(124,58,237,0.4);
  transform: scale(1.02);
}

.btt-video-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.btt-video-play {
  position: relative;
  z-index: 2;
  width: 44px;
  height: 44px;
  background: rgba(124,58,237,0.85);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: #fff;
  backdrop-filter: blur(4px);
  transition: background 0.2s, transform 0.2s;
}

.btt-video-card:hover .btt-video-play {
  background: #7C3AED;
  transform: scale(1.1);
}

.btt-video-title {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 0.5rem 0.75rem;
  font-size: 0.7rem;
  font-weight: 600;
  color: rgba(255,255,255,0.75);
  background: linear-gradient(transparent, rgba(0,0,0,0.8));
  z-index: 2;
}

/* ============================================================
   STATS SECTION
   ============================================================ */
.ueg-stats {
  padding: 3.5rem 0;
  border-top: 1px solid var(--ueg-border-dark);
  border-bottom: 1px solid var(--ueg-border-dark);
}

.ueg-stats--compact { padding: 2.5rem 0; }
.ueg-stats--gold { background: rgba(212,168,67,0.04); }

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}

.stat-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  text-align: center;
  padding: 1rem;
  border-right: 1px solid var(--ueg-border-dark);
}

.stat-item:last-child { border-right: none; }

.stat-num {
  font-family: var(--font-display);
  font-size: 2.25rem;
  font-weight: 800;
  color: var(--ueg-white);
  line-height: 1;
  display: flex;
  align-items: baseline;
  gap: 2px;
}

.stat-suffix {
  font-size: 1.25rem;
  color: var(--ueg-gold);
}

.stat-label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.4);
  font-weight: 600;
}

/* Stats section — span the inner container across all columns of the parent grid */
.ueg-stats > .container {
  grid-column: 1 / -1;
}

/* 2-column trust layout */
.stats-layout {
  display: flex;
  align-items: center;
  gap: 3rem;
}

.stats-grid--2x2 {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 0 !important;
  flex-shrink: 0;
  min-width: 320px;
}

.stats-grid--2x2 .stat-item {
  border-right: 1px solid var(--ueg-border-dark);
  border-bottom: 1px solid var(--ueg-border-dark);
  padding: 1.5rem 1.25rem;
}

.stats-grid--2x2 .stat-item:nth-child(2),
.stats-grid--2x2 .stat-item:nth-child(4) {
  border-right: none;
}

.stats-grid--2x2 .stat-item:nth-child(3),
.stats-grid--2x2 .stat-item:nth-child(4) {
  border-bottom: none;
}

.stats-divider {
  width: 1px;
  align-self: stretch;
  min-height: 140px;
  background: var(--ueg-border-dark);
  flex-shrink: 0;
}

.stats-trust-panel {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  flex: 1;
}

.stats-stars {
  color: var(--ueg-gold);
  font-size: 1rem;
  letter-spacing: 0.1em;
  margin-bottom: 0.5rem;
}

.stats-quote__text {
  font-size: 0.95rem;
  line-height: 1.65;
  color: rgba(255,255,255,0.82);
  font-style: italic;
  margin: 0 0 0.5rem;
  border-left: 3px solid var(--ueg-gold);
  padding-left: 0.85rem;
}

.stats-quote__cite {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.06em;
  font-style: normal;
  text-transform: uppercase;
}

.stats-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.stats-badge {
  font-size: 0.73rem;
  color: rgba(255,255,255,0.65);
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--ueg-border-dark);
  border-radius: 100px;
  padding: 0.3rem 0.75rem;
  white-space: nowrap;
  letter-spacing: 0.02em;
}

/* Responsive — stack on tablet/mobile */
@media (max-width: 900px) {
  .stats-layout {
    flex-direction: column;
    align-items: flex-start;
    gap: 2rem;
  }
  .stats-divider { display: none; }
  .stats-trust-panel { width: 100%; }
  .stats-grid--2x2 { min-width: 0; width: 100%; }
}

/* ============================================================
   FOOTER — missing non-BEM classes
   ============================================================ */
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 3rem;
  padding: 4rem 0 3rem;
}

.footer-brand .logo-wrap { margin-bottom: 1rem; }

.footer-tagline {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.45);
  line-height: 1.6;
  margin-top: 0.75rem;
  max-width: 260px;
}

.footer-social {
  display: flex;
  gap: 0.85rem;
  margin-top: 1.25rem;
}

.footer-social a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--ueg-charcoal);
  border: 1px solid var(--ueg-border-dark);
  border-radius: 50%;
  color: rgba(255,255,255,0.5);
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}

.footer-social a:hover {
  color: var(--ueg-white);
  border-color: var(--ueg-border-gold);
  background: rgba(212,168,67,0.08);
}

.footer-social-all {
  display: inline-block;
  margin-top: 1rem;
  font-size: 0.75rem;
  color: var(--ueg-gold);
  text-decoration: none;
  letter-spacing: 0.04em;
  transition: opacity 0.2s;
}
.footer-social-all:hover { opacity: 0.75; }

.footer-heading {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: rgba(255,255,255,0.35);
  margin-bottom: 1.25rem;
}

.footer-menu {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.footer-menu a {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.55);
  text-decoration: none;
  transition: color 0.2s;
}

.footer-menu a:hover { color: var(--ueg-white); }

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.5rem 0;
  border-top: 1px solid var(--ueg-border-dark);
}

.footer-copy {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.3);
}

.footer-legal {
  display: flex;
  gap: 1.25rem;
  align-items: center;
  font-size: 0.8rem;
}

.footer-legal a {
  color: rgba(255,255,255,0.35);
  text-decoration: none;
  transition: color 0.2s;
}

.footer-legal a:hover { color: var(--ueg-white); }

.footer-legal span { color: rgba(255,255,255,0.2); }

/* ============================================================
   MARKETING PAGE — packages & why-partner
   ============================================================ */
.ueg-why-partner {
  padding: var(--space-2xl) 0;
}

.packages-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: var(--space-xl);
}

.package-card {
  background: var(--ueg-charcoal);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-lg);
  padding: 2.5rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
  transition: border-color 0.3s, transform 0.3s var(--ease-out);
}

.package-card:hover {
  border-color: rgba(212,168,67,0.25);
  transform: translateY(-3px);
}

.package-card--featured {
  border-color: var(--ueg-gold);
  background: linear-gradient(135deg, var(--ueg-charcoal) 0%, rgba(212,168,67,0.06) 100%);
  box-shadow: 0 0 0 1px rgba(212,168,67,0.2), 0 20px 60px rgba(0,0,0,0.3);
}

.package-badge {
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--ueg-gold);
  color: var(--ueg-black);
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 0.3rem 1rem;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
}

.package-icon {
  font-size: 1.75rem;
  line-height: 1;
}

.package-tier {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--ueg-white);
}

.package-price {
  font-family: var(--font-display);
  font-size: 2.25rem;
  font-weight: 800;
  color: var(--ueg-white);
  line-height: 1;
  display: flex;
  align-items: baseline;
  gap: 0.35rem;
}

.package-period {
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-weight: 400;
  color: rgba(255,255,255,0.45);
}

.package-desc {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.6;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--ueg-border-dark);
}

.package-features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  flex: 1;
}

.package-features li {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.7);
  display: flex;
  gap: 0.6rem;
  align-items: flex-start;
}

.package-features li span {
  color: var(--ueg-gold);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}

.package-card .ueg-btn-primary,
.package-card .ueg-btn-secondary {
  width: 100%;
  justify-content: center;
  margin-top: auto;
}

.ueg-packages { padding: var(--space-2xl) 0; }

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-mission {
  padding: var(--space-2xl) 0;
  text-align: center;
  border-bottom: 1px solid var(--ueg-border-dark);
}

.about-mission blockquote {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 700;
  color: var(--ueg-white);
  line-height: 1.35;
  max-width: 780px;
  margin: 0 auto 1.5rem;
  font-style: italic;
}

.about-mission p {
  font-size: 1rem;
  color: rgba(255,255,255,0.55);
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.75;
}

.about-values {
  padding: var(--space-2xl) 0;
}

.about-story {
  padding: var(--space-2xl) 0;
  border-top: 1px solid var(--ueg-border-dark);
}

.about-story__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
  align-items: center;
}

.about-story__text h2 {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 2.8vw, 2.25rem);
  font-weight: 800;
  color: var(--ueg-white);
  line-height: 1.2;
  margin-bottom: 1.25rem;
}

.about-story__text p {
  font-size: 0.95rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.8;
  margin-bottom: 1rem;
}

.about-story__visual {
  background: linear-gradient(135deg, var(--ueg-charcoal), var(--ueg-graphite));
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-lg);
  aspect-ratio: 4/3;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 5rem;
  position: relative;
  overflow: hidden;
}

.about-story__visual::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, rgba(212,168,67,0.08) 0%, transparent 70%);
}

.about-founder {
  padding: var(--space-2xl) 0;
  background: var(--ueg-charcoal);
  border-top: 1px solid var(--ueg-border-dark);
}

.founder-card {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
}

.founder-avatar {
  width: 80px;
  height: 80px;
  background: linear-gradient(135deg, var(--ueg-gold), var(--ueg-amber));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.25rem;
}

.founder-name {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--ueg-white);
  margin-bottom: 0.25rem;
}

.founder-title {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ueg-gold);
  font-weight: 600;
  margin-bottom: 1.25rem;
}

.founder-bio {
  font-size: 0.95rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.75;
  font-style: italic;
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.ueg-contact { padding: var(--space-2xl) 0; }

.contact-inner {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: var(--space-2xl);
  align-items: start;
}

.contact-info { display: flex; flex-direction: column; gap: 1.25rem; }

.contact-info-card {
  background: var(--ueg-charcoal);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  transition: border-color 0.3s;
}

.contact-info-card:hover { border-color: rgba(212,168,67,0.3); }

.contact-info-icon {
  font-size: 1.5rem;
  line-height: 1;
  flex-shrink: 0;
  margin-top: 2px;
}

.contact-info-card h3 {
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.4);
  margin-bottom: 0.35rem;
}

.contact-info-card p, .contact-info-card a {
  font-size: 0.95rem;
  color: var(--ueg-white);
  text-decoration: none;
  line-height: 1.5;
}

.contact-info-card a:hover { color: var(--ueg-gold); }

/* ============================================================
   LEGAL PAGES (privacy policy, terms)
   ============================================================ */
.ueg-legal-hero {
  padding: 8rem 0 4rem;
  text-align: center;
  border-bottom: 1px solid var(--ueg-border-dark);
}

.ueg-legal-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 800;
  color: var(--ueg-white);
  margin-bottom: 0.75rem;
}

.ueg-legal-hero .legal-date {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.4);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.ueg-legal-body {
  max-width: 780px;
  margin: 0 auto;
  padding: var(--space-2xl) 2rem;
}

.legal-section {
  margin-bottom: var(--space-xl);
}

.legal-section h2 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--ueg-white);
  margin-bottom: 0.85rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid var(--ueg-border-dark);
}

.legal-section h3 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--ueg-white);
  margin: 1rem 0 0.5rem;
}

.legal-section p {
  font-size: 0.92rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.85;
  margin-bottom: 0.85rem;
}

.legal-section ul, .legal-section ol {
  padding-left: 1.5rem;
  margin-bottom: 0.85rem;
}

.legal-section li {
  font-size: 0.92rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.75;
  margin-bottom: 0.4rem;
}

.legal-section a {
  color: var(--ueg-gold);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ============================================================
   ABOUT PAGE — additional classes
   ============================================================ */
.about-mission__inner {
  max-width: 820px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.about-mission__body {
  font-size: 1rem;
  color: rgba(255,255,255,0.55);
  max-width: 620px;
  margin: 0 auto;
  line-height: 1.75;
}

.about-story__copy {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.about-story__text {
  font-size: 0.95rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.8;
}

.about-story__img-wrap {
  width: 100%;
  height: 100%;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.about-story__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-moments {
  padding: var(--space-2xl) 0;
  border-top: 1px solid var(--ueg-border-dark);
}

.about-photo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
  margin-top: var(--space-xl);
}

.about-photo-item {
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--ueg-charcoal);
}

.about-photo-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s var(--ease-out);
}

.about-photo-item:hover img { transform: scale(1.04); }

/* ============================================================
   CONTACT PAGE — additional classes
   ============================================================ */
.ueg-contact-body {
  padding: var(--space-2xl) 0;
}

.contact-info__heading,
.contact-form__heading {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--ueg-white);
  margin-bottom: 1.5rem;
}

.contact-link {
  display: inline-block;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--ueg-gold);
  text-decoration: none;
  margin-top: 0.35rem;
  transition: color 0.2s;
}

.contact-link:hover { color: var(--ueg-amber); }

.contact-social {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  margin-top: 0.5rem;
  flex-wrap: wrap;
  font-size: 0.88rem;
}

.contact-social a {
  color: var(--ueg-gold);
  text-decoration: none;
  font-weight: 600;
  transition: color 0.2s;
}

.contact-social a:hover { color: var(--ueg-amber); }

.contact-social span { color: rgba(255,255,255,0.2); }

.contact-form-wrap {
  background: var(--ueg-charcoal);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-lg);
  padding: 2.5rem;
}

.form-select,
.ueg-capture-form textarea {
  width: 100%;
  background: var(--ueg-graphite);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-sm);
  color: var(--ueg-white);
  font-family: var(--font-body);
  font-size: 0.9rem;
  padding: 0.85rem 1rem;
  outline: none;
  transition: border-color 0.2s;
  appearance: none;
  -webkit-appearance: none;
}

.form-select:focus,
.ueg-capture-form textarea:focus {
  border-color: rgba(212,168,67,0.5);
}

.form-select option { background: var(--ueg-graphite); color: var(--ueg-white); }

.ueg-capture-form textarea {
  resize: vertical;
  min-height: 120px;
  line-height: 1.6;
}

.ueg-contact-faq {
  padding: var(--space-2xl) 0;
  border-top: 1px solid var(--ueg-border-dark);
  background: var(--ueg-charcoal);
}

.contact-faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  margin-top: var(--space-xl);
}

.contact-faq-item {
  background: var(--ueg-graphite);
  border: 1px solid var(--ueg-border-dark);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  transition: border-color 0.3s;
}

.contact-faq-item:hover { border-color: rgba(212,168,67,0.25); }

.contact-faq-q {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--ueg-white);
  margin-bottom: 0.65rem;
  line-height: 1.3;
}

.contact-faq-a {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.7;
}

/* ============================================================
   LEGAL PAGES — additional classes
   ============================================================ */
.ueg-pill--muted {
  color: rgba(255,255,255,0.45);
  border-color: rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.05);
}

.legal-list {
  list-style: none;
  padding: 0;
  margin: 0 0 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.legal-list li {
  font-size: 0.92rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.7;
  padding-left: 1.25rem;
  position: relative;
}

.legal-list li::before {
  content: '–';
  position: absolute;
  left: 0;
  color: var(--ueg-gold);
}

.legal-link {
  color: var(--ueg-gold);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color 0.2s;
}

.legal-link:hover { color: var(--ueg-amber); }

.legal-nav {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: var(--space-2xl);
  padding-top: var(--space-xl);
  border-top: 1px solid var(--ueg-border-dark);
}

/* ============================================================
   COMMUNITY JOIN SECTION — #join
   ============================================================ */
.comm-join {
  position: relative;
  padding: var(--space-3xl) 0;
  overflow: hidden;
}
.comm-join__bg {
  position: absolute;
  inset: 0;
  background-image: url('/wp-content/uploads/ueg-community/ucw-summer-festival-crowd.jpg');
  background-size: cover;
  background-position: center 30%;
  z-index: 0;
}
.comm-join__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(8,8,8,0.93) 0%,
    rgba(10,10,10,0.88) 50%,
    rgba(15,10,5,0.90) 100%
  );
  z-index: 1;
}
.comm-join .container { position: relative; z-index: 2; }

.comm-join__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: start;
}

/* ── Left copy ── */
.comm-join__copy { padding-top: 1rem; }

.comm-join__headline {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 900;
  color: var(--ueg-white);
  line-height: 1.1;
  margin: 1rem 0 1.1rem;
  letter-spacing: -0.02em;
}

.comm-join__sub {
  font-size: 1.05rem;
  color: rgba(255,255,255,0.65);
  line-height: 1.7;
  margin-bottom: 2rem;
  max-width: 480px;
}

/* Stats strip */
.comm-join__stats {
  display: flex;
  gap: 2rem;
  margin-bottom: 2rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.comm-join__stat {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.comm-join__stat-num {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 900;
  color: var(--ueg-gold);
  line-height: 1;
}
.comm-join__stat-label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.4);
  font-weight: 600;
}

/* Perks list */
.comm-join__perks {
  list-style: none;
  padding: 0;
  margin: 0 0 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.comm-join__perks li {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.95rem;
  color: rgba(255,255,255,0.8);
  line-height: 1.4;
}
.comm-join__perk-icon {
  font-size: 1.1rem;
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(212,168,67,0.12);
  border: 1px solid rgba(212,168,67,0.2);
  border-radius: 50%;
}

/* Destination pill tags */
.comm-join__destinations {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.comm-dest-tag {
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(255,255,255,0.5);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 999px;
  padding: 0.3rem 0.75rem;
  background: rgba(255,255,255,0.04);
  letter-spacing: 0.02em;
}

/* ── Right: Form card ── */
.comm-join__form-col { position: relative; }

.comm-join__form-card {
  background: var(--ueg-charcoal);
  border: 1px solid rgba(212,168,67,0.25);
  border-top: 3px solid var(--ueg-gold);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.05);
}

.comm-join__form-header {
  padding: 1.75rem 2rem 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  background: linear-gradient(135deg, var(--ueg-charcoal) 0%, var(--ueg-graphite) 100%);
}
.comm-join__form-title {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--ueg-white);
  margin: 0 0 0.3rem;
}
.comm-join__form-sub {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.45);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.comm-join__form-sub::before {
  content: '✓';
  color: var(--ueg-gold);
  font-weight: 700;
}

/* iframe wrapper — no overflow clipping, auto height */
.comm-join__form-body { background: #fff; }
.comm-join__iframe-wrap {
  width: 100%;
  overflow: visible;
}
.comm-join__iframe-wrap iframe {
  width: 100%;
  min-height: 520px;
  border: none;
  display: block;
}

/* Proof row at bottom of card */
.comm-join__proof {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 2rem;
  background: var(--ueg-graphite);
  border-top: 1px solid rgba(255,255,255,0.07);
}
.comm-join__proof .avatar-stack { font-size: 1rem; letter-spacing: -0.3em; }
.comm-join__proof p {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.5);
  margin: 0;
}

/* ============================================================
   CONNECT PAGE — Follow the Movement
   ============================================================ */

/* Hero photo variants */
.ueg-hero--about {
  background:
    linear-gradient(to bottom, rgba(8,8,8,0.55) 0%, rgba(8,8,8,0.75) 100%),
    url('/wp-content/uploads/ueg-community/dubai-atlantis-beach-day.jpg') center/cover no-repeat;
}
.ueg-hero--connect {
  background:
    linear-gradient(to bottom, rgba(8,8,8,0.50) 0%, rgba(8,8,8,0.80) 100%),
    url('/wp-content/uploads/ueg-community/dubai-desert-safari-group.jpg') center/cover no-repeat;
}

/* Quick-jump strip */
.connect-quick-strip {
  background: var(--ueg-graphite);
  border-bottom: 1px solid var(--ueg-border-dark);
  padding: 0.875rem 0;
  position: sticky;
  top: 72px;
  z-index: 80;
}
.connect-quick-strip .container {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.connect-quick-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ueg-muted);
  white-space: nowrap;
  margin: 0;
  flex-shrink: 0;
}
.connect-quick-links {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.connect-quick-link {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: rgba(255,255,255,0.55);
  text-decoration: none;
  padding: 0.3rem 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
  transition: color 0.2s, border-color 0.2s, background 0.2s;
  white-space: nowrap;
}
.connect-quick-link:hover {
  color: var(--ueg-white);
  border-color: var(--ueg-gold);
  background: rgba(212,168,67,0.08);
}

/* Brand sections */
.connect-brand {
  padding: var(--space-xl) 0;
  border-bottom: 1px solid var(--ueg-border-dark);
}
.connect-brand:nth-child(even) {
  background: var(--ueg-charcoal);
}
.connect-brand__header {
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
  margin-bottom: 2rem;
}
.connect-brand__icon {
  font-size: 2.5rem;
  line-height: 1;
  width: 3.5rem;
  height: 3.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-md);
  flex-shrink: 0;
}
.connect-brand__meta { flex: 1; }
.connect-brand__title {
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 2.5vw, 1.75rem);
  font-weight: 800;
  color: var(--ueg-white);
  margin: 0 0 0.35rem;
  /* Use --brand-color for accent */
  background: linear-gradient(90deg, var(--ueg-white) 60%, var(--brand-color, var(--ueg-gold)) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.connect-brand__sub {
  font-size: 0.9rem;
  color: var(--ueg-muted);
  margin: 0;
  line-height: 1.5;
}

/* Channel cards grid */
.connect-channels-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 0.875rem;
}
.connect-channel-card {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: var(--ueg-graphite);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: border-color 0.2s, background 0.2s, transform 0.2s;
  cursor: pointer;
}
.connect-channel-card:hover {
  border-color: var(--brand-color, var(--ueg-gold));
  background: color-mix(in srgb, var(--brand-color, var(--ueg-gold)) 8%, var(--ueg-graphite));
  transform: translateY(-2px);
}
.connect-channel-icon {
  font-size: 1.35rem;
  line-height: 1;
  width: 2.25rem;
  height: 2.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.06);
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.connect-channel-body {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
}
.connect-channel-platform {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ueg-muted);
  line-height: 1;
}
.connect-channel-handle {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ueg-white);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.connect-channel-count {
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--brand-color, var(--ueg-gold));
  white-space: nowrap;
  flex-shrink: 0;
}
.connect-channel-arrow {
  font-size: 0.9rem;
  color: rgba(255,255,255,0.2);
  transition: color 0.2s, transform 0.2s;
  flex-shrink: 0;
}
.connect-channel-card:hover .connect-channel-arrow {
  color: var(--brand-color, var(--ueg-gold));
  transform: translateX(3px);
}

/* Direct channels section */
.connect-direct {
  padding: var(--space-2xl) 0;
  background: linear-gradient(180deg, var(--ueg-charcoal) 0%, var(--ueg-dark) 100%);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .ueg-pillars { grid-template-columns: repeat(2, 1fr); }
  .ueg-events-grid { grid-template-columns: repeat(2, 1fr); }
  .ueg-package-grid { grid-template-columns: 1fr; }
  .community-grid { grid-template-columns: repeat(2, 1fr); }
  .capture-inner { grid-template-columns: 1fr; gap: 2.5rem; padding: 4rem 0; }
  .footer-grid,
  .footer-inner { grid-template-columns: 1fr 1fr; }
  .footer-newsletter__inner { grid-template-columns: 1fr; }
  .footer-newsletter__form { justify-content: flex-start; }

  /* New grid components */
  .pillars-grid { grid-template-columns: repeat(2, 1fr); }
  .pillars-grid--3 { grid-template-columns: repeat(2, 1fr); }
  .packages-grid { grid-template-columns: 1fr; }
  .btt-inner { grid-template-columns: 1fr; gap: var(--space-xl); }
  .about-story__inner { grid-template-columns: 1fr; gap: var(--space-xl); }
  .about-story__visual { max-height: 380px; }
  .about-photo-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-inner { grid-template-columns: 1fr; }
  .contact-faq-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .ueg-events-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .connect-channels-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
  .comm-join__inner { grid-template-columns: 1fr; gap: var(--space-xl); }
  .comm-join__stats { gap: 1.5rem; }
}

@media (max-width: 768px) {
  :root {
    --space-xl:  2.5rem;
    --space-2xl: 3.5rem;
    --space-3xl: 5rem;
  }

  .header-inner { padding: 0 1.25rem; height: 64px; }

  /* Hide desktop CTA from header on mobile — replaced by nav-mobile-cta inside drawer */
  .header-actions .nav-cta { display: none; }

  /* Mobile nav */
  .mobile-menu-toggle { display: flex; }

  .site-nav {
    /* Use visibility+opacity for clean open/close — avoids display:none ghost flicker */
    display: flex;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(8,8,8,0.98);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2rem;
    /* Above header (1000) and hamburger (1001) so nothing punches through */
    z-index: 1050;
    transition: opacity 0.25s ease, visibility 0.25s ease;
  }

  .site-nav.is-open {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
  }

  /* Hamburger stays on top of the open nav overlay */
  .mobile-menu-toggle { z-index: 1100; }

  .site-nav a {
    font-size: 1.25rem;
    letter-spacing: 0.06em;
  }

  /* Mobile drawer CTA styles */
  .nav-cta {
    font-size: 1rem !important;
    padding: 0.875rem 2rem !important;
  }

  .nav-mobile-cta { display: block; padding: 0.5rem 2rem 2rem; }

  body.menu-open { overflow: hidden; }

  .site-main { padding-top: 64px; }

  /* Hero */
  .ueg-hero__headline { font-size: clamp(2rem, 8vw, 3rem); }
  .ueg-hero__stats { gap: 1.5rem; }
  .ueg-hero__ctas { flex-direction: column; }
  .ueg-btn-primary, .ueg-btn-secondary { width: 100%; justify-content: center; }

  /* Grids */
  .ueg-pillars,
  .ueg-events-grid,
  .ueg-stats { grid-template-columns: 1fr; }
  .community-grid { grid-template-columns: 1fr; }

  .ueg-btt { grid-template-columns: 1fr; }

  .ueg-capture__form { flex-direction: column; }
  .ueg-capture__input { min-width: 100%; }

  /* Capture section mobile */
  .capture-inner { grid-template-columns: 1fr; gap: 2rem; padding: 3rem 0; }
  .capture-headline { font-size: 1.75rem; }
  .ueg-ghl-form-wrap iframe { min-height: 620px; }

  /* Footer capture mobile */
  .footer-capture-inner { grid-template-columns: 1fr; gap: 2rem; }
  .footer-ghl-form { max-width: 100%; }

  /* Community grid mobile */
  .community-grid { grid-template-columns: 1fr 1fr; }
  .ueg-community-grid { padding: 3rem 0; }

  /* Footer */
  .footer-grid,
.footer-inner { grid-template-columns: 1fr; gap: var(--space-lg); }
  .footer-bottom { flex-direction: column; text-align: center; }

  /* Entry content */
  .entry-content { padding: var(--space-lg) 1.25rem; }
  .entry-content h1:first-of-type { font-size: 1.75rem; }
  .entry-content h2 + ul, .ueg-highlights { grid-template-columns: 1fr; }
  .entry-content ul:not(.ueg-highlights) li { flex-direction: column; gap: 0.25rem; }
  .entry-content ul:not(.ueg-highlights) li strong { min-width: unset; }

  /* New components — mobile */
  .pillars-grid, .pillars-grid--3 { grid-template-columns: 1fr; }
  .btt-inner { grid-template-columns: 1fr; }
  .btt-videos { grid-template-columns: repeat(2, 1fr); }
  .packages-grid { grid-template-columns: 1fr; }
  .about-story__inner { grid-template-columns: 1fr; gap: var(--space-lg); }
  .about-photo-grid { grid-template-columns: repeat(2, 1fr); }
  .about-moments { padding: var(--space-xl) 0; }
  .contact-inner { grid-template-columns: 1fr; gap: var(--space-lg); }
  .contact-form-wrap { padding: 1.5rem; }
  .contact-faq-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .stat-item { border-right: none; border-bottom: 1px solid var(--ueg-border-dark); }
  .stat-item:last-child { border-bottom: none; }
  .ueg-events-grid--4 { grid-template-columns: 1fr; }
  .legal-nav { flex-direction: column; }
  .ueg-legal-hero { padding: 6rem 0 3rem; }

  /* Community join mobile */
  .comm-join__inner { grid-template-columns: 1fr; gap: var(--space-lg); }
  .comm-join__stats { gap: 1.25rem; }
  .comm-join__stat-num { font-size: 1.6rem; }
  .comm-join__form-header { padding: 1.25rem 1.5rem 1rem; }
  .comm-join__proof { padding: 0.875rem 1.5rem; }

  /* Connect page mobile */
  .connect-quick-strip { position: static; }
  .connect-quick-strip .container { gap: 0.5rem; }
  .connect-quick-label { display: none; }
  .connect-quick-links { gap: 0.4rem; }
  .connect-quick-link { font-size: 0.72rem; padding: 0.25rem 0.6rem; }
  .connect-brand__header { gap: 1rem; }
  .connect-brand__icon { width: 2.75rem; height: 2.75rem; font-size: 1.75rem; }
  .connect-channels-grid { grid-template-columns: 1fr; }
  .connect-channel-card { grid-template-columns: auto 1fr auto auto; }
}

@media (max-width: 480px) {
  .ueg-pillars { grid-template-columns: 1fr; }
  .ueg-stats { grid-template-columns: 1fr 1fr; }
  .ueg-audience-grid { grid-template-columns: 1fr; }
  .ueg-event-card__countdown { flex-wrap: wrap; }
  .about-photo-grid { grid-template-columns: 1fr; }
  .btt-videos { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .ueg-hero__actions { flex-direction: column; }
  .ueg-hero__actions .ueg-btn-primary,
  .ueg-hero__actions .ueg-btn-secondary { width: 100%; justify-content: center; }
}

/* ============================================================
   PRINT
   ============================================================ */
@media print {
  .site-header, .site-footer, .site-nav, .ueg-hero__scroll { display: none; }
  .site-content { padding-top: 0; }
  body { background: white; color: black; }
}

/* ============================================================
   TICKET MODAL
   ============================================================ */
.ueg-modal {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
}
.ueg-modal[hidden] { display: none; }

.ueg-modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.82);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.ueg-modal__box {
  position: relative; z-index: 1;
  background: var(--ueg-charcoal);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 16px;
  padding: 2.5rem;
  width: 100%; max-width: 520px;
  max-height: 90vh; overflow-y: auto;
  box-shadow: 0 24px 60px rgba(0,0,0,.6);
}
.ueg-modal__close {
  position: absolute; top: 1rem; right: 1rem;
  background: rgba(255,255,255,.08); border: none;
  border-radius: 50%; width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  color: var(--ueg-white); cursor: pointer;
  transition: background .2s;
}
.ueg-modal__close:hover { background: rgba(255,255,255,.18); }

.modal-event-badge {
  display: inline-block;
  background: rgba(239,68,68,.15);
  border: 1px solid rgba(239,68,68,.3);
  color: #f87171;
  font-size: .75rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; padding: .3rem .75rem;
  border-radius: 999px; margin-bottom: 1rem;
}
.modal-title {
  font-family: var(--ueg-font-serif);
  font-size: clamp(1.2rem, 3vw, 1.6rem);
  color: var(--ueg-white); margin: 0 0 .5rem;
  line-height: 1.25;
}
.modal-subtitle {
  font-size: .82rem; color: var(--ueg-gold);
  font-style: italic; margin: -.15rem 0 .65rem;
  opacity: .9; line-height: 1.4;
}
.modal-subtitle[hidden] { display: none; }
.modal-details {
  color: var(--ueg-muted); font-size: .9rem; margin-bottom: .25rem;
}
.modal-price {
  color: var(--ueg-gold); font-weight: 700; font-size: 1.1rem;
  margin-bottom: .2rem;
}
.modal-payment-note {
  font-size: .76rem; color: rgba(255,255,255,.42);
  margin: 0 0 1.25rem; letter-spacing: .01em;
}
.modal-value-prop {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px; padding: 1rem 1.25rem;
  margin-bottom: 1.5rem;
}
.modal-value-prop p { font-size: .85rem; color: var(--ueg-muted); margin-bottom: .5rem; }
.modal-value-prop ul { list-style: none; padding: 0; margin: 0; }
.modal-value-prop li { font-size: .85rem; color: rgba(255,255,255,.8); padding: .2rem 0; }

.modal-form { display: flex; flex-direction: column; gap: .75rem; }
.modal-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.modal-form input {
  width: 100%; padding: .75rem 1rem;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px; color: var(--ueg-white);
  font-size: .9rem; outline: none;
  transition: border-color .2s;
}
.modal-form input::placeholder { color: rgba(255,255,255,.35); }
.modal-form input:focus { border-color: var(--ueg-fire); }
.modal-form-error { color: #f87171; font-size: .82rem; margin: 0; }
.modal-form-error[hidden] { display: none; }

.modal-submit { width: 100%; padding: .9rem; font-size: 1rem; }
.modal-submit:disabled { opacity: .6; cursor: not-allowed; }
.modal-urgency {
  text-align: center; font-size: .75rem;
  color: var(--ueg-fire); font-weight: 600;
  margin: .3rem 0 0; letter-spacing: .02em;
}
.modal-disclaimer {
  text-align: center; font-size: .75rem;
  color: var(--ueg-muted); margin: 0;
}

/* Step 2 — success */
.modal-step[hidden] { display: none; }
.modal-success-icon {
  font-size: 3rem; text-align: center;
  display: block; margin-bottom: 1rem;
}
.modal-success-msg {
  color: var(--ueg-muted); text-align: center;
  margin-bottom: 1.5rem;
}
.modal-posh-btn {
  display: block; text-align: center;
  padding: .9rem; font-size: 1rem;
  margin-bottom: .75rem;
}
.modal-close-btn {
  display: block; width: 100%; text-align: center;
  padding: .75rem; font-size: .9rem; cursor: pointer;
  background: none; border: 1px solid rgba(255,255,255,.15);
  border-radius: 8px; color: var(--ueg-muted);
  transition: color .2s, border-color .2s;
}
.modal-close-btn:hover { color: var(--ueg-white); border-color: rgba(255,255,255,.3); }

body.modal-open { overflow: hidden; }

/* ============================================================
   EXIT INTENT POPUP
   ============================================================ */
.ueg-exit-intent {
  position: fixed; inset: 0; z-index: 9998;
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
}
.ueg-exit-intent[hidden] { display: none; }

.ueg-exit-intent__backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
}
.ueg-exit-intent__box {
  position: relative; z-index: 1;
  background: linear-gradient(135deg, #1a1a1a 0%, #111 100%);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 20px; padding: 2.5rem;
  width: 100%; max-width: 480px;
  box-shadow: 0 32px 80px rgba(0,0,0,.7);
  text-align: center;
}
.exit-badge {
  display: inline-block;
  background: rgba(234,179,8,.12);
  border: 1px solid rgba(234,179,8,.25);
  color: var(--ueg-gold);
  font-size: .72rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  padding: .3rem .85rem; border-radius: 999px;
  margin-bottom: 1.25rem;
}
.exit-headline {
  font-family: var(--ueg-font-serif);
  font-size: clamp(1.3rem, 4vw, 1.75rem);
  color: var(--ueg-white); margin: 0 0 .75rem; line-height: 1.25;
}
.exit-sub { color: var(--ueg-muted); font-size: .9rem; margin-bottom: 1.5rem; }

.exit-form { display: flex; flex-direction: column; gap: .75rem; }
.exit-form input {
  width: 100%; padding: .8rem 1rem;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px; color: var(--ueg-white); font-size: .9rem; outline: none;
  transition: border-color .2s; text-align: center;
}
.exit-form input::placeholder { color: rgba(255,255,255,.35); }
.exit-form input:focus { border-color: var(--ueg-fire); }
.exit-form-error { color: #f87171; font-size: .82rem; }
.exit-form-error[hidden] { display: none; }

.exit-submit { width: 100%; padding: .9rem; font-size: 1rem; }
.exit-success {
  color: #4ade80; font-weight: 600; font-size: .95rem;
  text-align: center; padding: .5rem;
}
.exit-success[hidden] { display: none; }
.exit-skip {
  background: none; border: none;
  color: var(--ueg-muted); font-size: .8rem; cursor: pointer;
  text-decoration: underline; padding: .5rem;
  transition: color .2s;
}
.exit-skip:hover { color: var(--ueg-white); }

/* ============================================================
   COOKIE CONSENT BAR
   ============================================================ */
.ueg-cookie-bar {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--ueg-graphite);
  border-top: 1px solid rgba(255,255,255,.1);
  z-index: 9000; padding: 1rem;
}
.ueg-cookie-bar[hidden] { display: none; }
.cookie-bar-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center;
  justify-content: space-between; gap: 1rem;
  flex-wrap: wrap;
}
.cookie-bar-inner p { font-size: .82rem; color: var(--ueg-muted); margin: 0; }
.cookie-bar-inner a { color: var(--ueg-gold); }
.cookie-bar-actions { display: flex; gap: .5rem; flex-shrink: 0; }

/* ============================================================
   EMAIL CAPTURE FORM — 2-col row
   ============================================================ */
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
}
@media (max-width: 480px) {
  .form-row { grid-template-columns: 1fr; }
  .modal-form-row { grid-template-columns: 1fr; }
}
