/* ============================================
   CHRIST EMBASSY VANDERBIJLPARK
   Deep Blue & Gold Royal Theme
   ============================================ */

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

/* ── CSS Variables ── */
:root {
  --black:      #0b1628;
  --dark:       #0d1f3c;
  --dark-card:  #122444;
  --dark-mid:   #1a3a6b;
  --border:     #1e3f72;
  --border-light: #2a5099;
  --gold:       #c9a84c;
  --gold-light: #e8c96e;
  --gold-dark:  #9a7a30;
  --blue:       #1a3a6b;
  --blue-bright:#2558b0;
  --blue-glow:  rgba(37, 88, 176, 0.3);
  --white:      #ffffff;
  --off-white:  #dce8f5;
  --text-muted: #7a9bc0;
  --font-display: 'Cormorant Garamond', serif;
  --font-body:    'Montserrat', sans-serif;
  --nav-height:   72px;
  --transition:   0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--black);
  color: var(--white);
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.7;
  overflow-x: hidden;
  padding-top: var(--nav-height);
}
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }
ul { list-style: none; }

/* ============================================
   LIVE NOTIFICATION BAR
   ============================================ */
.live-bar {
  background: linear-gradient(90deg, #0b1628, #1a3a6b, #0b1628);
  border-bottom: 1px solid var(--gold-dark);
  padding: 10px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 1000;
}
.live-content {
  display: flex;
  align-items: center;
  gap: 14px;
  flex: 1;
}
.pulsing-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: #ff3333;
  box-shadow: 0 0 0 0 rgba(255, 51, 51, 0.7);
  animation: pulse-red 1.5s infinite;
  flex-shrink: 0;
}
@keyframes pulse-red {
  0%   { box-shadow: 0 0 0 0 rgba(255,51,51,0.7); }
  70%  { box-shadow: 0 0 0 8px rgba(255,51,51,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,51,51,0); }
}
.live-content p { font-size: 13px; color: var(--off-white); letter-spacing: 0.5px; }
.live-content strong { color: var(--gold-light); }
.watch-btn {
  background: var(--gold);
  color: var(--black);
  padding: 5px 16px;
  border-radius: 2px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  transition: var(--transition);
  white-space: nowrap;
}
.watch-btn:hover { background: var(--gold-light); }
.close-notification {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 22px;
  cursor: pointer;
  padding: 4px 4px 4px 16px;
  transition: var(--transition);
  flex-shrink: 0;
  line-height: 1;
  position: relative;
  z-index: 10;
  pointer-events: all;
}
.close-notification:hover { color: var(--white); }

/* ============================================
   NAVBAR
   ============================================ */
.navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1100;
  background: rgba(4, 16, 34, 0.97);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  height: var(--nav-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 40px;
}
.logo img { height: 46px; object-fit: contain; }
.nav-links {
  display: flex;
  align-items: center;
  gap: 6px;
}
.nav-links li a {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 8px 14px;
  border-radius: 2px;
  transition: var(--transition);
  position: relative;
}
.nav-links li a::after {
  content: '';
  position: absolute;
  bottom: 2px; left: 14px; right: 14px;
  height: 1px;
  background: var(--gold);
  transform: scaleX(0);
  transition: var(--transition);
}
.nav-links li a:hover { color: var(--white); }
.nav-links li a:hover::after { transform: scaleX(1); }
.nav-links li a.active { color: var(--gold); }
.btn-nav {
  background: var(--gold) !important;
  color: var(--black) !important;
  border-radius: 2px !important;
  padding: 9px 20px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
}
.btn-nav:hover { background: var(--gold-light) !important; }
.btn-nav::after { display: none !important; }

/* Hamburger */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  background: none;
  border: none;
  padding: 4px;
}
.hamburger span {
  display: block;
  width: 26px; height: 2px;
  background: var(--gold);
  border-radius: 2px;
  transition: var(--transition);
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile nav */
.mobile-nav {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(2, 11, 24, 0.99);
  z-index: 998;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 32px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
}
.mobile-nav.open { opacity: 1; pointer-events: all; }
.mobile-nav a {
  font-family: var(--font-display);
  font-size: 36px;
  font-weight: 300;
  color: var(--off-white);
  letter-spacing: 3px;
  transition: var(--transition);
}
.mobile-nav a:hover { color: var(--gold); }
.mobile-nav .btn-nav-mobile {
  color: var(--black) !important;
  background: var(--gold);
  padding: 12px 36px;
  border-radius: 2px;
  font-size: 14px !important;
  font-family: var(--font-body);
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
}

/* ============================================
   HERO — INDEX
   ============================================ */
.hero-solid {
  min-height: calc(100vh - var(--nav-height));
  background:
    radial-gradient(ellipse at 30% 60%, rgba(26,74,156,0.35) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 20%, rgba(201,168,76,0.08) 0%, transparent 45%),
    linear-gradient(180deg, #0b1628 0%, #0d1f3c 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 80px 40px;
  position: relative;
  overflow: hidden;
}
.hero-solid::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background-image:
    linear-gradient(rgba(201,168,76,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201,168,76,0.04) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.hero-solid::after {
  content: '';
  position: absolute;
  bottom: -100px; right: -100px;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(26,74,156,0.2) 0%, transparent 70%);
  pointer-events: none;
}
.hero-content-wrapper {
  max-width: 700px;
  text-align: center;
  position: relative;
  z-index: 1;
  animation: fadeUp 1s ease both;
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}
.hero-logo-fixed {
  height: 90px;
  margin: 0 auto 28px;
  filter: drop-shadow(0 0 24px rgba(201,168,76,0.5));
}
.hero-tagline-gold {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 4px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 20px;
}
.hero-title-main {
  font-family: var(--font-display);
  font-size: clamp(52px, 8vw, 88px);
  font-weight: 300;
  line-height: 1.05;
  color: var(--white);
  margin-bottom: 24px;
}
.hero-title-main span {
  font-style: italic;
  background: linear-gradient(135deg, var(--gold-light), var(--gold));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero-paragraph {
  font-size: 15px;
  color: var(--text-muted);
  max-width: 480px;
  margin: 0 auto 40px;
  line-height: 1.8;
}
.hero-btn-group {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.btn-gold-action {
  background: linear-gradient(135deg, var(--gold), var(--gold-dark));
  color: var(--black);
  padding: 14px 32px;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  border-radius: 2px;
  transition: var(--transition);
  box-shadow: 0 4px 24px rgba(201,168,76,0.3);
}
.btn-gold-action:hover {
  background: linear-gradient(135deg, var(--gold-light), var(--gold));
  box-shadow: 0 6px 32px rgba(201,168,76,0.5);
  transform: translateY(-2px);
}
.btn-outline-action {
  border: 1px solid var(--border-light);
  color: var(--off-white);
  padding: 14px 32px;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  border-radius: 2px;
  transition: var(--transition);
}
.btn-outline-action:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: rgba(201,168,76,0.06);
  transform: translateY(-2px);
}

/* ============================================
   LIVE SECTION
   ============================================ */
.live {
  padding: 100px 40px;
  background: var(--dark);
  position: relative;
}
.live::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-dark), transparent);
}
.section-title {
  font-family: var(--font-display);
  font-size: clamp(32px, 5vw, 52px);
  font-weight: 300;
  text-align: center;
  margin-bottom: 60px;
  color: var(--white);
  position: relative;
}
.section-title::after {
  content: '';
  display: block;
  width: 60px; height: 2px;
  background: linear-gradient(90deg, var(--gold), var(--blue-bright));
  margin: 16px auto 0;
}
.live-split-wrapper {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 32px;
  max-width: 1200px;
  margin: 0 auto;
  align-items: start;
}
.main-video-stage { position: relative; }
.video-aspect-ratio {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  background: #0b1628;
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.video-aspect-ratio iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
}
.video-status {
  display: flex;
  gap: 10px;
  margin-top: 12px;
  align-items: center;
}
.badge-live {
  background: #cc0000;
  color: white;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  padding: 4px 10px;
  border-radius: 2px;
}
.badge-global { font-size: 11px; color: var(--text-muted); letter-spacing: 1px; }
.upcoming-sidebar {
  background: var(--dark-card);
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.sidebar-header {
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--dark-mid);
}
.sidebar-header h3 {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--white);
}
.stream-list { padding: 8px 0; }
.stream-card {
  padding: 18px 24px;
  border-bottom: 1px solid var(--border);
  transition: var(--transition);
}
.stream-card:last-child { border-bottom: none; }
.stream-card:hover { background: rgba(26,74,156,0.15); }
.service-tag {
  font-size: 9px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase;
  padding: 3px 8px; border-radius: 2px;
}
.service-tag.special { background: rgba(201,168,76,0.15); color: var(--gold); }
.stream-card h4 { font-size: 14px; font-weight: 600; color: var(--white); margin: 8px 0 4px; }
.stream-card p { font-size: 12px; color: var(--text-muted); }

