/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: Dec 12 2025 | 14:40:13 */
/**
 * Edenbridge Header V3 - Styles
 * 
 * @project    Edenbridge Band Website
 * @author     Tom der Medienmacher
 * @website    https://medienmacher.biz
 * @copyright  2025 Medienmacher e.U.
 * 
 * Table of Contents:
 * 1. VARIABLES & BASE
 * 2. TOP BAR & LOGO
 * 3. NAVIGATION
 * 4. MOBILE DRAWER
 * 5. HERO SECTION BASE
 * 6. HERO TABS
 * 7. HERO PANELS
 * 8. VIDEO COMPONENTS
 * 9. VIDEO MODE
 * 10. TOUR PANEL
 * 11. DARKFIRE PANEL (Modal)
 * 12. BUTTONS & CHIPS  
 * 13. LANGUAGE POPUP
 * 14. UTILITIES & ANIMATIONS
 */

/* ================================================================
   1. VARIABLES & BASE
   ================================================================ */

:root {
  --ebx-glow-strip: radial-gradient(80% 70% at 50% 100%, var(--lava-22), var(--gold-10) 45%, rgba(0, 0, 0, 0) 80%);
  --z-behind: -1;
  --z-base: 1;
  --z-content-high: 10;
  --z-nav: 100;
  --z-top: 200;
  --z-dd: 300;
  --z-hero-toggle: 400;
  --z-overlay: 500;
  --z-modal: 1000;
  --z-toast: 2000;
  --vw: 100svw;

  /* Font variables - inherit from Elementor global typography */
  /* Primary = Heading font (e.g., Cinzel) */
  /* Text = Body font (e.g., Plus Jakarta Sans) */
  /* Accent = Navigation font (e.g., Montserrat) */
  --ebx-font-primary: var(--e-global-typography-primary-font-family, inherit);
  --ebx-font-text: var(--e-global-typography-text-font-family, inherit);
  --ebx-font-accent: var(--e-global-typography-accent-font-family, inherit);
  --ebx-font-secondary: var(--e-global-typography-secondary-font-family, inherit);
}

@supports not (width: 100svw) {
  :root {
    --vw: 100vw;
  }
}

@media (hover: none) {
  :root {
    --sbw: 0px;
  }
}

html {
  overflow-y: scroll;
}

html,
body {
  margin: 0;
  padding: 0;
  background: #0b0b0d;
}

.ebx,
.ebx * {
  box-sizing: border-box;
}

.ebx a {
  color: inherit;
  text-decoration: none;
}

/* Focus State Overrides - Fix browser pink/magenta defaults */
.ebx *:focus {
  outline: none;
}

.ebx *:focus-visible {
  outline: 2px solid var(--gold, #d4a03c) !important;
  outline-offset: 2px !important;
  box-shadow: 0 0 0 4px rgba(250, 104, 31, .25) !important;
}

.ebx button:focus-visible,
.ebx a:focus-visible,
.ebx [tabindex]:focus-visible {
  outline: 2px solid var(--gold, #d4a03c) !important;
  outline-offset: 2px !important;
}

/* Remove default button focus states */
.ebx button:focus,
.ebx button:-moz-focusring {
  outline: none;
}

/* Active/Pressed State - no pink */
.ebx button:active,
.ebx a:active {
  outline: none !important;
}

/* Mobile drawer specific focus */
.dm-root:focus-visible,
.dm-item:focus-visible {
  outline: 2px solid var(--lava, #fa681f) !important;
  outline-offset: -2px !important;
  box-shadow: inset 0 0 0 2px var(--lava-35) !important;
}

.ebx-full-bleed {
  width: calc(100vw - var(--sbw));
  margin-inline: calc(50% - 50vw + var(--sbw)/2);
}

/* Scroll Lock */
html.ebx-no-scroll,
html.ebx-no-scroll body {
  overflow: hidden;
}

/* Full-width elements */
#ebx,
.ebx-top,
.ebx-bar,
.ebx-nav,
#ebx-hero-alt,
.ebx-hero-toggle-wrap {
  width: var(--vw) !important;
  margin-left: calc(50% - var(--vw)/2) !important;
  margin-right: calc(50% - var(--vw)/2) !important;
  max-width: none !important;
}

#ebx,
#ebx-hero-alt {
  padding-left: max(env(safe-area-inset-left), 0);
  padding-right: max(env(safe-area-inset-right), 0);
}

#ebx {
  position: relative;
  top: 0 !important;
  padding-top: calc(max(env(safe-area-inset-top), 0) + 1px);
  background-color: #0f1318;
}

/* Hero visibility control */
#ebx-hero-alt {
  display: none;
}

html[data-hero="show"] #ebx-hero-alt {
  display: block;
}

/* Elementor integration */
.elementor-location-header,
.elementor-location-header>.elementor {
  width: var(--vw) !important;
  margin-left: calc(50% - var(--vw)/2) !important;
  margin-right: calc(50% - var(--vw)/2) !important;
  max-width: none !important;
}

.elementor-location-header .elementor-section,
.elementor-location-header .elementor-container,
.elementor-location-header .elementor-row,
.elementor-location-header .elementor-column,
.elementor-location-header .elementor-widget-wrap {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box;
}

body,
.elementor-location-header,
.elementor-location-header>.elementor {
  margin-top: 0 !important;
  padding-top: 0 !important;
  border-top: 0 !important;
}

.elementor-location-header+.site-content>*:first-child,
#ebx-hero-alt+* {
  margin-top: 0 !important;
}


/* ================================================================
   2. TOP BAR & LOGO
   ================================================================ */

.ebx-bar {
  position: relative;
  z-index: var(--z-top);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: .85rem 0;
  background: repeating-linear-gradient(100deg, rgba(255, 255, 255, .035) 0 1px, rgba(255, 255, 255, 0) 1px 3px),
    repeating-linear-gradient(280deg, rgba(0, 0, 0, .06) 0 1px, rgba(0, 0, 0, 0) 1px 4px),
    linear-gradient(180deg, rgba(15, 19, 24, .88), rgba(11, 13, 14, .92));
  background-blend-mode: overlay, normal, normal;
  border-bottom: 1px solid var(--lava-15);
  box-shadow: inset 0 6px 18px rgba(0, 0, 0, .45), inset 0 1px 0 var(--white-06);
  backdrop-filter: var(--backdrop-glass);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  background-color: #0b0b0d;
  animation: bar-fade-in .8s ease-out;
  will-change: transform, opacity;
}

.ebx-bar::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .24;
  background: repeating-linear-gradient(112deg, var(--white-12) 0 1px, rgba(255, 255, 255, 0) 1px 3px),
    repeating-linear-gradient(292deg, rgba(0, 0, 0, .22) 0 1px, rgba(0, 0, 0, 0) 1px 4px);
  mix-blend-mode: overlay;
}

.ebx-bar>:not(canvas) {
  position: relative;
  z-index: var(--z-base);
}

@keyframes bar-fade-in {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Logo */
.ebx-logo {
  transition: transform .3s ease, filter .3s ease;
}

.ebx-logo:hover {
  transform: translateY(-3px);
  filter: drop-shadow(0 0 24px rgba(250, 104, 31, .4));
}

.ebx-logo:focus-visible {
  outline: 3px solid rgba(250, 104, 31, .6);
  outline-offset: 8px;
  border-radius: var(--radius-sm);
}

.ebx-logo img {
  height: 118px;
  width: auto;
  display: block;
  filter: drop-shadow(0 2px 0 rgba(0, 0, 0, .85)) drop-shadow(0 12px 28px rgba(0, 0, 0, .45));
  transition: filter .3s ease;
}

.ebx-logo:hover img {
  filter: drop-shadow(0 2px 0 rgba(0, 0, 0, .85)) drop-shadow(0 12px 28px rgba(0, 0, 0, .45)) drop-shadow(0 0 20px rgba(250, 104, 31, .5));
}

/* Mobile Menu Button (Sickle) */
#ebx-sickle {
  position: absolute;
  left: 50%;
  top: calc(100% - 42px);
  transform: translateX(-50%);
  width: 46px;
  height: 46px;
  min-width: 46px;
  min-height: 46px;
  border-radius: var(--radius-pill);
  display: none;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(18, 22, 30, .65), rgba(12, 14, 18, .75)),
    radial-gradient(140% 100% at 50% 0%, var(--lava-12), transparent 70%);
  border: 1px solid var(--lava-25);
  box-shadow: inset 0 1px 0 var(--white-15), inset 0 0 0 1px var(--white-08), 0 10px 26px rgba(0, 0, 0, .42), 0 0 18px var(--lava-08);
  backdrop-filter: saturate(130%) blur(var(--blur-lg));
  stroke: #f5e8dc;
  stroke-width: 2.2;
  stroke-linecap: round;
  transition: transform .18s, box-shadow .18s, border-color .18s, background .18s;
}

#ebx-sickle:hover {
  border-color: var(--lava-40);
  background: linear-gradient(135deg, rgba(18, 22, 30, .70), rgba(12, 14, 18, .80)),
    radial-gradient(140% 100% at 50% 0%, var(--lava-18), transparent 70%);
  box-shadow: inset 0 1px 0 var(--white-20), inset 0 0 0 1px var(--white-12), 0 12px 32px rgba(0, 0, 0, .48), 0 0 24px var(--lava-15);
}

#ebx-sickle:active {
  transform: translateX(-50%) scale(.96);
  box-shadow: 0 0 0 2px var(--lava-45), 0 0 18px var(--lava-40), 0 12px 32px rgba(0, 0, 0, .6);
}

#ebx-sickle[aria-expanded="true"] {
  box-shadow: 0 0 0 2px var(--lava-28), 0 0 16px var(--lava-35);
}

#ebx-sickle[aria-expanded="true"] .top {
  transform: translateY(5px) rotate(45deg);
}

#ebx-sickle[aria-expanded="true"] .mid {
  opacity: 0;
}

#ebx-sickle[aria-expanded="true"] .bot {
  transform: translateY(-5px) rotate(-45deg);
}

/* Desktop Bar Overrides */
@media (min-width: 981px) {
  .ebx-bar {
    margin-top: -2px;
    padding: 1.1rem 0;
    background: linear-gradient(200deg, rgba(12, 16, 20, .92), rgba(8, 10, 12, .85));
    border-top: 1px solid var(--white-05);
    border-bottom: 1px solid var(--white-08);
    box-shadow: 0 26px 48px rgba(0, 0, 0, .55);
  }

  #ebx-sickle {
    display: none;
  }
}

@media (max-width: 1180px) {
  .ebx-logo img {
    height: 92px;
  }
}

@media (max-width: 980px) {
  .ebx-bar {
    position: relative;
    z-index: var(--z-top);
  }

  .ebx-bar::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1px;
    height: 24px;
    pointer-events: none;
    background: var(--ebx-glow-strip);
    filter: blur(var(--blur-sm));
  }

  .ebx-logo img {
    height: 72px;
  }

  #ebx-sickle {
    display: flex;
  }
}


/* ================================================================
   3. NAVIGATION
   ================================================================ */

.ebx-nav {
  position: relative;
  z-index: var(--z-nav);
  border-top: 1px solid rgba(255, 255, 255, .1);
  border-bottom: 1px solid var(--lava-18);
  background: linear-gradient(180deg, rgba(15, 19, 24, .82), rgba(11, 13, 14, .78)),
    radial-gradient(800px 100% at 50% 0, var(--lava-08), transparent 70%);
  backdrop-filter: var(--backdrop-glass-strong);
  contain: layout style;
  box-shadow: 0 8px 24px var(--black-35), inset 0 1px 0 var(--white-06);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  background-color: #0b0b0d;
}

.ebx-nav>:not(canvas) {
  position: relative;
  z-index: var(--z-base);
}

.ebx-nav::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 28px;
  pointer-events: none;
  background: radial-gradient(80% 70% at 50% 100%, var(--lava-28), var(--gold-12) 45%, rgba(0, 0, 0, 0) 80%);
  filter: blur(var(--blur-sm));
}

