/* ═══════════════════════════════════════════════════════════
   NAIJA FOOD CARNIVAL 2026 — MASTER CSS
   Single source of truth — no duplicates
   ═══════════════════════════════════════════════════════════ */

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

:root {
  --green:       #1a5c2e;
  --green-mid:   #2d8a4e;
  --green-light: #e8f5ed;
  --gold:        #f7c430;
  --gold-dark:   #e6a800;
  --red:         #c8200a;
  --red-light:   #fdf0ee;
  --dark:        #0b1a0e;
  --white:       #ffffff;
  --off-white:   #f8f8f6;
  --border:      #e4e9e6;
  --text-muted:  #6b7c74;
  --shadow:      0 4px 24px rgba(0,0,0,0.08);
  --shadow-md:   0 8px 40px rgba(0,0,0,0.12);
  --radius:      10px;
  --radius-lg:   16px;
  --transition:  0.2s ease;
}

html { scroll-behavior: smooth; }
body { font-family: 'Inter', 'Segoe UI', Arial, sans-serif; font-size: 15px; color: var(--dark); background: var(--white); line-height: 1.6; -webkit-font-smoothing: antialiased; }
img  { max-width: 100%; height: auto; display: block; }
a    { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
ul, ol { list-style: none; }

.skip-link { position: absolute; top: -100px; left: 16px; background: var(--green); color: var(--white); padding: 8px 16px; border-radius: 4px; font-weight: 700; z-index: 9999; transition: top 0.2s; }
.skip-link:focus { top: 16px; }

/* ── ANNOUNCEMENT BAR ────────────────────────────────────── */
.ann-bar { background: var(--dark); border-bottom: 1px solid rgba(247,196,48,0.18); padding: 9px 0; text-align: center; position: relative; z-index: 999; }
.ann-bar-inner { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; color: rgba(255,255,255,0.7); flex-wrap: wrap; justify-content: center; }
.ann-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); flex-shrink: 0; animation: nfc-pulse 2s infinite; }
.ann-bar-inner a { color: var(--gold); font-weight: 700; display: inline-flex; align-items: center; gap: 5px; transition: gap 0.2s; }
.ann-bar-inner a:hover { gap: 8px; }

@keyframes nfc-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.4)} }
@keyframes nfc-float { 0%{transform:translateY(0) rotate(0)} 100%{transform:translateY(-36px) rotate(12deg)} }

/* ── NAVIGATION ──────────────────────────────────────────── */
.navbar, .nav2 {
  position: sticky; top: 0; z-index: 1100;
  background: rgba(255,255,255,0.98);
  border-bottom: 1px solid var(--border);
  transition: box-shadow 0.3s;
}
.navbar::before, .nav2::before {
  content: ''; position: absolute; inset: 0;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  z-index: -1;
  pointer-events: none;
}
.navbar.scrolled, .nav2.scrolled { box-shadow: 0 4px 24px rgba(0,0,0,0.09); }

.nav-container, .nav2-inner {
  max-width: 1280px; margin: 0 auto;
  padding: 0 40px;
  display: flex; align-items: center;
  justify-content: space-between;
  height: 76px;
}

.nav-logo, .nav2-logo { display: flex; align-items: center; text-decoration: none; flex-shrink: 0; }
.nav2-logo-img, .nav-logo img {
  width: 68px; height: 68px;
  object-fit: contain; display: block; border-radius: 8px;
}

.nav-links, .nav2-links { display: flex; align-items: center; gap: 2px; }
.nav2-mobile-header { display: none; }

.nav-link, .nav2-link {
  padding: 8px 14px; font-size: 14px; font-weight: 500;
  color: var(--text-muted); text-decoration: none;
  border-radius: 6px; transition: all 0.15s;
  position: relative; white-space: nowrap;
}
.nav-link:hover, .nav2-link:hover { color: var(--dark); background: var(--off-white); }
.nav-link.active, .nav2-active { color: var(--green) !important; font-weight: 600; }
.nav-link.active::after, .nav2-active::after {
  content: ''; position: absolute;
  bottom: 2px; left: 14px; right: 14px;
  height: 2px; background: var(--green); border-radius: 2px;
}

.nav-advertise, .nav2-advertise-link {
  color: var(--green) !important; font-weight: 700 !important;
  background: var(--green-light); border-radius: 6px;
}
.nav-advertise i, .nav2-advertise-link i { font-size: 11px; margin-right: 3px; }
.nav-advertise:hover, .nav2-advertise-link:hover { background: var(--green) !important; color: var(--white) !important; }

/* ── Get Involved dropdown ── */
.nav-dropdown-wrap { position: relative; display: inline-flex; align-items: center; }
.nav-dropdown-toggle { background: none; border: none; cursor: pointer; font-family: inherit; font-size: inherit; display: flex; align-items: center; }
.nav-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 200px;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.12);
  padding: 8px 0;
  z-index: 900;
  animation: dropFadeIn 0.15s ease;
}
@keyframes dropFadeIn { from { opacity:0; transform:translateY(-6px); } to { opacity:1; transform:translateY(0); } }
.nav-dropdown-menu.open { display: block; }
.nav-dropdown-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 18px; font-size: 13px; font-weight: 600; color: var(--dark);
  text-decoration: none; transition: background 0.15s, color 0.15s;
  white-space: nowrap;
}
.nav-dropdown-item i { width: 16px; text-align: center; color: var(--green); font-size: 12px; }
.nav-dropdown-item:hover, .nav-dropdown-item:focus { background: var(--off-white); color: var(--green); outline: none; }
.nav-dropdown-active { color: var(--green) !important; font-weight: 700; }
.nav-dropdown-divider { height: 1px; background: var(--border); margin: 6px 0; }

.btn-nav, .nav2-ticket-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--green); color: var(--white) !important;
  padding: 9px 20px; border-radius: 6px;
  font-weight: 700; font-size: 13px; text-decoration: none;
  margin-left: 12px; transition: all 0.2s; white-space: nowrap; flex-shrink: 0;
}
.btn-nav:hover, .nav2-ticket-btn:hover { background: #0f4423; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(26,92,46,0.3); }

.nav-toggle, .nav2-toggle {
  display: none; flex-direction: column; justify-content: center;
  gap: 5px; width: 44px; height: 44px; padding: 10px;
  background: var(--green); border: none;
  border-radius: 8px; z-index: 1200; flex-shrink: 0;
  cursor: pointer;
}
.nav-toggle span, .nav2-toggle span {
  display: block; width: 22px; height: 2.5px;
  background: #fff; border-radius: 2px;
  transition: all 0.25s ease; transform-origin: center;
}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 24px; border-radius: 8px;
  font-weight: 600; font-size: 14px;
  text-decoration: none; border: 2px solid transparent;
  cursor: pointer; transition: all 0.2s; font-family: inherit;
}
.btn-lg  { padding: 15px 32px; font-size: 15px; }
.btn-sm  { padding: 8px 16px; font-size: 13px; }
.btn-full { width: 100%; justify-content: center; }
.btn-primary { background: var(--green); color: var(--white); border-color: var(--green); }
.btn-primary:hover { background: #0f4423; border-color: #0f4423; transform: translateY(-1px); }
.btn-outline-primary { background: transparent; color: var(--green); border-color: var(--green); }
.btn-outline-primary:hover { background: var(--green); color: var(--white); }
.btn-gold { background: var(--gold); color: var(--dark); border-color: var(--gold); }
.btn-gold:hover { background: var(--gold-dark); border-color: var(--gold-dark); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(247,196,48,0.35); }
.btn-outline-white { background: transparent; color: var(--white); border-color: rgba(255,255,255,0.4); }
.btn-outline-white:hover { background: rgba(255,255,255,0.1); border-color: var(--white); }
.req { color: var(--red); }

/* ── LAYOUT ──────────────────────────────────────────────── */
.container { max-width: 1280px; margin: 0 auto; padding: 0 40px; }
.section    { padding: 90px 0; }
.section-header.centered { text-align: center; max-width: 600px; margin: 0 auto 48px; }
.section-tag {
  display: inline-block; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 3px; color: var(--green);
  border-bottom: 2px solid var(--green); padding-bottom: 4px; margin-bottom: 16px;
}
.section-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(26px,3.5vw,42px); font-weight: 900;
  color: var(--dark); line-height: 1.15; margin-bottom: 16px;
}
.section-body     { color: var(--text-muted); font-size: 15px; line-height: 1.8; margin-bottom: 16px; }
.section-subtitle { color: var(--text-muted); font-size: 15px; line-height: 1.7; max-width: 560px; margin: 0 auto; }

/* ── ALERTS ──────────────────────────────────────────────── */
.alert {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 18px; border-radius: 10px; font-size: 14px; line-height: 1.6;
}
.alert-error   { background: var(--red-light); color: var(--red); border: 1px solid rgba(200,32,10,0.2); border-left: 4px solid var(--red); }
.alert-success { background: var(--green-light); color: var(--green); border: 1px solid rgba(26,92,46,0.2); border-left: 4px solid var(--green); }
.alert-warning { background: #fffbeb; color: #92400e; border: 1px solid #fde68a; border-left: 4px solid #f59e0b; }
.alert-sandbox { background: #fffbea; color: #7a5c00; border: 1px solid #f7c430; border-left: 4px solid #f7c430; }
.alert-sandbox i { color: #e8a800; }
.alert-sandbox code { background: rgba(0,0,0,0.07); padding: 1px 6px; border-radius: 4px; font-family: monospace; font-size: 12px; }

/* ── FORMS ───────────────────────────────────────────────── */
.form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.form-group label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); }
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%; padding: 11px 14px;
  border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 14px; font-family: inherit; color: var(--dark);
  background: var(--white); outline: none; box-sizing: border-box;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(26,92,46,0.1); }
.form-group textarea { resize: vertical; }

/* ── BREADCRUMB ──────────────────────────────────────────── */
.breadcrumb-wrapper { background: var(--off-white); border-bottom: 1px solid var(--border); padding: 10px 0; }
.breadcrumb { display: flex; align-items: center; gap: 6px; padding: 0; }
.breadcrumb li, .breadcrumb span { font-size: 12px; color: var(--text-muted); }
.breadcrumb a { color: var(--green); font-weight: 500; }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb-sep { color: var(--border); }
.breadcrumb-current { color: var(--dark); font-weight: 600; }

