/* =============================================================================
   Explora Parks — Booking CSS v6
   Strategy: every rule prefixed with #ep-booking-root + !important on critical
   layout properties. This beats Elementor/theme overrides reliably.

   Brand: exploraparks.com — Salta. Brinca. Explora.
   Colors: green primary, orange CTA, warm cream background.
   Fonts: Poppins (everywhere — display + body)
   ============================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800;900&display=swap');

/* ─── ROOT RESET & TOKENS ─────────────────────────────────────────────────── */
#ep-booking-root {
  /* Tokens — intensified palette matching exploraparks.com */
  --g900: #063621;
  --g800: #0a4a2c;
  --g700: #1a6b3c;
  --g600: #20974a;
  --g500: #26b85c;
  --g400: #4dd283;
  --g300: #9be9b8;
  --g100: #d5f5e0;
  --g50:  #ecfbf1;

  --o700: #b83e0f;
  --o600: #e8631a;
  --o500: #ff8028;
  --o400: #ff9a52;
  --o300: #ffbd8e;
  --o100: #ffe4ce;
  --o50:  #fff4e8;

  --cream:  #faf7f2;
  --cream2: #f4efe6;
  --paper:  #ffffff;
  --ink:    #1a1f1c;
  --soft:   #3d4a42;
  --muted:  #6b7570;
  --muted2: #9ba8a0;
  --border: #e5ddcf;
  --bord2:  #ded5c2;

  /* Brand category colors — real Explora Parks palette */
  --festa:    #ff6b1a;    /* orange — same family as hero */
  --festa-2:  #ffc107;    /* golden yellow accent */
  --escolar:  #01befe;    /* electric cyan (brand) */
  --escolar-2:#0099d9;    /* deeper cyan */
  --indiv:    #70e000;    /* lime green (brand) */
  --indiv-2:  #4eb000;    /* deeper lime */

  /* Extra vibrant accents */
  --brand-cyan:   #01befe;
  --brand-lime:   #70e000;
  --brand-yellow: #ffc107;
  --brand-pink:   #ff3b7f;

  --r1: 10px;
  --r2: 14px;
  --r3: 20px;
  --pill: 999px;

  /* Host styles */
  display: block !important;
  font-family: 'Poppins', -apple-system, BlinkMacSystemFont, sans-serif !important;
  color: var(--ink) !important;
  line-height: 1.55 !important;
  font-size: 15px !important;
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(1,190,254,.12) 0%, transparent 60%),
    radial-gradient(ellipse 70% 40% at 100% 100%, rgba(112,224,0,.08) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 0% 50%, rgba(232,99,26,.06) 0%, transparent 55%),
    linear-gradient(180deg, #0a1628 0%, #0d1a30 50%, #0a1628 100%) !important;
  padding: 1.5rem 1rem 3rem !important;
  min-height: 100vh !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  box-sizing: border-box !important;
  width: 100% !important;
}

#ep-booking-root *,
#ep-booking-root *::before,
#ep-booking-root *::after {
  box-sizing: border-box !important;
  font-family: inherit !important;
}

/* Reset specific elements only (not universal) */
#ep-booking-root div,
#ep-booking-root span,
#ep-booking-root p,
#ep-booking-root h1,
#ep-booking-root h2,
#ep-booking-root h3,
#ep-booking-root h4,
#ep-booking-root ul,
#ep-booking-root li,
#ep-booking-root label,
#ep-booking-root small,
#ep-booking-root button,
#ep-booking-root input,
#ep-booking-root select,
#ep-booking-root textarea {
  margin: 0 !important;
  padding: 0 !important;
  background: transparent;
  color: inherit;
  line-height: inherit;
  text-align: left;
  text-transform: none;
  letter-spacing: normal;
  list-style: none;
}

#ep-booking-root h1,
#ep-booking-root h2,
#ep-booking-root h3,
#ep-booking-root h4 {
  font-weight: 800;
}

#ep-booking-root p { margin: 0 !important; }

/* ─── HERO ─────────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-hero {
  max-width: 960px !important;
  margin: 0 auto 1.75rem auto !important;
  text-align: center !important;
  padding: 3rem 1.5rem 2.5rem !important;
  position: relative !important;
  overflow: hidden !important;
  border-radius: var(--r3) !important;
}

/* Floating decorative shapes */
#ep-booking-root .ep-hero::before {
  content: '' !important;
  position: absolute !important;
  top: -40px !important;
  left: -100px !important;
  width: 260px !important;
  height: 260px !important;
  background: radial-gradient(circle,
    #70e000 0%,
    rgba(112,224,0,.5) 30%,
    transparent 70%) !important;
  opacity: .45 !important;
  border-radius: 50% !important;
  z-index: 0 !important;
  animation: ep-float 8s ease-in-out infinite !important;
  filter: blur(4px) !important;
}

#ep-booking-root .ep-hero::after {
  content: '' !important;
  position: absolute !important;
  bottom: -60px !important;
  right: -100px !important;
  width: 300px !important;
  height: 300px !important;
  background: radial-gradient(circle,
    #01befe 0%,
    rgba(1,190,254,.4) 35%,
    transparent 70%) !important;
  opacity: .4 !important;
  border-radius: 50% !important;
  z-index: 0 !important;
  animation: ep-float 10s ease-in-out infinite reverse !important;
  filter: blur(4px) !important;
}

@keyframes ep-float {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(20px, -15px); }
}

#ep-booking-root .ep-hero > * { position: relative; z-index: 1 !important; }

#ep-booking-root .ep-hero h1 {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 900 !important;
  font-size: clamp(2.2rem, 5.5vw, 3.75rem) !important;
  line-height: 1 !important;
  letter-spacing: -0.04em !important;
  color: var(--g900) !important;
  margin: 0 0 0.85rem !important;
}

#ep-booking-root .ep-hero h1 .accent {
  background: linear-gradient(135deg, #ffa12a 0%, #ff6b1a 40%, #e8420d 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  position: relative !important;
  display: inline-block !important;
}

#ep-booking-root .ep-hero h1 .accent::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 3% !important;
  right: 3% !important;
  height: 12px !important;
  background: linear-gradient(90deg, #ffa12a, #ff6b1a, #e8420d) !important;
  opacity: .35 !important;
  z-index: -1 !important;
  border-radius: 999px !important;
  filter: blur(1px) !important;
}

#ep-booking-root .ep-hero .tagline,
#ep-booking-root .ep-hero p {
  font-size: clamp(.95rem, 1.5vw, 1.1rem) !important;
  color: var(--soft) !important;
  font-weight: 500 !important;
  margin: .5rem 0 0 !important;
}