/* ============================================
   MINISTRIES SECTION (HOME)
   ============================================ */
.ministries-hero-new {
  padding: 100px 40px;
  background: var(--black);
  position: relative;
  overflow: hidden;
}
.ministries-hero-new::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(26,74,156,0.2) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 50%, rgba(201,168,76,0.05) 0%, transparent 50%);
  pointer-events: none;
}
.blue-curve-bg {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
  position: relative;
  z-index: 1;
}
.ministry-title-new {
  font-family: var(--font-display);
  font-size: clamp(40px, 6vw, 68px);
  font-weight: 300;
  line-height: 1.1;
  color: var(--white);
  margin-bottom: 20px;
}
.ministry-divider-new {
  width: 80px; height: 2px;
  background: linear-gradient(90deg, var(--blue-bright), var(--gold));
  margin: 0 auto 28px;
}
.ministry-text-new {
  font-size: 15px;
  color: var(--text-muted);
  max-width: 600px;
  margin: 0 auto 40px;
  line-height: 1.9;
}
.btn-read-more-new {
  display: inline-block;
  border: 1px solid var(--gold-dark);
  color: var(--gold);
  padding: 13px 36px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  border-radius: 2px;
  transition: var(--transition);
}
.btn-read-more-new:hover { background: rgba(201,168,76,0.08); border-color: var(--gold); }

/* ============================================
   VISIT US
   ============================================ */
.visit-us {
  padding: 100px 40px;
  background: var(--dark);
  position: relative;
}
.visit-us::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border-light), transparent);
}
.visit-container {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.contact-details-side h1 {
  font-family: var(--font-display);
  font-size: clamp(36px, 5vw, 58px);
  font-weight: 300;
  line-height: 1.1;
  margin-bottom: 48px;
  color: var(--white);
}
.info-block {
  display: flex;
  gap: 20px;
  margin-bottom: 36px;
  align-items: flex-start;
}
.icon-circle {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--border-light);
  background: rgba(26,74,156,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
  font-size: 16px;
  flex-shrink: 0;
}
.text-content h3 {
  font-size: 11px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--gold); margin-bottom: 6px;
}
.text-content p { color: var(--text-muted); font-size: 14px; line-height: 1.7; }
.direction-link, .email-link {
  color: var(--gold); font-size: 12px;
  letter-spacing: 1px;
  border-bottom: 1px solid transparent;
  transition: var(--transition);
  display: inline-block; margin-top: 4px;
}
.direction-link:hover, .email-link:hover { border-color: var(--gold); }
.map-frame {
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
  height: 380px;
  box-shadow: 0 0 40px rgba(26,74,156,0.2);
}
.map-frame iframe { width: 100%; height: 100%; }

/* ============================================
   FOOTER
   ============================================ */
.main-footer {
  background: #010810;
  border-top: 1px solid var(--border);
  padding: 80px 40px 0;
  position: relative;
}
.main-footer::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-dark), transparent);
}
.footer-container {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 64px;
  padding-bottom: 64px;
  border-bottom: 1px solid var(--border);
}
.footer-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.footer-logo img { height: 40px; }
.footer-logo h2 { font-size: 13px; font-weight: 700; letter-spacing: 2px; color: var(--gold); }
.brand-info p { font-size: 13px; color: var(--text-muted); line-height: 1.8; margin-bottom: 24px; max-width: 280px; }
.social-links { display: flex; gap: 12px; }
.social-icon {
  width: 38px; height: 38px;
  border: 1px solid var(--border);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted); font-size: 14px;
  transition: var(--transition);
}
.social-icon:hover { border-color: var(--gold); color: var(--gold); background: rgba(201,168,76,0.08); }
.footer-col h3 { font-size: 11px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); margin-bottom: 24px; }
.footer-nav li { margin-bottom: 12px; }
.footer-nav a { font-size: 13px; color: var(--text-muted); transition: var(--transition); }
.footer-nav a:hover { color: var(--white); padding-left: 4px; }
.contact-info address { font-style: normal; font-size: 13px; color: var(--text-muted); line-height: 1.8; margin-bottom: 16px; }
.contact-info .phone { font-size: 13px; color: var(--text-muted); margin-bottom: 6px; }
.contact-info .email { font-size: 12px; color: var(--gold); }
.footer-bottom {
  max-width: 1200px; margin: 0 auto;
  padding: 24px 0;
  display: flex; justify-content: space-between;
  align-items: center; flex-wrap: wrap; gap: 8px;
}
.footer-bottom p { font-size: 11px; color: var(--text-muted); letter-spacing: 1.5px; }
.footer-bottom .tagline { color: var(--gold-dark); font-style: italic; letter-spacing: 2px; }

/* ============================================
   PAGE HERO (inner pages)
   ============================================ */
.page-hero {
  padding: 100px 40px 80px;
  text-align: center;
  background:
    radial-gradient(ellipse at center top, rgba(26,74,156,0.3) 0%, transparent 60%),
    var(--black);
  border-bottom: 1px solid var(--border);
  position: relative;
}
.page-hero h1 { font-family: var(--font-display); font-size: clamp(48px, 7vw, 80px); font-weight: 300; color: var(--white); margin-bottom: 16px; }
.page-hero p { font-size: 15px; color: var(--text-muted); max-width: 560px; margin: 0 auto; }

/* ============================================
   MINISTRIES PAGE
   ============================================ */