.ebx-nav__container {
  max-width: 1400px;
  margin: 0 auto;
  padding: .55rem clamp(18px, 4vw, 48px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}

/* Menu */
.ebx-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: clamp(1.4rem, 3.5vw, 2.8rem);
  align-items: center;
  justify-content: flex-start;
  flex: 1;
}

.menu-root {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .55rem 2.4rem .55rem 1rem;
  border-radius: var(--radius-lg);
  font: 900 .98rem/1 var(--ebx-font-primary, 'Cinzel', serif);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: transparent;
  background: linear-gradient(180deg, #edf2f7, #cbd3da);
  -webkit-background-clip: text;
  background-clip: text;
  transition: transform .16s ease, filter .2s ease;
}

.menu-root .menu-arrow {
  position: absolute;
  right: .75rem;
  top: 50%;
  transform: translateY(-50%);
  transition: transform .18s ease, color .18s ease;
  color: var(--ink-3);
  font-size: .75em;
}

.menu-root:hover .menu-arrow,
.has-dd.open>.menu-root .menu-arrow {
  color: var(--gold);
  transform: translateY(-50%) rotate(180deg);
}

.menu-root::before {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, var(--white-05), rgba(0, 0, 0, .08));
  opacity: 0;
  transition: opacity .2s ease;
  z-index: var(--z-behind);
}

.menu-root:hover::before {
  opacity: 1;
}

.menu-root::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 2px;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--lava) 20%, var(--gold) 50%, var(--lava) 80%, transparent);
  box-shadow: 0 0 10px rgba(250, 104, 31, .5);
  opacity: 0;
  transition: width .28s ease, opacity .22s ease;
}

.menu-root:hover,
.has-dd.open>.menu-root {
  filter: none;
  background-image: linear-gradient(180deg, #fff9f0, #ffe5c5, #ffb66f);
  text-shadow: 0 2px 10px rgba(250, 104, 31, .4), 0 0 20px var(--gold-28);
  transform: translateY(-1px);
}

.menu-root:hover::after,
.has-dd.open>.menu-root::after {
  opacity: 1;
  width: 80%;
}

.menu-root:focus-visible {
  outline: 2px solid rgba(250, 104, 31, .6);
  outline-offset: 4px;
}

.menu-root:active {
  transform: translateY(0);
}

/* Dropdown */
.has-dd {
  position: relative;
}

.ebx-dd {
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
  min-width: 220px;
  padding: .55rem .8rem;
  border-radius: var(--radius-sm);
  display: none;
  z-index: var(--z-dd);
  background: linear-gradient(180deg, rgba(16, 20, 27, .68), rgba(11, 14, 18, .74));
  border: 1px solid var(--white-14);
  box-shadow: 0 18px 40px rgba(0, 0, 0, .45), inset 0 0 0 1px var(--white-03);
  backdrop-filter: var(--backdrop-glass);
  justify-content: space-between;
  gap: .6rem;
  color: #e9eef4;
  font-weight: 800;
}

.ebx-dd a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
}

.ebx-dd a i {
  font-size: .9em;
  opacity: .7;
}

.ebx-dd a:hover {
  background: linear-gradient(180deg, rgba(184, 74, 58, .22), rgba(184, 74, 58, .08));
  color: #ffe7c2;
}

.ebx-dd a:hover i {
  opacity: 1;
}

.has-dd.open .ebx-dd {
  display: flex;
  flex-direction: column;
}

/* Nav CTAs */
.ebx-nav__ctas {
  display: flex;
  gap: .65rem;
  align-items: center;
}

.nav-cta {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .5rem 1.1rem;
  border-radius: var(--radius-pill);
  font: 700 .88rem/1 var(--ebx-font-accent, 'Space Grotesk', system-ui);
  letter-spacing: .06em;
  text-transform: uppercase;
  border: 1px solid var(--white-16);
  background: linear-gradient(180deg, var(--white-08), rgba(0, 0, 0, .14));
  backdrop-filter: blur(var(--blur-md));
  color: #e5ecf3;
  box-shadow: inset 0 1px 0 var(--white-15), 0 6px 16px rgba(0, 0, 0, .25);
  transition: transform .16s ease, background .18s ease, border-color .18s ease, box-shadow .2s ease, color .18s ease;
}

.nav-cta i {
  font-size: .95rem;
  opacity: .85;
}

.nav-cta:hover {
  transform: translateY(-2px);
  border-color: rgba(255, 227, 146, .3);
  background: linear-gradient(180deg, var(--white-12), var(--black-10));
  backdrop-filter: blur(var(--blur-lg));
  color: #fff;
  box-shadow: inset 0 1px 0 var(--white-22), 0 0 0 1px var(--lava-18), 0 10px 24px rgba(250, 104, 31, .2);
}

.nav-cta:hover i {
  opacity: 1;
}

.nav-cta--booking {
  background: linear-gradient(115deg, var(--lava-32), rgba(250, 104, 31, .20));
  border-color: rgba(250, 104, 31, .5);
  color: #fff9f5;
  font-weight: 800;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .28), inset 0 0 0 1px var(--gold-15), 0 8px 20px var(--lava-32);
}

.nav-cta--booking i {
  opacity: 1;
}

.nav-cta--booking:hover {
  background: linear-gradient(115deg, rgba(250, 104, 31, .42), var(--lava-28));
  border-color: rgba(250, 104, 31, .7);
  color: #fffefb;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .35), inset 0 0 0 1px var(--gold-22), 0 0 0 1px rgba(250, 104, 31, .4), 0 12px 28px rgba(250, 104, 31, .42);
}

.nav-cta--lang {
  position: relative;
  padding: .5rem .65rem;
  min-width: auto;
}

.nav-cta--lang i {
  font-size: 1.05rem;
}

/* Desktop Nav Overrides */
@media (min-width: 981px) {
  .ebx-nav {
    margin-top: -2px;
  }

  .ebx-nav__container {
    padding: .65rem clamp(24px, 4vw, 48px);
  }

  .ebx-menu {
    gap: clamp(1.6rem, 4vw, 3rem);
  }

  .menu-root {
    letter-spacing: .14em;
    padding: .6rem 2.6rem .6rem 1.1rem;
  }

  .nav-cta {
    padding: .55rem 1.3rem;
  }
}

@media (max-width: 980px) {

  .ebx-top,
  .ebx-nav {
    display: none;
  }

  .ebx-nav__ctas {
    display: none;
  }
}


/* ================================================================
   4. MOBILE DRAWER
   ================================================================ */

.ebx-drawer {
  position: fixed;
  inset: 0 0 0 auto;
  width: min(90vw, 440px);
  transform: translateX(100%);
  transition: transform .28s ease;
  z-index: var(--z-modal);
  border-left: 1px solid var(--white-10);
  background: linear-gradient(180deg, rgba(14, 16, 22, .7), rgba(9, 12, 16, .74)),
    radial-gradient(800px 240px at 20% 0, var(--lava-10), transparent 70%);
  backdrop-filter: var(--backdrop-glass);
  contain: layout style paint;
}

.ebx-drawer.open {
  transform: translateX(0);
}

.ebx-drawer::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 36px;
  pointer-events: none;
  background: radial-gradient(80% 70% at 50% 100%, var(--lava-22), var(--gold-10) 45%, rgba(0, 0, 0, 0) 80%);
  filter: blur(var(--blur-sm));
}

.ebx-drawer::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -1px;
  height: 22px;
  pointer-events: none;
  background: radial-gradient(80% 70% at 50% 0%, var(--lava-12), rgba(255, 227, 146, .06) 45%, rgba(0, 0, 0, 0) 80%);
  filter: blur(var(--blur-sm));
}

.ebx-drawer-inner {
  height: 100%;
  overflow: auto;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  position: relative;
}

.ebx-drawer-inner::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(2px 2px at 18% 24%, var(--lava-22), transparent 60%),
    radial-gradient(1.6px 1.6px at 62% 14%, var(--gold-18), transparent 60%),
    radial-gradient(1.8px 1.8px at 84% 32%, var(--lava-18), transparent 60%);
  animation: drawer-sparks 12s linear infinite;
  opacity: .45;
  will-change: transform;
}

@keyframes drawer-sparks {
  to {
    transform: translateY(-26px);
  }
}

.ebx-drawer-close {
  position: sticky;
  top: 8px;
  align-self: flex-end;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--white-18);
  background: var(--black-38);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 1.5rem;
  line-height: 1;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .4);
  transition: transform .16s ease, box-shadow .18s ease, color .18s ease;
}

.ebx-drawer-close:hover {
  color: #ffe7c2;
  box-shadow: 0 0 0 2px var(--lava-22), 0 16px 38px var(--lava-28);
  transform: translateY(-1px);
}

/* Drawer Social */
.drawer-social {
  display: flex;
  gap: .45rem;
  align-items: center;
  justify-content: center;
  padding: 12px 4px 14px;
  border-top: 1px solid var(--white-06);
  order: 999;
}

.drawer-social a {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-md-plus);
  border: 1px solid var(--white-10);
  background: linear-gradient(180deg, var(--white-03), rgba(0, 0, 0, .12));
  color: #b0bac8;
  font-size: .85rem;
  box-shadow: inset 0 1px 0 var(--white-12), 0 8px 18px rgba(8, 10, 14, .25);
  transition: transform .16s ease, box-shadow .18s ease, color .18s ease, border-color .18s ease;
}

.drawer-social a:hover {
  color: #ffe7c2;
  border-color: var(--lava-25);
  box-shadow: 0 0 0 1px rgba(250, 104, 31, .2), 0 12px 24px rgba(250, 104, 31, .2);
  transform: translateY(-1px);
}

.drawer-social a:focus-visible {
  outline: 2px solid rgba(250, 104, 31, .65);
  outline-offset: 4px;
}

/* Drawer Quick Links */
.drawer-quick {
  padding: 16px;
  border-radius: var(--radius-2xl);
  border: 1px solid var(--white-08);
  background: linear-gradient(180deg, var(--white-03), var(--black-10));
  display: grid;
  gap: .6rem;
  grid-template-columns: repeat(2, 1fr);
}

.drawer-quick::before {
  content: 'Quick Links';
  font: 600 .72rem/1 var(--ebx-font-text, 'Plus Jakarta Sans', system-ui);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #8a95a5;
  margin-bottom: 6px;
  display: block;
  grid-column: 1/-1;
}

.drawer-quick a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  padding: .6rem 1rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--white-14);
  background: linear-gradient(180deg, var(--white-06), rgba(0, 0, 0, .16));
  backdrop-filter: blur(var(--blur-sm));
  font: 700 .88rem/1 var(--ebx-font-accent, 'Space Grotesk', system-ui);
  letter-spacing: .05em;
  text-transform: uppercase;
  color: #dee5ee;
  box-shadow: inset 0 1px 0 var(--white-15), 0 8px 18px rgba(8, 10, 14, .25);
  transition: transform .16s ease, box-shadow .18s ease, color .18s ease, background .18s ease, border-color .18s ease;
  min-height: 44px;
}

.drawer-quick a i {
  font-size: .92rem;
  opacity: .9;
}

.drawer-quick a:hover {
  color: #fffaf5;
  border-color: var(--lava-45);
  background: linear-gradient(95deg, rgba(255, 233, 196, .15), var(--lava-18));
  backdrop-filter: blur(var(--blur-lg));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .2), 0 0 0 1px rgba(250, 104, 31, .2), 0 12px 28px var(--lava-18);
  transform: translateY(-2px);
}

.drawer-quick a:focus-visible {
  outline: 2px solid rgba(250, 104, 31, .65);
  outline-offset: 4px;
}

.drawer-quick a[data-quick="booking"] {
  grid-column: 1/-1;
  justify-content: center;
  background: linear-gradient(115deg, rgba(250, 104, 31, .30), var(--lava-18));
  border-color: var(--lava-45);
  color: #fff5eb;
  font-size: .92rem;
  font-weight: 800;
  box-shadow: inset 0 1px 0 var(--white-25), inset 0 0 0 1px var(--gold-12), 0 12px 28px var(--lava-28);
}

.drawer-quick a[data-quick="booking"] i {
  font-size: 1rem;
  opacity: 1;
}

