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

/* ===================== CSS VARIABLES ===================== */
:root {
  --dark: #0e0c0a;
  --dark-2: #151210;
  --dark-3: #1a1612;
  --dark-4: #1e1a14;
  --gold: #c9a86c;
  --gold-light: #e0bf80;
  --gold-pale: rgba(201,168,108,0.12);
  --white: #ffffff;
  --off-white: #faf8f4;
  --cream: #f5f0e8;
  --text-dark: #1a1612;
  --text-mid: #4a4540;
  --text-light: #8a8580;
  --border-dark: rgba(240,235,227,0.1);
  --border-light: rgba(26,22,18,0.1);
  --font-serif: 'Cormorant Garamond', Georgia, serif;
  --font-sans: 'Montserrat', sans-serif;
}

/* ===================== RESET ===================== */
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-serif); overflow-x: hidden; }
a { text-decoration: none; color: inherit; }
button { cursor: pointer; border: none; background: none; }

/* ===================== TYPOGRAPHY ===================== */
.t-display { font-family: var(--font-serif); font-weight: 300; font-style: italic; }
.t-heading { font-family: var(--font-serif); font-weight: 300; }
.t-label { font-family: var(--font-sans); font-size: 10px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; }
.t-body { font-family: var(--font-sans); font-size: 12px; font-weight: 300; line-height: 1.8; }
.t-meta { font-family: var(--font-sans); font-size: 10px; font-weight: 300; letter-spacing: 1px; }

/* ===================== SHARED NAV — DARK ===================== */
.nav-dark {
  display: flex; justify-content: space-between; align-items: center;
  padding: 22px 56px;
  border-bottom: 0.5px solid var(--border-dark);
  background: rgba(14,12,10,0.95);
  backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 100;
}
.nav-light {
  display: flex; justify-content: space-between; align-items: center;
  padding: 22px 56px;
  border-bottom: 0.5px solid var(--border-light);
  background: rgba(250,248,244,0.97);
  backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 100;
}
.logo-dark { font-family: var(--font-serif); font-size: 22px; font-weight: 300; letter-spacing: 6px; text-transform: uppercase; color: #f0ebe3; }
.logo-dark em, .logo-light em { font-style: normal; color: var(--gold); }
.logo-light { font-family: var(--font-serif); font-size: 22px; font-weight: 300; letter-spacing: 6px; text-transform: uppercase; color: var(--text-dark); }
.nav-links-dark a { font-family: var(--font-sans); font-size: 10px; font-weight: 400; letter-spacing: 3px; text-transform: uppercase; color: rgba(240,235,227,0.6); margin-left: 28px; transition: color 0.3s; }
.nav-links-dark a:hover { color: var(--gold); }
.nav-links-light a { font-family: var(--font-sans); font-size: 10px; font-weight: 400; letter-spacing: 3px; text-transform: uppercase; color: var(--text-mid); margin-left: 28px; transition: color 0.3s; }
.nav-links-light a:hover { color: var(--gold); }
.btn-nav { font-family: var(--font-sans); font-size: 10px; font-weight: 500; letter-spacing: 2px; text-transform: uppercase; background: var(--gold); color: var(--dark); padding: 10px 22px; transition: background 0.3s; }
.btn-nav:hover { background: var(--gold-light); }

/* ===================== BUTTONS ===================== */
.btn-dark { display: inline-block; font-family: var(--font-sans); font-size: 10px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; background: var(--gold); color: var(--dark); padding: 14px 32px; transition: background 0.3s; }
.btn-dark:hover { background: var(--gold-light); }
.btn-outline-dark { display: inline-block; font-family: var(--font-sans); font-size: 10px; font-weight: 400; letter-spacing: 3px; text-transform: uppercase; color: rgba(240,235,227,0.65); border-bottom: 0.5px solid rgba(240,235,227,0.3); padding-bottom: 2px; transition: color 0.3s; }
.btn-outline-light { display: inline-block; font-family: var(--font-sans); font-size: 10px; font-weight: 400; letter-spacing: 3px; text-transform: uppercase; color: var(--text-mid); border-bottom: 0.5px solid rgba(26,22,18,0.2); padding-bottom: 2px; transition: color 0.3s; }

/* ===================== SECTION HEADERS ===================== */
.section-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 40px; }
.section-title-dark { font-size: 44px; font-weight: 300; font-style: italic; color: #f0ebe3; }
.section-title-light { font-size: 44px; font-weight: 300; font-style: italic; color: var(--text-dark); }
.section-link-gold { font-family: var(--font-sans); font-size: 10px; font-weight: 400; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); border-bottom: 0.5px solid var(--gold); padding-bottom: 2px; transition: opacity 0.3s; }