/* ─── WRAPPER ──────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-container,
#ep-booking-root .ep-booking-wrap {
  max-width: 960px !important;
  margin: 0 auto !important;
  display: block !important;
}

/* ─── PROGRESS ─────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-progress {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 1rem 1.75rem !important;
  background: var(--paper) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r3) !important;
  margin: 0 0 1.25rem !important;
  box-shadow: 0 1px 2px rgba(15,61,46,.04), 0 4px 12px rgba(15,61,46,.05) !important;
  position: relative !important;
  overflow: hidden !important;
  gap: 1rem !important;
}

#ep-booking-root .ep-progress::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important;
  height: 5px !important;
  background: linear-gradient(90deg, var(--g500) 0%, var(--g400) 30%, var(--o500) 70%, var(--o400) 100%) !important;
  width: var(--progress, 25%) !important;
  transition: width .4s cubic-bezier(.4,0,.2,1) !important;
  box-shadow: 0 2px 8px rgba(38,184,92,.3) !important;
}

#ep-booking-root .ep-progress .ep-step {
  display: flex !important;
  align-items: center !important;
  gap: .6rem !important;
  font-size: .78rem !important;
  font-weight: 700 !important;
  color: var(--muted2) !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  flex: 0 0 auto !important;
}

#ep-booking-root .ep-progress .ep-step .ep-step-num {
  width: 30px !important;
  height: 30px !important;
  border-radius: 50% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--cream2) !important;
  color: var(--muted) !important;
  font-size: .82rem !important;
  font-weight: 800 !important;
  border: 1.5px solid var(--bord2) !important;
  transition: all .25s cubic-bezier(.4,0,.2,1) !important;
  flex-shrink: 0 !important;
}

#ep-booking-root .ep-progress .ep-step .ep-step-num.active {
  background: linear-gradient(135deg, var(--g600), var(--g800)) !important;
  color: #fff !important;
  border-color: var(--g700) !important;
  transform: scale(1.15) !important;
  box-shadow:
    0 0 0 4px var(--g100),
    0 6px 16px rgba(32,151,74,.4) !important;
}

#ep-booking-root .ep-progress .ep-step .ep-step-num.done {
  background: var(--g500) !important;
  color: #fff !important;
  border-color: var(--g500) !important;
}

#ep-booking-root .ep-progress .ep-step .ep-step-label {
  color: inherit !important;
  transition: color .2s !important;
}

#ep-booking-root .ep-progress .ep-step .ep-step-label.active { color: var(--g800) !important; }

/* ─── ALERT ────────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-alert {
  display: none !important;
  padding: .85rem 1.1rem !important;
  border-radius: var(--r1) !important;
  font-size: .88rem !important;
  font-weight: 600 !important;
  margin: 0 0 1rem !important;
  background: #fff0f0 !important;
  color: #b33 !important;
  border: 1.5px solid #f5c0c0 !important;
}
#ep-booking-root .ep-alert.show { display: block !important; }

/* ─── CARDS ────────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-card {
  background: var(--paper) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r3) !important;
  padding: 1.75rem 1.75rem !important;
  margin: 0 0 1.25rem !important;
  box-shadow: 0 1px 2px rgba(15,61,46,.04), 0 8px 20px rgba(15,61,46,.05) !important;
  position: relative !important;
}

#ep-booking-root .ep-card-title {
  display: flex !important;
  align-items: center !important;
  gap: .85rem !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 800 !important;
  font-size: 1.3rem !important;
  letter-spacing: -.02em !important;
  color: var(--g900) !important;
  margin: 0 0 1.25rem !important;
  padding: 0 0 1rem !important;
  border-bottom: 2px dashed var(--bord2) !important;
}

#ep-booking-root .ep-card-icon {
  width: 42px !important;
  height: 42px !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, var(--g500), var(--g700)) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.25rem !important;
  flex-shrink: 0 !important;
  border: none !important;
  box-shadow:
    0 4px 12px rgba(32,151,74,.3),
    inset 0 1px 0 rgba(255,255,255,.2) !important;
}

/* ─── CATEGORY TABS ────────────────────────────────────────────────────────── */
#ep-booking-root .ep-program-tabs,
#ep-booking-root .ep-categories {
  display: flex !important;
  gap: .5rem !important;
  margin: 0 0 1.5rem !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
}

#ep-booking-root .ep-program-tab,
#ep-booking-root .ep-cat-btn {
  padding: .65rem 1.35rem !important;
  border-radius: var(--pill) !important;
  background: var(--paper) !important;
  border: 2px solid var(--bord2) !important;
  color: var(--muted) !important;
  font-size: .88rem !important;
  font-weight: 700 !important;
  font-family: inherit !important;
  cursor: pointer !important;
  transition: all .2s !important;
  letter-spacing: .005em !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: .4rem !important;
}

#ep-booking-root .ep-program-tab:hover,
#ep-booking-root .ep-cat-btn:hover {
  border-color: var(--g500) !important;
  color: var(--g700) !important;
  transform: translateY(-1px) !important;
}

#ep-booking-root .ep-program-tab.active,
#ep-booking-root .ep-cat-btn.active {
  background: linear-gradient(135deg, var(--g600), var(--g800)) !important;
  border-color: var(--g700) !important;
  color: #fff !important;
  box-shadow:
    0 2px 0 rgba(6,54,33,.25),
    0 6px 16px rgba(32,151,74,.35),
    inset 0 1px 0 rgba(255,255,255,.2) !important;
  text-shadow: 0 1px 2px rgba(0,0,0,.15) !important;
  transform: translateY(-1px) !important;
}

/* Tab hover with category-specific color preview */
#ep-booking-root .ep-program-tab[data-cat="festa"]:hover {
  border-color: var(--festa) !important;
  color: var(--festa) !important;
}
#ep-booking-root .ep-program-tab[data-cat="escolar"]:hover {
  border-color: var(--escolar) !important;
  color: var(--escolar-2) !important;
}
#ep-booking-root .ep-program-tab[data-cat="individual"]:hover {
  border-color: var(--indiv-2) !important;
  color: var(--indiv-2) !important;
}


/* ─── PRODUCT GRID (STEP 1) ────────────────────────────────────────────────── */
#ep-booking-root .ep-products-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 1rem !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

/* Respect inline display:none on hidden grids (JS toggles active category) */
#ep-booking-root .ep-products-grid[style*="display:none"],
#ep-booking-root .ep-products-grid[style*="display: none"] {
  display: none !important;
}


#ep-booking-root .ep-product-card {
  background: var(--paper) !important;
  border: 2px solid var(--border) !important;
  border-radius: var(--r2) !important;
  padding: 1.35rem 1.35rem 1.25rem !important;
  cursor: pointer !important;
  transition: all .25s cubic-bezier(.4,0,.2,1) !important;
  position: relative !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  gap: .4rem !important;
}

#ep-booking-root .ep-product-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 5px !important;
  background: linear-gradient(90deg, var(--cat-color, var(--g500)), var(--cat-color-2, var(--g400))) !important;
  transform: scaleX(1) !important;
  transition: all .3s !important;
}

#ep-booking-root .ep-product-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 4px 8px rgba(15,61,46,.08), 0 16px 40px rgba(15,61,46,.1) !important;
  border-color: var(--cat-color, var(--g500)) !important;
}
#ep-booking-root .ep-product-card:hover::before { transform: scaleX(1) !important; }

#ep-booking-root .ep-product-card.selected {
  border-color: var(--cat-color, var(--g500)) !important;
  background: var(--cat-bg, var(--g50)) !important;
  box-shadow:
    0 0 0 4px color-mix(in srgb, var(--cat-color, var(--g500)) 20%, transparent),
    0 16px 40px rgba(15,61,46,.12) !important;
  transform: translateY(-2px) !important;
}
#ep-booking-root .ep-product-card.selected::before { transform: scaleX(1) !important; }