.drawer-quick a[data-quick="booking"]:hover {
  color: #fffbf7;
  border-color: rgba(250, 104, 31, .65);
  background: linear-gradient(115deg, var(--lava-40), var(--lava-25));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .3), inset 0 0 0 1px var(--gold-18), 0 0 0 1px var(--lava-35), 0 16px 36px var(--lava-38);
}

.drawer-quick a[data-quick="spotify"] {
  background: linear-gradient(135deg, rgba(30, 215, 96, .22), rgba(30, 215, 96, .12));
  border-color: rgba(30, 215, 96, .35);
  color: #e8f5ee;
  box-shadow: inset 0 1px 0 var(--white-18), inset 0 0 0 1px rgba(30, 215, 96, .08), 0 10px 24px rgba(30, 215, 96, .15);
}

.drawer-quick a[data-quick="spotify"]:hover {
  background: linear-gradient(135deg, rgba(30, 215, 96, .30), rgba(30, 215, 96, .18));
  border-color: rgba(30, 215, 96, .50);
  color: #f5fffa;
  box-shadow: inset 0 1px 0 var(--white-25), inset 0 0 0 1px rgba(30, 215, 96, .15), 0 0 0 1px rgba(30, 215, 96, .25), 0 14px 32px rgba(30, 215, 96, .25);
}

/* Drawer Main Menu */
.drawer-main {
  display: grid;
  gap: clamp(16px, 4vw, 20px);
}

.dm-item {
  padding: clamp(14px, 4vw, 18px);
  border-radius: var(--radius-3xl);
  border: 1px solid var(--white-12);
  background: linear-gradient(180deg, var(--white-05), rgba(0, 0, 0, .16));
  box-shadow: inset 0 0 0 1px var(--white-03), 0 16px 36px rgba(8, 10, 14, .38);
  transition: border-color .2s ease, box-shadow .2s ease, transform .18s ease;
}

.dm-item:hover {
  border-color: rgba(255, 227, 146, .25);
  box-shadow: inset 0 0 0 1px var(--white-06), 0 18px 40px var(--lava-15);
  transform: translateX(3px);
}

.dm-item--open {
  border-color: var(--lava-55);
  border-left: 3px solid var(--lava);
  background: linear-gradient(180deg, var(--lava-08), rgba(0, 0, 0, .16));
  box-shadow: inset 0 0 0 1px var(--gold-08), 0 22px 48px var(--lava-28), 0 0 0 1px var(--lava-12);
  transform: translateX(3px);
}

.dm-item--open .dm-root__icon {
  background: linear-gradient(120deg, var(--lava), var(--gold));
  color: #1b1209;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .5), 0 16px 34px var(--lava-32);
}

.dm-item--open .dm-root__text {
  color: #ffe8c7;
}

.dm-item--open .dm-root__sub {
  color: #ffd9a4;
}

.dm-root {
  width: 100%;
  display: flex;
  align-items: center;
  gap: .75rem;
  justify-content: flex-start;
  background: none;
  border: 0;
  padding: 0;
  color: #eef3f8;
  font: 600 1rem/1.2 var(--ebx-font-primary, 'Cinzel', system-ui);
  letter-spacing: .05em;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .2s ease, border-color .2s ease, color .2s ease, background .2s ease;
}

.dm-root:focus-visible {
  outline: 2px solid rgba(250, 104, 31, .65) !important;
  outline-offset: 4px !important;
  background: transparent !important;
}

.dm-root:active {
  transform: translateY(1px);
  background: transparent !important;
}

/* Block external pink/magenta CSS from WordPress/Elementor */
.ebx-drawer .dm-item,
.ebx-drawer .dm-root,
.ebx-drawer .dm-link,
.ebx-drawer button {
  background-color: transparent !important;
}

.ebx-drawer .dm-item:hover,
.ebx-drawer .dm-root:hover,
.ebx-drawer .dm-link:hover,
.ebx-drawer button:hover {
  background-color: transparent !important;
  background: linear-gradient(180deg, var(--white-05), rgba(0, 0, 0, .08)) !important;
}

.ebx-drawer .dm-item:active,
.ebx-drawer .dm-root:active,
.ebx-drawer .dm-link:active,
.ebx-drawer button:active {
  background: rgba(250, 104, 31, .12) !important;
  outline: none !important;
}

.ebx-drawer .dm-item.dm-item--open {
  background: linear-gradient(180deg, var(--lava-08), rgba(0, 0, 0, .16)) !important;
}

/* Drawer close button - explicit hover/active colors */
.ebx-drawer-close:hover,
.ebx-drawer-close:focus,
.ebx-drawer-close:active {
  background: var(--black-55, rgba(0, 0, 0, .55)) !important;
  color: #ffe7c2 !important;
}

.dm-root__icon {
  flex: 0 0 42px;
  width: 42px;
  height: 42px;
  border-radius: var(--radius-lg-plus);
  background: linear-gradient(180deg, var(--white-14), rgba(0, 0, 0, .2));
  display: grid;
  place-items: center;
  color: #ffe7c2;
  font-size: 1.08rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .4), 0 12px 26px rgba(8, 10, 14, .35);
}

.dm-root__icon--letter {
  font-weight: 700;
}

.dm-root__label {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-align: left;
}

.dm-root__text {
  font-weight: 700;
  letter-spacing: .06em;
}

.dm-root__sub {
  font: 500 .78rem/1.2 var(--ebx-font-text, 'Plus Jakarta Sans', system-ui);
  text-transform: none;
  color: #c5cdd9;
  letter-spacing: .06em;
}

.dm-root__chevron {
  font-size: 1rem;
  color: #ffe0ba;
  transition: transform .2s ease;
}

.dm-root:hover .dm-root__icon {
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .45), 0 16px 32px var(--lava-24);
}

.dm-root:hover .dm-root__text,
.dm-root:hover .dm-root__sub {
  color: #ffe8c7;
}

.dm-root[aria-expanded="true"] .dm-root__chevron {
  transform: rotate(-180deg);
}

.dm-dd {
  display: none;
  margin: 0;
  padding: 0;
}

.dm-item--open .dm-dd {
  display: block;
  margin-top: .75rem;
}

.dm-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .65rem;
}

.dm-list li {
  margin: 0;
}

.dm-link {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .55rem .8rem;
  border-radius: var(--radius-xl);
  border: 1px solid var(--white-12);
  background: linear-gradient(180deg, var(--white-05), var(--black-18));
  color: #eef3f8;
  font: 500 .9rem/1.4 var(--ebx-font-text, 'Plus Jakarta Sans', system-ui);
  letter-spacing: .03em;
  text-transform: none;
  text-decoration: none;
  box-shadow: inset 0 1px 0 var(--white-14);
  transition: transform .16s ease, box-shadow .2s ease, border-color .2s ease, color .2s ease, background .2s ease;
}

.dm-link__icon {
  width: 34px;
  height: 34px;
  border-radius: var(--radius-lg);
  background: var(--white-08);
  display: grid;
  place-items: center;
  color: #ffe7c2;
  font-size: .95rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .3), 0 8px 18px rgba(8, 10, 14, .28);
}

.dm-link__icon--dot {
  font-weight: 700;
}

.dm-link__label {
  flex: 1;
  display: block;
}

.dm-link:hover {
  border-color: var(--lava-45);
  box-shadow: 0 0 0 1px var(--lava-22) inset, 0 12px 26px rgba(8, 10, 14, .38);
  color: #ffe7c2;
}

.dm-link:active {
  transform: translateY(1px);
}

.dm-link:focus-visible {
  outline: 2px solid rgba(250, 104, 31, .65);
  outline-offset: 4px;
}

.drawer-lang {
  margin-top: auto;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: .5rem;
}

/* Mobile Drawer Glow */
@media (max-width: 980px) {

  .ebx-drawer::before,
  .ebx-drawer::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    pointer-events: none;
    background: var(--ebx-glow-strip);
  }

  .ebx-drawer::before {
    top: -1px;
    height: 22px;
    filter: blur(var(--blur-sm));
  }

  .ebx-drawer::after {
    bottom: -1px;
    height: 24px;
    filter: blur(var(--blur-sm));
  }
}


/* ================================================================
   5. HERO SECTION BASE
   ================================================================ */

#ebx-hero-alt {
  position: relative;
  color: #f6f9fb;
  isolation: isolate;
  contain: layout style paint;
  margin: 0;
  padding: 0;
}

#ebx-hero-alt .ebx-hero-bg {
  position: absolute;
  inset: 0;
  z-index: var(--z-behind);
  background: radial-gradient(1200px 55% at 50% 12%, var(--lava-10), transparent 66%),
    linear-gradient(180deg, rgba(0, 0, 0, .42) 0%, var(--black-18) 34%, rgba(0, 0, 0, .55) 100%),
    url('https://www.edenbridge.org/wp-content/uploads/2025/08/Edenbridge__Bandpic_6034__3000px-1-scaled.jpg') center 35%/cover no-repeat;
}

#ebx-hero-alt .ebx-hero-bg::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -2px;
  height: 26px;
  pointer-events: none;
  background: radial-gradient(80% 70% at 50% 0%, var(--lava-22), var(--gold-10) 45%, rgba(0, 0, 0, 0) 80%);
  filter: blur(var(--blur-sm));
}

#ebx-hero-alt::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 32px;
  background: linear-gradient(180deg, transparent 0%, var(--lava-08) 30%, var(--lava-15) 60%, rgba(11, 13, 16, .95) 100%);
  border-top: 1px solid var(--lava-25);
  box-shadow: inset 0 1px 0 var(--white-08), inset 0 8px 20px var(--lava-12), 0 6px 16px rgba(0, 0, 0, .65);
  backdrop-filter: var(--backdrop-glass-light);
  z-index: var(--z-fixed);
  pointer-events: none;
}

#ebx-hero-alt .ebx-hero__shell {
  max-width: min(1200px, 100%);
  margin: 0 auto;
  padding: clamp(10px, 2vw, 22px);
  padding-bottom: 64px;
  position: relative;
}

#ebx-hero-alt .ebx-hero__grid {
  display: grid;
  grid-template-columns: clamp(220px, 30vw, 500px) 1fr;
  gap: clamp(18px, 3vw, 40px);
  align-items: end;
  min-height: 70vh;
  padding-top: clamp(34px, 7vh, 110px);
}

#ebx-hero-alt+* {
  margin-top: 0;
}

/* Cover Image */
#ebx-cover {
  align-self: end;
  transition: opacity .25s, transform .25s;
}

#ebx-cover img {
  display: block;
  width: clamp(240px, 22vw, 360px);
  height: auto;
  outline: 2px solid rgba(10, 12, 16, .96);
  outline-offset: -2px;
  box-shadow: inset 0 0 0 3px var(--white-08), 0 16px 48px rgba(0, 0, 0, .55);
}

#ebx-cover a:focus-visible {
  outline: 3px solid rgba(250, 104, 31, .6);
  outline-offset: 6px;
  border-radius: var(--radius-2xs);
}

#ebx-hero-alt .ebx-cover:hover,
.ebx-logo:hover {
  transform: none !important;
}

/* Hero Copy */
#ebx-hero-alt .ebx-copy {
  position: relative;
  z-index: 50;
  isolation: isolate;
  transition: opacity .25s, transform .25s;
}

#ebx-hero-alt .ebx-badge,
#ebx-hero-alt .ebx-ctas {
  position: relative;
  z-index: var(--z-content-high);
}

#ebx-hero-alt .ebx-ctas {
  margin-bottom: 14px;
}

/* Hero Info Hidden State */
#ebx-hero-alt[data-info="hidden"] .ebx-copy,
#ebx-hero-alt[data-info="hidden"] #ebx-cover {
  opacity: 0 !important;
  transform: translateY(22px) !important;
  pointer-events: none !important;
  transition: opacity .25s, transform .25s;
}

#ebx-hero-alt[data-info="hidden"] .hero-toggle i {
  transform: rotate(180deg);
  transition: transform .2s;
}

html[data-hero="hide"] .ebx-hero-toggle-wrap {
  display: none !important;
}

/* Hero Toggle Buttons */
.ebx-hero-toggle-wrap {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 1rem;
  display: flex;
  gap: .5rem;
  pointer-events: none;
  z-index: 200;
  width: auto;
  justify-content: center;
}