/* ── PAGE HERO ───────────────────────────────────────────── */
.page-hero2 {
  background: linear-gradient(135deg, #0b3518 0%, #1a5c2e 60%, #0e4020 100%);
  padding: 72px 40px 64px; position: relative; overflow: hidden;
}
.page-hero2::before {
  content: ''; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.025'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events: none;
}
.page-hero2::after {
  content: ''; position: absolute; bottom: -1px; left: 0; right: 0;
  height: 56px; background: linear-gradient(to bottom right, transparent 49%, #ffffff 50%);
  pointer-events: none;
}
.page-hero2-content { position: relative; z-index: 1; max-width: 1280px; margin: 0 auto; }
.page-hero2-content h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(36px,5vw,60px); font-weight: 900;
  color: var(--white); margin-bottom: 12px; line-height: 1.1;
}
.page-hero2-content p { font-size: 16px; color: rgba(255,255,255,0.65); margin: 0; max-width: 560px; }

/* ── MODAL ───────────────────────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 2000;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity 0.2s; padding: 20px;
}
.modal-overlay.active { opacity: 1; pointer-events: all; }
.modal {
  background: var(--white); border-radius: 20px;
  max-width: 480px; width: 100%; max-height: 90vh; overflow-y: auto;
  position: relative; box-shadow: 0 32px 80px rgba(0,0,0,0.3);
}
.modal-close {
  position: absolute; top: 16px; right: 16px;
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--off-white); border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted); font-size: 14px; transition: background 0.2s; z-index: 1;
}
.modal-close:hover { background: var(--border); }

/* ── FOOTER ──────────────────────────────────────────────── */
.footer2 { background: #080f0a; color: rgba(255,255,255,0.5); }
.footer2-top {
  max-width: 1280px; margin: 0 auto; padding: 72px 40px 56px;
  display: grid; grid-template-columns: 2fr 1fr 1fr 1.6fr; gap: 56px;
}
.footer2-logo { width: 72px; height: 72px; object-fit: contain; display: block; margin-bottom: 16px; border-radius: 10px; background: rgba(255,255,255,0.06); padding: 4px; }
.footer2-desc { font-size: 14px; line-height: 1.8; margin-bottom: 24px; color: rgba(255,255,255,0.4); max-width: 280px; }
.footer2-social { display: flex; gap: 10px; }
.footer2-social a {
  width: 38px; height: 38px; border-radius: 8px;
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.08);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.45); font-size: 14px; text-decoration: none; transition: all 0.2s;
}
.footer2-social a:hover { background: var(--gold); border-color: var(--gold); color: var(--dark); transform: translateY(-2px); }
.footer2-col { display: flex; flex-direction: column; gap: 10px; padding-top: 4px; }
.footer2-col-head { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: var(--white); margin-bottom: 8px; padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,0.07); }
.footer2-col a, .footer2-col span { font-size: 13px; color: rgba(255,255,255,0.42); text-decoration: none; transition: color 0.15s; display: flex; align-items: center; gap: 8px; line-height: 1.5; }
.footer2-col a:hover { color: var(--gold); }
.footer2-col i { font-size: 11px; width: 14px; color: rgba(255,255,255,0.2); flex-shrink: 0; }
.footer2-bottom { border-top: 1px solid rgba(255,255,255,0.06); padding: 20px 40px; max-width: 1280px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
.footer2-bottom p { font-size: 12px; color: rgba(255,255,255,0.22); margin: 0; }
.footer2-bottom strong { color: var(--gold); }

/* ── LIGHTBOX ────────────────────────────────────────────── */
#lightboxOverlay { position: fixed; inset: 0; background: rgba(0,0,0,0.94); z-index: 9999; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 16px; opacity: 0; pointer-events: none; transition: opacity 0.25s ease; }
#lightboxOverlay.lb-open { opacity: 1; pointer-events: all; }
#lightboxImgWrap { position: relative; max-width: min(90vw,960px); max-height: 75vh; display: flex; align-items: center; justify-content: center; }
#lightboxImg { max-width: min(90vw,960px); max-height: 75vh; object-fit: contain; border-radius: 10px; transition: opacity 0.2s; display: block; box-shadow: 0 24px 72px rgba(0,0,0,0.6); }
#lightboxLoader { position: absolute; inset: 0; display: none; align-items: center; justify-content: center; color: var(--white); font-size: 32px; }
#lightboxCaption { color: rgba(255,255,255,0.8); font-size: 14px; text-align: center; max-width: 600px; padding: 0 20px; }
#lightboxDots { display: flex; gap: 8px; }
.lb-dot { width: 8px; height: 8px; border-radius: 50%; border: none; background: rgba(255,255,255,0.3); cursor: pointer; transition: all 0.2s; padding: 0; }
.lb-dot.lb-dot-active, .lb-dot:hover { background: var(--gold); transform: scale(1.3); }
#lightboxClose { position: fixed; top: 20px; right: 24px; background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.2); color: var(--white); width: 42px; height: 42px; border-radius: 50%; font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.2s; z-index: 10001; }
#lightboxClose:hover { background: rgba(255,255,255,0.25); }
#lightboxPrev, #lightboxNext { position: fixed; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.15); color: var(--white); width: 50px; height: 50px; border-radius: 50%; font-size: 18px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.2s; z-index: 10001; }
#lightboxPrev { left: 20px; } #lightboxNext { right: 20px; }
#lightboxPrev:hover, #lightboxNext:hover { background: rgba(255,255,255,0.25); }

/* ════════════════════════════════════════════════════════════
   HOMEPAGE
   ════════════════════════════════════════════════════════════ */

/* ── Hero ── */
.hero2 { position: relative; min-height: 100vh; display: flex; align-items: center; padding-top: 76px; }
.hero2-bg { position: absolute; inset: 0; z-index: 0; }
.hero2-bg-img { position: absolute; inset: 0; background-size: cover; background-position: center 30%; }
.hero2-bg-overlay { position: absolute; inset: 0; background: linear-gradient(110deg,rgba(7,28,14,0.97) 0%,rgba(11,53,24,0.92) 40%,rgba(11,53,24,0.6) 70%,rgba(0,0,0,0.3) 100%); }
.hero2-noise { position: absolute; inset: 0; opacity: 0.05; mix-blend-mode: overlay; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.hero2-layout { position: relative; z-index: 1; max-width: 1280px; margin: 0 auto; padding: 80px 40px; display: grid; grid-template-columns: 1fr 420px; gap: 64px; align-items: center; width: 100%; }
.hero2-pill { display: inline-flex; align-items: center; gap: 8px; background: rgba(247,196,48,0.12); border: 1px solid rgba(247,196,48,0.3); color: var(--gold); font-size: 13px; font-weight: 600; padding: 7px 16px; border-radius: 50px; letter-spacing: 0.5px; margin-bottom: 28px; }
.hero2-pill-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); animation: nfc-pulse 2s infinite; }
.hero2-h1 { font-family: 'Playfair Display', serif; line-height: 0.9; margin-bottom: 20px; color: var(--white); }
.hero2-h1-thin { display: block; font-size: clamp(28px,4vw,56px); font-weight: 700; color: rgba(255,255,255,0.6); letter-spacing: 6px; text-transform: uppercase; font-style: italic; }
.hero2-h1-bold { display: block; font-size: clamp(56px,9vw,112px); font-weight: 900; color: var(--white); line-height: 0.9; }
.hero2-tagline { color: var(--gold); font-size: 14px; letter-spacing: 2px; text-transform: uppercase; font-weight: 500; margin-bottom: 28px; border-left: 3px solid var(--gold); padding-left: 14px; }
.hero2-meta { display: flex; gap: 24px; margin-bottom: 36px; flex-wrap: wrap; }
.hero2-meta-item { display: flex; align-items: center; gap: 8px; color: rgba(255,255,255,0.65); font-size: 14px; }
.hero2-meta-item i { color: var(--gold); font-size: 13px; }
.hero2-actions { display: flex; gap: 16px; flex-wrap: wrap; }
.hero2-btn-primary { display: inline-flex; align-items: center; gap: 10px; background: var(--gold); color: var(--dark); padding: 15px 32px; border-radius: 6px; font-weight: 700; font-size: 15px; text-decoration: none; transition: all 0.2s; }
.hero2-btn-primary:hover { background: var(--gold-dark); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(247,196,48,0.4); }
.hero2-btn-ghost { display: inline-flex; align-items: center; gap: 8px; background: transparent; color: var(--white); padding: 15px 28px; border-radius: 6px; border: 1px solid rgba(255,255,255,0.3); font-weight: 600; font-size: 15px; text-decoration: none; transition: all 0.2s; }
.hero2-btn-ghost:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.6); }