#ep-booking-root .ep-product-card[data-category="festa"] {
  --cat-color: var(--festa) !important;
  --cat-color-2: var(--festa-2) !important;
  --cat-bg: #fff4e4 !important;
}
#ep-booking-root .ep-product-card[data-category="escolar"] {
  --cat-color: var(--escolar) !important;
  --cat-color-2: var(--escolar-2) !important;
  --cat-bg: #e1f7ff !important;
}
#ep-booking-root .ep-product-card[data-category="individual"] {
  --cat-color: var(--indiv) !important;
  --cat-color-2: var(--indiv-2) !important;
  --cat-bg: #eefce1 !important;
}

#ep-booking-root .ep-product-emoji {
  font-size: 2rem !important;
  line-height: 1 !important;
  margin: 0 0 .4rem !important;
}

#ep-booking-root .ep-product-name {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  font-size: 1.12rem !important;
  letter-spacing: -.01em !important;
  color: var(--g900) !important;
  margin: 0 0 .25rem !important;
  line-height: 1.2 !important;
}

#ep-booking-root .ep-product-desc {
  font-size: .82rem !important;
  color: var(--muted) !important;
  line-height: 1.5 !important;
  margin: 0 0 .5rem !important;
  flex-grow: 1 !important;
}

#ep-booking-root .ep-product-min {
  font-size: .72rem !important;
  color: var(--muted2) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
  margin: .25rem 0 !important;
}

#ep-booking-root .ep-product-price {
  font-family: 'Poppins', sans-serif !important;
  font-size: 1.4rem !important;
  font-weight: 900 !important;
  background: linear-gradient(135deg, var(--cat-color, var(--g700)), var(--cat-color-2, var(--g500))) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  padding: .65rem 0 0 !important;
  margin-top: auto !important;
  border-top: 1.5px dashed var(--bord2) !important;
  letter-spacing: -.02em !important;
  line-height: 1.1 !important;
}
#ep-booking-root .ep-product-price span {
  font-size: .72rem !important;
  font-weight: 600 !important;
  opacity: .7 !important;
  letter-spacing: 0 !important;
  -webkit-text-fill-color: var(--muted) !important;
  color: var(--muted) !important;
  background: none !important;
  -webkit-background-clip: initial !important;
}

/* ─── VARIANT (step 2 program summary) ─────────────────────────────────────── */
#ep-booking-root .ep-variant {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 1rem 1.25rem !important;
  background: var(--g50) !important;
  border: 2px solid var(--g300) !important;
  border-radius: var(--r2) !important;
  gap: 1rem !important;
}

#ep-booking-root .ep-variant-name {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  color: var(--g900) !important;
}

#ep-booking-root .ep-variant-detail {
  font-size: .78rem !important;
  color: var(--muted) !important;
  margin-top: 2px !important;
}

#ep-booking-root .ep-variant-price {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 800 !important;
  color: var(--g700) !important;
}

/* ─── PAYMENT METHOD OPTIONS (.ep-variant with data-method) ─────────────── */
#ep-booking-root .ep-variant[data-method] {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 1.1rem 1.4rem 1.1rem 1.6rem !important;
  margin: 0 0 .6rem !important;
  background: var(--paper) !important;
  border: 2px solid var(--border) !important;
  border-radius: var(--r2) !important;
  cursor: pointer !important;
  transition: all .2s cubic-bezier(.4,0,.2,1) !important;
  position: relative !important;
  overflow: hidden !important;
  gap: 1rem !important;
}

#ep-booking-root .ep-variant[data-method]::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important; top: 0 !important; bottom: 0 !important;
  width: 5px !important;
  background: var(--method-color, var(--g500)) !important;
  opacity: 0 !important;
  transition: opacity .2s !important;
}

/* Color each method */
#ep-booking-root .ep-variant[data-method="mbway"]          { --method-color: #FF3B7F; --method-soft: #FFE8EF; }
#ep-booking-root .ep-variant[data-method="multibanco"]     { --method-color: #2d5fa6; --method-soft: #E7EEF8; }
#ep-booking-root .ep-variant[data-method="cartao"]         { --method-color: #6c4cd4; --method-soft: #ECE7FA; }
#ep-booking-root .ep-variant[data-method="transferencia"]  { --method-color: #1a6b3c; --method-soft: #E3F4EA; }

#ep-booking-root .ep-variant[data-method]:hover {
  border-color: var(--method-color) !important;
  background: var(--paper) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,.07) !important;
}
#ep-booking-root .ep-variant[data-method]:hover::before { opacity: 1 !important; }

#ep-booking-root .ep-variant[data-method].selected {
  border-color: var(--method-color) !important;
  background: var(--method-soft) !important;
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--method-color) 15%, transparent),
    0 4px 14px rgba(0,0,0,.08) !important;
  transform: translateY(-1px) !important;
}
#ep-booking-root .ep-variant[data-method].selected::before { opacity: 1 !important; }

#ep-booking-root .ep-variant[data-method] .ep-variant-name {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  font-size: 1.05rem !important;
  color: var(--g900) !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: .5rem !important;
}

#ep-booking-root .ep-variant[data-method] .ep-variant-detail {
  font-size: .82rem !important;
  color: var(--muted) !important;
  margin-top: 3px !important;
  font-weight: 500 !important;
}

/* "Recomendado" badge — orange vibrant pill */
#ep-booking-root .ep-variant[data-method] .ep-variant-price {
  font-family: 'Poppins', sans-serif !important;
  font-size: .7rem !important;
  font-weight: 800 !important;
  color: #fff !important;
  background: linear-gradient(135deg, #ff7a33, #e8631a) !important;
  padding: .3rem .75rem !important;
  border-radius: var(--pill) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  box-shadow: 0 3px 8px rgba(232,99,26,.35) !important;
  white-space: nowrap !important;
}



/* ─── FORM INPUTS ──────────────────────────────────────────────────────────── */
#ep-booking-root .ep-form-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 1rem !important;
}
#ep-booking-root .ep-form-row.single { grid-template-columns: 1fr !important; }
#ep-booking-root .ep-form-row.three  { grid-template-columns: 1fr 1fr 1fr !important; }

#ep-booking-root .ep-form-group {
  display: flex !important;
  flex-direction: column !important;
  gap: .4rem !important;
}

#ep-booking-root .ep-form-group label,
#ep-booking-root label {
  font-size: .72rem !important;
  font-weight: 800 !important;
  color: var(--muted) !important;
  text-transform: uppercase !important;
  letter-spacing: .07em !important;
  display: block !important;
  margin: 0 !important;
}

#ep-booking-root input[type="text"],
#ep-booking-root input[type="email"],
#ep-booking-root input[type="tel"],
#ep-booking-root input[type="date"],
#ep-booking-root input[type="number"],
#ep-booking-root select,
#ep-booking-root textarea {
  width: 100% !important;
  padding: .8rem 1rem !important;
  border: 1.5px solid var(--bord2) !important;
  border-radius: var(--r1) !important;
  background: var(--paper) !important;
  font-size: .95rem !important;
  font-family: 'Poppins', sans-serif !important;
  color: var(--ink) !important;
  transition: all .15s !important;
  line-height: 1.4 !important;
}

#ep-booking-root input:focus,
#ep-booking-root select:focus,
#ep-booking-root textarea:focus {
  outline: none !important;
  border-color: var(--g500) !important;
  box-shadow: 0 0 0 4px rgba(37,160,88,.12) !important;
}