.ministries-container { max-width: 1200px; margin: 0 auto; padding: 80px 40px; }
.ministries-container h1 {
  font-family: var(--font-display);
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 300; text-align: center;
  color: var(--white); margin-bottom: 60px;
}
.ministries-container h1::after {
  content: ''; display: block;
  width: 60px; height: 2px;
  background: linear-gradient(90deg, var(--blue-bright), var(--gold));
  margin: 16px auto 0;
}
.flip-grid-wrapper { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 24px; }
.flip-grid { perspective: 1000px; }
.flip-card { position: relative; cursor: pointer; height: 260px; }
.flip-card-inner { position: relative; width: 100%; height: 100%; transition: transform 0.6s cubic-bezier(0.4,0,0.2,1); transform-style: preserve-3d; }
.flip-card:hover .flip-card-inner { transform: rotateY(180deg); }
.flip-card-front, .flip-card-back {
  position: absolute; inset: 0;
  backface-visibility: hidden;
  border-radius: 4px; padding: 36px 32px;
  display: flex; flex-direction: column; justify-content: center;
}
.flip-card-front { background: var(--dark-card); border: 1px solid var(--border); }
.flip-card-front h3 { font-family: var(--font-display); font-size: 28px; font-weight: 400; color: var(--white); margin-bottom: 12px; }
.flip-card-front p { font-size: 12px; color: var(--gold); letter-spacing: 1.5px; text-transform: uppercase; }
.flip-card-back { background: linear-gradient(135deg, #041830, #0a2d5e); border: 1px solid var(--gold-dark); transform: rotateY(180deg); }
.flip-card-back h3 { font-size: 13px; font-weight: 700; letter-spacing: 2px; color: var(--gold); text-transform: uppercase; margin-bottom: 12px; }
.flip-card-back p { font-size: 14px; color: var(--off-white); line-height: 1.7; margin-bottom: 16px; }
.flip-card-back small { font-size: 11px; color: var(--gold-dark); letter-spacing: 1px; }
.expanded-content {
  display: none; position: fixed;
  top: 50%; left: 50%; transform: translate(-50%, -50%);
  background: var(--dark-card); border: 1px solid var(--gold-dark);
  border-radius: 4px; padding: 48px;
  max-width: 600px; width: 90%; z-index: 2000;
  box-shadow: 0 0 60px rgba(26,74,156,0.4);
}
.expanded-content h2 { font-family: var(--font-display); font-size: 36px; font-weight: 300; color: var(--white); margin-bottom: 16px; }
.expanded-content p { color: var(--text-muted); line-height: 1.8; }
.close-btn { position: absolute; top: 16px; right: 20px; font-size: 24px; color: var(--text-muted); cursor: pointer; transition: var(--transition); }
.close-btn:hover { color: var(--white); }
#overlay { display: none; position: fixed; inset: 0; background: rgba(2,11,24,0.9); z-index: 1999; backdrop-filter: blur(4px); }

/* ============================================
   FORMS
   ============================================ */
.registration-wrapper {
  min-height: calc(100vh - var(--nav-height));
  display: flex; align-items: center; justify-content: center;
  padding: 60px 24px;
  background: radial-gradient(ellipse at 20% 50%, rgba(26,74,156,0.2) 0%, transparent 55%), var(--black);
}
.glass-card {
  display: grid; grid-template-columns: 1fr 1fr;
  max-width: 900px; width: 100%;
  background: var(--dark-card); border: 1px solid var(--border);
  border-radius: 6px; overflow: hidden;
  box-shadow: 0 0 60px rgba(26,74,156,0.15);
}
.form-section { padding: 56px 48px; }
.form-section h2 { font-family: var(--font-display); font-size: 38px; font-weight: 300; color: var(--white); margin-bottom: 8px; }
#selected-service-display { font-size: 12px; color: var(--text-muted); margin-bottom: 36px; }
#selected-service-display span { color: var(--gold); }
.input-row { margin-bottom: 18px; }
.input-row label { display: block; font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-muted); margin-bottom: 6px; }
.input-row input, .input-row select, .input-row textarea {
  width: 100%;
  background: rgba(26,74,156,0.08); border: 1px solid var(--border);
  border-radius: 2px; color: var(--white);
  padding: 12px 16px; font-family: var(--font-body); font-size: 14px;
  transition: var(--transition); outline: none;
}
.input-row input::placeholder, .input-row textarea::placeholder { color: #3a5a80; }
.input-row input:focus, .input-row select:focus, .input-row textarea:focus { border-color: var(--gold-dark); background: rgba(201,168,76,0.04); }
.input-row select { appearance: none; cursor: pointer; }
.input-row select option { background: var(--dark); }
.btn-submit {
  width: 100%;
  background: linear-gradient(135deg, var(--gold), var(--gold-dark));
  color: var(--black); border: none; padding: 15px;
  font-family: var(--font-body); font-size: 12px; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  border-radius: 2px; cursor: pointer; transition: var(--transition); margin-top: 8px;
}
.btn-submit:hover { background: linear-gradient(135deg, var(--gold-light), var(--gold)); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(201,168,76,0.3); }
.poster-section { background: linear-gradient(135deg, #041830, #071a3a); display: flex; align-items: center; justify-content: center; padding: 32px; border-left: 1px solid var(--border); }
.poster-placeholder { text-align: center; color: var(--text-muted); }
.footer-blue { background: var(--dark); border-top: 1px solid var(--border); padding: 60px 40px; text-align: center; }
.footer-blue h3 { font-family: var(--font-display); font-size: 28px; font-weight: 300; color: var(--white); margin-bottom: 36px; }
.footer-cards { display: flex; justify-content: center; gap: 24px; flex-wrap: wrap; }
.f-card { background: var(--dark-card); border: 1px solid var(--border); border-radius: 4px; padding: 28px 36px; min-width: 160px; transition: var(--transition); }
.f-card:hover { border-color: var(--gold-dark); box-shadow: 0 0 24px rgba(26,74,156,0.2); }
.f-card h4 { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); margin-bottom: 8px; }
.f-card p { font-size: 22px; font-weight: 300; color: var(--white); margin-bottom: 4px; }
.f-card span { font-size: 11px; color: var(--text-muted); }

.testimony-wrapper {
  min-height: calc(100vh - var(--nav-height));
  display: flex; align-items: center; justify-content: center;
  padding: 80px 24px;
  background: radial-gradient(ellipse at 80% 20%, rgba(26,74,156,0.25) 0%, transparent 55%), var(--black);
}
.testimony-card { background: var(--dark-card); border: 1px solid var(--border); border-radius: 6px; padding: 64px; max-width: 680px; width: 100%; box-shadow: 0 0 60px rgba(26,74,156,0.15); }
.testimony-card .eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); margin-bottom: 12px; }
.testimony-card h2 { font-family: var(--font-display); font-size: 44px; font-weight: 300; color: var(--white); margin-bottom: 8px; line-height: 1.1; }
.testimony-card .subtitle { font-size: 14px; color: var(--text-muted); margin-bottom: 40px; border-bottom: 1px solid var(--border); padding-bottom: 32px; }
.testimony-card .input-row textarea { min-height: 160px; resize: vertical; }
.testimony-footer { background: #010810; border-top: 1px solid var(--border); padding: 20px 40px; text-align: center; font-size: 11px; color: var(--text-muted); }

.give-wrapper { max-width: 800px; margin: 0 auto; padding: 80px 40px; text-align: center; }
.give-wrapper h1 { font-family: var(--font-display); font-size: clamp(44px, 6vw, 72px); font-weight: 300; color: var(--white); margin-bottom: 16px; }
.give-wrapper .subtitle { font-size: 15px; color: var(--text-muted); max-width: 500px; margin: 0 auto 56px; line-height: 1.8; }
.give-divider { width: 60px; height: 2px; background: linear-gradient(90deg, var(--blue-bright), var(--gold)); margin: 0 auto 20px; }
.bank-details-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; margin: 48px 0; text-align: left; }
.bank-card { background: var(--dark-card); border: 1px solid var(--border); border-radius: 4px; padding: 28px; transition: var(--transition); }
.bank-card:hover { border-color: var(--gold-dark); box-shadow: 0 0 20px rgba(26,74,156,0.2); }
.bank-card .label { font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gold); margin-bottom: 8px; }
.bank-card .value { font-size: 18px; font-weight: 300; color: var(--white); font-family: var(--font-display); }
.give-note { font-size: 13px; color: var(--text-muted); background: rgba(26,74,156,0.08); border: 1px solid var(--border); border-radius: 4px; padding: 20px 24px; margin-top: 32px; line-height: 1.8; }