/* Countdown card */
.hero2-countdown-card { background: rgba(255,255,255,0.05); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border: 1px solid rgba(255,255,255,0.12); border-radius: 20px; padding: 32px 28px; }
.hcc-label { color: var(--gold); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 20px; text-align: center; }
.hcc-timer { display: flex; align-items: center; justify-content: center; gap: 6px; margin-bottom: 24px; }
.hcc-unit { text-align: center; }
.hcc-num { display: block; font-family: 'Playfair Display', serif; font-size: 44px; font-weight: 900; color: var(--white); line-height: 1; background: rgba(255,255,255,0.06); border-radius: 8px; padding: 8px 12px; min-width: 64px; }
.hcc-text { display: block; font-size: 10px; color: rgba(255,255,255,0.4); text-transform: uppercase; letter-spacing: 1px; margin-top: 6px; }
.hcc-colon { font-size: 32px; color: var(--gold); font-weight: 900; margin-bottom: 16px; line-height: 1; }
.hcc-features { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 24px; border-top: 1px solid rgba(255,255,255,0.08); padding-top: 20px; }
.hcc-feat { display: flex; align-items: center; gap: 8px; color: rgba(255,255,255,0.65); font-size: 12px; }
.hcc-feat i { color: var(--gold); font-size: 11px; flex-shrink: 0; }
.hcc-cta { display: block; text-align: center; background: var(--green); color: var(--white); padding: 13px; border-radius: 8px; font-weight: 700; font-size: 14px; text-decoration: none; transition: background 0.2s, transform 0.2s; }
.hcc-cta:hover { background: #2d8a4e; transform: translateY(-1px); }

/* ── Impact strip ── */
.impact-strip { background: var(--gold); }
.impact-strip-inner { max-width: 1280px; margin: 0 auto; display: flex; align-items: stretch; }
.impact-item { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 22px 20px; gap: 2px; }
.impact-item strong { font-family: 'Playfair Display', serif; font-size: 28px; font-weight: 900; color: var(--dark); line-height: 1; }
.impact-item span { font-size: 11px; font-weight: 600; color: rgba(0,0,0,0.55); text-transform: uppercase; letter-spacing: 1px; }
.impact-div { width: 1px; background: rgba(0,0,0,0.12); margin: 12px 0; }

/* ── What's On ── */
.whats-on { background: #f8f8f6; padding: 100px 0; }
.wo-container { max-width: 1280px; margin: 0 auto; padding: 0 40px; }
.wo-header { text-align: center; max-width: 560px; margin: 0 auto 56px; }
.wo-eyebrow { display: inline-block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 3px; color: var(--green); border-bottom: 2px solid var(--green); padding-bottom: 4px; margin-bottom: 16px; }
.wo-title { font-family: 'Playfair Display', serif; font-size: clamp(30px,4vw,44px); font-weight: 900; color: var(--dark); margin-bottom: 12px; line-height: 1.1; }
.wo-sub { color: var(--text-muted); font-size: 15px; line-height: 1.7; }
.wo-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.wo-card { border-radius: 16px; overflow: hidden; background: var(--white); box-shadow: 0 2px 16px rgba(0,0,0,0.07); transition: transform 0.3s, box-shadow 0.3s; }
.wo-card:hover { transform: translateY(-6px); box-shadow: 0 16px 48px rgba(0,0,0,0.13); }
.wo-card-img { height: 180px; background-size: cover; background-position: center; }
.wo-card-body { padding: 20px; }
.wo-card-icon { width: 42px; height: 42px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 18px; margin-bottom: 12px; color: var(--white); }
.wo-card-food .wo-card-icon   { background: #c8200a; }
.wo-card-culture .wo-card-icon { background: #7c3aed; }
.wo-card-family .wo-card-icon  { background: #1a5c2e; }
.wo-card-market .wo-card-icon  { background: #b45309; }
.wo-card-body h3 { font-size: 16px; font-weight: 700; color: var(--dark); margin-bottom: 8px; }
.wo-card-body p  { font-size: 13px; color: var(--text-muted); line-height: 1.6; margin-bottom: 14px; }
.wo-tag { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; padding: 3px 10px; border-radius: 50px; background: var(--green-light); color: var(--green); }

/* ── About split ── */
.about2 { display: grid; grid-template-columns: 1fr 1fr; min-height: 600px; }
.about2-image-col { position: relative; overflow: hidden; }
.about2-image-col img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 6s ease; }
.about2-image-col:hover img { transform: scale(1.04); }
.about2-badge { position: absolute; bottom: 32px; right: 32px; background: var(--gold); color: var(--dark); border-radius: 14px; padding: 16px 20px; text-align: center; box-shadow: 0 8px 24px rgba(0,0,0,0.2); }
.ab-year  { font-family: 'Playfair Display', serif; font-size: 32px; font-weight: 900; line-height: 1; }
.ab-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; opacity: 0.7; margin-top: 4px; }
.about2-text-col { background: var(--dark); padding: 80px 64px; display: flex; flex-direction: column; justify-content: center; }
.about2-eyebrow { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 3px; color: var(--gold); border-bottom: 2px solid var(--gold); padding-bottom: 4px; display: inline-block; margin-bottom: 24px; }
.about2-title { font-family: 'Playfair Display', serif; font-size: clamp(26px,3vw,40px); font-weight: 900; color: var(--white); line-height: 1.15; margin-bottom: 20px; }
.about2-body { color: rgba(255,255,255,0.65); font-size: 15px; line-height: 1.8; margin-bottom: 12px; }
.about2-points { margin: 24px 0; display: flex; flex-direction: column; gap: 10px; }
.ab-point { display: flex; align-items: center; gap: 12px; color: rgba(255,255,255,0.8); font-size: 14px; }
.ab-point i { color: var(--gold); font-size: 14px; flex-shrink: 0; }
.about2-btn { display: inline-flex; align-items: center; gap: 10px; background: var(--gold); color: var(--dark); padding: 14px 28px; border-radius: 6px; font-weight: 700; font-size: 14px; text-decoration: none; transition: all 0.2s; width: fit-content; margin-top: 8px; }
.about2-btn:hover { background: var(--gold-dark); transform: translateY(-2px); }

/* ── Tickets2 ── */
.tickets2 { background: var(--white); padding: 80px 0 100px; }
.tickets2-container { max-width: 1280px; margin: 0 auto; padding: 0 40px; }
.tickets2-header { text-align: center; margin-bottom: 48px; }
.t2-eyebrow { display: inline-block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 3px; color: var(--green); border-bottom: 2px solid var(--green); padding-bottom: 4px; margin-bottom: 16px; }
.t2-title { font-family: 'Playfair Display', serif; font-size: clamp(28px,4vw,44px); font-weight: 900; color: var(--dark); margin-bottom: 12px; }
.t2-sub   { color: var(--text-muted); font-size: 15px; max-width: 560px; margin: 0 auto; }
.t2-section-label { margin-bottom: 20px; }
.t2-section-tag { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; padding: 8px 18px; border-radius: 50px; }
.t2-tag-early   { background: #e8f5ed; color: var(--green); border: 1.5px solid #c6e8d2; }
.t2-tag-premium { background: #fffbeb; color: #92400e;      border: 1.5px solid #fde68a; }
.t2-section-tag i { font-size: 11px; }
.t2-grid { display: grid; gap: 20px; }
.t2-grid-early   { grid-template-columns: repeat(4,1fr); }
.t2-grid-premium { grid-template-columns: repeat(3,1fr); }
.t2-card { border-radius: 16px; overflow: hidden; border: 2px solid var(--border); background: var(--white); transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s; position: relative; display: flex; flex-direction: column; }
.t2-card:hover { transform: translateY(-6px); box-shadow: 0 20px 48px rgba(0,0,0,0.12); }
.t2-card-featured { border-color: var(--green); }
.t2-card-featured:hover { box-shadow: 0 20px 48px rgba(26,92,46,0.18); }
.t2-featured-badge { position: absolute; top: 0; right: 16px; background: var(--green); color: var(--white); font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; padding: 4px 12px; border-radius: 0 0 8px 8px; z-index: 1; }
.t2-card-top { padding: 24px 20px 18px; text-align: center; color: var(--white); }
.t2-card-icon { font-size: 32px; margin-bottom: 8px; line-height: 1; }
.t2-card-type { font-family: 'Playfair Display', serif; font-size: 17px; font-weight: 900; margin-bottom: 3px; }
.t2-card-age  { font-size: 11px; color: rgba(255,255,255,0.65); margin-bottom: 10px; }
.t2-price-badge { display: inline-block; background: rgba(255,255,255,0.18); color: var(--white); font-size: 9px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; padding: 3px 10px; border-radius: 50px; border: 1px solid rgba(255,255,255,0.25); }
.t2-card-body { padding: 18px 20px 22px; display: flex; flex-direction: column; flex: 1; }
.t2-price { font-family: 'Playfair Display', serif; font-size: 28px; font-weight: 900; color: var(--dark); margin-bottom: 14px; }
.t2-perks { list-style: none; padding: 0; margin: 0 0 18px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.t2-perks li { display: flex; align-items: flex-start; gap: 8px; font-size: 12.5px; color: var(--text-muted); line-height: 1.4; }
.t2-perks li i { color: var(--green); font-size: 10px; flex-shrink: 0; margin-top: 3px; }
.t2-btn { display: block; text-align: center; padding: 11px 16px; border-radius: 8px; font-weight: 700; font-size: 13px; text-decoration: none; transition: all 0.2s; border: 2px solid transparent; }
.t2-btn-early       { background: var(--green);  color: var(--white); border-color: var(--green); }
.t2-btn-early:hover { background: #0f4423; }
.t2-btn-kids-eb     { background: #fef9e7; color: #c49a00; border-color: #f7c430; }
.t2-btn-kids-eb:hover { background: #f7c430; color: #111111; }
.t2-btn-family      { background: #fff0ee; color: #c8200a; border-color: #f4a49a; }
.t2-btn-family:hover  { background: #c8200a; color: var(--white); }
.t2-btn-squad       { background: #f2f2f2; color: #111111; border-color: #333333; }
.t2-btn-squad:hover   { background: #111111; color: var(--white); }
.t2-btn-premium     { background: rgba(26,92,46,0.1); color: var(--green); border-color: var(--green); }
.t2-btn-premium:hover { background: var(--green); color: var(--white); }
.t2-btn-vip-table   { background: #fff0ee; color: #c8200a; border-color: #f4a49a; }
.t2-btn-vip-table:hover   { background: #c8200a; color: var(--white); border-color: #c8200a; }
.t2-btn-vvip-table  { background: #f2f2f2; color: #111111; border-color: #333333; }
.t2-btn-vvip-table:hover  { background: #111111; color: var(--white); border-color: #111111; }
.t2-cta { text-align: center; margin-top: 48px; }


/* ── Gallery2 ── */
.gallery2 { background: var(--dark); padding: 80px 0 0; overflow: hidden; }
.gallery2-header { max-width: 1280px; margin: 0 auto; padding: 0 40px 48px; display: flex; align-items: flex-end; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.g2-eyebrow { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 3px; color: var(--gold); border-bottom: 2px solid var(--gold); padding-bottom: 4px; margin-bottom: 12px; display: block; }
.g2-title { font-family: 'Playfair Display', serif; font-size: clamp(28px,4vw,48px); font-weight: 900; color: var(--white); margin: 0; }
.g2-link { display: inline-flex; align-items: center; gap: 8px; color: var(--gold); font-weight: 600; font-size: 14px; text-decoration: none; transition: gap 0.2s; }
.g2-link:hover { gap: 12px; }
.gallery2-strip { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; grid-template-rows: 280px 280px; gap: 4px; }
.g2-item { position: relative; overflow: hidden; cursor: pointer; }
.g2-tall { grid-row: span 2; }
.g2-item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.5s ease; }
.g2-item:hover img { transform: scale(1.07); }
.g2-hover { position: absolute; inset: 0; background: rgba(0,0,0,0); display: flex; align-items: center; justify-content: center; opacity: 0; transition: all 0.3s; color: var(--white); font-size: 24px; }
.g2-item:hover .g2-hover { background: rgba(0,0,0,0.35); opacity: 1; }

/* ── Partner2 ── */
.partner2 { background: linear-gradient(135deg,#0b3518 0%,#1a5c2e 100%); padding: 100px 0; }
.partner2-inner { max-width: 1280px; margin: 0 auto; padding: 0 40px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.p2-eyebrow { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 3px; color: var(--gold); border-bottom: 2px solid var(--gold); padding-bottom: 4px; display: inline-block; margin-bottom: 20px; }
.p2-title { font-family: 'Playfair Display', serif; font-size: clamp(28px,3.5vw,44px); font-weight: 900; color: var(--white); line-height: 1.15; margin-bottom: 16px; }
.p2-body { color: rgba(255,255,255,0.65); font-size: 15px; line-height: 1.8; margin-bottom: 32px; }
.p2-stats { display: flex; gap: 36px; }
.p2-stat { display: flex; flex-direction: column; gap: 2px; }
.p2-stat strong { font-family: 'Playfair Display', serif; font-size: 32px; font-weight: 900; color: var(--gold); line-height: 1; }
.p2-stat span   { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,0.4); }
.partner2-cards { display: flex; flex-direction: column; gap: 20px; }
.p2-card { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); border-radius: 16px; padding: 28px; text-decoration: none; transition: all 0.3s; display: block; }
.p2-card:hover { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.25); transform: translateX(6px); }
.p2-card i { font-size: 28px; color: var(--gold); margin-bottom: 12px; display: block; }

.faq-container { max-width: 880px; }
.p2-card h3 { font-size: 18px; font-weight: 700; color: var(--white); margin-bottom: 6px; }
.p2-card p  { font-size: 13px; color: rgba(255,255,255,0.55); line-height: 1.6; margin-bottom: 14px; }
.p2-card-link { font-size: 13px; font-weight: 700; color: var(--gold); display: inline-flex; align-items: center; gap: 6px; transition: gap 0.2s; }
.p2-card:hover .p2-card-link { gap: 10px; }

/* ── Reviews carousel ── */
.reviews-section { background: var(--dark); overflow: hidden; }
.reviews-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; margin-bottom: 48px; flex-wrap: wrap; }
.reviews-header .section-tag { color: var(--gold); border-color: var(--gold); }
.reviews-header .section-title { color: var(--white); margin-bottom: 0; }
.reviews-overall { text-align: right; }
.reviews-stars-big { font-size: 22px; color: var(--gold); margin-bottom: 4px; }
.reviews-score { font-family: 'Playfair Display', serif; font-size: 40px; font-weight: 900; color: var(--white); line-height: 1; }
.reviews-score span { font-size: 18px; color: rgba(255,255,255,0.4); font-family: 'Inter',sans-serif; font-weight: 400; }
.reviews-count { font-size: 12px; color: rgba(255,255,255,0.35); margin-top: 4px; }
.reviews-carousel-wrap { position: relative; overflow: hidden; }
.reviews-track { display: flex; gap: 24px; transition: transform 0.45s cubic-bezier(0.4,0,0.2,1); will-change: transform; }
.review-card { flex: 0 0 calc(33.333% - 16px); background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); border-radius: 16px; padding: 28px; display: flex; flex-direction: column; gap: 16px; transition: background 0.2s, border-color 0.2s; }
.review-card:hover { background: rgba(255,255,255,0.08); border-color: rgba(247,196,48,0.3); }
.rc-stars { font-size: 18px; color: var(--gold); letter-spacing: 2px; }
.rc-text { font-size: 14px; line-height: 1.8; color: rgba(255,255,255,0.75); margin: 0; flex: 1; font-style: italic; }
.rc-text::before { content: '"'; font-size: 24px; color: var(--gold); line-height: 0; vertical-align: -6px; margin-right: 2px; }
.rc-author { display: flex; align-items: center; gap: 12px; border-top: 1px solid rgba(255,255,255,0.07); padding-top: 16px; }
.rc-avatar { width: 42px; height: 42px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 800; color: var(--white); flex-shrink: 0; }
.rc-name { font-size: 14px; font-weight: 700; color: var(--white); }
.rc-role { font-size: 11px; color: rgba(255,255,255,0.4); margin-top: 2px; }
.reviews-arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 44px; height: 44px; border-radius: 50%; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15); color: var(--white); font-size: 15px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.2s; z-index: 2; }
.reviews-arrow:hover { background: var(--gold); border-color: var(--gold); color: var(--dark); }
.reviews-prev { left: -22px; } .reviews-next { right: -22px; }
.reviews-dots { display: flex; justify-content: center; gap: 8px; margin-top: 32px; }
.rdot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.2); border: none; cursor: pointer; transition: all 0.2s; padding: 0; }
.rdot.active { background: var(--gold); transform: scale(1.3); }

/* ════════════════════════════════════════════════════════════
   ABOUT PAGE
   ════════════════════════════════════════════════════════════ */
.about-intro-section { background: var(--white); }
.about-intro-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.about-intro-text .section-body { margin-bottom: 16px; }
.about-brand-statement { background: var(--dark); border-radius: 14px; padding: 24px 28px; margin-top: 28px; display: flex; gap: 16px; align-items: flex-start; }
.about-brand-statement i { font-size: 24px; color: var(--gold); flex-shrink: 0; margin-top: 4px; }
.about-brand-statement p { font-family: 'Playfair Display', serif; font-size: 17px; font-style: italic; color: var(--white); line-height: 1.7; margin: 0; font-weight: 700; }
.about-intro-image { position: relative; border-radius: 20px; overflow: hidden; height: 480px; }
.about-intro-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 6s ease; }
.about-intro-image:hover img { transform: scale(1.04); }
.about-intro-badge { position: absolute; bottom: 24px; right: 24px; background: var(--gold); color: var(--dark); border-radius: 14px; padding: 14px 18px; text-align: center; box-shadow: 0 8px 24px rgba(0,0,0,0.2); }
.aib-year  { font-family: 'Playfair Display', serif; font-size: 30px; font-weight: 900; line-height: 1; }
.aib-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; opacity: 0.7; margin-top: 4px; }
.about-story-section { background: #f8f8f6; }
.about-story-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.about-story-image { border-radius: 20px; overflow: hidden; height: 560px; position: sticky; top: 100px; }
.about-story-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.about-story-text .section-body { margin-bottom: 16px; }
.about-story-quote { background: var(--green); border-radius: 12px; padding: 20px 24px; margin: 24px 0; }
.about-story-quote span { font-family: 'Playfair Display', serif; font-size: 18px; font-weight: 900; font-style: italic; color: var(--white); line-height: 1.5; }
.about-vm-section { background: var(--dark); }
.about-vm-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.about-vm-card { border-radius: 20px; padding: 40px 36px; border: 1px solid rgba(255,255,255,0.08); }
.about-vm-vision  { background: linear-gradient(135deg,rgba(247,196,48,0.08),rgba(247,196,48,0.03)); border-color: rgba(247,196,48,0.2); }
.about-vm-mission { background: linear-gradient(135deg,rgba(26,92,46,0.3),rgba(26,92,46,0.1)); border-color: rgba(45,138,78,0.3); }
.avm-icon { width: 52px; height: 52px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 22px; margin-bottom: 20px; }
.about-vm-vision  .avm-icon { background: rgba(247,196,48,0.15); color: var(--gold); }
.about-vm-mission .avm-icon { background: rgba(26,92,46,0.4); color: var(--green); }
.about-vm-card h3 { font-family: 'Playfair Display', serif; font-size: 26px; font-weight: 900; color: var(--white); margin-bottom: 14px; }
.about-vm-card > p { font-size: 14px; color: rgba(255,255,255,0.6); line-height: 1.8; margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid rgba(255,255,255,0.08); }
.avm-goals { display: flex; flex-direction: column; gap: 12px; }
.avm-goal { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; color: rgba(255,255,255,0.75); line-height: 1.5; }
.about-vm-vision  .avm-goal i { color: var(--gold); flex-shrink: 0; margin-top: 2px; }
.about-vm-mission .avm-goal i { color: #4ade80; flex-shrink: 0; margin-top: 2px; }
.about-what-section { background: var(--white); }
.about-features-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 48px; }
.about-feat { background: var(--off-white); border: 1.5px solid var(--border); border-radius: 16px; padding: 28px 24px; transition: all 0.3s; }
.about-feat:hover { border-color: var(--green); transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,0.08); }
.af-icon { font-size: 36px; margin-bottom: 14px; }
.about-feat h4 { font-size: 16px; font-weight: 700; color: var(--dark); margin-bottom: 8px; }
.about-feat p  { font-size: 13px; color: var(--text-muted); line-height: 1.6; margin: 0; }
.about-sustain-section { background: #f8f8f6; }
.about-sustain-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.sustain-points { display: flex; flex-direction: column; gap: 14px; margin-top: 24px; }
.sp-item { display: flex; align-items: flex-start; gap: 14px; font-size: 14px; color: var(--dark); line-height: 1.5; }
.sp-item i { width: 36px; height: 36px; background: var(--green-light); color: var(--green); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; }
.about-sustain-image { position: relative; border-radius: 20px; overflow: visible; }
.about-sustain-image img { width: 100%; height: 420px; object-fit: cover; border-radius: 20px; display: block; }
.sustain-stat-card { position: absolute; bottom: -24px; left: 24px; right: 24px; background: var(--white); border-radius: 14px; padding: 20px 24px; display: flex; justify-content: space-around; box-shadow: 0 8px 32px rgba(0,0,0,0.12); border: 1px solid var(--border); }
.ssc-item { text-align: center; }
.ssc-item strong { display: block; font-family: 'Playfair Display', serif; font-size: 28px; font-weight: 900; color: var(--green); line-height: 1; }
.ssc-item span   { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); font-weight: 600; margin-top: 4px; display: block; }
.about-cta-section { background: linear-gradient(135deg,#0b3518 0%,#1a5c2e 60%,#0b3518 100%); padding: 96px 0; }
.about-cta-inner { text-align: center; max-width: 860px; margin: 0 auto; padding: 0 40px; }
.about-cta-text h2 { font-family: 'Playfair Display', serif; font-size: clamp(26px,3.5vw,44px); font-weight: 900; color: var(--white); line-height: 1.25; margin-bottom: 20px; }
.about-cta-text h2 span { color: var(--gold); }
.about-cta-text p { font-size: 18px; color: rgba(255,255,255,0.7); margin-bottom: 40px; }
.about-cta-text strong { color: var(--gold); }
.about-cta-actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ════════════════════════════════════════════════════════════
   GALLERY PAGE
   ════════════════════════════════════════════════════════════ */
.gallery-tabs { display: flex; gap: 8px; margin-bottom: 36px; flex-wrap: wrap; }
.gallery-tab { padding: 8px 20px; border-radius: 50px; border: 1.5px solid var(--border); background: var(--white); font-size: 13px; font-weight: 600; color: var(--text-muted); cursor: pointer; transition: all 0.2s; }
.gallery-tab:hover { border-color: var(--green); color: var(--green); }
.gallery-tab.active { background: var(--green); border-color: var(--green); color: var(--white); }
.gallery-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 280px)); gap: 12px; margin-bottom: 48px; justify-content: center; }
.gallery-item { border-radius: 10px; overflow: hidden; position: relative; cursor: pointer; aspect-ratio: 1/1; background: var(--off-white); }
.gallery-item.large { grid-column: span 2; aspect-ratio: 2/1; }
.gallery-item.tall  { grid-row: span 2; aspect-ratio: 1/2; }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease; }
.gallery-item:hover img { transform: scale(1.06); }
.gallery-hover-info { position: absolute; inset: 0; background: rgba(0,0,0,0); display: flex; align-items: flex-end; padding: 20px; opacity: 0; transition: all 0.3s; }
.gallery-item:hover .gallery-hover-info { background: rgba(0,0,0,0.4); opacity: 1; }
.gallery-hover-info p { color: var(--white); font-size: 13px; font-weight: 600; margin: 0; }

/* ════════════════════════════════════════════════════════════
   TICKETS PAGE
   ════════════════════════════════════════════════════════════ */
.tickets-cat-section { padding: 72px 0; }
.tickets-cat-early   { background: #f8f8f6; }
.tickets-cat-premium { background: var(--dark); }
.tkt-cat-header { text-align: center; max-width: 640px; margin: 0 auto 48px; }
.tkt-cat-eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 2.5px; color: var(--green); margin-bottom: 12px; }
.tickets-cat-premium .tkt-cat-eyebrow { color: var(--gold); }
.tkt-cat-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; animation: nfc-pulse 2s infinite; }
.tkt-dot-early   { background: var(--green); }
.tkt-dot-premium { background: var(--gold); }
.tkt-cat-title { font-family: 'Playfair Display', serif; font-size: clamp(28px,4vw,40px); font-weight: 900; color: var(--dark); margin-bottom: 10px; }
.tickets-cat-premium .tkt-cat-title { color: var(--white); }
.tkt-cat-sub { font-size: 15px; color: var(--text-muted); line-height: 1.7; }
.tickets-cat-premium .tkt-cat-sub { color: rgba(255,255,255,0.55); }
.tkt-early-grid   { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.tkt-premium-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.tkt-card { background: var(--white); border: 2px solid var(--border); border-radius: 18px; overflow: hidden; position: relative; transition: transform 0.3s, box-shadow 0.3s; display: flex; flex-direction: column; }
.tkt-card:hover { transform: translateY(-6px); box-shadow: 0 20px 48px rgba(0,0,0,0.12); }
.tkt-featured { transform: translateY(-6px); box-shadow: 0 12px 40px rgba(0,0,0,0.15); }
.tkt-featured:hover { transform: translateY(-10px); }
.tkt-card-premium { border-color: rgba(255,255,255,0.1); background: rgba(255,255,255,0.04); }
.tkt-card-premium:hover { border-color: rgba(247,196,48,0.4); background: rgba(255,255,255,0.07); }
.tkt-featured.tkt-card-premium { border-color: var(--gold); }
.tkt-badge { position: absolute; top: 0; right: 14px; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; padding: 4px 12px; border-radius: 0 0 8px 8px; z-index: 1; }
.tkt-badge-early   { background: var(--green); color: var(--white); }
.tkt-badge-premium { background: var(--gold); color: var(--dark); }
.tkt-card-top { padding: 24px 20px 18px; text-align: center; color: var(--white); }
.tkt-icon     { font-size: 32px; margin-bottom: 8px; }
.tkt-name     { font-family: 'Playfair Display', serif; font-size: 17px; font-weight: 900; margin-bottom: 4px; }
.tkt-capacity { font-size: 11px; color: rgba(255,255,255,0.65); margin-bottom: 10px; }
.tkt-price    { font-family: 'Playfair Display', serif; font-size: 24px; font-weight: 900; }
.tkt-price-large { font-size: 28px; }
.tkt-card-body { padding: 18px 20px 22px; display: flex; flex-direction: column; flex: 1; }
.tkt-desc { font-size: 13px; color: var(--text-muted); line-height: 1.6; margin-bottom: 14px; }
.tickets-cat-premium .tkt-desc { color: rgba(255,255,255,0.5); }
.tkt-includes-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.2px; color: var(--gold); margin-bottom: 8px; }
.tkt-perks { list-style: none; padding: 0; margin: 0 0 18px; display: flex; flex-direction: column; gap: 7px; flex: 1; }
.tkt-perks li { display: flex; align-items: flex-start; gap: 8px; font-size: 12.5px; line-height: 1.4; color: var(--dark); }
.tickets-cat-premium .tkt-perks li { color: rgba(255,255,255,0.8); }
.tkt-perks li i { font-size: 11px; color: var(--green); flex-shrink: 0; margin-top: 2px; }
.tkt-perks-premium li i { color: var(--gold); }
.tkt-perk-note { color: var(--text-muted) !important; }
.tkt-perk-note i { color: #94a3b8 !important; }
.tkt-buy-btn { width: 100%; display: flex; align-items: center; justify-content: center; gap: 8px; padding: 12px; border-radius: 8px; font-weight: 700; font-size: 13px; cursor: pointer; border: none; font-family: inherit; transition: all 0.2s; background: var(--green); color: var(--white); }
.tkt-buy-btn:hover { background: #0f4423; transform: translateY(-1px); }
.tkt-buy-btn-premium { background: var(--gold); color: var(--dark); }
.tkt-buy-btn-premium:hover { background: var(--gold-dark); }
.tkt-modal { max-width: 480px; padding: 0; }
.tkt-modal-header { background: linear-gradient(135deg,#0b3518,#1a5c2e); padding: 24px 28px; text-align: center; border-radius: 20px 20px 0 0; }
.tkt-modal-icon { font-size: 32px; margin-bottom: 6px; }
.tkt-modal-name { font-family: 'Playfair Display', serif; font-size: 20px; font-weight: 900; color: var(--white); }
.tkt-modal-capacity { font-size: 12px; color: rgba(255,255,255,0.55); margin: 4px 0; }
.tkt-modal-price { font-size: 28px; font-weight: 900; color: var(--gold); font-family: 'Playfair Display', serif; }
.tkt-modal-body { padding: 24px 28px 28px; }
.tkt-modal-body h3 { font-family: 'Playfair Display', serif; font-size: 20px; font-weight: 900; color: var(--dark); margin-bottom: 4px; }
.tkt-modal-body > p { font-size: 13px; color: var(--text-muted); margin-bottom: 20px; }
.tkt-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.tkt-modal-body .form-group { margin-bottom: 14px; }
.tkt-modal-body label { display: block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); margin-bottom: 5px; }
.tkt-modal-body input { width: 100%; padding: 11px 13px; border: 1.5px solid var(--border); border-radius: 8px; font-size: 14px; font-family: inherit; color: var(--dark); background: var(--white); outline: none; box-sizing: border-box; transition: border-color 0.2s, box-shadow 0.2s; }
.tkt-modal-body input:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(26,92,46,0.1); }
.tkt-qty-ctrl { display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; width: fit-content; }
.tkt-qty-ctrl button { width: 38px; height: 38px; border: none; background: var(--off-white); cursor: pointer; font-size: 13px; color: var(--dark); transition: background 0.15s; }
.tkt-qty-ctrl button:hover { background: var(--border); }
.tkt-qty-ctrl span { min-width: 44px; text-align: center; font-size: 16px; font-weight: 700; color: var(--dark); }
.tkt-total-row { display: flex; align-items: center; justify-content: space-between; background: var(--off-white); border-radius: 8px; padding: 12px 16px; margin: 16px 0; font-size: 14px; color: var(--text-muted); }
.tkt-total-row strong { font-size: 20px; font-weight: 900; color: var(--green); }
.tkt-pay-btn { width: 100%; display: flex; align-items: center; justify-content: center; gap: 8px; padding: 14px; border-radius: 10px; border: none; background: var(--green); color: var(--white); font-weight: 800; font-size: 15px; cursor: pointer; font-family: inherit; transition: all 0.2s; }
.tkt-pay-btn:hover { background: #0f4423; transform: translateY(-1px); }
.tkt-pay-btn:disabled { opacity: 0.7; cursor: not-allowed; transform: none; }
.tkt-secure-note { text-align: center; font-size: 12px; color: var(--text-muted); margin-top: 10px; }
.tkt-secure-note i { color: var(--green); }

/* ════════════════════════════════════════════════════════════
   FAQ PAGE
   ════════════════════════════════════════════════════════════ */
.faq-section { background: var(--off-white); }
.faq-category { margin-bottom: 48px; }
.faq-category-header { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; padding-bottom: 12px; border-bottom: 2px solid var(--green); }
.faq-category-header i { width: 38px; height: 38px; background: var(--green); color: var(--white); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 15px; flex-shrink: 0; }
.faq-category-header h2 { font-family: 'Playfair Display', serif; font-size: 20px; font-weight: 700; color: var(--dark); margin: 0; }
.faq-item { border: 1px solid var(--border); border-radius: var(--radius); margin-bottom: 12px; background: var(--white); }
.faq-question { padding: 18px 20px; display: flex; justify-content: space-between; align-items: center; gap: 16px; cursor: pointer; font-weight: 600; font-size: 15px; user-select: none; transition: background var(--transition); }
.faq-question:hover { background: var(--green-light); }
.faq-item.open .faq-question { background: var(--green-light); color: var(--green); }
.faq-icon { flex-shrink: 0; transition: transform var(--transition); color: var(--text-muted); }
.faq-item.open .faq-icon { transform: rotate(180deg); color: var(--green); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.4s cubic-bezier(0.4,0,0.2,1); }
.faq-item.open .faq-answer { max-height: 1000px; }
.faq-answer p { padding: 0 20px 18px; color: var(--text-muted); font-size: 14.5px; line-height: 1.7; margin: 0; }
.faq-link { color: var(--green); text-decoration: underline; font-weight: 500; }
.faq-cta { text-align: center; background: linear-gradient(135deg,#0b3518,#1a5c2e); border-radius: 20px; padding: 48px 32px; color: var(--white); margin-top: 12px; }
.faq-cta-icon { font-size: 40px; margin-bottom: 16px; color: var(--gold); }
.faq-cta h3 { font-family: 'Playfair Display', serif; font-size: 28px; font-weight: 700; color: var(--white); margin-bottom: 12px; }
.faq-cta p { color: rgba(255,255,255,0.75); margin-bottom: 28px; font-size: 15px; }
.faq-cta p a { color: var(--gold); }
.faq-cta-btns { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ════════════════════════════════════════════════════════════
   CONTACT PAGE
   ════════════════════════════════════════════════════════════ */
.contact-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 64px; align-items: start; }
.contact-info h3 { font-family: 'Playfair Display', serif; font-size: 28px; font-weight: 900; color: var(--dark); margin-bottom: 12px; }
.contact-info > p { color: var(--text-muted); font-size: 15px; line-height: 1.7; margin-bottom: 32px; }
.contact-items { display: flex; flex-direction: column; gap: 20px; margin-bottom: 32px; }
.contact-item { display: flex; gap: 16px; align-items: flex-start; }
.ci-icon { width: 42px; height: 42px; flex-shrink: 0; background: var(--green-light); color: var(--green); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 16px; }
.contact-item h5 { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); margin-bottom: 4px; }
.contact-item a, .contact-item p { font-size: 14px; color: var(--dark); text-decoration: none; display: block; margin: 0; }
.contact-item a:hover { color: var(--green); }
.contact-social { display: flex; gap: 10px; }
.social-link { width: 38px; height: 38px; border-radius: 8px; background: var(--green-light); color: var(--green); display: flex; align-items: center; justify-content: center; font-size: 15px; text-decoration: none; transition: all 0.2s; }
.social-link:hover { background: var(--green); color: var(--white); }
.contact-form-wrap { background: var(--off-white); border-radius: 20px; padding: 40px; }

/* ════════════════════════════════════════════════════════════
   VENDORS PAGE
   ════════════════════════════════════════════════════════════ */
.vendor-stats-strip { background: var(--dark); }
.vss-grid { max-width: 1280px; margin: 0 auto; padding: 0 40px; display: flex; align-items: stretch; }
.vss-item { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; padding: 20px 16px; }
.vss-item i { font-size: 18px; color: var(--gold); margin-bottom: 4px; }
.vss-item strong { font-family: 'Playfair Display', serif; font-size: 24px; font-weight: 900; color: var(--white); line-height: 1; }
.vss-item span { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,0.4); }
.vss-div { width: 1px; background: rgba(255,255,255,0.08); margin: 12px 0; }
.vendor-packages-section { background: #f8f8f6; }
.vpkg-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.vpkg-card { background: var(--white); border: 2px solid var(--border); border-radius: 18px; overflow: hidden; position: relative; transition: transform 0.3s, box-shadow 0.3s; display: flex; flex-direction: column; }
.vpkg-card:hover { transform: translateY(-6px); box-shadow: 0 20px 48px rgba(0,0,0,0.12); }
.vpkg-featured { border-color: var(--green); box-shadow: 0 8px 32px rgba(26,92,46,0.15); }
.vpkg-top { border-color: var(--gold); }
.vpkg-badge { position: absolute; top: 0; right: 16px; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; padding: 4px 14px; border-radius: 0 0 8px 8px; z-index: 1; }
.vpkg-badge { background: var(--green); color: var(--white); }
.vpkg-badge-gold { background: var(--gold); color: var(--dark); }
.vpkg-header { padding: 28px 24px 20px; text-align: center; background: var(--off-white); }
.vpkg-basic             { background: linear-gradient(135deg,#e0f2fe,#bae6fd); }
.vpkg-single_canopy     { background: linear-gradient(135deg,#dcfce7,#bbf7d0); }
.vpkg-standard_canopy   { background: linear-gradient(135deg,#d1fae5,#a7f3d0); }
.vpkg-premium_canopy    { background: linear-gradient(135deg,#0b3518,#1a5c2e); }
.vpkg-pagoda_business   { background: linear-gradient(135deg,#4c1d95,#6d28d9); }
.vpkg-platinum_showcase { background: linear-gradient(135deg,#78350f,#b45309); }
.vpkg-icon     { font-size: 32px; margin-bottom: 10px; }
.vpkg-name     { font-size: 18px; font-weight: 800; color: var(--dark); margin-bottom: 2px; }
.vpkg-premium_canopy .vpkg-name, .vpkg-pagoda_business .vpkg-name, .vpkg-platinum_showcase .vpkg-name { color: var(--white); }
.vpkg-subtitle { font-size: 12px; color: rgba(0,0,0,0.5); margin-bottom: 12px; }
.vpkg-premium_canopy .vpkg-subtitle, .vpkg-pagoda_business .vpkg-subtitle, .vpkg-platinum_showcase .vpkg-subtitle { color: rgba(255,255,255,0.6); }
.vpkg-price { font-family: 'Playfair Display', serif; font-size: 30px; font-weight: 900; color: var(--dark); }
.vpkg-premium_canopy .vpkg-price, .vpkg-pagoda_business .vpkg-price, .vpkg-platinum_showcase .vpkg-price { color: var(--gold); }
.vpkg-body { padding: 20px 24px 24px; display: flex; flex-direction: column; flex: 1; }
.vpkg-list { list-style: none; padding: 0; margin: 0 0 20px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.vpkg-list li { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; line-height: 1.5; }
.vpkg-yes { color: var(--dark); }
.vpkg-yes i { color: var(--green); flex-shrink: 0; margin-top: 2px; font-size: 11px; }
.vpkg-no  { color: var(--text-muted); }
.vpkg-no  i { color: #ccc; flex-shrink: 0; margin-top: 2px; font-size: 11px; }
.vpkg-btn { display: flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 20px; border-radius: 8px; font-weight: 700; font-size: 14px; cursor: pointer; border: 2px solid transparent; transition: all 0.2s; font-family: inherit; width: 100%; text-decoration: none; }
.vpkg-btn-primary { background: var(--green); color: var(--white); border-color: var(--green); }
.vpkg-btn-primary:hover { background: #0f4423; }
.vpkg-btn-outline { background: transparent; color: var(--green); border-color: var(--green); }
.vpkg-btn-outline:hover { background: var(--green); color: var(--white); }
.vendor-why-section { background: var(--white); }
.vendor-why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.vendor-why-points { display: flex; flex-direction: column; gap: 20px; margin: 28px 0; }
.vwp { display: flex; gap: 16px; align-items: flex-start; }
.vwp > i { width: 42px; height: 42px; background: var(--green-light); color: var(--green); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; margin-top: 2px; }
.vwp h4 { font-size: 15px; font-weight: 700; color: var(--dark); margin-bottom: 4px; }
.vwp p  { font-size: 13px; color: var(--text-muted); margin: 0; line-height: 1.6; }
.vendor-why-img { position: relative; border-radius: 16px; overflow: hidden; height: 440px; }
.vendor-why-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.vwi-badge { position: absolute; bottom: 20px; left: 20px; background: var(--gold); color: var(--dark); font-size: 13px; font-weight: 700; padding: 8px 16px; border-radius: 50px; }
.vendor-modal { max-width: 520px; padding: 0; }
.vmodal-header { background: linear-gradient(135deg,#0b3518,#1a5c2e); padding: 24px 28px; display: flex; align-items: center; justify-content: space-between; border-radius: 20px 20px 0 0; }
.vmodal-pkg-name  { font-size: 16px; font-weight: 700; color: var(--white); }
.vmodal-pkg-price { font-family: 'Playfair Display', serif; font-size: 26px; font-weight: 900; color: var(--gold); }
.vmodal-body { padding: 28px; }
.vmodal-body h3 { font-family: 'Playfair Display', serif; font-size: 22px; font-weight: 900; color: var(--dark); margin-bottom: 6px; }
.vmodal-body > p { font-size: 14px; color: var(--text-muted); margin-bottom: 20px; }
.vmodal-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.vmodal-body .form-group { margin-bottom: 16px; }
.vmodal-body label { display: block; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); margin-bottom: 6px; }
.vmodal-body input, .vmodal-body textarea { width: 100%; padding: 11px 14px; border: 1.5px solid var(--border); border-radius: 8px; font-size: 14px; font-family: inherit; color: var(--dark); background: var(--white); outline: none; box-sizing: border-box; transition: border-color 0.2s, box-shadow 0.2s; }
.vmodal-body input:focus, .vmodal-body textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(26,92,46,0.1); }
.vmodal-body textarea { resize: vertical; }
.vmodal-secure { text-align: center; font-size: 12px; color: var(--text-muted); margin-top: 12px; }
.vmodal-secure i { color: var(--green); }
.vendor-success-wrap { min-height: calc(100vh - 120px); background: var(--off-white); display: flex; align-items: center; justify-content: center; padding: 60px 20px; }
.vsuccess-card { background: var(--white); border-radius: 20px; padding: 48px 40px; max-width: 680px; width: 100%; box-shadow: 0 8px 40px rgba(0,0,0,0.08); text-align: center; }
.vsuccess-icon  { font-size: 64px; margin-bottom: 16px; }
.vsuccess-title { font-family: 'Playfair Display', serif; font-size: 36px; font-weight: 900; color: var(--dark); margin-bottom: 12px; }
.vsuccess-sub   { font-size: 15px; color: var(--text-muted); line-height: 1.7; margin-bottom: 32px; }
.vsuccess-booking-card { background: var(--off-white); border-radius: 14px; border: 1.5px solid var(--border); overflow: hidden; margin-bottom: 28px; text-align: left; }
.vbc-header { background: var(--green); padding: 16px 20px; display: flex; align-items: center; justify-content: space-between; }
.vbc-label { font-size: 10px; text-transform: uppercase; letter-spacing: 1.5px; color: rgba(255,255,255,0.6); margin-bottom: 2px; }
.vbc-id { font-family: monospace; font-size: 16px; font-weight: 800; color: var(--white); letter-spacing: 1px; }
.vbc-status-badge { background: rgba(255,255,255,0.15); color: var(--white); font-size: 12px; font-weight: 700; padding: 5px 12px; border-radius: 50px; }
.vbc-grid { display: grid; grid-template-columns: 1fr 1fr; padding: 8px; gap: 2px; }
.vbc-cell { padding: 12px 14px; background: var(--white); border-radius: 8px; }
.vbc-cell-label { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); margin-bottom: 3px; }
.vbc-cell-val   { display: block; font-size: 14px; font-weight: 600; color: var(--dark); }
.vsuccess-next { background: var(--off-white); border-radius: 14px; padding: 24px; text-align: left; margin-bottom: 28px; }
.vsuccess-next h3 { font-size: 16px; font-weight: 700; color: var(--dark); margin-bottom: 16px; }
.vsuccess-steps { display: flex; flex-direction: column; gap: 14px; }
.vs-step { display: flex; gap: 14px; align-items: flex-start; }
.vs-step-num { width: 28px; height: 28px; background: var(--green); color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 800; flex-shrink: 0; }
.vs-step strong { font-size: 14px; color: var(--dark); display: block; margin-bottom: 2px; }
.vs-step p { font-size: 13px; color: var(--text-muted); margin: 0; line-height: 1.5; }
.vsuccess-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-bottom: 16px; }
.vsuccess-ref { font-size: 12px; color: var(--text-muted); }
.vsuccess-ref code { background: var(--off-white); padding: 2px 8px; border-radius: 4px; font-size: 11px; letter-spacing: 0.5px; }

/* ════════════════════════════════════════════════════════════
   SPONSORS PAGE
   ════════════════════════════════════════════════════════════ */
.sp-hero { position: relative; min-height: 92vh; display: flex; align-items: center; overflow: hidden; padding-top: 76px; }
.sp-hero-bg { position: absolute; inset: 0; z-index: 0; }
.sp-hero-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; filter: brightness(0.35) saturate(0.7); }
.sp-hero-overlay { position: absolute; inset: 0; background: linear-gradient(110deg,rgba(7,28,14,0.97) 0%,rgba(11,53,24,0.92) 45%,rgba(7,28,14,0.7) 100%); }
.sp-hero-content { position: relative; z-index: 1; max-width: 1280px; margin: 0 auto; padding: 80px 40px; width: 100%; }
.sp-hero-eyebrow { display: inline-flex; align-items: center; gap: 8px; background: rgba(247,196,48,0.12); border: 1px solid rgba(247,196,48,0.3); color: var(--gold); font-size: 12px; font-weight: 700; padding: 7px 16px; border-radius: 50px; letter-spacing: 1px; margin-bottom: 28px; text-transform: uppercase; }
.sp-eyebrow-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); flex-shrink: 0; animation: nfc-pulse 2s infinite; }
.sp-hero-title { font-family: 'Playfair Display',serif; font-size: clamp(36px,5.5vw,72px); font-weight: 900; color: var(--white); line-height: 1.05; margin-bottom: 24px; max-width: 840px; }
.sp-hero-title-gold { color: var(--gold); }
.sp-hero-sub { font-size: 16px; color: rgba(255,255,255,0.65); line-height: 1.8; max-width: 600px; margin-bottom: 40px; }
.sp-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; }
.sp-btn-primary { display: inline-flex; align-items: center; gap: 9px; background: var(--gold); color: var(--dark); padding: 14px 28px; border-radius: 7px; font-weight: 800; font-size: 14px; text-decoration: none; transition: all 0.2s; white-space: nowrap; }
.sp-btn-primary:hover { background: var(--gold-dark); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(247,196,48,0.4); }
.sp-btn-ghost { display: inline-flex; align-items: center; gap: 9px; background: rgba(255,255,255,0.08); color: var(--white); padding: 14px 24px; border-radius: 7px; border: 1px solid rgba(255,255,255,0.25); font-weight: 600; font-size: 14px; text-decoration: none; transition: all 0.2s; white-space: nowrap; }
.sp-btn-ghost:hover { background: rgba(255,255,255,0.15); border-color: rgba(255,255,255,0.5); }
.sp-impact-bar { background: var(--gold); }
.sp-impact-grid { max-width: 1280px; margin: 0 auto; padding: 0 40px; display: flex; align-items: stretch; }
.sp-impact-item { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; padding: 20px 12px; }
.sp-impact-item strong { font-family: 'Playfair Display',serif; font-size: 26px; font-weight: 900; color: var(--dark); line-height: 1; }
.sp-impact-item span { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: rgba(0,0,0,0.5); }
.sp-impact-div { width: 1px; background: rgba(0,0,0,0.1); margin: 12px 0; }
.sp-why-section { background: var(--white); }
.sp-why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start; }
.sp-why-points { display: flex; flex-direction: column; gap: 12px; margin-top: 24px; }
.sp-why-pt { display: flex; align-items: center; gap: 12px; font-size: 14px; color: var(--dark); font-weight: 500; }
.sp-why-pt i { color: var(--green); font-size: 16px; flex-shrink: 0; }
.sp-why-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.sp-diff-card { background: var(--off-white); border-radius: 14px; padding: 24px 20px; border: 1.5px solid var(--border); transition: all 0.25s; }
.sp-diff-card:hover { border-color: var(--green); transform: translateY(-3px); box-shadow: 0 10px 28px rgba(0,0,0,0.08); }
.sp-diff-card i { font-size: 24px; color: var(--green); margin-bottom: 10px; display: block; }
.sp-diff-card h4 { font-size: 14px; font-weight: 800; color: var(--dark); margin-bottom: 6px; line-height: 1.3; }
.sp-diff-card p  { font-size: 13px; color: var(--text-muted); line-height: 1.6; margin: 0; }
.sp-tiers-section { background: #f8f8f6; }
.sp-tiers-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.sp-tier { background: var(--white); border: 2px solid var(--border); border-radius: 18px; padding: 32px 28px; display: flex; flex-direction: column; transition: all 0.3s; }
.sp-tier:hover { transform: translateY(-5px); box-shadow: 0 20px 48px rgba(0,0,0,0.1); }
.sp-tier-title    { border-color: var(--gold); background: linear-gradient(180deg,#fffbeb 0%,#fff 50%); }
.sp-tier-platinum { border-color: #a855f7; }
.sp-tier-gold     { border-color: #f59e0b; }
.sp-tier-silver   { border-color: #94a3b8; }
.sp-tier-experience { border-color: var(--green); }
.sp-tier-vendor   { border-color: #3b82f6; }
.sp-tier-medal    { font-size: 36px; margin-bottom: 10px; }
.sp-tier-name     { font-family: 'Playfair Display',serif; font-size: 22px; font-weight: 900; color: var(--dark); margin-bottom: 4px; }
.sp-tier-tagline  { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: var(--green); margin-bottom: 14px; }
.sp-tier-title .sp-tier-tagline    { color: #b45309; }
.sp-tier-platinum .sp-tier-tagline { color: #7c3aed; }
.sp-tier-gold .sp-tier-tagline     { color: #d97706; }
.sp-tier-silver .sp-tier-tagline   { color: #64748b; }
.sp-tier-vendor .sp-tier-tagline   { color: #2563eb; }
.sp-tier-desc { font-size: 13px; color: var(--text-muted); line-height: 1.7; margin-bottom: 18px; padding-bottom: 18px; border-bottom: 1px solid var(--border); }
.sp-tier-perks { list-style: none; padding: 0; margin: 0 0 24px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.sp-tier-perks li { display: flex; align-items: flex-start; gap: 9px; font-size: 13px; color: var(--dark); line-height: 1.4; }
.sp-tier-perks li i { color: var(--green); font-size: 11px; flex-shrink: 0; margin-top: 3px; }
.sp-tier-btn { display: block; text-align: center; padding: 12px 20px; border-radius: 8px; font-weight: 700; font-size: 13px; text-decoration: none; transition: all 0.2s; border: 2px solid transparent; }
.sp-tier-btn-gold    { background: var(--gold); color: var(--dark); border-color: var(--gold); }
.sp-tier-btn-gold:hover { background: var(--gold-dark); }
.sp-tier-btn-primary { background: var(--green); color: var(--white); border-color: var(--green); }
.sp-tier-btn-primary:hover { background: #0f4423; }
.sp-tier-btn-outline { background: transparent; color: var(--green); border-color: var(--green); }
.sp-tier-btn-outline:hover { background: var(--green); color: var(--white); }
.sp-activation-section { background: var(--dark); }
.sp-activation-section .section-tag { color: var(--gold); border-color: var(--gold); }
.sp-activation-section .section-title { color: var(--white); }
.sp-activation-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-top: 48px; }
.sp-act-item { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); border-radius: 12px; padding: 24px 18px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 12px; transition: all 0.25s; }
.sp-act-item:hover { background: rgba(247,196,48,0.08); border-color: rgba(247,196,48,0.3); transform: translateY(-3px); }
.sp-act-item i { font-size: 26px; color: var(--gold); }
.sp-act-item span { font-size: 13px; font-weight: 600; color: rgba(255,255,255,0.75); line-height: 1.4; }
.sp-gains-section { background: var(--white); }
.sp-gains-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start; }
.sp-gains-list { display: flex; flex-direction: column; gap: 20px; margin-top: 24px; }
.sp-gain { display: flex; gap: 14px; align-items: flex-start; }
.sp-gain-icon { width: 44px; height: 44px; flex-shrink: 0; background: var(--green-light); color: var(--green); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 17px; }
.sp-gain strong { display: block; font-size: 14px; font-weight: 700; color: var(--dark); margin-bottom: 3px; }
.sp-gain p { font-size: 13px; color: var(--text-muted); margin: 0; line-height: 1.6; }
.sp-promise-card { background: linear-gradient(135deg,#0b3518,#1a5c2e); border-radius: 20px; padding: 40px 36px; color: var(--white); position: sticky; top: 100px; }
.sp-promise-icon { font-size: 48px; margin-bottom: 16px; }
.sp-promise-card h3 { font-family: 'Playfair Display',serif; font-size: 28px; font-weight: 900; color: var(--white); margin-bottom: 12px; }
.sp-promise-card p { font-size: 15px; color: rgba(255,255,255,0.65); margin-bottom: 4px; line-height: 1.7; }
.sp-promise-bold { font-size: 18px; font-weight: 800; color: var(--gold) !important; font-style: italic; margin-bottom: 28px !important; }
.sp-audience-stats { display: flex; flex-direction: column; gap: 14px; margin-top: 24px; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 24px; }
.sp-aud-stat { display: flex; gap: 12px; align-items: flex-start; }
.sp-aud-stat > i { font-size: 16px; color: var(--gold); margin-top: 2px; flex-shrink: 0; width: 20px; }
.sp-aud-stat strong { display: block; font-size: 13px; font-weight: 700; color: var(--white); }
.sp-aud-stat span   { font-size: 12px; color: rgba(255,255,255,0.45); }
.sp-form-section { background: var(--off-white); }
.sp-form-layout { display: grid; grid-template-columns: 1fr 1.4fr; gap: 64px; align-items: start; }
.sp-contact-methods { display: flex; flex-direction: column; gap: 12px; margin-top: 28px; }
.sp-contact-item { display: flex; gap: 14px; align-items: center; background: var(--white); border: 1.5px solid var(--border); border-radius: 12px; padding: 16px 20px; text-decoration: none; transition: all 0.2s; }
.sp-contact-item:hover { border-color: var(--green); transform: translateX(4px); }
.sp-contact-item i { font-size: 20px; color: var(--green); flex-shrink: 0; }
.sp-contact-item strong { display: block; font-size: 13px; font-weight: 700; color: var(--dark); margin-bottom: 2px; }
.sp-contact-item span   { font-size: 13px; color: var(--text-muted); }
.sp-form-card { background: var(--white); border-radius: 20px; overflow: hidden; box-shadow: 0 8px 40px rgba(0,0,0,0.08); }
.sp-form-card-header { background: linear-gradient(135deg,#0b3518,#1a5c2e); padding: 28px 32px; text-align: center; }
.sp-form-card-header i { font-size: 28px; color: var(--gold); margin-bottom: 10px; display: block; }
.sp-form-card-header h3 { font-family: 'Playfair Display',serif; font-size: 22px; font-weight: 900; color: var(--white); margin-bottom: 6px; }
.sp-form-card-header p  { font-size: 13px; color: rgba(255,255,255,0.6); margin: 0; }
.sp-form-body { padding: 28px 32px 32px; }
.sp-form-body .form-group { margin-bottom: 16px; }
.sp-form-body label { display: block; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); margin-bottom: 6px; }
.sp-form-body input, .sp-form-body select, .sp-form-body textarea { width: 100%; padding: 11px 14px; border: 1.5px solid var(--border); border-radius: 8px; font-size: 14px; font-family: inherit; color: var(--dark); background: var(--white); box-sizing: border-box; outline: none; transition: border-color 0.2s, box-shadow 0.2s; }
.sp-form-body input:focus, .sp-form-body select:focus, .sp-form-body textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(26,92,46,0.1); }
.sp-form-body textarea { resize: vertical; }
.sp-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.sp-final-cta { background: linear-gradient(135deg,#0b3518 0%,#1a5c2e 60%,#0b3518 100%); padding: 100px 0; }
.sp-final-inner { text-align: center; max-width: 800px; margin: 0 auto; padding: 0 40px; }
.sp-final-title { font-family: 'Playfair Display',serif; font-size: clamp(30px,4.5vw,52px); font-weight: 900; color: var(--white); margin-bottom: 16px; line-height: 1.1; }
.sp-final-sub { font-size: 16px; color: rgba(255,255,255,0.65); line-height: 1.8; margin-bottom: 40px; }
.sp-final-actions { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }
.sp-btn-ghost-dark { display: inline-flex; align-items: center; gap: 9px; background: rgba(255,255,255,0.08); color: var(--white); padding: 14px 24px; border-radius: 7px; border: 1px solid rgba(255,255,255,0.25); font-weight: 600; font-size: 14px; text-decoration: none; transition: all 0.2s; }
.sp-btn-ghost-dark:hover { background: rgba(255,255,255,0.16); border-color: rgba(255,255,255,0.5); }

/* ════════════════════════════════════════════════════════════
   ADVERTISE PAGE
   ════════════════════════════════════════════════════════════ */
.advertise-section { background: #f8f8f6; }
.adv-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start; }
.adv-title { font-family: 'Playfair Display',serif; font-size: clamp(26px,3vw,38px); font-weight: 900; color: var(--dark); margin-bottom: 14px; line-height: 1.15; }
.adv-body  { font-size: 15px; color: var(--text-muted); line-height: 1.8; margin-bottom: 28px; }
.adv-benefits { display: flex; flex-direction: column; gap: 18px; margin-bottom: 28px; }
.adv-benefit { display: flex; gap: 14px; align-items: flex-start; }
.adv-benefit > i { width: 40px; height: 40px; background: var(--green-light); color: var(--green); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 15px; flex-shrink: 0; }
.adv-benefit strong { display: block; font-size: 14px; font-weight: 700; color: var(--dark); margin-bottom: 2px; }
.adv-benefit p { font-size: 13px; color: var(--text-muted); margin: 0; line-height: 1.5; }
.adv-options-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
.adv-opt { background: var(--white); border: 1.5px solid var(--border); border-radius: 10px; padding: 12px; text-align: center; font-size: 12px; font-weight: 600; color: var(--dark); transition: all 0.2s; }
.adv-opt i { display: block; font-size: 18px; color: var(--green); margin-bottom: 6px; }
.adv-opt:hover { border-color: var(--green); background: var(--green-light); }
.adv-form-card { background: var(--white); border-radius: 20px; overflow: hidden; box-shadow: 0 8px 40px rgba(0,0,0,0.08); }
.adv-form-header { background: linear-gradient(135deg,#0b3518,#1a5c2e); padding: 28px 32px; text-align: center; }
.adv-form-header i { font-size: 28px; color: var(--gold); margin-bottom: 10px; display: block; }
.adv-form-header h3 { font-family: 'Playfair Display',serif; font-size: 22px; font-weight: 900; color: var(--white); margin-bottom: 6px; }
.adv-form-header p  { font-size: 13px; color: rgba(255,255,255,0.6); margin: 0; }
.adv-form { padding: 24px 32px 32px; }
.adv-form .form-group { margin-bottom: 16px; }
.adv-form label { display: block; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); margin-bottom: 6px; }
.adv-form input, .adv-form select, .adv-form textarea { width: 100%; padding: 11px 14px; border: 1.5px solid var(--border); border-radius: 8px; font-size: 14px; font-family: inherit; color: var(--dark); background: var(--white); box-sizing: border-box; outline: none; transition: border-color 0.2s, box-shadow 0.2s; }
.adv-form input:focus, .adv-form select:focus, .adv-form textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(26,92,46,0.1); }
.adv-form textarea { resize: vertical; }
.adv-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.adv-success-wrap { display: flex; align-items: center; justify-content: center; padding: 40px 0; }
.adv-success-card { background: var(--white); border-radius: 20px; padding: 48px 40px; max-width: 560px; width: 100%; text-align: center; box-shadow: 0 8px 40px rgba(0,0,0,0.08); }
.adv-success-icon { font-size: 64px; margin-bottom: 16px; }
.adv-success-card h2 { font-family: 'Playfair Display',serif; font-size: 32px; font-weight: 900; color: var(--dark); margin-bottom: 12px; }
.adv-success-card p  { font-size: 15px; color: var(--text-muted); line-height: 1.7; margin-bottom: 20px; }
.adv-ref { background: var(--off-white); border-radius: 8px; padding: 12px 20px; font-size: 14px; margin-bottom: 24px; }
.adv-ref code { background: var(--white); padding: 2px 8px; border-radius: 4px; font-family: monospace; font-size: 13px; color: var(--green); font-weight: 700; }
.adv-success-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ════════════════════════════════════════════════════════════
   GALLERY — VIDEO / EVENT HIGHLIGHTS SECTION
   ════════════════════════════════════════════════════════════ */
.video-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 360px)); gap: 20px; margin-bottom: 48px; justify-content: center; }
.video-item { border-radius: 16px; overflow: hidden; background: var(--white); border: 1.5px solid var(--border); transition: transform 0.3s, box-shadow 0.3s; }
.video-item:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,0.1); }
.video-thumbnail { display: flex; flex-direction: column; }
.video-thumb-placeholder { position: relative; aspect-ratio: 16/9; background: linear-gradient(135deg, #1a5c2e, #2d8a4e); display: flex; align-items: center; justify-content: center; cursor: pointer; overflow: hidden; }
.video-emoji { font-size: 48px; opacity: 0.6; }
.play-button { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.play-button i { width: 56px; height: 56px; background: rgba(255,255,255,0.9); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--green); transition: transform 0.2s, background 0.2s; padding-left: 4px; }
.video-thumb-placeholder:hover .play-button i { transform: scale(1.1); background: #fff; }
.video-info { padding: 16px; }
.video-info h4 { font-family: 'Playfair Display', serif; font-size: 14px; font-weight: 700; color: var(--dark); margin: 0 0 6px; line-height: 1.4; }
.video-info p { font-size: 12px; color: var(--text-muted); margin: 0; }

.youtube-section { text-align: center; background: var(--off-white); border-radius: 16px; padding: 48px 32px; border: 1.5px solid var(--border); margin-bottom: 48px; }
.youtube-section h3 { font-family: 'Playfair Display', serif; font-size: 24px; font-weight: 900; color: var(--dark); margin-bottom: 10px; }
.youtube-section p { font-size: 14px; color: var(--text-muted); margin-bottom: 24px; }


.success-page-wrap { background: var(--off-white); min-height: calc(100vh - 140px); padding: 60px 24px; display: flex; align-items: center; justify-content: center; }
.ticket-brand-logo { width: 52px; height: 52px; object-fit: contain; flex-shrink: 0; border-radius: 8px; background: rgba(255,255,255,0.12); padding: 2px; }

/* Ticket-type badge colours on success page */
.ticket-type-badge { display: inline-block; font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; padding: 5px 14px; border-radius: 50px; }
.ticket-type-regular_early  { background: #1a5c2e; color: #ffffff; }
.ticket-type-kids_early     { background: #f7c430; color: #111111; }
.ticket-type-family         { background: #c8200a; color: #ffffff; }
.ticket-type-squad          { background: #111111; color: #ffffff; }
.ticket-type-standing_social{ background: #1a5c2e; color: #ffffff; }
.ticket-type-vip_table      { background: #c8200a; color: #ffffff; }
.ticket-type-vvip_table     { background: #111111; color: #f7c430; }

/* ── Breadcrumb light variant (for dark hero headers) ─────── */
.breadcrumb-light li, .breadcrumb-light span, .breadcrumb-light .breadcrumb-current { color: rgba(255,255,255,0.75); }
.breadcrumb-light a { color: var(--gold); }
.breadcrumb-light .breadcrumb-sep { color: rgba(255,255,255,0.35); }

/* ── Ticket Success Page ──────────────────────────────────── */
.success-page { background: var(--off-white); min-height: calc(100vh - 140px); padding: 60px 24px; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.success-container { max-width: 640px; width: 100%; position: relative; z-index: 1; }
.success-card { background: var(--white); border-radius: 20px; padding: 48px 40px; box-shadow: 0 8px 40px rgba(0,0,0,0.08); text-align: center; }
.success-icon { font-size: 56px; margin-bottom: 16px; }
.success-title { font-family: 'Playfair Display', serif; font-size: 32px; font-weight: 900; color: var(--dark); margin-bottom: 12px; }
.success-subtitle { font-size: 15px; color: var(--text-muted); line-height: 1.7; margin-bottom: 32px; }
.success-subtitle strong { color: var(--dark); }

.confetti-wrapper { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; }
.confetti-piece { position: absolute; top: -10px; opacity: 0.9; animation: confetti-fall linear forwards; }
@keyframes confetti-fall {
  to { transform: translateY(110vh) rotate(360deg); opacity: 0; }
}

/* Ticket card */
.ticket-display { background: var(--dark); border-radius: 16px; padding: 24px; text-align: left; margin-bottom: 28px; position: relative; }
.ticket-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 20px; }
.ticket-brand { display: flex; align-items: center; gap: 12px; }
.ticket-brand-name { color: var(--white); font-weight: 800; font-size: 15px; }
.ticket-brand-year { color: var(--gold); font-size: 12px; font-weight: 600; }

.ticket-details-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; padding-bottom: 20px; }
.ticket-detail { display: flex; flex-direction: column; gap: 4px; }
.td-label { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,0.45); font-weight: 700; }
.td-value { font-size: 15px; color: var(--white); font-weight: 600; }
.ticket-id-code, .qr-id-code { font-family: 'Courier New', monospace; letter-spacing: 1px; }
.amount-paid { color: var(--gold); }

.ticket-perforations { border-top: 2px dashed rgba(255,255,255,0.15); margin: 0 -24px 20px; }

.ticket-qr-section { text-align: center; }
.qr-instruction { color: rgba(255,255,255,0.6); font-size: 13px; margin-bottom: 12px; }
.ticket-qr-img { background: var(--white); padding: 8px; border-radius: 12px; display: block; margin: 0 auto 12px; }
.qr-id-code { color: var(--white); font-size: 13px; font-weight: 700; }

/* Notes box */
.success-info-box { background: var(--green-light); border-radius: 12px; padding: 20px 24px; text-align: left; margin-bottom: 28px; }
.success-info-box h4 { font-size: 14px; color: var(--green); margin-bottom: 10px; }
.success-info-box ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.success-info-box li { font-size: 13px; color: var(--dark); padding-left: 22px; position: relative; line-height: 1.5; }
.success-info-box li::before { content: '•'; color: var(--green); position: absolute; left: 6px; font-weight: 900; }

.success-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

@media (max-width: 600px) {
  .success-card { padding: 32px 20px; }
  .ticket-details-row { grid-template-columns: 1fr 1fr; }
  .ticket-perforations { margin: 0 -20px 20px; }
}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .wo-grid, .tkt-early-grid, .t2-grid-early { grid-template-columns: repeat(2,1fr); }
  .video-grid { grid-template-columns: repeat(2, minmax(0, 360px)); }
  .gallery-grid { grid-template-columns: repeat(3, minmax(0, 280px)); }
  .t2-grid-premium { grid-template-columns: repeat(2,1fr); }
  .t2-card-featured { transform: none; }
  .gallery2-strip { grid-template-columns: 1fr 1fr 1fr; grid-template-rows: 220px 220px 220px; }
  .partner2-inner { grid-template-columns: 1fr; gap: 48px; }
  .about-features-grid { grid-template-columns: repeat(2,1fr); }
  .sp-tiers-grid { grid-template-columns: repeat(2,1fr); }
  .sp-activation-grid { grid-template-columns: repeat(2,1fr); }
  .tkt-premium-grid { grid-template-columns: repeat(2,1fr); }
  .vpkg-grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 900px) {
  .about2 { grid-template-columns: 1fr; }
  .about2-image-col { height: 320px; }
  .about2-text-col { padding: 48px 32px; }
  .about-intro-grid, .about-story-grid, .about-sustain-grid { grid-template-columns: 1fr; gap: 48px; }
  .about-vm-grid { grid-template-columns: 1fr; }
  .about-story-image { height: 300px; position: static; }
  .about-intro-image { height: 320px; }
  .about-sustain-image img { height: 280px; }
  .sustain-stat-card { position: static; margin-top: 16px; }
  .sp-why-grid, .sp-gains-grid, .sp-form-layout { grid-template-columns: 1fr; gap: 48px; }
  .sp-why-cards { grid-template-columns: 1fr 1fr; }
  .sp-promise-card { position: static; }
  .vendor-why-grid { grid-template-columns: 1fr; gap: 40px; }
  .vendor-why-img { height: 280px; }
  .adv-layout { grid-template-columns: 1fr; gap: 40px; }
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }
}

@media (max-width: 768px) {
  .nav-container, .nav2-inner { height: 64px; padding: 0 20px; }
  .nav2-logo-img, .nav-logo img { width: 54px; height: 54px; }
  .nav-links, .nav2-links {
    display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: #fff; flex-direction: column; align-items: stretch;
    justify-content: flex-start; padding: 16px 24px 60px;
    gap: 0; z-index: 9999; overflow-y: auto; overflow-x: hidden;
    -webkit-overflow-scrolling: touch; overscroll-behavior: contain;
  }
  .nav-links.open, .nav2-links.open { display: flex; animation: slideInMenu 0.22s ease forwards; }
  @keyframes slideInMenu { from{transform:translateX(20px);opacity:0} to{transform:translateX(0);opacity:1} }
  .nav2-mobile-header { display: flex; align-items: center; gap: 12px; padding: 12px 0 14px; margin-bottom: 4px; border-bottom: 2px solid var(--border); flex-shrink: 0; }
  .nav-link, .nav2-link { font-size: 18px; font-weight: 600; padding: 13px 0; border-bottom: 1px solid var(--border); border-radius: 0; width: 100%; display: block; }
  .nav-link:hover, .nav2-link:hover { background: none; color: var(--green); }
  .nav-link.active::after, .nav2-active::after { display: none; }
  /* Dropdown becomes flat list on mobile */
  .nav-dropdown-wrap { display: block; width: 100%; }
  .nav-dropdown-toggle { font-size: 18px; font-weight: 600; padding: 13px 0; border-bottom: 1px solid var(--border); width: 100%; color: var(--dark); }
  .nav-dropdown-menu { display: block; position: static; box-shadow: none; border: none; border-radius: 0; padding: 0; animation: none; background: var(--off-white); }
  .nav-dropdown-item { font-size: 15px; font-weight: 500; padding: 11px 20px; border-bottom: 1px solid var(--border); }
  .nav-dropdown-divider { display: none; }
  .btn-nav, .nav2-ticket-btn { margin: 24px 0 0; padding: 16px 24px; font-size: 16px; border-radius: 10px; justify-content: center; }
  .nav-toggle, .nav2-toggle { display: flex; z-index: 1200; }
  #navClose { background: var(--off-white) !important; border: 1.5px solid var(--border) !important; border-radius: 8px !important; width: 36px !important; height: 36px !important; display: flex !important; align-items: center; justify-content: center; cursor: pointer; font-size: 20px; color: var(--dark) !important; flex-shrink: 0; padding: 0; }
  .ann-bar-inner { font-size: 11px; gap: 6px; }
  .hero2-layout { grid-template-columns: 1fr; gap: 32px; padding: 48px 20px 52px; }
  .hero2-right { order: -1; }
  .hero2-h1-thin { font-size: 28px; letter-spacing: 4px; }
  .hero2-h1-bold { font-size: 54px; }
  .hero2-tagline { font-size: 13px; }
  .hero2-meta { flex-direction: column; gap: 10px; }
  .hero2-actions { flex-direction: column; gap: 12px; }
  .hero2-btn-primary, .hero2-btn-ghost { justify-content: center; width: 100%; padding: 14px 24px; }
  .hcc-num { font-size: 32px; padding: 6px 8px; min-width: 48px; }
  .hcc-colon { font-size: 24px; }
  .hcc-features { grid-template-columns: 1fr 1fr; gap: 6px; }
  .impact-strip-inner { flex-wrap: wrap; justify-content: center; }
  .impact-item { min-width: 45%; }
  .impact-div { display: none; }
  .whats-on { padding: 60px 0; }
  .wo-container { padding: 0 20px; }
  .wo-grid { grid-template-columns: 1fr; }
  .wo-card-img { height: 160px; }
  .about2 { grid-template-columns: 1fr; }
  .about2-image-col { height: 260px; }
  .about2-text-col { padding: 36px 24px; }
  .tickets2, .partner2 { padding: 60px 0; }
  .tickets2-container { padding: 0 20px; }
  .t2-grid-early, .t2-grid-premium { grid-template-columns: 1fr; }
  .gallery2 { padding: 60px 0 0; }
  .gallery2-header { padding: 0 20px 32px; flex-direction: column; }
  .gallery2-strip { grid-template-columns: 1fr 1fr; grid-template-rows: repeat(4, 180px); }
  .partner2-inner { padding: 0 20px; }
  .p2-stats { gap: 20px; flex-wrap: wrap; }
  .page-hero2 { padding: 48px 20px 40px; }
  .page-hero2::after { height: 36px; }
  .page-hero2-content h1 { font-size: 32px; }
  .page-hero2-content p  { font-size: 14px; }
  .container { padding: 0 20px; }
  .section { padding: 60px 0; }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .gallery-item.large { grid-column: span 1; }
  .tkt-early-grid, .tkt-premium-grid, .t2-grid-early, .t2-grid-premium { grid-template-columns: 1fr; }
  .video-grid { grid-template-columns: 1fr; }
  .tkt-featured { transform: none; }
  .tkt-form-row { grid-template-columns: 1fr; }
  .vpkg-grid { grid-template-columns: 1fr; }
  .vss-grid { flex-wrap: wrap; }
  .vss-item { min-width: 45%; }
  .vss-div { display: none; }
  .vmodal-row { grid-template-columns: 1fr; }
  .vsuccess-card { padding: 32px 20px; }
  .vbc-grid { grid-template-columns: 1fr; }
  .about-features-grid { grid-template-columns: 1fr; }
  .about-cta-inner { padding: 0 20px; }
  .about-cta-actions { flex-direction: column; align-items: center; }
  .about-vm-card { padding: 28px 24px; }
  .sp-hero { min-height: auto; }
  .sp-hero-content { padding: 60px 24px; }
  .sp-hero-title { font-size: clamp(28px,8vw,42px); }
  .sp-hero-actions, .sp-final-actions { flex-direction: column; }
  .sp-btn-primary, .sp-btn-ghost { width: 100%; justify-content: center; }
  .sp-tiers-grid { grid-template-columns: 1fr; }
  .sp-activation-grid { grid-template-columns: repeat(2,1fr); }
  .sp-why-cards { grid-template-columns: 1fr; }
  .sp-form-row { grid-template-columns: 1fr; }
  .sp-impact-grid { flex-wrap: wrap; }
  .sp-impact-item { min-width: 45%; }
  .sp-impact-div { display: none; }
  .sp-form-body { padding: 20px; }
  .sp-final-cta { padding: 60px 0; }
  .sp-final-inner { padding: 0 20px; }
  .adv-form-row { grid-template-columns: 1fr; }
  .adv-options-grid { grid-template-columns: repeat(2,1fr); }
  .adv-success-card { padding: 32px 20px; }
  .contact-form-wrap { padding: 24px 20px; }
  .faq-cta-btns { flex-direction: column; align-items: center; }
  .reviews-header { flex-direction: column; }
  .reviews-overall { text-align: left; }
  .review-card { flex: 0 0 calc(100% - 80px); }
  .footer2-top { grid-template-columns: 1fr 1fr; gap: 32px; padding: 40px 20px; }
  .footer2-bottom { padding: 16px 20px; flex-direction: column; gap: 4px; text-align: center; }
}

@media (max-width: 480px) {
  .hero2-h1-thin { font-size: 22px; letter-spacing: 3px; }
  .hero2-h1-bold { font-size: 44px; }
  .hcc-num { font-size: 28px; min-width: 40px; }
  .hcc-features { grid-template-columns: 1fr; }
  .impact-item { min-width: 100%; }
  .gallery2-strip { grid-template-columns: 1fr 1fr; grid-template-rows: repeat(4, 160px); }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .gallery-item.large { grid-column: span 2; aspect-ratio: 2/1; }
  .gallery-item.tall  { grid-row: span 1; aspect-ratio: 1/1; }
  .review-card { flex: 0 0 85vw; }
  .footer2-top { grid-template-columns: 1fr; }
  .sp-activation-grid { grid-template-columns: 1fr; }
  .sp-impact-item { min-width: 100%; }
  .sp-final-inner { padding: 0 20px; }
  .vss-item { min-width: 100%; }
  .adv-options-grid { grid-template-columns: repeat(3,1fr); }
  .about-cta-section { padding: 60px 0; }
  .page-hero2-content h1 { font-size: 26px; }
}
/* ════════════════════════════════════════════════════════════
   404 ERROR PAGE
   ════════════════════════════════════════════════════════════ */
.error-page {
  position: relative;
  min-height: calc(100vh - 76px);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 60px 24px;
  overflow: hidden;
}
.error-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, #0b3518 0%, #1a5c2e 50%, #0b3518 100%);
}
.error-bg-overlay {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.025'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.error-content {
  position: relative;
  z-index: 1;
  max-width: 600px;
  width: 100%;
}
.error-emoji {
  font-size: 72px;
  margin-bottom: 16px;
  animation: nfc-float 3s ease-in-out infinite alternate;
}
.error-code {
  font-family: 'Playfair Display', serif;
  font-size: clamp(100px, 20vw, 180px);
  font-weight: 900;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 8px;
  text-shadow: 0 4px 40px rgba(247,196,48,0.3);
}
.error-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(24px, 4vw, 36px);
  font-weight: 900;
  color: var(--white);
  margin-bottom: 16px;
}
.error-message {
  font-size: 16px;
  color: rgba(255,255,255,0.65);
  line-height: 1.7;
  margin-bottom: 40px;
}
.error-actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 36px;
}
.error-links {
  display: flex;
  gap: 24px;
  justify-content: center;
  flex-wrap: wrap;
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: 28px;
}
.error-links a {
  font-size: 14px;
  color: rgba(255,255,255,0.5);
  text-decoration: none;
  transition: color 0.2s;
}
.error-links a:hover { color: var(--gold); }

@media (max-width: 480px) {
  .error-actions { flex-direction: column; align-items: center; }
  .error-emoji { font-size: 56px; }
}