#ep-booking-root textarea {
  min-height: 90px !important;
  resize: vertical !important;
}

#ep-booking-root .ep-field-hint {
  font-size: .72rem !important;
  color: var(--muted2) !important;
  font-style: italic !important;
}

/* ─── COUNTER ──────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-counter {
  display: inline-flex !important;
  align-items: center !important;
  gap: .5rem !important;
  background: var(--cream2) !important;
  border: 1.5px solid var(--bord2) !important;
  border-radius: var(--pill) !important;
  padding: 4px !important;
}

#ep-booking-root .ep-counter-btn {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  background: var(--paper) !important;
  border: 1.5px solid var(--bord2) !important;
  color: var(--g700) !important;
  font-size: 1.15rem !important;
  font-weight: 800 !important;
  cursor: pointer !important;
  transition: all .15s !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  line-height: 1 !important;
  font-family: inherit !important;
}

#ep-booking-root .ep-counter-btn:hover {
  border-color: var(--g500) !important;
  background: var(--g50) !important;
  transform: scale(1.05) !important;
}

#ep-booking-root .ep-counter-val {
  font-family: 'Poppins', sans-serif !important;
  font-size: 1.4rem !important;
  font-weight: 800 !important;
  color: var(--g900) !important;
  min-width: 40px !important;
  text-align: center !important;
}

/* ─── SLOTS ────────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-slots-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(82px, 1fr)) !important;
  gap: .5rem !important;
}

#ep-booking-root .ep-slot {
  padding: .7rem .5rem !important;
  border: 2px solid var(--bord2) !important;
  border-radius: var(--r1) !important;
  background: var(--paper) !important;
  color: var(--soft) !important;
  font-weight: 700 !important;
  font-size: .9rem !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: all .15s !important;
  font-variant-numeric: tabular-nums !important;
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 3px !important;
  min-height: 50px !important;
  justify-content: center !important;
}

#ep-booking-root .ep-slot:hover {
  border-color: var(--g500) !important;
  color: var(--g800) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 8px rgba(37,160,88,.15) !important;
}

#ep-booking-root .ep-slot.selected {
  background: var(--g700) !important;
  border-color: var(--g700) !important;
  color: #fff !important;
  box-shadow: 0 4px 10px rgba(26,107,60,.3) !important;
}

#ep-booking-root .ep-slot.occupied {
  opacity: .5 !important;
  cursor: not-allowed !important;
  background: var(--cream2) !important;
  pointer-events: auto !important; /* allow tooltip on hover */
}
#ep-booking-root .ep-slot.occupied:hover {
  transform: none !important;
  box-shadow: none !important;
  border-color: var(--bord2) !important;
  color: var(--soft) !important;
}
#ep-booking-root .ep-slot.occupied .ep-slot-time {
  text-decoration: line-through !important;
}

/* Badge shown on partially-occupied slots — e.g. "15 livres" */
#ep-booking-root .ep-slot-badge {
  font-size: .62rem !important;
  font-weight: 800 !important;
  padding: 1px 6px !important;
  border-radius: 999px !important;
  background: rgba(37,160,88,.12) !important;
  color: #1a6b3c !important;
  letter-spacing: .02em !important;
  line-height: 1.4 !important;
}
#ep-booking-root .ep-slot-badge-low {
  background: rgba(239,68,68,.14) !important;
  color: #b91c1c !important;
  animation: ep-slot-badge-pulse 1.4s ease-in-out infinite !important;
}
@keyframes ep-slot-badge-pulse {
  0%,100% { opacity: 1 }
  50%     { opacity: .65 }
}
#ep-booking-root .ep-slot.selected .ep-slot-badge {
  background: rgba(255,255,255,.22) !important;
  color: #fff !important;
}

/* Specific visual hint when a slot is disabled because park is full */
#ep-booking-root .ep-slot-reason-full {
  background: #fef2f2 !important;
  border-color: #fecaca !important;
}
#ep-booking-root .ep-slot-reason-full .ep-slot-time {
  color: #b91c1c !important;
}
#ep-booking-root .ep-slot-reason-insufficient {
  background: #fffbeb !important;
  border-color: #fcd34d !important;
}
#ep-booking-root .ep-slot-reason-insufficient .ep-slot-time {
  color: #92400e !important;
}

/* ─── AGE CHIPS ────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-age-chip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 4px 4px 4px 12px !important;
  background: linear-gradient(135deg, var(--g100), var(--g50)) !important;
  color: var(--g800) !important;
  border-radius: var(--pill) !important;
  font-size: .8rem !important;
  font-weight: 700 !important;
  border: 1.5px solid var(--g300) !important;
  white-space: nowrap !important;
  width: auto !important;
  flex: 0 0 auto !important;
  line-height: 1.3 !important;
  transition: all .15s !important;
}
#ep-booking-root .ep-age-chip:hover {
  background: linear-gradient(135deg, var(--g300), var(--g100)) !important;
  transform: scale(1.05) !important;
}

#ep-booking-root .ep-age-chip button {
  background: transparent !important;
  border: none !important;
  color: var(--g700) !important;
  cursor: pointer !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  padding: 0 4px !important;
  border-radius: 50% !important;
  opacity: .6 !important;
  font-family: inherit !important;
}
#ep-booking-root .ep-age-chip button:hover { opacity: 1 !important; }

/* Age chips container - FLEX WRAP, not grid */
#ep-booking-root #ep-age-chips,
#ep-booking-root .ep-age-chips,
#ep-booking-root .ep-ages-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin: 0 0 .5rem !important;
  grid-template-columns: none !important;
  padding: 0 !important;
  min-height: 0 !important;
}

/* Input + button row (different element) */
#ep-booking-root .ep-age-input-row {
  display: flex !important;
  gap: 10px !important;
  align-items: center !important;
  margin-top: 12px !important;
}