/* Hide the toggle wrap from hero shell */
#ebx-hero-alt>.ebx-hero-toggle-wrap {
  display: none;
}

/* Video Controls Container */
.ebx-video-controls {
  position: absolute;
  bottom: 1rem;
  right: 1rem;
  display: flex;
  gap: .5rem;
  z-index: 100;
  pointer-events: none;
}

.hero-toggle,
.ebx-mute-toggle {
  pointer-events: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, .65);
  border: 1px solid rgba(255, 255, 255, .3);
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  max-width: 44px !important;
  flex-shrink: 0;
  padding: 0 !important;
  border-radius: 50%;
  color: #fff;
  z-index: var(--z-hero-toggle);
  backdrop-filter: blur(10px);
  transition: background .25s ease, border-color .25s ease, transform .25s ease;
}

.hero-toggle:hover,
.ebx-mute-toggle:hover {
  background: var(--lava-55);
  border-color: var(--lava);
  transform: scale(1.08);
  box-shadow: 0 4px 16px var(--lava-35);
}

.hero-toggle:focus-visible,
.ebx-mute-toggle:focus-visible {
  outline: 2px solid rgba(250, 104, 31, .65);
  outline-offset: 4px;
}

#hero-info-toggle {
  /* Mobile Toggle Button */
  display: flex !important;
  pointer-events: auto;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, .65);
  border: 1px solid rgba(255, 255, 255, .3);
  width: 44px !important;
  height: 44px !important;
  border-radius: 50%;
  color: #fff;
  z-index: 100 !important;
  backdrop-filter: blur(10px);
}

/* Desktop Hero */
/* Desktop Hero - Breakpoint raised for tablets */
@media (min-width: 981px) {
  #ebx-hero-alt {
    transform: none !important;
  }

  #ebx-hero-alt .ebx-hero__shell {
    /* Padding Left = Sidebar Width exactly (Close Gap) */
    padding-left: clamp(160px, 20vw, 220px) !important;
    position: static !important;
  }

  .ebx-hero-inner {
    width: 100%;
    height: 100%;
    position: static;
  }
}

/* Mobile Hero */
/* Mobile Hero */
@media (max-width: 980px) {
  #ebx-hero-alt {
    margin-bottom: 32px;
  }

  #ebx-hero-alt .ebx-hero__grid {
    min-height: auto;
    padding-top: 10px;
  }

  #ebx-hero-alt .ebx-cover {
    margin: 10px auto 0;
    text-align: center;
    width: 100%;
    display: none;
  }

  #ebx-hero-alt .ebx-cover img {
    width: min(420px, 90vw);
    border-radius: var(--radius-lg);
    outline: 1px solid var(--white-08);
    box-shadow: 0 18px 36px rgba(0, 0, 0, .6), 0 0 22px var(--lava-28), inset 0 0 0 1px var(--white-05);
  }

  #ebx-hero-alt .ebx-copy {
    width: min(92vw, 520px);
    margin: 10px auto 0;
    padding: 14px;
    border-radius: var(--radius-xl);
    background: linear-gradient(180deg, rgba(15, 18, 24, .84), rgba(10, 12, 18, .9));
    border: 1px solid var(--gold-18);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .42), inset 0 0 0 1px var(--white-03);
    text-align: center;
  }

  #ebx-hero-alt .ebx-hero-bg {
    position: absolute !important;
    inset: 0 !important;
    height: 100% !important;
  }

  .ebx-hero-toggle-wrap {
    bottom: 8px;
    left: 50%;
    transform: translateX(-50%);
    justify-content: center;
    width: auto;
  }

  /* Raise controls to avoid bottom clipping */
  .ebx-video-controls {
    bottom: 4rem !important;
    z-index: 200 !important;
  }
}

/* Base Styles for Tabs */
.ebx-hero-tabs {
  display: flex;
  gap: .5rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: clamp(16px, 2vw, 24px);
  padding: 0 clamp(12px, 2vw, 24px);
  /* Ensure Tabs are above video */
  position: relative;
  z-index: 10;
}

.ebx-hero-tab {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .6rem 1.2rem;
  border: 1px solid var(--white-18);
  border-radius: var(--radius-pill);
  background: linear-gradient(180deg, var(--white-08), var(--black-18));
  backdrop-filter: blur(var(--blur-md));
  color: var(--ink-2);
  font: 700 .85rem/1 var(--font-sans);
  letter-spacing: .04em;
  cursor: pointer;
  transition: all .25s ease;
}

.ebx-hero-tab i {
  font-size: .9rem;
  opacity: .7;
  transition: opacity .2s ease;
}

.ebx-hero-tab:hover {
  border-color: var(--gold-45);
  color: var(--ink);
  background: linear-gradient(180deg, var(--white-12), var(--black-12));
}

.ebx-hero-tab:hover i {
  opacity: 1;
}

.ebx-hero-tab.is-active {
  border-color: var(--lava-55);
  background: linear-gradient(115deg, var(--lava-28), var(--lava-15));
  color: #fff;
  box-shadow: inset 0 1px 0 var(--white-25), 0 6px 18px var(--lava-28);
}

.ebx-hero-tab.is-active i {
  opacity: 1;
  color: var(--gold);
}

.ebx-hero-tab:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}

.ebx-hero-tab:active {
  transform: scale(.96);
  opacity: .85;
}