/* ===================== DARK SECTIONS ===================== */
.bg-dark { background: var(--dark); color: #f0ebe3; }
.bg-dark-2 { background: var(--dark-2); color: #f0ebe3; }
.section-dark { padding: 80px 56px; background: var(--dark); }
.section-dark-2 { padding: 80px 56px; background: var(--dark-2); }

/* ===================== WHITE/LIGHT SECTIONS ===================== */
.bg-white { background: var(--white); color: var(--text-dark); }
.bg-off-white { background: var(--off-white); color: var(--text-dark); }
.bg-cream { background: var(--cream); color: var(--text-dark); }
.section-white { padding: 80px 56px; background: var(--white); }
.section-off-white { padding: 80px 56px; background: var(--off-white); }
.section-cream { padding: 80px 56px; background: var(--cream); }

/* ===================== TICKER ===================== */
.ticker { background: var(--gold); padding: 10px 0; overflow: hidden; }
.ticker-track { display: flex; gap: 48px; white-space: nowrap; animation: ticker 25s linear infinite; }
.ticker-item { font-family: var(--font-sans); font-size: 10px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: var(--dark); }
.ticker-dot { color: rgba(14,12,10,0.3); }
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ===================== CARDS — DARK ===================== */
.card-dark { background: var(--dark-2); border: 0.5px solid rgba(240,235,227,0.05); transition: all 0.3s; }
.card-dark:hover { background: var(--dark-3); border-color: rgba(201,168,108,0.2); }

/* ===================== CARDS — LIGHT ===================== */
.card-light { background: var(--white); border: 0.5px solid rgba(26,22,18,0.08); transition: all 0.3s; box-shadow: 0 2px 20px rgba(0,0,0,0.04); }
.card-light:hover { box-shadow: 0 8px 40px rgba(0,0,0,0.1); transform: translateY(-2px); }

/* ===================== GOLD DIVIDER ===================== */
.divider-gold { width: 48px; height: 1px; background: var(--gold); margin: 24px 0; }
.divider-gold-center { width: 48px; height: 1px; background: var(--gold); margin: 24px auto; }

/* ===================== FOOTER ===================== */
.footer { background: var(--dark); color: #f0ebe3; padding: 56px; border-top: 0.5px solid var(--border-dark); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
.footer-logo { font-family: var(--font-serif); font-size: 24px; font-weight: 300; letter-spacing: 6px; text-transform: uppercase; margin-bottom: 16px; }
.footer-tagline { font-family: var(--font-sans); font-size: 11px; font-weight: 300; color: rgba(240,235,227,0.35); line-height: 1.8; max-width: 240px; }
.footer-col-title { font-family: var(--font-sans); font-size: 9px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); margin-bottom: 20px; }
.footer-col a { display: block; font-family: var(--font-sans); font-size: 11px; font-weight: 300; color: rgba(240,235,227,0.45); margin-bottom: 10px; transition: color 0.3s; }
.footer-col a:hover { color: var(--gold); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 32px; border-top: 0.5px solid var(--border-dark); }
.footer-copy { font-family: var(--font-sans); font-size: 10px; color: rgba(240,235,227,0.2); letter-spacing: 1px; }
.footer-social { display: flex; gap: 20px; }
.footer-social a { font-family: var(--font-sans); font-size: 10px; color: rgba(240,235,227,0.35); letter-spacing: 2px; transition: color 0.3s; }
.footer-social a:hover { color: var(--gold); }

/* ===================== UTILITIES ===================== */
.container { max-width: 1280px; margin: 0 auto; padding: 0 56px; }
.gold { color: var(--gold); }
.italic { font-style: italic; }
.gap-2 { gap: 2px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); }

/* ===================== ANIMATIONS ===================== */
@keyframes fadeUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.animate-up { animation: fadeUp 0.8s ease forwards; }
.animate-in { animation: fadeIn 0.6s ease forwards; }

/* ===================== RESPONSIVE ===================== */
@media (max-width: 768px) {
  .nav-dark, .nav-light { padding: 16px 24px; }
  .nav-links-dark, .nav-links-light { display: none; }
  .section-dark, .section-white, .section-off-white, .section-cream, .section-dark-2 { padding: 48px 24px; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}

/* ── SCROLLABLE NAV FOR MANY LINKS ── */
.nav-dark .nav-links-dark,
.nav-light .nav-links-light {
  display: flex;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.nav-dark .nav-links-dark::-webkit-scrollbar,
.nav-light .nav-links-light::-webkit-scrollbar { display: none; }
.nav-links-dark a, .nav-links-light a { margin-left: 20px; white-space: nowrap; }

/* Live nav link highlight */
.nav-links-dark a[href*="live"],
.nav-links-light a[href*="live"] { color: #4caf50 !important; }

/* ── REAL IMAGE HELPERS ── */
.img-cover{width:100%;height:100%;object-fit:cover;display:block}
.img-aspect-hero{aspect-ratio:16/9;overflow:hidden}
.img-aspect-card{aspect-ratio:3/2;overflow:hidden}
.img-aspect-portrait{aspect-ratio:2/3;overflow:hidden}
.img-aspect-square{aspect-ratio:1;overflow:hidden}
.img-zoom{transition:transform 0.6s ease}
.img-zoom:hover{transform:scale(1.05)}

/* Page hero with image */
.page-hero-img{position:relative;height:55vh;overflow:hidden;display:flex;align-items:flex-end}
.page-hero-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.page-hero-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,8,6,0.96) 0%,rgba(10,8,6,0.4) 60%,rgba(10,8,6,0.15) 100%)}
.page-hero-img-content{position:relative;z-index:2;padding:0 56px 56px;width:100%}

/* ══════════════════════════════════════
   MEGA MENU NAVIGATION
══════════════════════════════════════ */
.mega-nav {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 48px;
  border-bottom: 0.5px solid var(--border-dark);
  background: rgba(14,12,10,0.97);
  backdrop-filter: blur(12px);
  position: sticky; top: 0; z-index: 200;
  height: 64px;
}
.mega-nav-light {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 48px;
  border-bottom: 0.5px solid var(--border-light);
  background: rgba(250,248,244,0.97);
  backdrop-filter: blur(12px);
  position: sticky; top: 0; z-index: 200;
  height: 64px;
}
.mega-logo-dark { font-family:var(--font-serif);font-size:20px;font-weight:300;letter-spacing:6px;text-transform:uppercase;color:#f0ebe3;text-decoration:none;display:flex;align-items:center;flex-shrink:0 }
.mega-logo-dark em, .mega-logo-light em { font-style:normal;color:var(--gold) }
.mega-logo-light { font-family:var(--font-serif);font-size:20px;font-weight:300;letter-spacing:6px;text-transform:uppercase;color:var(--text-dark);text-decoration:none;display:flex;align-items:center;flex-shrink:0 }
.brand-logo { height:26px;width:auto;max-width:none;flex-shrink:0;display:block }
.footer-logo-img { height:34px;width:auto;max-width:none;flex-shrink:0;display:block;margin-bottom:16px }
.nl-logo-img { height:54px;width:auto;max-width:none;flex-shrink:0;display:block;margin-bottom:12px }
.mega-links { display:flex;align-items:stretch;height:64px }
.mega-item { position:relative;display:flex;align-items:center }
.mega-item > a {
  font-family:var(--font-sans);font-size:10px;font-weight:400;letter-spacing:2.5px;text-transform:uppercase;
  color:rgba(240,235,227,0.6);padding:0 16px;height:64px;display:flex;align-items:center;
  text-decoration:none;white-space:nowrap;transition:color 0.3s;border-bottom:2px solid transparent;
}
.mega-item > a:hover { color:#f0ebe3; border-bottom-color:var(--gold) }
.mega-item > a.live-link { color:#4caf50; position:relative }
.mega-item > a.live-link::after {
  content:'';position:absolute;top:18px;right:6px;
  width:5px;height:5px;border-radius:50%;background:#4caf50;
  box-shadow:0 0 6px rgba(76,175,80,0.9);
  animation:liveBlink 1.4s ease-in-out infinite;
}
@keyframes liveBlink { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.15;transform:scale(0.65)} }
.mega-item > a.active-link { color:#f0ebe3; border-bottom-color:var(--gold) }
/* Light nav links */
.mega-nav-light .mega-item > a { color:var(--text-light) }
.mega-nav-light .mega-item > a:hover { color:var(--text-dark) }
.mega-nav-light .mega-item > a.live-link { color:#2e7d32 }
.mega-nav-light .mega-item > a.live-link::after { background:#2e7d32;box-shadow:0 0 6px rgba(46,125,50,0.7) }

/* DROPDOWN PANEL */
.mega-dropdown {
  position:absolute;top:64px;left:50%;transform:translateX(-50%);
  background:rgba(14,12,10,0.98);border-top:1px solid var(--gold);
  padding:36px 40px;min-width:520px;
  opacity:0;visibility:hidden;transition:all 0.25s ease;
  pointer-events:none;box-shadow:0 24px 64px rgba(0,0,0,0.5);
}
.mega-item:hover .mega-dropdown { opacity:1;visibility:visible;pointer-events:all }
.mega-item.mega-open > .mega-dropdown { opacity:1;visibility:visible;pointer-events:all }
.mega-nav-light .mega-dropdown { background:rgba(250,248,244,0.99);box-shadow:0 24px 64px rgba(0,0,0,0.12) }
.mega-dropdown-grid { display:grid;gap:32px }
.mega-dropdown-grid.cols-2 { grid-template-columns:1fr 1fr }
.mega-dropdown-grid.cols-3 { grid-template-columns:1fr 1fr 1fr }
.mega-dropdown-grid.cols-4 { grid-template-columns:1fr 1fr 1fr 1fr }
.mega-col-title {
  font-family:var(--font-sans);font-size:8px;font-weight:600;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold);margin-bottom:16px;padding-bottom:8px;border-bottom:0.5px solid rgba(201,168,108,0.2)
}
.mega-link {
  display:block;font-family:var(--font-sans);font-size:11px;font-weight:300;
  color:rgba(240,235,227,0.55);text-decoration:none;padding:6px 0;
  transition:all 0.2s;letter-spacing:0.5px;
}
.mega-link:hover { color:var(--gold);padding-left:6px }
.mega-nav-light .mega-link { color:var(--text-light) }
.mega-nav-light .mega-link:hover { color:var(--gold) }
.mega-nav-light .mega-col-title { color:var(--gold) }
.mega-view-all {
  display:inline-block;margin-top:12px;font-family:var(--font-sans);font-size:9px;font-weight:500;
  letter-spacing:2px;text-transform:uppercase;color:var(--gold);text-decoration:none;
  border-bottom:0.5px solid rgba(201,168,108,0.4);padding-bottom:2px;
}
.mega-nav-cta {
  font-family:var(--font-sans);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;
  background:var(--gold);color:var(--dark);padding:10px 20px;text-decoration:none;
  transition:background 0.3s;white-space:nowrap;flex-shrink:0;margin-left:16px;
}
.mega-nav-cta:hover { background:var(--gold-light) }

/* ══════════════════════════════════════
   EVENTS PAGE STYLES
══════════════════════════════════════ */
.events-hero { position:relative;height:65vh;display:flex;align-items:flex-end;overflow:hidden }
.events-hero img { position:absolute;inset:0;width:100%;height:100%;object-fit:cover }
.events-hero-overlay { position:absolute;inset:0;background:linear-gradient(to top,rgba(10,8,6,0.96) 0%,rgba(10,8,6,0.4) 60%,transparent 100%) }
.events-hero-content { position:relative;z-index:2;padding:0 56px 64px;width:100% }
.events-filter { background:var(--white);padding:0 56px;display:flex;gap:0;border-bottom:0.5px solid rgba(26,22,18,0.08);position:sticky;top:64px;z-index:50;overflow-x:auto }
.events-filter-btn { font-family:var(--font-sans);font-size:10px;font-weight:400;letter-spacing:3px;text-transform:uppercase;color:var(--text-light);padding:18px 22px;border-bottom:2px solid transparent;background:none;border-top:none;border-left:none;border-right:none;cursor:pointer;transition:all 0.3s;white-space:nowrap }
.events-filter-btn:hover,.events-filter-btn.active { color:var(--text-dark);border-bottom-color:var(--gold) }
.events-featured { padding:64px 56px;background:var(--dark) }
.events-featured-inner { display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--dark-2) }
.ef-img { aspect-ratio:1;overflow:hidden;position:relative }
.ef-img img { width:100%;height:100%;object-fit:cover }
.ef-badge { position:absolute;top:20px;left:20px;font-family:var(--font-sans);font-size:8px;font-weight:500;letter-spacing:3px;text-transform:uppercase;background:var(--gold);color:var(--dark);padding:6px 14px }
.ef-content { padding:48px 40px;display:flex;flex-direction:column;justify-content:center }
.ef-month { font-family:var(--font-sans);font-size:9px;font-weight:500;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:8px }
.ef-title { font-size:40px;font-weight:300;font-style:italic;color:#f0ebe3;line-height:1.2;margin-bottom:16px }
.ef-desc { font-family:var(--font-sans);font-size:12px;color:rgba(240,235,227,0.5);line-height:1.9;margin-bottom:24px }
.ef-meta { display:flex;gap:24px;margin-bottom:28px }
.ef-meta-item { display:flex;flex-direction:column;gap:4px }
.ef-meta-label { font-family:var(--font-sans);font-size:8px;letter-spacing:2px;text-transform:uppercase;color:rgba(240,235,227,0.3) }
.ef-meta-val { font-family:var(--font-sans);font-size:12px;color:rgba(240,235,227,0.7) }
.events-grid-section { padding:64px 56px;background:var(--off-white) }
.events-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:2px }
.event-card { background:var(--white);overflow:hidden;cursor:pointer;transition:all 0.3s;box-shadow:0 2px 12px rgba(0,0,0,0.04) }
.event-card:hover { box-shadow:0 16px 48px rgba(0,0,0,0.1);transform:translateY(-4px) }
.event-card-img { aspect-ratio:3/2;overflow:hidden;position:relative }
.event-card-img img { width:100%;height:100%;object-fit:cover;transition:transform 0.5s }
.event-card:hover .event-card-img img { transform:scale(1.05) }
.event-date-badge { position:absolute;top:16px;left:16px;background:var(--gold);color:var(--dark);padding:8px 14px;text-align:center }
.event-date-day { font-size:22px;font-weight:300;font-style:italic;line-height:1 }
.event-date-month { font-family:var(--font-sans);font-size:8px;font-weight:500;letter-spacing:2px;text-transform:uppercase }
.event-card-body { padding:24px }
.event-cat { font-family:var(--font-sans);font-size:9px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:8px }
.event-name { font-size:22px;font-weight:300;font-style:italic;color:var(--text-dark);margin-bottom:6px }
.event-location { font-family:var(--font-sans);font-size:10px;color:var(--text-light);margin-bottom:10px }
.event-desc { font-family:var(--font-sans);font-size:11px;color:var(--text-light);line-height:1.7;margin-bottom:16px }
.event-footer { display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:0.5px solid rgba(26,22,18,0.08) }
.event-price { font-family:var(--font-sans);font-size:11px;font-weight:500;color:var(--gold) }
.event-timing { font-family:var(--font-sans);font-size:10px;color:var(--text-light) }
.calendar-section { padding:64px 56px;background:var(--white) }
.cal-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:40px }
.cal-month { background:var(--off-white);padding:24px }
.cal-month-name { font-family:var(--font-sans);font-size:9px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:16px }
.cal-event { padding:10px 0;border-bottom:0.5px solid rgba(26,22,18,0.06);cursor:pointer;transition:all 0.2s }
.cal-event:hover { padding-left:6px }
.cal-event:last-child { border:none }
.cal-event-date { font-family:var(--font-sans);font-size:9px;color:rgba(26,22,18,0.3);margin-bottom:2px }
.cal-event-name { font-size:14px;font-weight:300;font-style:italic;color:var(--text-dark) }
.cal-event-type { font-family:var(--font-sans);font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-top:2px }

/* ═══ WHATSAPP FLOATING BUTTON ═══ */
.wa-float{position:fixed;right:24px;bottom:24px;z-index:9999;display:flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:50%;background:#25D366;box-shadow:0 6px 22px rgba(0,0,0,0.28);transition:transform .25s ease,box-shadow .25s ease}
.wa-float:hover{transform:scale(1.08);box-shadow:0 10px 30px rgba(37,211,102,0.45)}
.wa-float svg{width:32px;height:32px;fill:#fff}
@media(max-width:768px){.wa-float{right:18px;bottom:18px;width:52px;height:52px}.wa-float svg{width:28px;height:28px}}