/* ─── EXTRAS ───────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-extras-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: .6rem !important;
}

#ep-booking-root .ep-extra {
  display: flex !important;
  align-items: center !important;
  gap: .8rem !important;
  padding: .85rem 1rem !important;
  border: 2px solid var(--border) !important;
  border-radius: var(--r1) !important;
  background: var(--paper) !important;
  cursor: pointer !important;
  transition: all .15s !important;
  user-select: none !important;
}

#ep-booking-root .ep-extra:hover {
  border-color: var(--o500) !important;
  background: var(--o50) !important;
  transform: translateY(-1px) !important;
}

#ep-booking-root .ep-extra.selected {
  border-color: var(--o600) !important;
  background: var(--o100) !important;
  box-shadow: 0 0 0 3px rgba(232,99,26,.12) !important;
}

#ep-booking-root .ep-extra-check {
  width: 22px !important;
  height: 22px !important;
  border: 2px solid var(--bord2) !important;
  border-radius: 7px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: .85rem !important;
  font-weight: 800 !important;
  flex-shrink: 0 !important;
  transition: all .15s !important;
  background: var(--paper) !important;
}

#ep-booking-root .ep-extra.selected .ep-extra-check {
  background: var(--o600) !important;
  border-color: var(--o600) !important;
  color: #fff !important;
}

#ep-booking-root .ep-extra-name {
  flex: 1 !important;
  font-size: .9rem !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
}

#ep-booking-root .ep-extra-price {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 800 !important;
  color: var(--o600) !important;
  font-size: .92rem !important;
  font-variant-numeric: tabular-nums !important;
}

/* ─── SUMMARY ──────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-summary {
  background: linear-gradient(135deg, var(--cream), var(--cream2)) !important;
  border: 1.5px solid var(--bord2) !important;
  border-radius: var(--r2) !important;
  padding: 1.25rem 1.5rem !important;
}

#ep-booking-root .ep-summary-section {
  padding: .6rem 0 !important;
  border-bottom: 1.5px dashed var(--bord2) !important;
}
#ep-booking-root .ep-summary-section:last-child {
  border-bottom: none !important;
  padding-bottom: 0 !important;
}

#ep-booking-root .ep-summary-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: baseline !important;
  padding: .3rem 0 !important;
  font-size: .88rem !important;
  gap: 1rem !important;
}

#ep-booking-root .ep-summary-row .ep-lbl {
  color: var(--muted) !important;
  font-weight: 600 !important;
  font-size: .82rem !important;
}

#ep-booking-root .ep-summary-row .ep-val {
  color: var(--ink) !important;
  font-weight: 700 !important;
  font-variant-numeric: tabular-nums !important;
  text-align: right !important;
}

#ep-booking-root .ep-summary-row.total {
  padding: .9rem 0 .35rem !important;
  border-top: 2px solid var(--g700) !important;
  margin-top: .35rem !important;
}

#ep-booking-root .ep-summary-row.total .ep-lbl {
  font-family: 'Poppins', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--g900) !important;
}

#ep-booking-root .ep-summary-row.total .ep-val {
  font-family: 'Poppins', sans-serif !important;
  font-size: 1.85rem !important;
  font-weight: 900 !important;
  background: linear-gradient(135deg, var(--g700), var(--g500)) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  letter-spacing: -.02em !important;
}

#ep-booking-root .ep-summary-hint {
  font-size: .75rem !important;
  color: var(--muted) !important;
  margin: .5rem 0 0 !important;
  font-style: italic !important;
}

#ep-booking-root .ep-line {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: .3rem 0 !important;
  font-size: .92rem !important;
}
#ep-booking-root .ep-line .ep-item-n { color: var(--soft) !important; font-weight: 500 !important; }
#ep-booking-root .ep-line .ep-item-v { color: var(--ink) !important; font-weight: 700 !important; font-variant-numeric: tabular-nums !important; }

/* ─── BUTTONS ──────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-actions {
  display: flex !important;
  justify-content: space-between !important;
  gap: .75rem !important;
  margin: 1.5rem 0 0 !important;
}

#ep-booking-root .ep-btn {
  padding: .95rem 1.75rem !important;
  border-radius: var(--pill) !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: .92rem !important;
  font-weight: 800 !important;
  cursor: pointer !important;
  border: none !important;
  transition: all .2s cubic-bezier(.4,0,.2,1) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .5rem !important;
  letter-spacing: .01em !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
}

#ep-booking-root .ep-btn-primary {
  background: linear-gradient(135deg, #ff7a33 0%, #e8631a 50%, #c2471a 100%) !important;
  color: #fff !important;
  font-size: 1rem !important;
  padding: 1.1rem 2.25rem !important;
  letter-spacing: .02em !important;
  box-shadow:
    0 2px 0 rgba(145,52,12,.3),
    0 8px 16px rgba(232,99,26,.3),
    inset 0 1px 0 rgba(255,255,255,.3) !important;
  position: relative !important;
  overflow: hidden !important;
  text-shadow: 0 1px 2px rgba(0,0,0,.15) !important;
}

#ep-booking-root .ep-btn-primary::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(120deg,
    transparent 20%,
    rgba(255,255,255,.35) 40%,
    rgba(255,255,255,.35) 50%,
    transparent 70%) !important;
  transform: translateX(-100%) !important;
  transition: transform .6s cubic-bezier(.4,0,.2,1) !important;
  pointer-events: none !important;
}

#ep-booking-root .ep-btn-primary:hover {
  transform: translateY(-2px) !important;
  box-shadow:
    0 4px 0 rgba(145,52,12,.3),
    0 14px 28px rgba(232,99,26,.45),
    inset 0 1px 0 rgba(255,255,255,.3) !important;
}
#ep-booking-root .ep-btn-primary:hover::before { transform: translateX(100%) !important; }

#ep-booking-root .ep-btn-primary:active {
  transform: translateY(0) !important;
  box-shadow:
    0 1px 0 rgba(145,52,12,.3),
    0 4px 10px rgba(232,99,26,.3),
    inset 0 1px 0 rgba(255,255,255,.2) !important;
}

/* ─── ORANGE BUTTON (primary action on payment/proposal/new-booking) ─── */
#ep-booking-root .ep-btn-orange {
  background: linear-gradient(135deg, #ff8c42 0%, #ff6b1a 50%, #c2471a 100%) !important;
  color: #fff !important;
  font-size: 1.05rem !important;
  font-weight: 800 !important;
  padding: 1.1rem 2.5rem !important;
  letter-spacing: .03em !important;
  text-transform: none !important;
  border: none !important;
  border-radius: var(--pill) !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .6rem !important;
  line-height: 1.2 !important;
  font-family: 'Poppins', sans-serif !important;
  transition: all .25s cubic-bezier(.4,0,.2,1) !important;
  position: relative !important;
  overflow: hidden !important;
  text-shadow: 0 1px 2px rgba(0,0,0,.18) !important;
  box-shadow:
    0 3px 0 #8b3411,
    0 8px 18px rgba(232,99,26,.4),
    0 0 0 1px rgba(255,255,255,.1) inset,
    0 1px 0 rgba(255,255,255,.35) inset !important;
}

#ep-booking-root .ep-btn-orange::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: -30% !important;
  height: 100% !important;
  width: 30% !important;
  background: linear-gradient(120deg,
    transparent 0%,
    rgba(255,255,255,.0) 30%,
    rgba(255,255,255,.5) 50%,
    rgba(255,255,255,.0) 70%,
    transparent 100%) !important;
  transform: skewX(-20deg) !important;
  transition: left .7s cubic-bezier(.4,0,.2,1) !important;
  pointer-events: none !important;
}

#ep-booking-root .ep-btn-orange:hover {
  transform: translateY(-3px) !important;
  box-shadow:
    0 6px 0 #8b3411,
    0 14px 30px rgba(232,99,26,.55),
    0 0 0 1px rgba(255,255,255,.15) inset,
    0 1px 0 rgba(255,255,255,.4) inset !important;
}

#ep-booking-root .ep-btn-orange:hover::before { left: 130% !important; }

#ep-booking-root .ep-btn-orange:active {
  transform: translateY(0) !important;
  box-shadow:
    0 1px 0 #8b3411,
    0 3px 10px rgba(232,99,26,.35),
    0 0 0 1px rgba(255,255,255,.1) inset !important;
}



#ep-booking-root .ep-btn-secondary {
  background: var(--paper) !important;
  color: var(--soft) !important;
  border: 2px solid var(--bord2) !important;
}

#ep-booking-root .ep-btn-secondary:hover {
  border-color: var(--g700) !important;
  color: var(--g800) !important;
  background: var(--g50) !important;
}