/* Desktop: Cover Thumbnail Column */
@media (min-width: 1025px) {
  .ebx-hero-tabs {
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    transform: none !important;
    z-index: 100 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: .5rem !important;
    width: clamp(220px, 22vw, 260px) !important;
    /* Responsive width with safe min for wrapping */
    padding: .5rem !important;
    margin: 0 !important;
    border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
    overflow: visible;
    background: linear-gradient(180deg, rgba(12, 16, 22, .9), rgba(8, 10, 14, .95));
    border: 1px solid var(--white-12);
    border-left: none;
    box-shadow: 4px 0 24px rgba(0, 0, 0, .5);
  }

  .ebx-hero-tab {
    width: 100% !important;
    min-width: unset !important;
    height: auto !important;
    min-height: 0 !important;
    flex: 1 1 0% !important;
    /* Reverted to 0% to ensure equal height distribution and prevent wrapping issues */
    padding: 0 !important;
    margin: 0 !important;
    border-radius: var(--radius-sm) !important;
    display: block !important;
    overflow: visible !important;
    transition: border-color .3s ease, box-shadow .3s ease, transform .25s ease, background .3s ease !important;
    /* DARK LAVA BASE */
    background: linear-gradient(165deg,
        rgba(30, 18, 12, .95) 0%,
        rgba(18, 12, 8, .97) 50%,
        rgba(10, 6, 4, .98) 100%) !important;
    border: 2px solid rgba(120, 60, 30, .35) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 120, 60, .06),
      inset 0 -2px 8px rgba(0, 0, 0, .6),
      0 4px 16px rgba(0, 0, 0, .7) !important;
  }

  /* Subtle ember glow at bottom */
  .ebx-hero-tab::before {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 10% !important;
    right: 10% !important;
    height: 50% !important;
    z-index: 0 !important;
    pointer-events: none !important;
    background: radial-gradient(ellipse 100% 100% at 50% 100%,
        rgba(250, 120, 50, .12),
        transparent 70%) !important;
    opacity: .6 !important;
    transition: opacity .3s ease !important;
  }

  /* Film grain texture overlay */
  .ebx-hero-tab::after {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 4 !important;
    pointer-events: none !important;
    opacity: .25 !important;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E") !important;
    background-size: 150px 150px !important;
    mix-blend-mode: soft-light !important;
  }

  /* Dark corners vignette */
  .ebx-hero-tab .ebx-tab-info::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background:
      radial-gradient(ellipse 120% 120% at 0% 0%, rgba(0, 0, 0, .3), transparent 40%),
      radial-gradient(ellipse 120% 120% at 100% 100%, rgba(0, 0, 0, .25), transparent 40%);
    opacity: .6;
  }

  /* ============================================
     CD COVER THUMBNAILS ON LEFT
     ============================================ */

  /* Tab becomes flex container */
  .ebx-hero-tab {
    display: flex !important;
    flex-direction: row !important;
    align-items: stretch !important;
  }

  /* Cover image - square, left side - PLASTIC 3D LOOK */
  .ebx-hero-tab img {
    display: block !important;
    width: auto !important;
    height: 100% !important;
    aspect-ratio: 1 / 1 !important;
    object-fit: cover !important;
    object-position: center !important;
    flex-shrink: 0 !important;
    /* Plastic CD case look - layered shadows */
    border-right: 3px solid rgba(20, 12, 8, .9) !important;
    border-top: 1px solid rgba(255, 220, 180, .15) !important;
    border-bottom: 1px solid rgba(0, 0, 0, .6) !important;
    box-shadow:
      /* Inner highlight - top edge shine */
      inset 0 1px 0 rgba(255, 240, 200, .25),
      /* Inner shadow - bottom depth */
      inset 0 -2px 4px rgba(0, 0, 0, .3),
      /* Outer right shadow - case thickness */
      3px 0 0 rgba(40, 25, 15, .9),
      4px 0 0 rgba(20, 12, 8, .8),
      /* Ambient shadow */
      5px 3px 12px rgba(0, 0, 0, .5),
      /* Glow on right edge */
      inset -2px 0 6px rgba(255, 180, 100, .08) !important;
    filter: saturate(1.15) contrast(1.08) !important;
    /* GPU acceleration for smooth animation */
    transform: translateZ(0) !important;
    -webkit-backface-visibility: hidden !important;
    backface-visibility: hidden !important;
    will-change: transform, filter, box-shadow !important;
    transition: transform .35s cubic-bezier(.4, 0, .2, 1),
      filter .35s cubic-bezier(.4, 0, .2, 1),
      box-shadow .35s cubic-bezier(.4, 0, .2, 1) !important;
    transform-origin: left center !important;
    image-rendering: -webkit-optimize-contrast !important;
    image-rendering: crisp-edges !important;
  }

  /* Hover - smooth lift animation + enhanced glow */
  .ebx-hero-tab:hover img {
    transform: translateZ(0) scale(1.02) translateX(1px) !important;
    filter: saturate(1.2) contrast(1.1) brightness(1.06) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 240, 200, .35),
      inset 0 -2px 4px rgba(0, 0, 0, .25),
      3px 0 0 rgba(50, 32, 20, .95),
      4px 0 0 rgba(30, 18, 10, .85),
      8px 5px 20px rgba(0, 0, 0, .55),
      inset -2px 0 8px rgba(255, 200, 120, .15),
      0 0 20px rgba(250, 150, 80, .15) !important;
  }

  /* Direct cover hover - enhanced glow effect */
  .ebx-hero-tab img:hover {
    filter: saturate(1.3) contrast(1.15) brightness(1.1) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 240, 200, .4),
      inset 0 -2px 4px rgba(0, 0, 0, .2),
      3px 0 0 rgba(60, 40, 25, 1),
      4px 0 0 rgba(40, 28, 15, .9),
      6px 4px 20px rgba(0, 0, 0, .6),
      inset -2px 0 10px rgba(255, 200, 120, .2),
      0 0 30px rgba(250, 150, 80, .35) !important;
    cursor: pointer !important;
  }

  /* Active state - subtle constant glow */
  .ebx-hero-tab.is-active img {
    filter: saturate(1.2) contrast(1.1) brightness(1.05) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 240, 200, .3),
      inset 0 -2px 4px rgba(0, 0, 0, .25),
      3px 0 0 rgba(60, 40, 25, .95),
      4px 0 0 rgba(35, 22, 12, .85),
      6px 4px 16px rgba(0, 0, 0, .5),
      inset -2px 0 8px rgba(255, 180, 100, .12),
      0 0 25px rgba(250, 120, 50, .2) !important;
  }

  /* Active + direct hover - enhanced glow */
  .ebx-hero-tab.is-active img:hover {
    filter: saturate(1.35) contrast(1.18) brightness(1.12) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 240, 200, .45),
      inset 0 -2px 4px rgba(0, 0, 0, .2),
      3px 0 0 rgba(70, 45, 28, 1),
      4px 0 0 rgba(45, 30, 18, .95),
      8px 5px 24px rgba(0, 0, 0, .6),
      inset -2px 0 12px rgba(255, 200, 120, .25),
      0 0 40px rgba(250, 130, 60, .4) !important;
    cursor: pointer !important;
  }

  /* Tour tab: hide image, use icon instead */
  .ebx-hero-tab[data-tab="tour"] img {
    display: none !important;
  }

  /* Tour icon placeholder with FA icon */
  .ebx-hero-tab[data-tab="tour"]::before {
    content: '\f3b5' !important;
    /* fa-microphone-alt */
    font-family: 'Font Awesome 6 Free' !important;
    font-weight: 900 !important;
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    width: auto !important;
    height: 100% !important;
    aspect-ratio: 1 / 1 !important;
    flex-shrink: 0 !important;
    background: linear-gradient(145deg,
        rgba(80, 50, 30, .9) 0%,
        rgba(50, 30, 18, .95) 100%) !important;
    border-right: 2px solid rgba(0, 0, 0, .5) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 2 !important;
    opacity: 1 !important;
    border-radius: 0 !important;
    font-size: clamp(1.5rem, 4vw, 2.2rem) !important;
    color: rgba(250, 180, 100, .7) !important;
    text-shadow: 0 2px 8px rgba(0, 0, 0, .5) !important;
  }

  /* Adjust tab-info to account for cover */
  .ebx-tab-info {
    position: relative !important;
    flex: 1 !important;
    inset: auto !important;
  }

  /* Hover state - warmer glow */
  .ebx-hero-tab:hover {
    background: linear-gradient(165deg,
        rgba(80, 45, 25, .9) 0%,
        rgba(50, 30, 18, .92) 50%,
        rgba(28, 16, 10, .95) 100%) !important;
    border-color: rgba(250, 150, 80, .5) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 200, 120, .15),
      0 0 20px rgba(250, 120, 50, .2),
      0 6px 20px rgba(0, 0, 0, .5) !important;
    transform: translateX(4px);
  }

  .ebx-hero-tab:hover::before {
    opacity: 1 !important;
  }

  /* Active state - FIRE GLOW */
  .ebx-hero-tab.is-active {
    background: linear-gradient(165deg,
        rgba(120, 60, 30, .9) 0%,
        rgba(70, 40, 22, .92) 50%,
        rgba(35, 20, 12, .95) 100%) !important;
    border-color: rgba(250, 130, 50, .7) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 220, 150, .2),
      inset 0 0 20px rgba(250, 100, 30, .15),
      0 0 30px rgba(250, 100, 30, .35),
      0 0 60px rgba(250, 80, 20, .15),
      0 8px 24px rgba(0, 0, 0, .5) !important;
  }

  .ebx-hero-tab.is-active::before {
    opacity: 1 !important;
    background: radial-gradient(ellipse 120% 120% at 50% 100%,
        rgba(250, 100, 30, .25),
        transparent 60%) !important;
  }

  /* ============================================
     CONTENT-THEMED TAB STYLING
     ============================================ */

  /* Video Tabs (1-3): Fire/Lava Theme */
  .ebx-hero-tab[data-tab^="video"] {
    background: linear-gradient(160deg,
        rgba(250, 104, 31, .2) 0%,
        rgba(120, 60, 30, .35) 40%,
        rgba(40, 25, 15, .7) 100%) !important;
  }

  .ebx-hero-tab[data-tab^="video"]::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 0;
    background: radial-gradient(ellipse 120% 80% at 50% 100%, var(--lava-15), transparent 60%);
    opacity: 0;
    transition: opacity .3s ease;
    pointer-events: none;
  }

  .ebx-hero-tab[data-tab^="video"]:hover::after,
  .ebx-hero-tab[data-tab^="video"].is-active::after {
    opacity: 1;
  }

  .ebx-hero-tab[data-tab^="video"]:hover {
    border-color: var(--lava-55) !important;
    box-shadow: 0 0 20px var(--lava-35), 0 4px 16px rgba(250, 104, 31, .25) !important;
  }

  .ebx-hero-tab[data-tab^="video"].is-active {
    background: linear-gradient(160deg,
        rgba(250, 104, 31, .35) 0%,
        rgba(140, 70, 35, .5) 40%,
        rgba(50, 30, 18, .8) 100%) !important;
    border-color: var(--lava) !important;
    box-shadow: 0 0 28px var(--lava-55), inset 0 0 0 1px var(--lava-35), 0 8px 24px rgba(250, 104, 31, .4) !important;
  }

  /* Album Tab: Gold Disc Theme */
  .ebx-hero-tab[data-tab="album"] {
    background: linear-gradient(160deg,
        rgba(212, 160, 60, .25) 0%,
        rgba(120, 100, 50, .4) 40%,
        rgba(45, 35, 20, .7) 100%) !important;
  }

  .ebx-hero-tab[data-tab="album"]::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
      radial-gradient(ellipse 100% 60% at 50% 0%, rgba(255, 227, 146, .12), transparent 50%),
      radial-gradient(ellipse 120% 80% at 50% 100%, rgba(212, 160, 60, .18), transparent 60%);
    opacity: 0;
    transition: opacity .3s ease;
    pointer-events: none;
  }

  .ebx-hero-tab[data-tab="album"]:hover::after,
  .ebx-hero-tab[data-tab="album"].is-active::after {
    opacity: 1;
  }

  .ebx-hero-tab[data-tab="album"]:hover {
    border-color: rgba(212, 160, 60, .65) !important;
    box-shadow: 0 0 20px rgba(212, 160, 60, .35), 0 4px 16px rgba(255, 227, 146, .2) !important;
  }

  .ebx-hero-tab[data-tab="album"].is-active {
    background: linear-gradient(160deg,
        rgba(212, 160, 60, .4) 0%,
        rgba(140, 110, 50, .55) 40%,
        rgba(55, 45, 25, .8) 100%) !important;
    border-color: var(--gold) !important;
    box-shadow: 0 0 32px rgba(212, 160, 60, .6), inset 0 0 0 1px rgba(255, 227, 146, .35), 0 8px 28px rgba(212, 160, 60, .45) !important;
  }

  .ebx-hero-tab[data-tab="album"]:hover .ebx-tab-label,
  .ebx-hero-tab[data-tab="album"].is-active .ebx-tab-label {
    color: rgba(255, 227, 146, 1) !important;
    text-shadow: 0 0 12px rgba(212, 160, 60, .5);
  }

  /* Tour Tab: Stage/Purple Theme */
  .ebx-hero-tab[data-tab="tour"] {
    background: linear-gradient(160deg,
        rgba(138, 92, 168, .25) 0%,
        rgba(90, 60, 120, .4) 40%,
        rgba(35, 25, 50, .7) 100%) !important;
  }

  .ebx-hero-tab[data-tab="tour"]::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
      radial-gradient(ellipse 80% 50% at 50% 0%, rgba(168, 132, 200, .15), transparent 50%),
      radial-gradient(ellipse 120% 80% at 50% 100%, rgba(138, 92, 168, .2), transparent 60%);
    opacity: 0;
    transition: opacity .3s ease;
    pointer-events: none;
  }

  .ebx-hero-tab[data-tab="tour"]:hover::after,
  .ebx-hero-tab[data-tab="tour"].is-active::after {
    opacity: 1;
  }

  .ebx-hero-tab[data-tab="tour"]:hover {
    border-color: rgba(168, 132, 200, .65) !important;
    box-shadow: 0 0 20px rgba(138, 92, 168, .35), 0 44px 16px rgba(168, 132, 200, .2) !important;
  }

  .ebx-hero-tab[data-tab="tour"].is-active {
    background: linear-gradient(160deg,
        rgba(138, 92, 168, .4) 0%,
        rgba(100, 70, 140, .55) 40%,
        rgba(45, 32, 65, .8) 100%) !important;
    border-color: rgba(180, 150, 210, .9) !important;
    box-shadow: 0 0 32px rgba(138, 92, 168, .65), inset 0 0 0 1px rgba(180, 150, 210, .4), 0 8px 28px rgba(138, 92, 168, .45) !important;
  }

  .ebx-hero-tab[data-tab="tour"]:hover .ebx-tab-label,
  .ebx-hero-tab[data-tab="tour"].is-active .ebx-tab-label {
    color: rgba(200, 175, 225, 1) !important;
    text-shadow: 0 0 12px rgba(138, 92, 168, .5);
  }

  .ebx-hero-tab[data-tab="tour"]:hover .ebx-tab-desc,
  .ebx-hero-tab[data-tab="tour"].is-active .ebx-tab-desc {
    color: rgba(220, 200, 240, .85) !important;
  }

  /* Tab Info - right side of cover */
  .ebx-tab-info {
    position: relative !important;
    inset: auto !important;
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: flex-start !important;
    gap: clamp(2px, .5vw, 6px) !important;
    padding: clamp(.5rem, 1.2vw, 1rem) !important;
    padding-left: clamp(.8rem, 1.5vw, 1.2rem) !important;
    background: transparent !important;
    text-align: left !important;
    z-index: 2 !important;
  }

  /* Icons removed - too comic-like for gothic metal */

  /* Glass shine effect on tabs */
  .ebx-hero-tab::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 45%;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(180deg,
        rgba(255, 255, 255, .12) 0%,
        rgba(255, 255, 255, .04) 40%,
        transparent 100%);
    border-radius: inherit;
    opacity: .6;
    transition: opacity .3s ease;
  }

  .ebx-hero-tab:hover::before {
    opacity: 1;
  }

  /* White Title Label Style */
  .ebx-tab-label {
    display: block !important;
    font-family: 'Cinzel Decorative', 'Cinzel', serif !important;
    font-size: clamp(.75rem, 2.4vw, .95rem) !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    /* Pure white */
    letter-spacing: .05em !important;
    text-transform: uppercase !important;
    line-height: 1.15 !important;
    /* Embossed text effect */
    text-shadow:
      0 1px 0 rgba(255, 255, 255, .15),
      0 -1px 0 rgba(0, 0, 0, .9),
      0 2px 6px rgba(0, 0, 0, .7),
      0 0 12px rgba(250, 120, 50, .2) !important;
    transition: all .3s ease;
  }

  /* Slogan/Description - muted amber color */
  .ebx-tab-desc {
    display: block !important;
    font-family: var(--ebx-font-text, 'Plus Jakarta Sans', system-ui) !important;
    font-size: clamp(.65rem, 2vw, .8rem) !important;
    font-weight: 500 !important;
    font-style: italic !important;
    color: rgba(200, 160, 120, .9) !important;
    /* Muted amber/rust */
    letter-spacing: .03em !important;
    line-height: 1.3 !important;
    text-shadow: 0 1px 4px rgba(0, 0, 0, .5) !important;
  }

  /* Hover/Active: Glowing gold text */
  .ebx-hero-tab:hover .ebx-tab-label,
  .ebx-hero-tab.is-active .ebx-tab-label {
    color: #ffd9a0 !important;
    /* Bright gold */
    text-shadow:
      0 1px 0 rgba(255, 240, 200, .5),
      0 -1px 0 rgba(60, 30, 15, .8),
      0 2px 8px rgba(0, 0, 0, .5),
      0 0 20px rgba(255, 180, 80, .5),
      0 0 40px rgba(250, 130, 50, .3) !important;
  }

  .ebx-hero-tab:hover .ebx-tab-desc,
  .ebx-hero-tab.is-active .ebx-tab-desc {
    color: rgba(255, 235, 210, .95) !important;
    text-shadow: 0 2px 6px rgba(0, 0, 0, .5), 0 0 15px rgba(250, 180, 100, .25) !important;
  }

  .ebx-hero-tab:hover {
    border-color: var(--gold-55) !important;
    box-shadow: 0 0 20px var(--lava-35), inset 0 1px 0 rgba(255, 255, 255, .15) !important;
    transform: scale(1.03);
  }

  .ebx-hero-tab.is-active {
    border-color: var(--lava) !important;
    box-shadow: 0 0 24px var(--lava-55), inset 0 0 0 1px var(--lava-35), inset 0 1px 0 rgba(255, 255, 255, .2) !important;
  }
}