.modal { display: none; position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%) scale(0.9); background: var(--dark-card); border: 1px solid var(--gold-dark); border-radius: 6px; padding: 48px; max-width: 440px; width: 90%; z-index: 3000; text-align: center; opacity: 0; transition: all 0.3s; box-shadow: 0 0 60px rgba(26,74,156,0.3); }
.modal.show { display: block; opacity: 1; transform: translate(-50%,-50%) scale(1); }
.modal h3 { font-family: var(--font-display); font-size: 32px; font-weight: 300; color: var(--white); margin-bottom: 12px; }
.modal p { font-size: 14px; color: var(--text-muted); line-height: 1.7; }
.modal-icon { font-size: 48px; margin-bottom: 16px; }

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 900px) {
  .live-split-wrapper { grid-template-columns: 1fr; }
  .visit-container { grid-template-columns: 1fr; gap: 40px; }
  .glass-card { grid-template-columns: 1fr; }
  .poster-section { display: none; }
  .footer-container { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 768px) {
  .navbar { padding: 0 20px; }
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .mobile-nav { display: flex; }
  .hero-solid, .live, .ministries-hero-new, .visit-us { padding: 60px 24px; }
  .main-footer { padding: 60px 24px 0; }
  .ministries-container { padding: 60px 24px; }
  .form-section { padding: 40px 28px; }
  .testimony-card { padding: 40px 28px; }
  .give-wrapper { padding: 60px 24px; }
  .footer-container { grid-template-columns: 1fr; gap: 32px; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .flip-grid-wrapper { grid-template-columns: 1fr; }
}

/* ============================================
   MINISTRIES 3D SLIDER
   ============================================ */
.ministries-slider-section {
  padding: 80px 0;
  background: var(--black);
  overflow: hidden;
  position: relative;
  width: 100%;
  box-sizing: border-box;
}
.ministries-slider-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(26,74,156,0.18) 0%, transparent 60%);
  pointer-events: none;
}
.slider-header {
  text-align: center;
  padding: 0 40px;
  margin-bottom: 48px;
  position: relative;
  z-index: 1;
}
.slider-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 4px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.slider-title {
  font-family: var(--font-display);
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 300;
  color: var(--white);
  line-height: 1.1;
  margin-bottom: 16px;
}
.slider-title em {
  font-style: italic;
  background: linear-gradient(135deg, var(--gold-light), var(--gold));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.slider-divider {
  width: 60px;
  height: 2px;
  background: linear-gradient(90deg, var(--blue-bright), var(--gold));
  margin: 0 auto 20px;
}
.slider-subtitle {
  font-size: 14px;
  color: var(--text-muted);
  max-width: 460px;
  margin: 0 auto;
}

/* Scene & Track */
.slider-scene {
  width: 100%;
  overflow: hidden;
  padding: 16px 0 32px;
  position: relative;
}
.slider-track {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 20px;
  padding: 10px 40px;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
  cursor: grab;
  user-select: none;
}
.slider-track:active { cursor: grabbing; }

/* Individual Slide Card */
.ministry-slide {
  flex-shrink: 0;
  flex-grow: 0;
  flex-basis: 180px;
  width: 180px;
  height: 260px;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
  display: block;
  text-decoration: none;
  transition: transform 0.4s ease, box-shadow 0.4s ease;
  transform: scale(0.9);
  box-shadow: 0 4px 20px rgba(0,0,0,0.4);
  border: 1px solid var(--border);
}
.ministry-slide.active-slide {
  transform: scale(1.05);
  box-shadow: 0 16px 48px rgba(26,74,156,0.5), 0 0 0 1px var(--gold-dark);
  z-index: 2;
}
.ministry-slide:hover {
  transform: scale(1.08);
  box-shadow: 0 20px 56px rgba(201,168,76,0.3);
}

/* Controls */
.slider-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-top: 12px;
}
.slider-btn {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--border-light);
  background: rgba(26,74,156,0.12);
  color: var(--white);
  font-size: 18px;
  cursor: pointer;
  transition: all 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.slider-btn:hover {
  background: var(--gold);
  color: var(--black);
  border-color: var(--gold);
}
.slider-dots {
  display: flex;
  gap: 8px;
  align-items: center;
}
.slider-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--border-light);
  cursor: pointer;
  transition: all 0.3s;
}
.slider-dot.active {
  background: var(--gold);
  width: 22px;
  border-radius: 3px;
}

/* ============================================
   EXPAND MAP CARD
   ============================================ */
.map-side {
  display: flex;
  align-items: center;
  justify-content: center;
}

.expand-map-card {
  position: relative;
  cursor: pointer;
  width: 100%;
}

/* ── Collapsed State ── */
.map-collapsed {
  position: relative;
  background: var(--dark-card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 28px;
  height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  transform-style: preserve-3d;
  transform: perspective(1000px) rotateX(0deg) rotateY(0deg);
}
.map-collapsed:hover {
  border-color: var(--gold-dark);
  box-shadow: 0 20px 60px rgba(26,74,156,0.3);
}
.expand-map-card.is-expanded .map-collapsed {
  display: none;
}

/* Grid background */
.map-card-grid {
  position: absolute;
  inset: 0;
  opacity: 0.04;
  background-image:
    linear-gradient(var(--gold) 1px, transparent 1px),
    linear-gradient(90deg, var(--gold) 1px, transparent 1px);
  background-size: 28px 28px;
  border-radius: 16px;
  pointer-events: none;
  transition: opacity 0.3s;
}
.map-collapsed:hover .map-card-grid { opacity: 0.07; }

.map-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.map-card-icon {
  color: var(--gold);
  filter: drop-shadow(0 0 6px rgba(201,168,76,0.4));
}
.map-live-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 99px;
  padding: 4px 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: var(--text-muted);
  text-transform: uppercase;
}
.map-live-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #34d399;
  box-shadow: 0 0 6px rgba(52,211,153,0.6);
  animation: pulse-green 2s infinite;
}
@keyframes pulse-green {
  0%, 100% { box-shadow: 0 0 0 0 rgba(52,211,153,0.5); }
  50%       { box-shadow: 0 0 0 6px rgba(52,211,153,0); }
}
.map-card-bottom { position: relative; z-index: 1; }
.map-card-bottom h3 {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 400;
  color: var(--white);
  margin-bottom: 4px;
  transition: transform 0.3s;
}
.map-collapsed:hover .map-card-bottom h3 { transform: translateX(4px); }
.map-card-bottom p { font-size: 12px; color: var(--text-muted); margin-bottom: 10px; }
.map-underline {
  height: 1px;
  background: linear-gradient(90deg, rgba(52,211,153,0.5), rgba(52,211,153,0.2), transparent);
  transform-origin: left;
  transform: scaleX(0.3);
  transition: transform 0.4s ease;
  margin-bottom: 10px;
}
.map-collapsed:hover .map-underline { transform: scaleX(1); }
.map-hint {
  font-size: 10px;
  color: var(--gold);
  letter-spacing: 1px;
  text-transform: uppercase;
  opacity: 0;
  transition: opacity 0.3s;
}
.map-collapsed:hover .map-hint { opacity: 1; }

/* ── Expanded State ── */
.map-expanded {
  display: none;
  flex-direction: column;
  background: var(--dark-card);
  border: 1px solid var(--gold-dark);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(26,74,156,0.4);
  animation: mapExpand 0.45s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}