/* ─── PAYMENT ──────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-pay-methods,
#ep-booking-root .ep-pay-options {
  display: flex !important;
  flex-direction: column !important;
  gap: .5rem !important;
}

#ep-booking-root .ep-pay-option {
  display: flex !important;
  align-items: center !important;
  gap: 1rem !important;
  padding: 1.1rem 1.35rem !important;
  border: 2px solid var(--border) !important;
  border-radius: var(--r2) !important;
  background: var(--paper) !important;
  cursor: pointer !important;
  transition: all .2s cubic-bezier(.4,0,.2,1) !important;
  position: relative !important;
  overflow: hidden !important;
}

#ep-booking-root .ep-pay-option::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 5px !important;
  background: var(--method-color, var(--g500)) !important;
  opacity: 0 !important;
  transition: opacity .2s !important;
}

/* Color-code each payment method */
#ep-booking-root .ep-pay-option[data-method="mbway"]          { --method-color: #FF3B7F; }
#ep-booking-root .ep-pay-option[data-method="multibanco"]     { --method-color: #2d5fa6; }
#ep-booking-root .ep-pay-option[data-method="cartao"]         { --method-color: #6c4cd4; }
#ep-booking-root .ep-pay-option[data-method="transferencia"]  { --method-color: #1a6b3c; }

#ep-booking-root .ep-pay-option:hover {
  border-color: var(--method-color, var(--g500)) !important;
  background: var(--paper) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,.06) !important;
}
#ep-booking-root .ep-pay-option:hover::before { opacity: 1 !important; }

#ep-booking-root .ep-pay-option.selected {
  border-color: var(--method-color, var(--g700)) !important;
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--method-color, var(--g700)) 8%, white),
    color-mix(in srgb, var(--method-color, var(--g700)) 3%, white)) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--method-color, var(--g700)) 15%, transparent),
              0 4px 12px rgba(0,0,0,.08) !important;
}
#ep-booking-root .ep-pay-option.selected::before { opacity: 1 !important; }

#ep-booking-root .ep-payment-split {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 1rem !important;
  margin: 1rem 0 0 !important;
  background: var(--g50) !important;
  border: 1.5px solid var(--g300) !important;
  border-radius: var(--r2) !important;
  padding: 1rem 1.25rem !important;
}

#ep-booking-root .ep-payment-split-col:first-child {
  border-right: 1.5px dashed var(--g300) !important;
  padding-right: 1rem !important;
}

#ep-booking-root .ep-payment-label {
  font-size: .7rem !important;
  font-weight: 800 !important;
  color: var(--g700) !important;
  text-transform: uppercase !important;
  letter-spacing: .07em !important;
  display: block !important;
}

#ep-booking-root .ep-payment-amount {
  font-family: 'Poppins', sans-serif !important;
  font-size: 1.35rem !important;
  font-weight: 800 !important;
  color: var(--g900) !important;
  margin-top: 2px !important;
  display: block !important;
}

/* ─── PROPOSAL NOTICE ──────────────────────────────────────────────────────── */
#ep-booking-root .ep-proposal-notice {
  display: flex !important;
  gap: 1rem !important;
  padding: 1.25rem 1.5rem !important;
  background: #e8eef8 !important;
  border: 1.5px solid var(--escolar) !important;
  border-radius: var(--r2) !important;
  margin: 0 0 1.25rem !important;
  align-items: flex-start !important;
}

#ep-booking-root .ep-proposal-notice > span:first-child {
  font-size: 1.75rem !important;
  flex-shrink: 0 !important;
  line-height: 1 !important;
}

#ep-booking-root .ep-proposal-notice > div {
  font-size: .88rem !important;
  color: var(--escolar) !important;
  line-height: 1.5 !important;
}

#ep-booking-root .ep-proposal-notice strong {
  color: var(--escolar) !important;
  font-weight: 800 !important;
}

/* ─── CONFIRMATION (step 5) ────────────────────────────────────────────────── */
#ep-booking-root .ep-confirmation {
  text-align: center !important;
  padding: 3rem 1.5rem 2rem !important;
  position: relative !important;
  background: radial-gradient(ellipse at top, rgba(37,160,88,.08) 0%, transparent 60%) !important;
  border-radius: var(--r3) !important;
  overflow: hidden !important;
}

#ep-booking-root .ep-confirmation::before {
  content: '🎉' !important;
  position: absolute !important;
  top: 1.5rem !important;
  left: 2rem !important;
  font-size: 2rem !important;
  opacity: .4 !important;
  animation: ep-float 4s ease-in-out infinite !important;
}

#ep-booking-root .ep-confirmation::after {
  content: '🎊' !important;
  position: absolute !important;
  top: 2rem !important;
  right: 2rem !important;
  font-size: 2rem !important;
  opacity: .4 !important;
  animation: ep-float 5s ease-in-out infinite reverse !important;
}

#ep-booking-root .ep-conf-icon {
  width: 110px !important;
  height: 110px !important;
  margin: 0 auto 1.5rem !important;
  background: linear-gradient(135deg, #25a058 0%, #1a6b3c 60%, #0f3d2e 100%) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 3.25rem !important;
  color: #fff !important;
  box-shadow:
    0 8px 24px rgba(26,107,60,.35),
    0 16px 48px rgba(26,107,60,.25),
    inset 0 2px 0 rgba(255,255,255,.2) !important;
  animation: ep-pop .6s cubic-bezier(.16,1.3,.6,1) !important;
  position: relative !important;
}

#ep-booking-root .ep-conf-icon::before {
  content: '' !important;
  position: absolute !important;
  inset: -8px !important;
  border: 3px dashed var(--g300) !important;
  border-radius: 50% !important;
  opacity: .5 !important;
  animation: ep-spin 20s linear infinite !important;
}

@keyframes ep-pop {
  0% { transform: scale(.5); opacity: 0; }
  60% { transform: scale(1.08); }
  100% { transform: scale(1); opacity: 1; }
}

#ep-booking-root .ep-conf-title {
  font-family: 'Poppins', sans-serif !important;
  font-size: clamp(1.85rem, 4vw, 2.5rem) !important;
  font-weight: 900 !important;
  color: var(--g900) !important;
  margin: 0 0 .5rem !important;
  letter-spacing: -.03em !important;
  text-align: center !important;
  line-height: 1.05 !important;
}
#ep-booking-root .ep-confirmation > p {
  text-align: center !important;
  color: var(--muted) !important;
  font-size: 1rem !important;
  margin: 0 !important;
}

#ep-booking-root .ep-booking-ref {
  display: inline-block !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 1.25rem !important;
  font-weight: 800 !important;
  color: var(--g800) !important;
  background: linear-gradient(135deg, var(--g100), var(--g50)) !important;
  padding: .7rem 1.6rem !important;
  border-radius: var(--pill) !important;
  margin: 1rem 0 1.75rem !important;
  border: 2px solid var(--g300) !important;
  letter-spacing: .04em !important;
  box-shadow: 0 4px 12px rgba(26,107,60,.12) !important;
  text-transform: uppercase !important;
}

#ep-booking-root .ep-conf-details {
  background: var(--cream) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r2) !important;
  padding: 1.25rem 1.5rem !important;
  text-align: left !important;
  margin: 0 0 1rem !important;
}

#ep-booking-root .ep-conf-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: baseline !important;
  padding: .5rem 0 !important;
  font-size: .92rem !important;
}