/* Desktop: With Text Labels */
@media (min-width: 1200px) {
  .ebx-hero-tabs {
    width: clamp(280px, 25vw, 420px) !important;
    gap: .75rem !important;
    padding: .75rem !important;
  }

  .ebx-hero-tab {
    position: relative;
    aspect-ratio: auto !important;
    flex: 1 1 0% !important;
    min-height: 0;
  }

  .ebx-hero-tab img {
    width: 100%;
    height: 100%;
    aspect-ratio: 16/9;
    object-fit: cover;
    object-position: center center;
  }

  .ebx-tab-label {
    display: block;
    padding: 0;
    font-size: clamp(.65rem, 1.2vw, .8rem);
    font-weight: 700;
    text-align: left;
    color: var(--ink, #f3f6fc);
    color: var(--ink, #f3f6fc);
    letter-spacing: .02em;
    line-height: 1.2;
    white-space: normal;
    /* Force wrap */
    word-wrap: break-word;
    /* Break long words if necessary */
    overflow-wrap: break-word;
  }

  .ebx-tab-info {
    display: flex;
    flex-direction: column;
    gap: clamp(2px, .3vw, 4px);
    padding: clamp(.35rem, .8vw, .5rem) clamp(.25rem, .5vw, .5rem);
    background: linear-gradient(to top, rgba(0, 0, 0, .92), rgba(0, 0, 0, .65));
    text-align: left;
    align-items: flex-start;
  }

  .ebx-tab-desc {
    display: block;
    font-size: clamp(.55rem, 1vw, .7rem);
    font-weight: 500;
    color: var(--ink-2, rgba(255, 255, 255, .55));
    letter-spacing: .01em;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .ebx-hero-tab:hover .ebx-tab-label,
  .ebx-hero-tab.is-active .ebx-tab-label {
    color: var(--gold);
  }

  .ebx-hero-tab:hover .ebx-tab-desc,
  .ebx-hero-tab.is-active .ebx-tab-desc {
    color: var(--ink, rgba(255, 255, 255, .75));
  }

  #ebx-hero-alt .ebx-hero__shell {
    padding-left: clamp(300px, 27vw, 460px) !important;
    max-width: 1800px;
  }
}

/* Ultra-wide */
@media (min-width: 1800px) {
  .ebx-hero-tabs {
    width: 440px !important;
  }

  .ebx-tab-label {
    font-size: .85rem;
    padding: .6rem .5rem;
  }

  #ebx-hero-alt .ebx-hero__shell {
    padding-left: 480px !important;
  }
}

/* Mobile: Circular Thumbnails - Force 5 in a row */
@media (max-width: 680px) {
  .ebx-hero-tabs {
    gap: clamp(4px, 2vw, 12px);
    overflow: visible;
    /* No scrolling */
    flex-wrap: nowrap;
    justify-content: center;
    /* Center the 5 tabs */
    padding: .5rem 0;
    margin-bottom: 1rem;
    width: 100%;
  }

  .ebx-hero-tabs::-webkit-scrollbar {
    display: none;
  }

  .ebx-hero-tab {
    padding: 0;
    /* responsive size to fit 5 items: approx 15-18% each max */
    width: clamp(42px, 16vw, 64px) !important;
    height: clamp(42px, 16vw, 64px) !important;
    min-width: 0 !important;
    /* Allow shrinking */
    min-height: 0 !important;
    border-radius: 50% !important;
    flex: 0 0 auto;
    /* Don't grow, don't shrink weirdly, stick to width */
    overflow: hidden;
    border: 2px solid transparent;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
  }

  .ebx-hero-tab img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    filter: brightness(0.7);
  }

  .ebx-hero-tab.is-active {
    border-color: var(--lava);
    box-shadow: 0 0 12px var(--lava-55);
    transform: scale(1.1);
    z-index: 2;
  }

  .ebx-hero-tab.is-active img {
    filter: brightness(1);
  }

  .ebx-hero-tab span,
  .ebx-hero-tab i {
    display: none;
  }
}

/* Touch Active States */
@media (hover: none) and (pointer: coarse) {
  .ebx-hero-tab:active {
    background: linear-gradient(115deg, var(--lava-35), var(--lava-18));
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .ebx-hero-tab {
    transition: none;
  }

  .ebx-hero-panel.is-active {
    animation: none;
    opacity: 1;
  }
}


/* ================================================================
   7. HERO PANELS
   ================================================================ */

.ebx-hero-panel {
  display: none !important;
  opacity: 0;
}

/* Album Panel Desktop - Center content properly */
@media (min-width: 1025px) {
  #panel-album {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 2rem 3rem !important;
  }

  #panel-album.is-active:not([hidden]) {
    display: flex !important;
  }

  #panel-album .ebx-copy {
    text-align: center !important;
    max-width: 600px !important;
    padding: 2rem !important;
    margin: 0 auto !important;
  }

  #panel-album .ebx-title {
    text-align: center !important;
  }

  #panel-album .ebx-badge {
    justify-content: center !important;
  }

  #panel-album .ebx-ctas {
    justify-content: center !important;
  }

  /* Tour Panel Desktop - Add left padding */
  #panel-tour {
    padding-left: clamp(2rem, 4vw, 4rem) !important;
    padding-right: 2rem !important;
  }

  #panel-tour .ebx-tour-content {
    max-width: 400px;
  }
}

.ebx-hero-panel.is-active {
  display: grid !important;
  opacity: 1;
  animation: heroFadeIn .4s ease forwards;
}

.ebx-hero-panel[hidden] {
  display: none !important;
}

#ebx-hero-alt .ebx-hero-panel:not(.is-active) {
  display: none !important;
}

@keyframes heroFadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Ensuring hidden panels are truly hidden */
#ebx-hero-alt .ebx-hero-panel[hidden],
#ebx-hero-alt.video-mode .ebx-hero-panel[hidden],
#ebx-hero-alt.video-mode .ebx-hero__grid.ebx-hero-panel[hidden] {
  display: none !important;
}

/* Video Panel Layout */
.ebx-hero-panel--video {
  /* Override Grid for Full Background Mode */
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;

  position: static !important;
  padding: 0 !important;
  margin: 0 !important;
  min-height: 70vh;
}

.ebx-hero-panel--video::before {
  /* Hide the blurred background pseudo since we have real video now */
  display: none !important;
}

.ebx-hero-panel--video .ebx-video-wrap {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-height: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  z-index: 0 !important;
  transform: none !important;
  left: 0 !important;
  top: 0 !important;
}

.ebx-hero-panel--video .ebx-copy {
  position: relative;
  z-index: 20;
  margin-top: auto;
  padding-bottom: 2rem;
  padding-left: 4rem;
  /* Breathing room from sidebar */
  padding-right: 4rem;
  pointer-events: none;
  /* Ensure text aligns to bottom since panel is block */
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
}

/* Mobile Panels */
@media (max-width: 1024px) {
  .ebx-hero-panel {
    display: none !important;
  }

  .ebx-hero-panel.is-active:not([hidden]) {
    display: flex !important;
    flex-direction: column;
    justify-content: flex-start;
    min-height: 70vh;
    padding-top: 80px;
    padding-bottom: 100px;
  }

  .ebx-hero-panel[hidden] {
    display: none !important;
  }

  #ebx-hero-alt:not(.video-mode) .ebx-hero__grid {
    padding-top: 60px !important;
    padding-bottom: 100px !important;
    min-height: 65vh !important;
    height: auto !important;
    gap: 1rem !important;
  }

  #panel-album.is-active:not([hidden]) {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
  }

  #ebx-hero-alt .ebx-copy {
    width: 100%;
    text-align: center;
    padding: 0 1.5rem;
  }

  #ebx-hero-alt.video-mode .ebx-copy {
    padding: 0 1rem !important;
    width: min(94vw, 520px) !important;
    overflow: visible;
  }
}


/* ================================================================
   8. VIDEO COMPONENTS
   ================================================================ */

.ebx-video-wrap {
  position: relative;
  aspect-ratio: 16 / 9;
  max-width: clamp(320px, 85vw, 1000px);
  width: 100%;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: #0a0c10;
  box-shadow: 0 16px 48px rgba(0, 0, 0, .55);
  cursor: pointer;
  margin: 0 auto;
}

.ebx-video-wrap .ebx-video-overlay {
  transition: opacity .4s ease;
}

.ebx-hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-lg);
}

.ebx-video-overlay {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: rgba(0, 0, 0, .35);
  transition: opacity .3s ease;
}

.ebx-video-wrap.is-playing .ebx-video-overlay {
  opacity: 0;
  pointer-events: none;
}

.ebx-video-wrap.is-paused .ebx-video-overlay {
  opacity: 1;
  pointer-events: auto;
}

.ebx-video-cover {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity .4s ease;
}

.ebx-video-wrap.is-playing .ebx-video-cover {
  opacity: 0;
}

.ebx-video-play {
  position: relative;
  z-index: 2;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 2px solid var(--white-35);
  background: linear-gradient(135deg, var(--lava), var(--gold));
  color: #fff;
  font-size: 1.6rem;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease;
  box-shadow: 0 8px 32px rgba(250, 104, 31, .45);
}

.ebx-video-play:hover {
  transform: scale(1.08);
  box-shadow: 0 12px 40px rgba(250, 104, 31, .55);
}

/* Video Controls Container - holds pause and mute buttons */
.ebx-video-controls {
  position: absolute;
  bottom: 1rem;
  right: 1rem;
  display: flex;
  gap: .5rem;
  z-index: 20;
  pointer-events: none;
  opacity: 1;
  transition: opacity .25s ease;
}

.ebx-video-controls>button {
  pointer-events: auto;
}

/* Mute Toggle - now inside video-controls */
.ebx-video-controls .ebx-mute-toggle,
.ebx-video-controls .ebx-pause-toggle {
  position: relative;
  bottom: auto;
  right: auto;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .35);
  background: rgba(0, 0, 0, .7);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  backdrop-filter: blur(12px);
  transition: all .25s ease;
  opacity: 1;
  pointer-events: auto;
}

.ebx-video-controls .ebx-mute-toggle .ebx-mute-icon,
.ebx-video-controls .ebx-pause-toggle i {
  font-size: 1rem;
  line-height: 1;
}

.ebx-video-controls .ebx-mute-toggle:hover,
.ebx-video-controls .ebx-pause-toggle:hover {
  background: var(--lava-55);
  border-color: var(--lava);
  transform: scale(1.08);
  box-shadow: 0 4px 16px var(--lava-35);
}

.ebx-video-controls .ebx-mute-toggle:focus-visible,
.ebx-video-controls .ebx-pause-toggle:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}

/* Video Error */
.ebx-hero-video.has-error+.ebx-video-overlay {
  opacity: 1 !important;
  pointer-events: auto;
}

.ebx-hero-video.has-error~.ebx-video-cover {
  opacity: 1 !important;
}

.ebx-video-error-msg {
  position: absolute;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
  padding: .5rem 1rem;
  background: rgba(0, 0, 0, .8);
  border-radius: var(--radius-sm);
  color: var(--ink-2);
  font-size: .75rem;
  z-index: 5;
}

/* Hidden floating covers (tabs show covers instead) */
.ebx-video-cover-float {
  display: none !important;
}


/* ================================================================
   9. VIDEO MODE
   ================================================================ */

#ebx-hero-alt.video-mode {
  position: relative !important;
  overflow: hidden !important;
  isolation: isolate !important;
}

#ebx-hero-alt.video-mode .ebx-hero-bg {
  opacity: 0 !important;
  visibility: hidden;
  pointer-events: none;
}

#ebx-hero-alt.video-mode .ebx-hero-panel[aria-hidden="false"] {
  position: static !important;
}

/* Video Background - Full Width */
#ebx-hero-alt.video-mode .ebx-video-wrap {
  position: absolute !important;
  inset: 12px !important;
  width: auto !important;
  height: auto !important;
  border-radius: var(--radius-2xl) !important;
  border: 1px solid var(--white-12) !important;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.6) !important;
  z-index: 0 !important;
  background: #000;
  margin: 0 !important;
  border-radius: 0 !important;
}

/* Legacy video offset removed */