.expand-map-card.is-expanded .map-expanded { display: flex; }
@keyframes mapExpand {
  from { opacity: 0; transform: scale(0.92) translateY(16px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
.map-expanded-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
}
.map-close-btn {
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border);
  color: var(--text-muted);
  width: 28px; height: 28px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}
.map-close-btn:hover { background: rgba(255,255,255,0.12); color: var(--white); }
.map-iframe-wrap {
  width: 100%;
  height: 320px;
}
.map-expanded-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
  gap: 12px;
}
.map-address-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.map-address-info strong { font-size: 13px; color: var(--white); font-weight: 600; }
.map-address-info span  { font-size: 11px; color: var(--text-muted); }
.map-directions-btn {
  background: var(--gold);
  color: var(--black);
  padding: 8px 18px;
  border-radius: 2px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  transition: all 0.2s;
  white-space: nowrap;
}
.map-directions-btn:hover { background: var(--gold-light); }

/* 3D tilt effect on hover */
.expand-map-card:not(.is-expanded) { perspective: 1000px; }


/* ============================================
   INLINE STYLES MOVED FROM INDEX.HTML
   ============================================ */
.page{display:none}.page.active{display:block}
        :root{--reg-navy:#0b1e3d;--reg-sky:#29abe2;--reg-gold:#f0b429;--reg-glass:rgba(255,255,255,0.08);--reg-border:rgba(255,255,255,0.15)}
        @keyframes regDrift{from{transform:translate(0,0) scale(1)}to{transform:translate(40px,30px) scale(1.1)}}
        @keyframes rStepIn{from{opacity:0;transform:translateY(20px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}
        @keyframes encShimmer{0%,100%{opacity:0.4}50%{opacity:0.9}}
        @keyframes rShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
        @keyframes sucRing{0%{transform:scale(1);opacity:0.6}100%{transform:scale(1.35);opacity:0}}
        @keyframes pulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(1.5)}}

        /* REGISTRATION */
        .reg-page{background:var(--reg-navy);min-height:100vh;position:relative;overflow:hidden;padding:90px 20px 100px;font-family:'DM Sans',sans-serif}
        .reg-orbs{position:absolute;inset:0;pointer-events:none;z-index:0}
        .reg-orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:0.2;animation:regDrift 18s ease-in-out infinite alternate}
        .reg-orb1{width:500px;height:500px;background:var(--reg-sky);top:-150px;left:-100px}
        .reg-orb2{width:400px;height:400px;background:#1a3c6d;bottom:-100px;right:-100px;animation-delay:-6s}
        .reg-orb3{width:300px;height:300px;background:var(--reg-gold);top:40%;left:55%;animation-delay:-12s}
        .reg-inner{position:relative;z-index:2;max-width:500px;margin:0 auto}
        .reg-heading{text-align:center;margin-bottom:36px}
        .reg-eyebrow{font-size:10px;font-weight:700;letter-spacing:0.25em;text-transform:uppercase;color:var(--reg-gold);margin-bottom:10px}
        .reg-heading h1{font-family:'Playfair Display',serif;font-size:38px;font-weight:900;color:white;line-height:1.1}
        .reg-heading h1 em{color:var(--reg-gold);font-style:normal}
        .reg-heading p{color:rgba(255,255,255,0.5);font-size:14px;margin-top:10px;line-height:1.6}
        .reg-track-wrap{margin-bottom:24px}
        .reg-track{width:100%;height:3px;background:rgba(255,255,255,0.1);border-radius:50px;overflow:hidden}
        .reg-fill{height:100%;background:linear-gradient(90deg,var(--reg-sky),var(--reg-gold));border-radius:50px;transition:width 0.6s cubic-bezier(0.4,0,0.2,1);box-shadow:0 0 12px rgba(240,180,41,0.5)}
        .reg-dots-row{display:flex;justify-content:space-between;margin-top:10px}
        .rdot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.15);transition:all 0.4s}
        .rdot.done{background:var(--reg-gold);box-shadow:0 0 8px rgba(240,180,41,0.6)}
        .rdot.active{background:white;transform:scale(1.4)}
        .reg-step-lbl{text-align:right;color:rgba(255,255,255,0.4);font-size:10px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;margin-top:6px}
        .enc-panel{background:var(--reg-glass);border:1px solid var(--reg-border);border-radius:20px;padding:18px 22px;margin-bottom:24px;min-height:66px;display:flex;align-items:center;gap:12px}
        .enc-icon{font-size:20px;flex-shrink:0}
        .enc-text{color:rgba(255,255,255,0.85);font-size:13px;line-height:1.5;font-style:italic}
        .enc-text.loading{animation:encShimmer 1.5s ease-in-out infinite}
        .reg-step{display:none;flex-direction:column}
        .reg-step.active{display:flex;animation:rStepIn 0.45s cubic-bezier(0.34,1.3,0.64,1) both}
        .reg-back{display:inline-flex;align-items:center;gap:6px;color:rgba(255,255,255,0.4);font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;background:none;border:none;cursor:pointer;padding:0;margin-bottom:20px;transition:color 0.2s;font-family:'DM Sans',sans-serif}
        .reg-back:hover{color:rgba(255,255,255,0.8)}
        .reg-question{font-family:'Playfair Display',serif;font-size:26px;font-weight:900;color:white;line-height:1.2;margin-bottom:24px;text-align:center}
        .reg-question em{color:var(--reg-gold);font-style:normal}
        .reg-fields{display:flex;flex-direction:column;gap:12px}
        .field-lbl{color:rgba(255,255,255,0.45);font-size:10px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;padding-left:8px;margin-bottom:-4px}
        .reg-fields input[type=text],.reg-fields input[type=tel],.reg-fields input[type=email],.reg-fields select{width:100%;padding:17px 24px;border:1.5px solid rgba(255,255,255,0.1);border-radius:50px;background:rgba(255,255,255,0.07);color:white;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:500;text-align:center;outline:none;transition:all 0.3s;-webkit-appearance:none}
        .reg-fields input::placeholder{color:rgba(255,255,255,0.3)}
        .reg-fields input:focus,.reg-fields select:focus{border-color:var(--reg-sky);background:rgba(41,171,226,0.1);box-shadow:0 0 0 4px rgba(41,171,226,0.15)}
        .reg-fields select option{background:var(--reg-navy);color:white}
        .reg-fields input.err,.reg-fields select.err{border-color:#ff6b6b;background:rgba(255,107,107,0.08)}
        .reg-errmsg{color:#ff8a8a;font-size:11px;font-weight:600;text-align:center;display:none}
        .reg-errmsg.show{display:block;animation:rShake 0.3s ease}
        .btn-rb{width:100%;padding:17px;background:linear-gradient(135deg,var(--reg-sky),#1a7abf);color:white;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;border:none;border-radius:50px;cursor:pointer;margin-top:6px;transition:all 0.3s;box-shadow:0 12px 30px rgba(41,171,226,0.3)}
        .btn-rb:hover{transform:translateY(-2px)}
        .btn-rg{width:100%;padding:17px;background:linear-gradient(135deg,var(--reg-gold),#e09000);color:#0b1e3d;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:800;letter-spacing:0.22em;text-transform:uppercase;border:none;border-radius:50px;cursor:pointer;margin-top:6px;transition:all 0.3s}
        .btn-rg:hover{transform:translateY(-2px)}
        .btn-rgrn{width:100%;padding:17px;background:linear-gradient(135deg,#22c55e,#16a34a);color:white;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:800;letter-spacing:0.22em;text-transform:uppercase;border:none;border-radius:50px;cursor:pointer;transition:all 0.3s;box-shadow:0 12px 30px rgba(34,197,94,0.3)}
        .btn-rgrn:hover{transform:translateY(-2px)}
        .btn-rgrn:disabled{opacity:0.6;cursor:not-allowed;transform:none}
        .sum-card{background:var(--reg-glass);border:1px solid var(--reg-border);border-radius:24px;padding:24px;margin-bottom:20px}
        .sum-row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid rgba(255,255,255,0.06)}
        .sum-row:first-child{padding-top:0}
        .sum-row:last-child{border-bottom:none;padding-bottom:0}
        .sum-lbl{color:rgba(255,255,255,0.4);font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase}
        .sum-val{color:white;font-size:13px;font-weight:600;text-align:right;max-width:60%}
        .sum-val.gold{color:var(--reg-gold)}
        #regSuccess{display:none;flex-direction:column;align-items:center;text-align:center;padding:20px 0}
        #regSuccess.show{display:flex;animation:rStepIn 0.6s cubic-bezier(0.34,1.3,0.64,1) both}
        .suc-ring{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,rgba(34,197,94,0.2),rgba(41,171,226,0.2));border:2px solid rgba(34,197,94,0.4);display:flex;align-items:center;justify-content:center;margin-bottom:24px;position:relative}
        .suc-ring::before{content:'';position:absolute;inset:-8px;border-radius:50%;border:1px solid rgba(34,197,94,0.2);animation:sucRing 2s ease-out infinite}
        .suc-emoji{font-size:42px}
        .suc-title{font-family:'Playfair Display',serif;font-size:38px;font-weight:900;color:white;margin-bottom:4px}
        .suc-sub{color:rgba(255,255,255,0.45);font-size:11px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;margin-bottom:28px}
        .blessing-card{width:100%;background:white;border-radius:24px;padding:28px;text-align:left;margin-bottom:28px;box-shadow:0 24px 60px rgba(0,0,0,0.3);position:relative;overflow:hidden}
        .blessing-card::before{content:'"';position:absolute;top:-10px;left:16px;font-family:'Playfair Display',serif;font-size:110px;color:rgba(41,171,226,0.1);line-height:1}
        .blessing-tag{display:inline-flex;align-items:center;gap:5px;background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#1d4ed8;font-size:9px;font-weight:800;letter-spacing:0.15em;text-transform:uppercase;padding:5px 12px;border-radius:50px;margin-bottom:14px}
        .blessing-body{color:#0b1e3d;font-size:15px;line-height:1.7;font-style:italic;position:relative;z-index:1}
        .btn-ragain{background:var(--reg-glass);border:1px solid var(--reg-border);color:rgba(255,255,255,0.7);font-family:'DM Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;padding:14px 32px;border-radius:50px;cursor:pointer;transition:all 0.3s;margin-bottom:12px;display:block}
        .btn-ragain:hover{background:rgba(255,255,255,0.15);color:white}
        .btn-backhome{background:none;border:none;color:rgba(255,255,255,0.4);font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;transition:color 0.2s}
        .btn-backhome:hover{color:white}

        /* WATCH REGISTER */
        .wr-page{background:#0b1628;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:100px 20px 60px;position:relative;overflow:hidden;font-family:'DM Sans',sans-serif}
        .wr-orbs{position:absolute;inset:0;pointer-events:none}
        .wr-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:0.15;animation:regDrift 20s ease-in-out infinite alternate}
        .wr-orb1{width:600px;height:600px;background:#29abe2;top:-200px;left:-150px}
        .wr-orb2{width:400px;height:400px;background:#f0b429;bottom:-100px;right:-100px;animation-delay:-8s}
        .wr-inner{position:relative;z-index:2;max-width:460px;width:100%;text-align:center}
        .wr-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,68,68,0.15);border:1px solid rgba(255,68,68,0.3);color:#ff6b6b;font-size:11px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;padding:8px 16px;border-radius:50px;margin-bottom:28px}
        .wr-live-dot{width:8px;height:8px;background:#ff4444;border-radius:50%;animation:pulseDot 1.2s ease-in-out infinite}
        .wr-title{font-family:'Playfair Display',serif;font-size:40px;font-weight:900;color:white;line-height:1.1;margin-bottom:14px}
        .wr-title em{color:#29abe2;font-style:normal}
        .wr-sub{color:rgba(255,255,255,0.45);font-size:14px;line-height:1.6;margin-bottom:36px}
        .wr-card{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:28px;padding:36px 32px;text-align:left}
        .wr-field{margin-bottom:28px}
        .wr-label{display:block;color:rgba(255,255,255,0.5);font-size:11px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:12px}
        .wr-input{width:100%;padding:17px 22px;border:1.5px solid rgba(255,255,255,0.1);border-radius:50px;background:rgba(255,255,255,0.07);color:white;font-family:'DM Sans',sans-serif;font-size:15px;outline:none;transition:all 0.3s;-webkit-appearance:none;box-sizing:border-box}
        .wr-input::placeholder{color:rgba(255,255,255,0.25)}
        .wr-input:focus{border-color:#29abe2;background:rgba(41,171,226,0.1);box-shadow:0 0 0 4px rgba(41,171,226,0.15)}
        .wr-input.err{border-color:#ff6b6b}
        .wr-err{color:#ff8a8a;font-size:11px;font-weight:600;margin-top:8px;padding-left:8px;display:none}
        .wr-err.show{display:block}
        .wr-counter{display:flex;align-items:center;background:rgba(255,255,255,0.07);border:1.5px solid rgba(255,255,255,0.1);border-radius:50px;overflow:hidden;width:180px}
        .wr-count-btn{background:none;border:none;color:white;font-size:22px;padding:14px 24px;cursor:pointer;transition:background 0.2s;line-height:1}
        .wr-count-btn:hover{background:rgba(255,255,255,0.1)}
        .wr-count-val{color:white;font-size:20px;font-weight:700;min-width:40px;text-align:center;font-family:'Playfair Display',serif}
        .wr-count-hint{color:rgba(255,255,255,0.3);font-size:11px;margin-top:10px;padding-left:4px}
        .wr-submit-btn{width:100%;padding:18px;background:linear-gradient(135deg,#29abe2,#1a7abf);color:white;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;border:none;border-radius:50px;cursor:pointer;transition:all 0.3s;box-shadow:0 12px 32px rgba(41,171,226,0.35);margin-top:4px}
        .wr-submit-btn:hover{transform:translateY(-2px)}
        .wr-submit-btn:disabled{opacity:0.6;cursor:not-allowed;transform:none}
        .wr-skip{background:none;border:none;color:rgba(255,255,255,0.25);font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer;margin-top:20px;transition:color 0.2s}
        .wr-skip:hover{color:rgba(255,255,255,0.6)}

        /* WATCH LIVE */
        .wl-page{background:#0b1628;min-height:100vh;font-family:'DM Sans',sans-serif}
        .wl-header{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;background:rgba(0,0,0,0.7);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,0.06);position:sticky;top:0;z-index:100}
        .wl-header-left{display:flex;align-items:center;gap:14px}
        .wl-live-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(255,68,68,0.2);border:1px solid rgba(255,68,68,0.4);color:#ff6b6b;font-size:10px;font-weight:800;letter-spacing:0.2em;padding:5px 12px;border-radius:50px}
        .wl-dot{width:6px;height:6px;background:#ff4444;border-radius:50%;animation:pulseDot 1.2s ease-in-out infinite}
        .wl-title-txt{color:rgba(255,255,255,0.7);font-size:13px;font-weight:600}
        .wl-back-btn{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.6);font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;padding:9px 18px;border-radius:50px;cursor:pointer;transition:all 0.2s}
        .wl-back-btn:hover{background:rgba(255,255,255,0.15);color:white}
        .wl-video-wrap{background:black}
        .wl-aspect{position:relative;width:100%;padding-top:56.25%}
        .wl-aspect iframe{position:absolute;inset:0;width:100%;height:100%}
        .wl-info-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;background:rgba(255,255,255,0.03);border-bottom:1px solid rgba(255,255,255,0.06);flex-wrap:wrap;gap:12px}
        .wl-viewer-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(41,171,226,0.15);border:1px solid rgba(41,171,226,0.3);color:#29abe2;font-size:12px;font-weight:600;padding:8px 16px;border-radius:50px}
        .wl-schedule{color:rgba(255,255,255,0.35);font-size:12px}
        .wl-upcoming{padding:40px 28px;max-width:1000px;margin:0 auto}
        .wl-upcoming-title{font-family:'Playfair Display',serif;color:white;font-size:22px;font-weight:700;margin-bottom:20px}
        .wl-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
        .wl-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:16px;padding:20px;transition:all 0.3s}
        .wl-card:hover{background:rgba(255,255,255,0.08);border-color:rgba(41,171,226,0.3)}
        .wl-tag{display:inline-block;background:rgba(41,171,226,0.15);color:#29abe2;font-size:9px;font-weight:800;letter-spacing:0.15em;text-transform:uppercase;padding:4px 10px;border-radius:50px;margin-bottom:10px}
        .wl-tag.special{background:rgba(240,180,41,0.15);color:#f0b429}
        .wl-card h4{color:white;font-size:14px;font-weight:600;margin-bottom:4px}
        .wl-card p{color:rgba(255,255,255,0.4);font-size:12px}

/* ── Expand Map Card ──────────────────────── */
/* ── Expand Map Card ── */
.map-side { display:flex; align-items:center; justify-content:center; }
.expand-map-card { position:relative; cursor:pointer; width:100%; }
.map-collapsed {
  position:relative; background:rgba(4,16,34,0.95);
  border:1px solid #1e3f72; border-radius:16px;
  padding:28px; height:220px;
  display:flex; flex-direction:column; justify-content:space-between;
  overflow:hidden;
  transition:border-color 0.3s, box-shadow 0.3s, transform 0.2s;
  transform-style:preserve-3d;
}
.map-collapsed:hover { border-color:#9a7a30; box-shadow:0 20px 60px rgba(26,74,156,0.3); }
.expand-map-card.is-expanded .map-collapsed { display:none; }
.map-card-grid {
  position:absolute; inset:0; border-radius:16px; pointer-events:none;
  opacity:0.04; transition:opacity 0.3s;
  background-image: linear-gradient(#c9a84c 1px,transparent 1px), linear-gradient(90deg,#c9a84c 1px,transparent 1px);
  background-size:28px 28px;
}
.map-collapsed:hover .map-card-grid { opacity:0.08; }
.map-card-top { display:flex; justify-content:space-between; align-items:flex-start; }
.map-card-icon { color:#c9a84c; filter:drop-shadow(0 0 6px rgba(201,168,76,0.4)); }
.map-live-badge {
  display:flex; align-items:center; gap:6px;
  background:rgba(255,255,255,0.04); border:1px solid #1e3f72;
  border-radius:99px; padding:4px 10px;
  font-size:10px; font-weight:700; letter-spacing:1.5px;
  color:#6a8ab0; text-transform:uppercase;
}
.map-live-dot {
  width:7px; height:7px; border-radius:50%;
  background:#34d399; box-shadow:0 0 6px rgba(52,211,153,0.6);
  animation:pulseGreen 2s infinite;
}
@keyframes pulseGreen {
  0%,100%{ box-shadow:0 0 0 0 rgba(52,211,153,0.5); }
  50%{ box-shadow:0 0 0 6px rgba(52,211,153,0); }
}
.map-card-bottom { position:relative; z-index:1; }
.map-card-bottom h3 {
  font-size:24px; font-weight:400; color:#fff; margin-bottom:4px;
  transition:transform 0.3s;
}
.map-collapsed:hover .map-card-bottom h3 { transform:translateX(4px); }
.map-card-bottom p { font-size:12px; color:#6a8ab0; margin-bottom:10px; }
.map-underline {
  height:1px; margin-bottom:10px;
  background:linear-gradient(90deg,rgba(52,211,153,0.5),rgba(52,211,153,0.2),transparent);
  transform-origin:left; transform:scaleX(0.3); transition:transform 0.4s ease;
}
.map-collapsed:hover .map-underline { transform:scaleX(1); }
.map-hint {
  font-size:10px; color:#c9a84c; letter-spacing:1px;
  text-transform:uppercase; opacity:0; transition:opacity 0.3s;
}
.map-collapsed:hover .map-hint { opacity:1; }
/* Expanded */
.map-expanded {
  display:none; flex-direction:column;
  background:#122444; border:1px solid #9a7a30;
  border-radius:16px; overflow:hidden;
  box-shadow:0 24px 80px rgba(26,74,156,0.4);
  animation:mapExpand 0.45s cubic-bezier(0.4,0,0.2,1) forwards;
}
.expand-map-card.is-expanded .map-expanded { display:flex; }
@keyframes mapExpand {
  from{ opacity:0; transform:scale(0.92) translateY(16px); }
  to{ opacity:1; transform:scale(1) translateY(0); }
}
.map-expanded-top {
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 20px; border-bottom:1px solid #1e3f72;
}
.map-close-btn {
  background:rgba(255,255,255,0.06); border:1px solid #1e3f72;
  color:#6a8ab0; width:28px; height:28px; border-radius:50%;
  cursor:pointer; font-size:13px; display:flex;
  align-items:center; justify-content:center; transition:all 0.2s;
}
.map-close-btn:hover { background:rgba(255,255,255,0.15); color:#fff; }
.map-iframe-wrap { width:100%; height:300px; }
.map-expanded-bottom {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 20px; border-top:1px solid #1e3f72; flex-wrap:wrap; gap:12px;
}
.map-address-info { display:flex; flex-direction:column; gap:2px; }
.map-address-info strong { font-size:13px; color:#fff; font-weight:600; }
.map-address-info span { font-size:11px; color:#6a8ab0; }
.map-directions-btn {
  background:#c9a84c; color:#0b1628; padding:8px 18px;
  border-radius:2px; font-size:11px; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase;
  transition:background 0.2s; white-space:nowrap; text-decoration:none;
}
.map-directions-btn:hover { background:#e8c96e; }

/* ── Attendance Modal ── */
/* ── Attendance Modal ── */
.att-backdrop {
    position:fixed; inset:0; background:rgba(2,11,24,0.85);
    backdrop-filter:blur(6px); z-index:9000;
    animation:attFadeIn 0.3s ease;
}
.att-modal {
    position:fixed; bottom:0; left:50%; transform:translateX(-50%);
    width:100%; max-width:480px;
    background:linear-gradient(160deg,#122444 0%,#0d1f3c 100%);
    border:1px solid #1e3f72;
    border-radius:28px 28px 0 0;
    padding:40px 32px 48px;
    z-index:9001; overflow:hidden;
    animation:attSlideUp 0.45s cubic-bezier(0.34,1.3,0.64,1);
}
@keyframes attFadeIn  { from{opacity:0} to{opacity:1} }
@keyframes attSlideUp { from{transform:translateX(-50%) translateY(100%)} to{transform:translateX(-50%) translateY(0)} }
@keyframes attSlideDown { from{transform:translateX(-50%) translateY(0)} to{transform:translateX(-50%) translateY(100%)} }
.att-modal.closing {
    animation:attSlideDown 0.35s ease forwards;
}

/* Orbs */
.att-orb { position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none; }
.att-orb1 { width:280px;height:280px;background:rgba(26,74,156,0.3);top:-100px;left:-80px; }
.att-orb2 { width:200px;height:200px;background:rgba(201,168,76,0.15);bottom:-60px;right:-60px; }

/* Close */
.att-close {
    position:absolute;top:16px;right:20px;
    background:rgba(255,255,255,0.06);border:1px solid #1e3f72;
    color:rgba(255,255,255,0.5);width:32px;height:32px;border-radius:50%;
    cursor:pointer;font-size:16px;line-height:1;
    display:flex;align-items:center;justify-content:center;
    transition:all 0.2s; z-index:2;
}
.att-close:hover { background:rgba(255,255,255,0.12);color:#fff; }

/* Handle bar */
.att-modal::before {
    content:'';display:block;width:40px;height:4px;
    background:rgba(255,255,255,0.15);border-radius:2px;
    margin:0 auto 28px;
}

/* Header */
.att-header { text-align:center;margin-bottom:28px;position:relative;z-index:1; }
.att-live-badge {
    display:inline-flex;align-items:center;gap:7px;
    background:rgba(255,68,68,0.15);border:1px solid rgba(255,68,68,0.3);
    color:#ff6b6b;font-size:10px;font-weight:700;letter-spacing:0.2em;
    text-transform:uppercase;padding:6px 14px;border-radius:50px;margin-bottom:16px;
}
.att-dot {
    width:7px;height:7px;border-radius:50%;background:#ff4444;
    animation:attPulse 1.2s ease-in-out infinite;
}
@keyframes attPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.5;transform:scale(1.5)} }
.att-title {
    font-family:'Playfair Display',serif;
    font-size:32px;font-weight:900;color:#fff;line-height:1.15;margin-bottom:10px;
}
.att-title em { color:var(--gold);font-style:normal; }
.att-sub { color:rgba(255,255,255,0.45);font-size:13px;line-height:1.6; }

/* Form */
.att-form { position:relative;z-index:1; }
.att-field { margin-bottom:20px; }
.att-label { display:block;color:rgba(255,255,255,0.45);font-size:10px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:10px; }
.att-input {
    width:100%;padding:16px 22px;
    border:1.5px solid rgba(255,255,255,0.1);border-radius:50px;
    background:rgba(255,255,255,0.07);color:#fff;
    font-family:'DM Sans',sans-serif;font-size:15px;
    outline:none;transition:all 0.3s;box-sizing:border-box;
}
.att-input::placeholder { color:rgba(255,255,255,0.25); }
.att-input:focus { border-color:var(--gold-dark);background:rgba(201,168,76,0.08);box-shadow:0 0 0 4px rgba(201,168,76,0.12); }
.att-input.err { border-color:#ff6b6b;background:rgba(255,107,107,0.08); }
.att-err { color:#ff8a8a;font-size:11px;font-weight:600;margin-top:8px;padding-left:8px;display:none; }
.att-err.show { display:block; }

/* Counter */
.att-counter { display:flex;align-items:center;background:rgba(255,255,255,0.07);border:1.5px solid rgba(255,255,255,0.1);border-radius:50px;overflow:hidden;width:160px; }
.att-count-btn { background:none;border:none;color:#fff;font-size:22px;padding:12px 20px;cursor:pointer;transition:background 0.2s;line-height:1; }
.att-count-btn:hover { background:rgba(255,255,255,0.1); }
.att-count-val { color:#fff;font-size:18px;font-weight:700;min-width:36px;text-align:center;font-family:'Playfair Display',serif; }
.att-count-hint { color:rgba(255,255,255,0.3);font-size:11px;margin-top:8px;padding-left:4px; }

/* Buttons */
.att-submit-btn {
    width:100%;padding:17px;
    background:linear-gradient(135deg,var(--gold),var(--gold-dark));
    color:var(--black);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:800;
    letter-spacing:0.2em;text-transform:uppercase;border:none;border-radius:50px;
    cursor:pointer;transition:all 0.3s;
    box-shadow:0 12px 32px rgba(201,168,76,0.3);margin-bottom:12px;
}
.att-submit-btn:hover { transform:translateY(-2px);box-shadow:0 16px 40px rgba(201,168,76,0.4); }
.att-submit-btn:disabled { opacity:0.6;cursor:not-allowed;transform:none; }
.att-skip-btn {
    width:100%;padding:12px;background:none;border:none;
    color:rgba(255,255,255,0.25);font-family:'DM Sans',sans-serif;
    font-size:12px;cursor:pointer;transition:color 0.2s;
}
.att-skip-btn:hover { color:rgba(255,255,255,0.6); }

/* Desktop — centre modal */
@media(min-width:600px){
    .att-modal {
        bottom:auto;top:50%;
        transform:translate(-50%,-50%);
        border-radius:28px;
    }
    @keyframes attSlideUp {
        from{transform:translate(-50%,-50%) scale(0.92);opacity:0}
        to{transform:translate(-50%,-50%) scale(1);opacity:1}
    }
    .att-modal.closing {
        animation:attSlideDownDesktop 0.3s ease forwards;
    }
    @keyframes attSlideDownDesktop {
        from{transform:translate(-50%,-50%) scale(1);opacity:1}
        to{transform:translate(-50%,-50%) scale(0.9);opacity:0}
    }
}

/* ── Live page offline screen ── */
.wl-offline {
    position:absolute; inset:0; z-index:10;
    background:linear-gradient(135deg,#0d1f3c,#122444);
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    text-align:center; padding:32px;
    border-radius:16px;
}
.wl-offline-icon { font-size:48px; margin-bottom:16px; }
.wl-offline-badge {
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(255,255,255,0.06); border:1px solid #1e3f72;
    border-radius:50px; padding:6px 16px; margin-bottom:16px;
    color:rgba(255,255,255,0.5); font-size:10px; font-weight:700;
    letter-spacing:0.2em; text-transform:uppercase;
}
.wl-offline-dot {
    width:7px; height:7px; border-radius:50%; background:#ff4444;
    animation:attPulse 1.2s ease-in-out infinite;
}
.wl-offline-title {
    font-family:'Playfair Display',serif;
    font-size:24px; color:#fff; margin-bottom:8px;
}
.wl-offline-sub {
    color:rgba(255,255,255,0.4); font-size:13px;
    line-height:1.6; max-width:320px; margin-bottom:20px;
}
.wl-offline-times {
    display:flex; gap:10px; flex-wrap:wrap; justify-content:center;
    font-size:12px; color:rgba(255,255,255,0.35); font-weight:600;
}
.wl-dot-sep { color:rgba(255,255,255,0.2); }

/* ── Service flyer card (replaces YouTube embed on homepage) ── */
.service-card-wrap {
    position: relative;
    width: 100%;
    border-radius: 16px;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    max-height: 480px;
    background: #0d1f3c;
}
.service-flyer-link {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
}
.service-flyer-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}
.service-flyer-link:hover .service-flyer-img {
    transform: scale(1.03);
}
.service-flyer-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(2,11,24,0.7) 0%, transparent 60%);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding-bottom: 24px;
    opacity: 0;
    transition: opacity 0.3s ease;
}
.service-flyer-link:hover .service-flyer-overlay {
    opacity: 1;
}
.flyer-watch-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--gold);
    color: var(--black);
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    padding: 12px 28px;
    border-radius: 50px;
    box-shadow: 0 8px 24px rgba(201,168,76,0.4);
}
.flyer-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #ff4444;
    animation: attPulse 1.2s ease-in-out infinite;
}