#ep-booking-root .ep-conf-row:not(:last-child) {
  border-bottom: 1px dashed var(--bord2) !important;
}

#ep-booking-root .ep-conf-lbl { color: var(--muted) !important; font-weight: 500 !important; }
#ep-booking-root .ep-conf-val { font-weight: 700 !important; color: var(--ink) !important; font-variant-numeric: tabular-nums !important; text-align: right !important; }

#ep-booking-root .ep-contact-redirect {
  background: var(--g50) !important;
  border: 1.5px solid var(--g300) !important;
  border-radius: var(--r2) !important;
  padding: 1.25rem 1.5rem !important;
  margin: 1rem 0 0 !important;
  font-size: .88rem !important;
  line-height: 1.6 !important;
  color: var(--g800) !important;
  text-align: left !important;
}

/* ─── NOTIFICATION ─────────────────────────────────────────────────────────── */
#ep-booking-root .ep-notif {
  position: fixed !important;
  bottom: 1.5rem !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(120%) !important;
  background: var(--ink) !important;
  color: #fff !important;
  padding: .85rem 1.5rem !important;
  border-radius: var(--pill) !important;
  font-weight: 600 !important;
  font-size: .9rem !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.25) !important;
  opacity: 0 !important;
  transition: all .3s cubic-bezier(.4,0,.2,1) !important;
  z-index: 9999 !important;
  pointer-events: none !important;
}

#ep-booking-root .ep-notif.show {
  opacity: 1 !important;
  transform: translateX(-50%) translateY(0) !important;
}

/* ─── LOADING ──────────────────────────────────────────────────────────────── */
#ep-booking-root .ep-loading {
  text-align: center !important;
  padding: 3rem 1rem !important;
  color: var(--muted) !important;
  font-size: .95rem !important;
  font-weight: 500 !important;
}

#ep-booking-root .ep-loading::before {
  content: '' !important;
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
  border: 2.5px solid var(--bord2) !important;
  border-top-color: var(--g700) !important;
  border-radius: 50% !important;
  margin-right: .5rem !important;
  vertical-align: middle !important;
  animation: ep-spin .8s linear infinite !important;
}

@keyframes ep-spin { to { transform: rotate(360deg); } }

/* ─── RESPONSIVE ───────────────────────────────────────────────────────────── */
@media (max-width: 720px) {
  #ep-booking-root .ep-form-row,
  #ep-booking-root .ep-form-row.three {
    grid-template-columns: 1fr !important;
  }
  #ep-booking-root .ep-progress { padding: .75rem 1rem !important; gap: .5rem !important; }
  #ep-booking-root .ep-progress .ep-step .ep-step-label { display: none !important; }
  #ep-booking-root .ep-card { padding: 1.25rem 1.1rem !important; }
  #ep-booking-root .ep-card-title { font-size: 1rem !important; }
  #ep-booking-root .ep-btn { padding: .8rem 1.25rem !important; font-size: .85rem !important; }
  #ep-booking-root .ep-actions { flex-direction: column-reverse !important; }
  #ep-booking-root .ep-actions .ep-btn { width: 100% !important; }
  #ep-booking-root .ep-payment-split { grid-template-columns: 1fr !important; gap: .75rem !important; padding: 1rem !important; }
  #ep-booking-root .ep-payment-split-col:first-child {
    border-right: none !important;
    border-bottom: 1.5px dashed var(--g300) !important;
    padding-right: 0 !important;
    padding-bottom: .75rem !important;
  }
}

/* ─── Confirmation layout — center everything ───────────────────────────── */
#ep-booking-root .ep-confirmation,
#ep-booking-root .ep-confirmation * {
  text-align: center !important;
}
#ep-booking-root .ep-confirmation .ep-conf-details,
#ep-booking-root .ep-confirmation .ep-conf-row,
#ep-booking-root .ep-confirmation .ep-conf-lbl,
#ep-booking-root .ep-confirmation .ep-conf-val,
#ep-booking-root .ep-confirmation .ep-contact-redirect,
#ep-booking-root .ep-confirmation .ep-success-bank,
#ep-booking-root .ep-confirmation .ep-success-bank-row {
  text-align: left !important;
}
#ep-booking-root .ep-confirmation .ep-conf-val { text-align: right !important; }



/* Subtle halftone pattern inside the main card (progress + wrap only) */
#ep-booking-root .ep-progress {
  background:
    radial-gradient(circle at 2px 2px, rgba(1,190,254,.05) 1px, transparent 0) 0 0 / 16px 16px,
    var(--paper) !important;
}

/* Card-icon — a bit punchier: rotate slightly, larger shadow */
#ep-booking-root .ep-card-icon {
  transform: rotate(-3deg) !important;
  transition: transform .3s !important;
}
#ep-booking-root .ep-card:hover .ep-card-icon {
  transform: rotate(3deg) scale(1.05) !important;
}

/* Counter buttons — brand cyan accent on hover */
#ep-booking-root .ep-counter-btn:hover {
  border-color: var(--brand-cyan) !important;
  color: var(--brand-cyan) !important;
  background: #e1f7ff !important;
}

/* Slot selected — use brand lime for extra energy */
#ep-booking-root .ep-slot.selected {
  background: linear-gradient(135deg, var(--g600), var(--g800)) !important;
  border-color: var(--g800) !important;
}

/* ─── CLICKABLE PROGRESS STEPS ────────────────────────────────────────────── */
/* Steps that are already "done" become clickable — user can jump back */
#ep-booking-root .ep-progress .ep-step.clickable {
  cursor: pointer !important;
  transition: transform .15s ease, opacity .15s ease !important;
  border-radius: 999px !important;
  padding: 4px 8px !important;
  margin: -4px -8px !important;
}

#ep-booking-root .ep-progress .ep-step.clickable:hover {
  transform: translateY(-1px) !important;
  background: var(--g50) !important;
}

#ep-booking-root .ep-progress .ep-step.clickable:hover .ep-step-num {
  box-shadow: 0 4px 12px rgba(26,107,60,.4) !important;
  transform: scale(1.12) !important;
}

#ep-booking-root .ep-progress .ep-step.clickable:hover .ep-step-label {
  color: var(--g800) !important;
}

#ep-booking-root .ep-progress .ep-step.clickable:focus-visible {
  outline: 2px solid var(--g500) !important;
  outline-offset: 2px !important;
}

#ep-booking-root .ep-progress .ep-step.clickable:active .ep-step-num {
  transform: scale(1.05) !important;
}

/* Subtle hint: done steps show they're interactive via tooltip-like cursor */
#ep-booking-root .ep-progress .ep-step.clickable::after {
  content: '' !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   HYBRID THEME (v5.9.8)
   Dark navy background · Dark hero · White glass cards (50% opacity + blur)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── HERO — DARK MODE ─────────────────────────────────────────────────── */
#ep-booking-root .ep-hero {
  background:
    radial-gradient(ellipse 70% 100% at 0% 0%, rgba(112,224,0,.20) 0%, transparent 55%),
    radial-gradient(ellipse 60% 100% at 100% 100%, rgba(1,190,254,.28) 0%, transparent 55%),
    radial-gradient(ellipse 50% 80% at 50% 50%, rgba(255,107,26,.10) 0%, transparent 60%),
    linear-gradient(135deg, #0e1c36 0%, #0a1628 60%, #0d1a30 100%) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  box-shadow:
    0 24px 60px rgba(0,0,0,.45),
    0 0 0 1px rgba(1,190,254,.15) inset,
    0 -2px 0 rgba(255,255,255,.04) inset !important;
}