/* Video Edge Vignette */
#ebx-hero-alt.video-mode .ebx-video-wrap::before,
#ebx-hero-alt.video-mode .ebx-video-wrap::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: clamp(60px, 10vw, 150px);
  z-index: 2;
  pointer-events: none;
}

#ebx-hero-alt.video-mode .ebx-video-wrap::before {
  left: 0;
  background: linear-gradient(90deg, rgba(8, 10, 14, .9) 0%, rgba(8, 10, 14, .5) 40%, transparent 100%);
}

#ebx-hero-alt.video-mode .ebx-video-wrap::after {
  right: 0;
  background: linear-gradient(270deg, rgba(8, 10, 14, .9) 0%, rgba(8, 10, 14, .5) 40%, transparent 100%);
}

#ebx-hero-alt.video-mode video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Legacy grid layout removed */


/* ================================================================
   10. TOUR PANEL
   ================================================================ */

.ebx-tour-content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.ebx-tour-meta {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  margin: .75rem 0;
}

.ebx-tour-meta__item {
  display: grid;
  gap: .25rem;
  padding: .75rem 1rem;
  border-radius: var(--radius-md, 12px);
  background: var(--white-08, rgba(255, 255, 255, .08));
  border: 1px solid var(--white-12, rgba(255, 255, 255, .12));
  min-width: 120px;
}

.ebx-tour-meta__item dt {
  font: 600 .7rem/1 var(--font-sans);
  color: var(--ink-2, #a8b8cc);
  letter-spacing: .06em;
  text-transform: uppercase;
}

.ebx-tour-meta__item dd {
  margin: 0;
  font: 700 1rem/1.2 var(--font-sans);
  color: var(--ink, #f3f6fc);
}

.ebx-tour-meta__item--highlight {
  background: linear-gradient(135deg, var(--lava-18, rgba(250, 104, 31, .18)), var(--gold-12, rgba(255, 227, 146, .12)));
  border-color: var(--lava-35, rgba(250, 104, 31, .35));
}

.ebx-tour-meta__item--highlight dd {
  color: var(--gold, #ffe392);
}

.ebx-tour-card {
  padding: clamp(18px, 2.5vw, 28px);
  border-radius: var(--radius-lg, 16px);
  background: linear-gradient(135deg, rgba(26, 32, 48, .85), rgba(11, 15, 24, .9));
  border: 1px solid var(--white-12, rgba(255, 255, 255, .12));
  backdrop-filter: blur(12px);
}

.ebx-tour-card__title {
  margin: 0 0 .75rem;
  font: 700 1rem/1.2 var(--font-serif, 'Cinzel', serif);
  color: var(--gold, #ffe392);
  letter-spacing: .04em;
}

.ebx-tour-card__list {
  margin: 0;
  padding-left: 1.25rem;
  color: var(--ink-2, #a8b8cc);
  font: 500 .9rem/1.5 var(--font-sans);
}

.ebx-tour-card__list li {
  margin-bottom: .5rem;
}

.ebx-tour-card__list li::marker {
  color: var(--lava, #fa681f);
}

.ebx-tour-card__note {
  margin: .75rem 0 0;
  font: 600 .8rem/1.4 var(--font-sans);
  color: var(--ink-2, #a8b8cc);
  font-style: italic;
}

/* Mobile Tour */
@media (max-width: 1024px) {
  .ebx-tour-meta {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 8px !important;
    margin: 10px auto !important;
    width: 100%;
    max-width: 320px;
  }

  .ebx-tour-meta__item {
    padding: 8px 10px !important;
    min-width: auto !important;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }

  .ebx-tour-meta__item:last-child {
    grid-column: span 2;
  }

  .ebx-tour-meta__item dt {
    font-size: .65rem !important;
  }

  .ebx-tour-meta__item dd {
    font-size: .95rem !important;
  }

  /* Center Header Content (Chip, Title) */
  .ebx-hero-panel--tour .ebx-tour-content {
    align-items: center !important;
    text-align: center !important;
    width: 100%;
  }

  .ebx-hero-panel--tour .ebx-tour-content .ebx-chip {
    align-self: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .ebx-tour-card {
    margin-top: 1rem;
    /* Force Left alignment for card content */
    text-align: left !important;
    display: flex;
    flex-direction: column;
    align-items: flex-start !important;
    width: 100%;
  }
}


/* ================================================================
   11. DARKFIRE PANEL (Modal)
   ================================================================ */

#darkfire-panel[hidden] {
  display: none;
}

#darkfire-panel {
  position: fixed;
  inset: 0;
  z-index: var(--z-toast);
  display: grid;
  place-items: center;
}

#darkfire-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .62);
  backdrop-filter: blur(4px);
  z-index: var(--z-base);
}

#darkfire-panel .panel-inner {
  position: relative;
  z-index: var(--z-content);
  width: min(860px, 92vw);
  max-height: min(92vh, 980px);
  overflow: auto;
  padding: 18px 18px 22px;
  border-radius: var(--radius-2xl);
  border: 1px solid var(--white-16);
  background: linear-gradient(180deg, rgba(16, 22, 30, .86), rgba(10, 14, 18, .78));
  box-shadow: 0 28px 80px rgba(0, 0, 0, .55), inset 0 0 0 1px var(--white-04);
  backdrop-filter: var(--backdrop-glass);
  will-change: transform, opacity;
  contain: layout paint style;
  backface-visibility: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  scrollbar-gutter: stable both-edges;
  transition: transform .24s ease, opacity .2s ease;
  transform: scale(.985);
  opacity: .98;
}

#darkfire-panel[data-open="1"] .panel-inner {
  transform: scale(1);
  opacity: 1;
}

#darkfire-panel .panel-close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--white-22);
  background: var(--black-35);
  color: #fff;
  z-index: var(--z-content);
}

#darkfire-panel .panel-actions {
  display: flex;
  gap: .6rem;
  justify-content: flex-end;
}

#darkfire-panel .panel-cover {
  position: relative;
  display: block;
  width: clamp(160px, 24vw, 220px);
  margin: 6px auto 12px;
}

#darkfire-panel .panel-cover::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -10px;
  width: 68%;
  height: 14px;
  border-radius: 50%;
  background: radial-gradient(60% 100% at 50% 50%, rgba(0, 0, 0, .55), transparent 70%);
  filter: blur(var(--blur-sm));
}

#darkfire-panel .panel-cover img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  outline: 2px solid rgba(10, 12, 16, .9);
  outline-offset: -2px;
  box-shadow: inset 0 0 0 2px var(--white-06), 0 12px 28px rgba(0, 0, 0, .5), 0 0 16px var(--lava-18);
}

#darkfire-panel h3 {
  margin: 0 0 1rem;
  font-size: clamp(1.3rem, 2.4vw, 1.8rem);
  font-weight: 900;
  font-family: var(--font-display);
  text-align: center;
  letter-spacing: .08em;
  line-height: 1.2;
  color: #f8f9fb;
  text-shadow: 0 2px 8px rgba(0, 0, 0, .5);
}

#darkfire-panel h3 em {
  color: var(--lava);
  font-style: normal;
}

#darkfire-panel p {
  margin: 0 0 1.2rem;
  font-size: clamp(.95rem, 1.4vw, 1.05rem);
  line-height: 1.65;
  color: rgba(230, 236, 247, .92);
  font-weight: 500;
}

#darkfire-panel p strong {
  color: #fff;
  font-weight: 700;
}

#darkfire-panel blockquote {
  margin: 1.4rem 0;
  padding: 1rem 1.2rem;
  border-left: 3px solid var(--lava);
  background: rgba(250, 104, 31, .08);
  border-radius: var(--radius-md);
}

#darkfire-panel blockquote p {
  margin: 0 0 .6rem;
  font-size: clamp(.92rem, 1.3vw, 1rem);
  font-style: italic;
  color: rgba(230, 236, 247, .88);
}

#darkfire-panel blockquote p:last-child {
  margin-bottom: 0;
}

#darkfire-panel blockquote cite {
  display: block;
  margin-top: .8rem;
  font-size: .88rem;
  font-style: normal;
  font-weight: 700;
  color: var(--bronze);
  letter-spacing: .04em;
}

@media (max-width: 980px) {
  #darkfire-panel {
    align-items: flex-end;
  }

  #darkfire-panel .panel-inner {
    width: 100vw;
    max-height: 86vh;
    border-radius: var(--radius-2xl) 16px 0 0;
    margin: 0;
    padding-bottom: calc(18px + env(safe-area-inset-bottom));
    transform: translateY(22px);
  }

  #darkfire-panel[data-open="1"] .panel-inner {
    transform: translateY(0);
  }
}


/* ================================================================
   12. BUTTONS & CHIPS
   ================================================================ */

.btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 46px;
  padding: 0 1.3rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--white-25);
  font: 800 .98rem/1 var(--ebx-font-accent, Montserrat, system-ui);
  letter-spacing: .08em;
  color: #f4f7fa;
  background: linear-gradient(180deg, rgba(18, 22, 30, .45), rgba(12, 14, 18, .55));
  backdrop-filter: var(--backdrop-glass);
  box-shadow: inset 0 0 0 1px var(--white-12), inset 0 1px 0 var(--white-15), 0 8px 18px var(--black-35);
  transition: transform .18s, background .2s, border-color .2s, box-shadow .25s, backdrop-filter .2s;
}

.btn:hover {
  transform: translateY(-2px);
  border-color: var(--gold-45);
  background: linear-gradient(180deg, rgba(22, 26, 36, .58), rgba(14, 16, 22, .68));
  backdrop-filter: var(--backdrop-glass-vivid);
  box-shadow: inset 0 0 0 1px rgba(255, 227, 146, .2), inset 0 1px 0 var(--white-25), 0 12px 28px var(--lava-22), 0 0 20px var(--lava-15);
}

.btn:focus-visible {
  outline: 3px solid rgba(250, 104, 31, .6);
  outline-offset: 3px;
  box-shadow: 0 0 0 3px rgba(250, 104, 31, .3), inset 0 1px 0 var(--white-25), 0 12px 28px var(--lava-25);
}

.btn.lava {
  color: #fff;
  background: linear-gradient(135deg, rgba(250, 104, 31, .12), rgba(184, 74, 58, .08));
  border: 1px solid var(--lava-35);
  backdrop-filter: blur(12px) saturate(180%);
  box-shadow: 0 4px 16px rgba(250, 104, 31, .15), inset 0 1px 0 rgba(255, 255, 255, .08), inset 0 0 0 1px rgba(250, 104, 31, .12);
  font-weight: 700;
  transition: all .3s cubic-bezier(.4, 0, .2, 1);
}

.btn.lava:hover {
  background: linear-gradient(135deg, rgba(250, 104, 31, .22), rgba(184, 74, 58, .18));
  border-color: var(--lava-55);
  backdrop-filter: blur(16px) saturate(200%);
  box-shadow: 0 8px 24px rgba(250, 104, 31, .3), 0 0 20px rgba(250, 104, 31, .2), inset 0 1px 0 rgba(255, 255, 255, .15), inset 0 0 0 1px rgba(250, 104, 31, .25);
  transform: translateY(-2px);
}

.btn.spotify {
  background: linear-gradient(135deg, rgba(30, 215, 96, .12), rgba(24, 182, 83, .08));
  color: #fff;
  font-weight: 700;
  border: 1px solid rgba(30, 215, 96, .35);
  backdrop-filter: blur(12px) saturate(180%);
  box-shadow: 0 4px 16px rgba(30, 215, 96, .15), inset 0 1px 0 rgba(255, 255, 255, .08), inset 0 0 0 1px rgba(30, 215, 96, .12);
}

.btn.spotify:hover {
  background: linear-gradient(135deg, rgba(30, 215, 96, .22), rgba(24, 182, 83, .18));
  border-color: rgba(30, 215, 96, .55);
  backdrop-filter: blur(16px) saturate(200%);
  box-shadow: 0 8px 24px rgba(30, 215, 96, .3), 0 0 20px rgba(30, 215, 96, .2), inset 0 1px 0 rgba(255, 255, 255, .15), inset 0 0 0 1px rgba(30, 215, 96, .25);
  transform: translateY(-2px);
}

.btn.spotify i {
  font-size: 1.05em;
}

.btn.ghost-lava {
  background: linear-gradient(135deg, rgba(255, 255, 255, .08), rgba(240, 240, 240, .04));
  color: #fff;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, .2);
  backdrop-filter: blur(12px) saturate(180%);
  box-shadow: 0 4px 16px rgba(0, 0, 0, .15), inset 0 1px 0 rgba(255, 255, 255, .08), inset 0 0 0 1px rgba(255, 255, 255, .06);
  transition: all .3s cubic-bezier(.4, 0, .2, 1);
}

.btn.ghost-lava:hover {
  background: linear-gradient(135deg, rgba(250, 104, 31, .18), rgba(184, 74, 58, .12));
  border-color: var(--lava-45);
  backdrop-filter: blur(16px) saturate(200%);
  box-shadow: 0 8px 24px rgba(250, 104, 31, .25), 0 0 20px rgba(250, 104, 31, .15), inset 0 1px 0 rgba(255, 255, 255, .12), inset 0 0 0 1px rgba(250, 104, 31, .2);
  transform: translateY(-2px);
}

@keyframes btn-pulse {

  0%,
  100% {
    box-shadow: 0 0 14px var(--lava-38), inset 0 1px 0 rgba(255, 255, 255, .45), inset 0 0 0 1px var(--gold-35);
  }

  50% {
    box-shadow: 0 0 20px var(--lava-55), inset 0 1px 0 rgba(255, 255, 255, .50), inset 0 0 0 1px var(--gold-45);
  }
}

/* Badge */
.ebx-badge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .6rem 1rem;
  border: 1px solid var(--gold-35);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(18, 22, 30, .75), rgba(10, 12, 16, .82));
  backdrop-filter: var(--backdrop-glass-vivid);
  box-shadow: inset 0 1px 0 var(--white-12), inset 0 0 0 1px var(--gold-15), 0 8px 18px var(--black-35);
  color: #fff;
  font: 700 .92rem/1.1 var(--ebx-font-accent, Montserrat, system-ui);
}

.ebx-badge__label {
  font-weight: 800;
  color: var(--gold-85);
}

.sep {
  color: rgba(255, 227, 146, .5);
}

.dot {
  width: .52rem;
  height: .52rem;
  border-radius: var(--radius-pill);
  background: radial-gradient(circle at 40% 40%, var(--gold), var(--lava));
}

.ebx-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  justify-content: center;
}

/* Chips */
.ebx-chip {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .45rem .9rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--gold-45);
  background: var(--gold-12);
  color: var(--gold);
  font: 700 .8rem/1 var(--font-sans);
  letter-spacing: .06em;
  margin-bottom: .75rem;
}

.ebx-chip--new {
  border-color: var(--lava-55);
  background: var(--lava-18);
  color: #ffe8d8;
  animation: chipPulse 2s ease-in-out infinite;
}

@keyframes chipPulse {

  0%,
  100% {
    box-shadow: 0 0 0 0 var(--lava-28);
  }

  50% {
    box-shadow: 0 0 16px 4px var(--lava-35);
  }
}

/* Mobile Badge */
@media (max-width: 980px) {
  .ebx-badge {
    font-size: .88rem;
    padding: .55rem .85rem;
    border-radius: var(--radius-md);
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
    gap: .4rem;
  }

  .ebx-badge__label {
    font-weight: 900;
  }
}


/* ================================================================
   13. TYPOGRAPHY
   ================================================================ */

.ebx-title {
  font-family: var(--font-display, 'Cinzel', serif);
  font-weight: 700;
  text-transform: uppercase;
  color: var(--white, #fff);
  line-height: 1.1;
  margin: 0 0 .5rem;
  font-size: clamp(1.8rem, 5vw, 4rem);
  letter-spacing: 0.02em;
}

.ebx-title--thin {
  font-weight: 300;
  letter-spacing: 0.08em;
  display: block;
}

.ebx-title--sm {
  font-size: clamp(1.2rem, 4vw, 2.5rem);
  font-weight: 700;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}

.ebx-lead {
  color: var(--ink-2);
  font: 500 clamp(0.9rem, 2vw, 1.1rem)/1.5 var(--font-sans);
  margin: 0 0 1rem;
  max-width: 48ch;
}

/* Title Glow Effects */
#ebx-hero-alt .ebx-title::before {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -6px;
  width: min(760px, 80%);
  height: 84px;
  background: radial-gradient(60% 80% at 50% 0, var(--lava-22), transparent 70%);
  filter: blur(var(--blur-sm));
  opacity: .6;
  pointer-events: none;
}

#ebx-hero-alt .ebx-title::after {
  content: "";
  position: absolute;
  inset: -28% -14%;
  z-index: var(--z-behind);
  border-radius: 2.2em;
  background: radial-gradient(80% 120% at 50% 55%, rgba(255, 80, 30, .28), transparent 70%),
    radial-gradient(64% 90% at 52% 52%, var(--lava-22), transparent 68%);
  filter: blur(var(--blur-lg)) saturate(135%);
  mix-blend-mode: screen;
  animation: emberDrift 10s ease-in-out infinite;
  will-change: transform, opacity;
}

@keyframes emberDrift {

  0%,
  100% {
    transform: translate(0, 0) scale(1);
    opacity: .9;
  }

  50% {
    transform: translate(-.6rem, -.3rem) scale(1.03);
    opacity: 1;
  }
}


/* ================================================================
   14. LANGUAGE POPUP
   ================================================================ */

.ebx-lang {
  position: relative;
  z-index: var(--z-modal);
}

.lang-panel {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 220px;
  max-height: 60vh;
  overflow: auto;
  border: 1px solid var(--white-12);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(12, 16, 22, .96), rgba(9, 12, 16, .94));
  box-shadow: 0 14px 40px rgba(0, 0, 0, .55);
  backdrop-filter: var(--backdrop-glass);
  display: none;
}

.lang-panel.open {
  display: block;
}

.lang-popup {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 220px;
  background: linear-gradient(180deg, rgba(18, 22, 30, .96), rgba(12, 14, 18, .98));
  backdrop-filter: blur(16px) saturate(180%);
  border: 1px solid var(--white-15);
  border-radius: var(--radius-lg);
  box-shadow: 0 12px 32px rgba(0, 0, 0, .45), inset 0 1px 0 var(--white-12), 0 0 0 1px var(--lava-12);
  padding: 12px;
  z-index: var(--z-dd);
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity .25s ease, transform .25s ease;
  pointer-events: none;
}

.lang-popup[hidden] {
  display: block;
  visibility: hidden;
}

.lang-popup:not([hidden]) {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.lang-popup__inner {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

#gt_float_wrapper,
.gt_float_wrapper {
  display: none !important;
}

.gtranslate_wrapper a,
.gtranslate_wrapper button {
  display: flex;
  align-items: center;
  gap: .55rem;
  width: 100%;
  padding: .5rem .7rem;
  border-radius: var(--radius-sm);
  color: #e9eef5;
  text-decoration: none;
  border: 0;
  background: transparent;
}

.gtranslate_wrapper a:hover,
.gtranslate_wrapper button:hover {
  background: linear-gradient(180deg, rgba(184, 74, 58, .22), rgba(184, 74, 58, .08));
  color: #ffe7c2;
  box-shadow: 0 0 0 2px var(--lava-18) inset;
}

.lang-popup .gtranslate_wrapper {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.lang-popup .gtranslate_wrapper a,
.lang-popup .gtranslate_wrapper button {
  padding: .65rem .95rem;
  border-radius: var(--radius-md);
  font-size: .9rem;
  transition: all .2s ease;
}

.lang-popup .gtranslate_wrapper a:hover,
.lang-popup .gtranslate_wrapper button:hover {
  background: linear-gradient(180deg, rgba(184, 74, 58, .28), rgba(184, 74, 58, .12));
  transform: translateX(3px);
}

.gtranslate_wrapper img {
  width: 18px;
  height: 18px;
  border-radius: var(--radius-xs);
  box-shadow: 0 0 0 1px var(--white-15);
}


/* ================================================================
   15. UTILITIES & MISC
   ================================================================ */

.ebx-quick {
  display: flex;
  gap: .45rem;
  align-items: center;
  flex-wrap: wrap;
}

.ebx-drawer a:active,
.dm-root:active {
  transform: translateY(1px);
  filter: brightness(1.06);
}

.ebx-drawer .dm-root,
.ebx-drawer .drawer-quick a,
.ebx-drawer .dm-link {
  transition: transform .16s ease, box-shadow .2s ease, border-color .2s ease, color .2s ease, background .2s ease;
}

.ebx-drawer .dm-root:active,
.ebx-drawer .drawer-quick a:active,
.ebx-drawer .dm-link:active {
  transform: translateY(1px);
}

/* ================================================================
   COVER ZOOM MODAL
   ================================================================ */

.ebx-cover-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s ease, visibility .3s ease;
}

.ebx-cover-modal[hidden] {
  display: none;
}

.ebx-cover-modal.is-open {
  opacity: 1;
  visibility: visible;
}

.ebx-cover-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.ebx-cover-modal__content {
  position: relative;
  z-index: 1;
  max-width: 90vw;
  max-height: 85vh;
  animation: coverZoomIn .4s cubic-bezier(.34, 1.56, .64, 1);
}

.ebx-cover-modal__img {
  display: block;
  max-width: 100%;
  max-height: 85vh;
  width: auto;
  height: auto;
  border-radius: 8px;
  box-shadow:
    0 0 0 4px rgba(250, 150, 80, .4),
    0 25px 80px rgba(0, 0, 0, .8),
    0 0 100px rgba(250, 100, 50, .2);
}

.ebx-cover-modal__close {
  position: absolute;
  top: -16px;
  right: -16px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(30, 20, 15, .95);
  border: 2px solid rgba(250, 150, 80, .5);
  color: rgba(250, 200, 150, .9);
  font-size: 1.2rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .5);
}

.ebx-cover-modal__close:hover {
  transform: scale(1.1);
  background: rgba(60, 35, 25, .95);
  box-shadow: 0 6px 20px rgba(0, 0, 0, .6), 0 0 20px rgba(250, 100, 50, .3);
}

@keyframes coverZoomIn {
  from {
    transform: scale(.7);
    opacity: 0;
  }

  to {
    transform: scale(1);
    opacity: 1;
  }
}

/* ================================================================
   15. MOBILE HERO ARROWS & JITTER FIX
   ================================================================ */

/* Fix for mobile scroll jitter */
.ebx-hero-tabs,
.ebx-hero__shell,
.ebx-hero-panel {
  touch-action: pan-y;
}

.ebx-hero-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: var(--z-content-high);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(15, 19, 24, 0.6);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.8);
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  backdrop-filter: blur(4px);
  transition: all 0.2s ease;
  padding: 0;
  display: none;
  /* Hidden by default */
}

.ebx-hero-arrow:hover {
  background: rgba(15, 19, 24, 0.8);
  border-color: rgba(255, 255, 255, 0.3);
  color: #fff;
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.5);
}

.ebx-hero-arrow:active {
  transform: translateY(-50%) scale(0.95);
}

.ebx-hero-arrow--prev {
  left: 10px;
}

.ebx-hero-arrow--next {
  right: 10px;
}

.ebx-hero-arrow {
  display: flex;
  min-width: 44px;
  min-height: 44px;
}

/* Remove hover on touch to prevent sticky hover states */
@media (hover: none) {
  .ebx-hero-arrow:hover {
    background: rgba(15, 19, 24, 0.6);
    border-color: rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 0.8);
    box-shadow: none;
  }

  .ebx-hero-arrow:active,
  .ebx-hero-arrow:focus {
    background: var(--lava-80) !important;
    border-color: var(--lava) !important;
    color: #fff !important;
    box-shadow: 0 0 15px var(--lava-40) !important;
    transform: translateY(-50%) scale(0.9);
    outline: none !important;
    -webkit-tap-highlight-color: transparent !important;
    backdrop-filter: none !important;
    /* Prevent crash on mobile */
  }
}

/* ================================================================
   CRITICAL MOBILE PERFORMANCE FIXES
   ================================================================ */
@media (max-width: 980px) {
  * {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
}