/* Blobs inside hero — brighter on dark, more saturated */
#ep-booking-root .ep-hero::before {
  background: radial-gradient(circle,
    #70e000 0%,
    rgba(112,224,0,.55) 30%,
    transparent 70%) !important;
  opacity: .55 !important;
  filter: blur(6px) !important;
}

#ep-booking-root .ep-hero::after {
  background: radial-gradient(circle,
    #01befe 0%,
    rgba(1,190,254,.5) 35%,
    transparent 70%) !important;
  opacity: .5 !important;
  filter: blur(6px) !important;
}

/* Hero text — white/light on dark */
#ep-booking-root .ep-hero h1 {
  color: #ffffff !important;
  text-shadow: 0 2px 24px rgba(0,0,0,.3) !important;
}

/* Underline behind "Reserva." — brighter on dark */
#ep-booking-root .ep-hero h1 .accent::after {
  opacity: .55 !important;
  height: 14px !important;
  filter: blur(2px) !important;
}

/* Tagline — softer white */
#ep-booking-root .ep-hero .tagline,
#ep-booking-root .ep-hero p {
  color: rgba(255,255,255,.75) !important;
  font-weight: 500 !important;
}

/* ─── CARDS (main step cards) — solid creamy white (readable over dark bg) ─ */
#ep-booking-root .ep-card {
  background: #fefdfb !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border: 1px solid rgba(255,255,255,0.15) !important;
  box-shadow:
    0 30px 80px rgba(0,0,0,.35),
    0 6px 16px rgba(0,0,0,.2),
    0 1px 0 rgba(255,255,255,.8) inset !important;
}

/* Progress bar — also solid */
#ep-booking-root .ep-progress {
  background: #fefdfb !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border: 1px solid rgba(255,255,255,0.15) !important;
  border-radius: var(--r2) !important;
  padding: 18px 22px !important;
  box-shadow:
    0 20px 50px rgba(0,0,0,.3),
    0 2px 8px rgba(0,0,0,.18),
    0 1px 0 rgba(255,255,255,.8) inset !important;
}

/* ─── PROGRAM CARDS — solid creamy white ────────────────────────────────── */
#ep-booking-root .ep-product-card {
  background: #ffffff !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border: 1px solid rgba(0,0,0,0.05) !important;
  box-shadow:
    0 16px 36px rgba(0,0,0,.3),
    0 3px 8px rgba(0,0,0,.15),
    0 1px 0 rgba(255,255,255,.9) inset !important;
}

#ep-booking-root .ep-product-card:hover {
  background: #ffffff !important;
  box-shadow:
    0 24px 50px rgba(0,0,0,.4),
    0 4px 10px rgba(0,0,0,.22),
    0 0 0 2px var(--cat-color, var(--o500)) inset !important;
}

/* Program tabs container — transparent (tabs float directly on the card) */
#ep-booking-root .ep-program-tabs {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

/* Non-active tabs: light pills with subtle border */
#ep-booking-root .ep-program-tab:not(.active) {
  background: #ffffff !important;
  border: 1.5px solid #e5ddcf !important;
  color: var(--g800) !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04) !important;
}

#ep-booking-root .ep-program-tab:not(.active):hover {
  background: #ffffff !important;
  border-color: var(--g500) !important;
  transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(0,0,0,0.08) !important;
}

/* ─── ALERTS / NOTIFICATIONS — stronger shadow on dark ─────────────────── */
#ep-booking-root .ep-alert,
#ep-booking-root .ep-notif {
  box-shadow: 0 10px 30px rgba(0,0,0,.45) !important;
}

/* ─── TYPOGRAPHY — Poppins tuning ──────────────────────────────────────── */
#ep-booking-root {
  font-weight: 400 !important;
  letter-spacing: -0.005em !important;
}

#ep-booking-root h1,
#ep-booking-root h2,
#ep-booking-root h3,
#ep-booking-root .ep-card-title,
#ep-booking-root .ep-product-name {
  letter-spacing: -0.025em !important;
}

#ep-booking-root .ep-hero h1 {
  letter-spacing: -0.04em !important;
  font-weight: 900 !important;
}

/* ─── MINOR: elevate form inputs so they sit nicely on glass cards ─────── */
#ep-booking-root input[type=text],
#ep-booking-root input[type=email],
#ep-booking-root input[type=tel],
#ep-booking-root input[type=date],
#ep-booking-root input[type=number],
#ep-booking-root select,
#ep-booking-root textarea {
  background: rgba(255,255,255,.85) !important;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

/* ─── VALIDATION STATES ───────────────────────────────────────────────── */
/* Invalid fields: red border + subtle shake animation */
#ep-booking-root .ep-field-invalid {
  border: 2px solid #e53935 !important;
  box-shadow: 0 0 0 3px rgba(229,57,53,.15) !important;
  animation: epShake .35s ease-in-out;
}
@keyframes epShake {
  0%,100% { transform: translateX(0); }
  25%     { transform: translateX(-4px); }
  75%     { transform: translateX(4px); }
}

/* For non-input elements (slots container, counter) */
#ep-booking-root #ep-slots.ep-field-invalid,
#ep-booking-root #ep-count.ep-field-invalid {
  border: 2px dashed #e53935 !important;
  background: rgba(229,57,53,.05) !important;
  border-radius: 10px !important;
  padding: 8px !important;
  box-shadow: 0 0 0 3px rgba(229,57,53,.1) !important;
}

/* Inline error message beneath a field */
#ep-booking-root .ep-field-error {
  display: block !important;
  font-size: .78rem !important;
  color: #c00 !important;
  font-weight: 700 !important;
  margin-top: 6px !important;
  padding: 6px 10px !important;
  background: rgba(229,57,53,.08) !important;
  border-left: 3px solid #e53935 !important;
  border-radius: 4px !important;
  animation: epFadeIn .25s ease-out;
}
@keyframes epFadeIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Error toast: top-right corner, always visible */
#ep-booking-root .ep-error-toast {
  position: fixed !important;
  top: 20px !important;
  right: 20px !important;
  z-index: 2147483647 !important;
  background: linear-gradient(135deg, #e53935 0%, #c62828 100%) !important;
  color: #fff !important;
  padding: 14px 20px !important;
  border-radius: 12px !important;
  font-size: .92rem !important;
  font-weight: 700 !important;
  box-shadow: 0 12px 30px rgba(229,57,53,.4), 0 4px 10px rgba(0,0,0,.2) !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  max-width: 360px !important;
  opacity: 0 !important;
  transform: translateX(20px) !important;
  transition: opacity .25s, transform .25s !important;
  pointer-events: none !important;
}
#ep-booking-root .ep-error-toast.show {
  opacity: 1 !important;
  transform: translateX(0) !important;
}
#ep-booking-root .ep-error-toast-icon {
  font-size: 1.25rem !important;
  flex-shrink: 0 !important;
}

/* Mobile: full-width toast at top */
@media (max-width: 640px) {
  #ep-booking-root .ep-error-toast {
    top: 12px !important;
    right: 12px !important;
    left: 12px !important;
    max-width: none !important;
  }
}
