/* ═══ JouryFit — Refined Design System ═══ */
:root {
  --jf-primary: #B76E79;
  --jf-primary-light: #D4939C;
  --jf-primary-dark: #9A5A63;
  --jf-secondary: #F5EDE8;
  --jf-background: #FDFBF9;
  --jf-accent: #C4938B;
  --jf-beige: #F3EDE7;
  --jf-warm: #EDE5DD;
  --jf-text: #1E1E1E;
  --jf-text-mid: #4A4A4A;
  --jf-text-light: #7A7A7A;
  --jf-white: #FFFFFF;
  --jf-border: #E8E0D8;
  --jf-shadow-sm: 0 1px 3px rgba(0,0,0,.04);
  --jf-shadow: 0 4px 16px rgba(0,0,0,.06);
  --jf-shadow-lg: 0 12px 40px rgba(0,0,0,.08);
  --jf-radius: 12px;
  --jf-radius-sm: 8px;
  --jf-radius-lg: 20px;
  --jf-transition: .3s ease;
  --jf-font-en: 'Poppins', system-ui, sans-serif;
  --jf-font-ar: 'Cairo', 'Tajawal', system-ui, sans-serif;
}

[data-theme="dark"] {
  --jf-background: #171215;
  --jf-text: #ECE4E6;
  --jf-text-mid: #B8ACB0;
  --jf-text-light: #8A7E82;
  --jf-secondary: #241C1F;
  --jf-beige: #1F1719;
  --jf-warm: #2A2024;
  --jf-white: #1F181B;
  --jf-border: #362C30;
  --jf-shadow-sm: 0 1px 3px rgba(0,0,0,.15);
  --jf-shadow: 0 4px 16px rgba(0,0,0,.25);
  --jf-shadow-lg: 0 12px 40px rgba(0,0,0,.35);
}

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0 }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100% }
body {
  font-family: var(--jf-font-en);
  background: var(--jf-background);
  color: var(--jf-text);
  line-height: 1.7;
  overflow-x: hidden;
  transition: background .3s, color .3s;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
[data-lang="ar"] body, [data-lang="ar"] * { font-family: var(--jf-font-ar) }
[data-lang="ar"] { direction: rtl }
[data-lang="en"] { direction: ltr }
img { max-width: 100%; height: auto; display: block }
a { text-decoration: none; color: inherit; transition: color var(--jf-transition) }
ul { list-style: none }
.jf-container { max-width: 1140px; margin: 0 auto; padding: 0 24px }

/* ═══ Preloader ═══ */
.jf-preloader { position: fixed; inset: 0; z-index: 9999; background: var(--jf-background); display: flex; align-items: center; justify-content: center; transition: opacity .5s, visibility .5s }
.jf-preloader.loaded { opacity: 0; visibility: hidden; pointer-events: none }
.jf-preloader-logo { font-family: var(--jf-font-en); font-size: 1.5rem; font-weight: 600; color: var(--jf-primary); letter-spacing: -.02em; margin-bottom: 16px }
.jf-preloader-bar { width: 160px; height: 2px; background: var(--jf-border); border-radius: 2px; overflow: hidden }
.jf-preloader-progress { height: 100%; background: var(--jf-primary); border-radius: 2px; animation: preload 1.2s ease forwards }
.jf-preloader-inner { text-align: center }
@keyframes preload { 0% { width: 0 } 100% { width: 100% } }

/* ═══ Header — Editorial, not template ═══ */
.jf-header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; padding: 20px 0; transition: all .3s }
.jf-header.scrolled { background: rgba(253,251,249,.92); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid var(--jf-border); padding: 12px 0 }
[data-theme="dark"] .jf-header.scrolled { background: rgba(23,18,21,.92) }
.jf-nav { display: flex; align-items: center; justify-content: space-between }
.jf-logo-text { font-size: 1.4rem; font-weight: 600; color: var(--jf-text); font-family: var(--jf-font-en) !important; letter-spacing: -.03em }
.jf-logo-accent { color: var(--jf-primary); font-weight: 700 }
.jf-nav-links { display: flex; gap: 4px; align-items: center }
.jf-nav-link { padding: 7px 14px; border-radius: 6px; font-size: .82rem; font-weight: 500; color: var(--jf-text-mid); transition: var(--jf-transition); letter-spacing: .01em }
.jf-nav-link:hover, .jf-nav-link.active { color: var(--jf-text); background: var(--jf-secondary) }
.jf-nav-actions { display: flex; align-items: center; gap: 8px }

/* ─ Theme Toggle: iOS-style pill switch ─ */
.jf-theme-toggle {
  background: none; border: none; cursor: pointer; padding: 4px;
  display: flex; align-items: center; position: relative;
}
.jf-toggle-track {
  position: relative; width: 48px; height: 26px;
  background: var(--jf-border); border-radius: 13px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 6px; transition: background .3s ease;
}
[data-theme="dark"] .jf-toggle-track { background: var(--jf-primary) }
.jf-toggle-thumb {
  position: absolute; top: 3px; left: 3px;
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--jf-white); box-shadow: 0 1px 4px rgba(0,0,0,.15);
  transition: transform .3s cubic-bezier(.4,.0,.2,1);
}
[data-theme="dark"] .jf-toggle-thumb { transform: translateX(22px); background: var(--jf-background) }
.jf-toggle-track .jf-icon-sun { color: #F59E0B; flex-shrink: 0; position: relative; z-index: 1 }
.jf-toggle-track .jf-icon-moon { color: #fff; flex-shrink: 0; position: relative; z-index: 1 }
[data-theme="light"] .jf-icon-sun { display: none }
[data-theme="light"] .jf-toggle-track .jf-icon-moon { color: var(--jf-text-light) }
[data-theme="dark"] .jf-icon-moon { display: none }
[data-theme="dark"] .jf-toggle-track .jf-icon-sun { color: rgba(255,255,255,.5) }
.jf-theme-toggle:hover .jf-toggle-track { box-shadow: 0 0 0 2px rgba(183,110,121,.2) }

/* ─ Language Toggle: Globe + text ─ */
.jf-lang-toggle {
  background: none; border: 1px solid var(--jf-border); border-radius: 20px;
  padding: 5px 12px 5px 8px; cursor: pointer; color: var(--jf-text-mid);
  font-size: .78rem; font-weight: 600; transition: var(--jf-transition);
  display: flex; align-items: center; gap: 5px; letter-spacing: .01em;
}
.jf-lang-icon { opacity: .6; transition: var(--jf-transition) }
.jf-lang-label { line-height: 1 }
.jf-lang-toggle:hover { border-color: var(--jf-primary); color: var(--jf-primary) }
.jf-lang-toggle:hover .jf-lang-icon { opacity: 1; color: var(--jf-primary) }

/* ─ Mobile Menu Toggle (hamburger icon) ─ */
.jf-menu-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 8px }
.jf-menu-toggle span { width: 22px; height: 1.5px; background: var(--jf-text); transition: var(--jf-transition) }
.jf-menu-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(4.5px, 4.5px) }
.jf-menu-toggle.active span:nth-child(2) { opacity: 0 }
.jf-menu-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(4.5px, -4.5px) }

/* ─ Mobile Overlay ─ */
.jf-mobile-overlay {
  position: fixed; inset: 0; z-index: 998;
  background: rgba(0,0,0,.45); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  opacity: 0; visibility: hidden; transition: all .35s ease;
}
.jf-mobile-overlay.active { opacity: 1; visibility: visible }

/* ─ Mobile Drawer — Premium Full-height Panel ─ */
.jf-mobile-drawer {
  position: fixed; top: 0; right: -100%; width: 80%; max-width: 320px;
  height: 100vh; height: 100dvh; z-index: 999;
  background: var(--jf-background);
  display: flex; flex-direction: column;
  transition: right .4s cubic-bezier(.16,1,.3,1);
  box-shadow: -8px 0 40px rgba(0,0,0,.15);
}
[data-lang="ar"] .jf-mobile-drawer { right: auto; left: -100%; box-shadow: 8px 0 40px rgba(0,0,0,.15) }
.jf-mobile-drawer.active { right: 0 }
[data-lang="ar"] .jf-mobile-drawer.active { left: 0; right: auto }

/* Drawer Header */
.jf-drawer-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 24px 24px 20px; border-bottom: 1px solid var(--jf-border);
}
.jf-drawer-brand {
  font-family: var(--jf-font-en); font-size: 1.3rem; font-weight: 600;
  color: var(--jf-text); letter-spacing: -.03em;
}
.jf-drawer-close {
  background: none; border: 1px solid var(--jf-border); border-radius: 50%;
  width: 38px; height: 38px; cursor: pointer; color: var(--jf-text-mid);
  display: flex; align-items: center; justify-content: center;
  transition: var(--jf-transition);
}
.jf-drawer-close:hover { border-color: var(--jf-primary); color: var(--jf-primary) }

/* Drawer Navigation */
.jf-drawer-nav {
  flex: 1; display: flex; flex-direction: column; gap: 2px;
  padding: 20px 8px; overflow-y: auto;
}
.jf-drawer-link {
  display: block; padding: 14px 20px; border-radius: 10px;
  font-size: 1rem; font-weight: 500; color: var(--jf-text-mid);
  transition: all .25s ease; position: relative;
  opacity: 0; transform: translateX(20px);
}
[data-lang="ar"] .jf-drawer-link { transform: translateX(-20px) }
.jf-mobile-drawer.active .jf-drawer-link {
  opacity: 1; transform: translateX(0);
}
.jf-mobile-drawer.active .jf-drawer-link:nth-child(1) { transition-delay: .08s }
.jf-mobile-drawer.active .jf-drawer-link:nth-child(2) { transition-delay: .12s }
.jf-mobile-drawer.active .jf-drawer-link:nth-child(3) { transition-delay: .16s }
.jf-mobile-drawer.active .jf-drawer-link:nth-child(4) { transition-delay: .20s }
.jf-mobile-drawer.active .jf-drawer-link:nth-child(5) { transition-delay: .24s }
.jf-mobile-drawer.active .jf-drawer-link:nth-child(6) { transition-delay: .28s }
.jf-mobile-drawer.active .jf-drawer-link:nth-child(7) { transition-delay: .32s }
.jf-drawer-link:hover, .jf-drawer-link.active {
  color: var(--jf-text); background: var(--jf-secondary);
}
.jf-drawer-link.active::before {
  content: ''; position: absolute; left: 8px; top: 50%; transform: translateY(-50%);
  width: 3px; height: 18px; border-radius: 3px; background: var(--jf-primary);
}
[data-lang="ar"] .jf-drawer-link.active::before { left: auto; right: 8px }

/* Drawer Footer */
.jf-drawer-footer {
  padding: 20px 24px 32px; border-top: 1px solid var(--jf-border);
  display: flex; flex-direction: column; gap: 16px;
}
.jf-drawer-cta {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 20px; border-radius: 10px;
  background: var(--jf-primary); color: #fff;
  font-size: .9rem; font-weight: 600; text-decoration: none;
  transition: all .3s ease;
}
.jf-drawer-cta:hover { background: var(--jf-primary-dark); transform: translateY(-1px) }
.jf-drawer-socials {
  display: flex; align-items: center; justify-content: center; gap: 16px;
}
.jf-drawer-socials a {
  width: 42px; height: 42px; border-radius: 50%;
  border: 1px solid var(--jf-border);
  display: flex; align-items: center; justify-content: center;
  color: var(--jf-text-mid); transition: var(--jf-transition);
}
.jf-drawer-socials a:hover { border-color: var(--jf-primary); color: var(--jf-primary) }

/* ═══ Buttons — Understated, intentional ═══ */
.jf-btn { display: inline-flex; align-items: center; gap: 8px; padding: 13px 26px; border-radius: 8px; font-weight: 500; font-size: .88rem; cursor: pointer; transition: var(--jf-transition); border: none; text-decoration: none; letter-spacing: .01em }
.jf-btn-primary { background: var(--jf-primary); color: #fff }
.jf-btn-primary:hover { background: var(--jf-primary-dark); transform: translateY(-1px); box-shadow: var(--jf-shadow) }
.jf-btn-secondary { background: var(--jf-white); border: 1px solid var(--jf-border); color: var(--jf-text) }
.jf-btn-secondary:hover { border-color: var(--jf-primary); color: var(--jf-primary) }
.jf-btn-outline { background: transparent; border: 1px solid var(--jf-border); color: var(--jf-text-mid) }
.jf-btn-outline:hover { border-color: var(--jf-primary); color: var(--jf-primary) }
.jf-btn-full { width: 100%; justify-content: center }
.jf-btn-lg { padding: 16px 32px; font-size: .95rem }

/* ═══ Section Shared ═══ */
.jf-section { padding: 100px 0; position: relative }
.jf-section-header { text-align: center; margin-bottom: 56px }
.jf-section-label { margin-bottom: 10px }
.jf-section-label span { display: inline-block; font-size: .72rem; font-weight: 600; color: var(--jf-primary); letter-spacing: .12em; text-transform: uppercase }
.jf-section-title { font-size: clamp(1.6rem, 3.5vw, 2.4rem); font-weight: 600; color: var(--jf-text); line-height: 1.35; margin-bottom: 12px; letter-spacing: -.02em }
.jf-section-subtitle { font-size: .95rem; color: var(--jf-text-light); max-width: 520px; margin: 0 auto; line-height: 1.7 }
/* ═══ Hero — Editorial, magazine-style ═══ */
.jf-hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  position: relative;
  background: var(--jf-beige);
  overflow: hidden;
}
.jf-hero-overlay { display: none }
/* Kill the AI particles */
.jf-hero-particles { display: none }
.jf-particle { display: none }

.jf-hero-content {
  position: relative; z-index: 2;
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
  padding: 140px 20px 80px;
}

.jf-hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 16px;
  border: 1px solid var(--jf-border);
  border-radius: 100px;
  font-size: .72rem; font-weight: 500;
  color: var(--jf-text-light);
  margin-bottom: 28px;
  letter-spacing: .04em;
}
.jf-badge-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--jf-primary) }

.jf-hero-title {
  font-size: clamp(2.2rem, 5vw, 3.2rem);
  font-weight: 600;
  line-height: 1.15;
  margin-bottom: 20px;
  color: var(--jf-text);
  letter-spacing: -.03em;
}

.jf-hero-subtitle {
  font-size: 1rem;
  color: var(--jf-text-mid);
  max-width: 560px;
  margin: 0 auto 36px;
  line-height: 1.75;
  font-weight: 400;
}

.jf-hero-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 56px }

.jf-hero-stats {
  display: flex; align-items: center; justify-content: center;
  gap: 0; width: 100%; max-width: 700px; margin: 0 auto;
  padding-top: 56px;
}
.jf-hero-stat {
  text-align: center; padding: 0 32px; position: relative;
}
.jf-hero-stat::after {
  content: '·'; position: absolute; right: -3px; top: 50%; transform: translateY(-60%);
  font-size: 1.6rem; color: var(--jf-text-light); opacity: .35; line-height: 1;
}
.jf-hero-stat:last-child::after { display: none }
[data-lang="ar"] .jf-hero-stat::after { right: auto; left: -3px }
[data-lang="ar"] .jf-hero-stat:last-child::after { display: none }
[data-lang="ar"] .jf-hero-stat:first-child::after { display: block }
.jf-stat-value {
  display: flex; align-items: baseline; justify-content: center; gap: 4px;
  margin-bottom: 6px; direction: ltr;
}
.jf-stat-number, .jf-stat-number-text {
  font-size: 2.2rem; font-weight: 700; letter-spacing: -.03em; line-height: 1;
  color: var(--jf-text);
}
.jf-stat-unit { font-size: .75rem; font-weight: 500; color: var(--jf-text-light); text-transform: uppercase; margin-inline-start: 2px }
.jf-stat-plus { font-size: 1.2rem; color: var(--jf-text-light); font-weight: 600; line-height: 1 }
.jf-stat-label { font-size: .65rem; color: var(--jf-text-light); display: block; letter-spacing: .04em; text-transform: uppercase; font-weight: 400; opacity: .7 }

.jf-scroll-indicator { position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%); z-index: 2 }
.jf-scroll-mouse { width: 20px; height: 32px; border: 1.5px solid var(--jf-text-light); border-radius: 10px; position: relative; opacity: .5 }
.jf-scroll-wheel { width: 2px; height: 6px; background: var(--jf-text-light); border-radius: 2px; position: absolute; top: 5px; left: 50%; transform: translateX(-50%); animation: scroll 2.5s infinite }
@keyframes scroll { 0% { opacity: 1; transform: translateX(-50%) translateY(0) } 100% { opacity: 0; transform: translateX(-50%) translateY(10px) } }

/* ═══ About — Asymmetric editorial layout ═══ */
.jf-about { background: var(--jf-background) }
.jf-about-grid { display: grid; grid-template-columns: 5fr 6fr; gap: 72px; align-items: start }

.jf-about-img-wrapper {
  position: relative; border-radius: var(--jf-radius); overflow: hidden;
  aspect-ratio: 3/4; background: var(--jf-secondary);
}
.jf-about-img-wrapper img { width: 100%; height: 100%; object-fit: cover }

/* ─ About Slideshow ─ */
.jf-about-slideshow {
  position: relative; width: 100%; height: 100%;
}
.jf-about-slideshow .jf-slide {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; opacity: 0;
  transition: opacity .8s ease-in-out;
}
.jf-about-slideshow .jf-slide.active { opacity: 1; position: relative }
.jf-slide-dots {
  position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 8px; z-index: 5;
}
.jf-slide-dot {
  width: 8px; height: 8px; border-radius: 50%; border: none;
  background: rgba(255,255,255,.4); cursor: pointer;
  transition: all .3s ease; padding: 0;
}
.jf-slide-dot.active {
  background: #fff; width: 24px; border-radius: 4px;
}

.jf-about-float-card {
  position: absolute; bottom: 20px; right: -16px;
  background: var(--jf-white); border: 1px solid var(--jf-border);
  border-radius: var(--jf-radius-sm); padding: 14px 18px;
  display: flex; align-items: center; gap: 10px;
  box-shadow: var(--jf-shadow);
  /* NO glassmorphism */
}
[data-lang="ar"] .jf-about-float-card { right: auto; left: -16px }
.jf-float-icon { font-size: 1.2rem }
.jf-float-number { font-size: 1.2rem; font-weight: 600; color: var(--jf-text); display: block }
.jf-float-number small { font-size: .65rem; color: var(--jf-text-light) }
.jf-float-label { font-size: .7rem; color: var(--jf-text-light) }

/* ═══ Horizontal Timeline ═══ */
.jf-timeline {
  margin-top: 32px; display: flex; flex-direction: row;
  position: relative; justify-content: space-between;
  padding: 0; border: none;
}
.jf-timeline::before {
  content: ''; position: absolute; top: 3px; left: 0; right: 0;
  height: 2px; background: var(--jf-border); z-index: 0;
}
[data-lang="ar"] .jf-timeline { padding: 0; border: none }
.jf-timeline-item {
  position: relative; flex: 1; text-align: center;
  padding: 20px 4px 0; padding-left: 0;
}
[data-lang="ar"] .jf-timeline-item { padding-left: 0; padding-right: 0 }
.jf-timeline-dot {
  position: absolute; top: -2px; left: 50%; transform: translateX(-50%);
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--jf-background); border: 2px solid var(--jf-primary);
  z-index: 1; transition: all .3s ease;
}
[data-lang="ar"] .jf-timeline-dot { left: 50%; right: auto }
.jf-timeline-dot-active { background: var(--jf-primary); border-color: var(--jf-primary); box-shadow: 0 0 0 4px rgba(183,110,121,.2) }
.jf-timeline-date { font-size: .68rem; font-weight: 600; color: var(--jf-primary); text-transform: uppercase; letter-spacing: .04em; display: block }
.jf-timeline-content p { font-size: .76rem; color: var(--jf-text-light); margin-top: 2px; line-height: 1.4 }

.jf-about-story { margin-bottom: 28px }
.jf-story-intro { font-size: 1.15rem; font-weight: 500; color: var(--jf-text); margin-bottom: 10px }
.jf-about-story p { margin-bottom: 10px; color: var(--jf-text-mid); line-height: 1.75; font-size: .92rem }

.jf-trust-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px }
.jf-trust-item { display: flex; align-items: center; gap: 8px; padding: 10px 12px; border: 1px solid var(--jf-border); border-radius: var(--jf-radius-sm); transition: var(--jf-transition); background: var(--jf-background) }
.jf-trust-item:hover { border-color: var(--jf-primary) }
.jf-trust-icon { font-size: 1.1rem }
.jf-trust-item span { font-size: .8rem; font-weight: 500; color: var(--jf-text-mid) }
/* ═══ Features — Clean cards, no glassmorphism ═══ */
.jf-features { background: var(--jf-background) }
.jf-features-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px }
.jf-feature-card {
  position: relative; background: var(--jf-white);
  border: 1px solid var(--jf-border); border-radius: var(--jf-radius);
  padding: 28px 22px; text-align: center; transition: var(--jf-transition); overflow: hidden;
}
.jf-feature-card:hover { border-color: var(--jf-primary); box-shadow: var(--jf-shadow); transform: translateY(-2px) }
.jf-feature-glow { display: none }
.jf-feature-icon {
  width: 48px; height: 48px; margin: 0 auto 16px;
  background: var(--jf-secondary); border-radius: var(--jf-radius-sm);
  display: flex; align-items: center; justify-content: center;
  color: var(--jf-primary); transition: var(--jf-transition);
}
.jf-feature-card:hover .jf-feature-icon { background: var(--jf-primary); color: #fff }
.jf-feature-title { font-size: .92rem; font-weight: 600; margin-bottom: 6px; color: var(--jf-text); letter-spacing: -.01em }
.jf-feature-desc { font-size: .82rem; color: var(--jf-text-light); line-height: 1.6 }

/* ═══ Programs — Premium Glassmorphism 2-Card ═══ */
.jf-programs { background: var(--jf-beige); padding: 80px 0 }
.jf-programs-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px;
  max-width: 780px; margin: 0 auto; align-items: stretch;
}
.jf-program-card {
  position: relative; background: var(--jf-white);
  border: 1px solid var(--jf-border); border-radius: 20px;
  padding: 40px 28px 32px; transition: all .4s cubic-bezier(.16,1,.3,1);
  text-align: center; overflow: hidden;
}
.jf-program-card:hover { box-shadow: 0 20px 60px rgba(183,110,121,.12); transform: translateY(-6px) }
.jf-program-highlight {
  border-color: var(--jf-primary);
  background: linear-gradient(160deg, var(--jf-white) 0%, rgba(183,110,121,.04) 100%);
  box-shadow: 0 0 0 1px var(--jf-primary), 0 12px 40px rgba(183,110,121,.1);
  transform: scale(1.03);
}
.jf-program-highlight:hover { transform: scale(1.03) translateY(-6px) }
.jf-program-highlight::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, var(--jf-primary), var(--jf-primary-light), var(--jf-primary));
  border-radius: 20px 20px 0 0;
}
.jf-program-badge {
  display: inline-block; margin-bottom: 16px;
  padding: 5px 14px; background: linear-gradient(135deg, var(--jf-primary), var(--jf-primary-dark));
  color: #fff; font-size: .68rem; font-weight: 600; border-radius: 100px;
  letter-spacing: .05em; text-transform: uppercase;
  animation: badgePulse 2s ease-in-out infinite;
}
@keyframes badgePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(183,110,121,.3) }
  50% { box-shadow: 0 0 0 8px rgba(183,110,121,0) }
}
.jf-program-title { font-size: 1.2rem; font-weight: 700; margin-bottom: 8px; letter-spacing: -.01em }
.jf-program-desc { font-size: .82rem; color: var(--jf-text-light); margin-bottom: 20px }
.jf-program-price { margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid var(--jf-border) }
.jf-price-amount { font-size: 2.8rem; font-weight: 800; color: var(--jf-text); letter-spacing: -.04em }
.jf-price-period { font-size: .8rem; color: var(--jf-text-light) }
.jf-program-features { margin-bottom: 28px; text-align: start }
.jf-program-features li {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0; font-size: .85rem; color: var(--jf-text-mid);
}
.jf-program-features svg { color: var(--jf-primary); flex-shrink: 0 }
.jf-btn-full { width: 100%; justify-content: center }

/* ═══ Testimonials — Editorial cards ═══ */
.jf-stories { background: var(--jf-background) }
.jf-testimonials-slider { position: relative; overflow: hidden }
.jf-testimonials-track { display: flex; gap: 20px; transition: transform .5s ease }
.jf-testimonial-card {
  flex: 0 0 calc(33.333% - 14px);
  background: var(--jf-white); border: 1px solid var(--jf-border);
  border-radius: var(--jf-radius); padding: 28px; position: relative;
}
.jf-testimonial-quote {
  position: absolute; top: 14px; right: 20px;
  font-size: 2.5rem; color: var(--jf-secondary);
  font-family: Georgia, serif; line-height: 1; opacity: .6;
}
[data-lang="ar"] .jf-testimonial-quote { right: auto; left: 20px }
.jf-testimonial-stars { display: flex; gap: 1px; margin-bottom: 14px }
.jf-testimonial-text { font-size: .86rem; color: var(--jf-text-mid); line-height: 1.7; margin-bottom: 18px; min-height: 72px }
.jf-testimonial-author { display: flex; align-items: center; gap: 10px }
.jf-testimonial-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--jf-secondary);
  display: flex; align-items: center; justify-content: center;
  color: var(--jf-primary); font-weight: 600; font-size: .8rem; flex-shrink: 0;
}
.jf-testimonial-name { font-weight: 600; font-size: .85rem; display: block }
.jf-testimonial-result { font-size: .72rem; color: var(--jf-primary); display: block }
.jf-testimonial-result strong { font-weight: 600 }

.jf-slider-controls { display: flex; align-items: center; justify-content: center; gap: 12px; margin-top: 28px }
.jf-slider-btn {
  width: 40px; height: 40px; border-radius: 50%;
  border: 1px solid var(--jf-border); background: var(--jf-white);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: var(--jf-transition); color: var(--jf-text-mid);
}
.jf-slider-btn:hover { border-color: var(--jf-primary); color: var(--jf-primary) }
.jf-slider-dots { display: flex; gap: 4px }
.jf-slider-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--jf-border); cursor: pointer; transition: var(--jf-transition) }
.jf-slider-dot.active { background: var(--jf-primary); width: 20px; border-radius: 3px }

/* ═══ CTA — Warm, not aggressive ═══ */
.jf-cta { padding: 100px 0; position: relative; overflow: hidden; background: var(--jf-primary) }
.jf-cta-bg { display: none } /* Hide the overlay image approach */
.jf-cta-overlay { display: none }
.jf-cta-content { position: relative; z-index: 2; text-align: center; max-width: 620px; margin: 0 auto }
.jf-cta-emoji { font-size: 2rem; margin-bottom: 16px; opacity: .8 }
.jf-cta-title { font-size: clamp(1.4rem, 3vw, 1.9rem); font-weight: 500; color: #fff; line-height: 1.5; margin-bottom: 12px; letter-spacing: -.01em }
.jf-cta-subtitle { font-size: .9rem; color: rgba(255,255,255,.75); margin-bottom: 28px }
.jf-cta .jf-btn-primary { background: #fff; color: var(--jf-primary); font-weight: 600 }
.jf-cta .jf-btn-primary:hover { background: rgba(255,255,255,.9); transform: translateY(-1px) }
/* ═══ FAQ — Minimal, structured ═══ */
.jf-faq { background: var(--jf-beige) }
.jf-faq-list { max-width: 680px; margin: 0 auto; display: flex; flex-direction: column; gap: 8px }
.jf-faq-item { background: var(--jf-white); border: 1px solid var(--jf-border); border-radius: var(--jf-radius-sm); overflow: hidden; transition: var(--jf-transition) }
.jf-faq-item:hover { border-color: var(--jf-primary) }
.jf-faq-question {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px; background: none; border: none; cursor: pointer;
  font-size: .9rem; font-weight: 500; color: var(--jf-text);
  text-align: left; font-family: inherit; gap: 14px;
}
[data-lang="ar"] .jf-faq-question { text-align: right }
.jf-faq-icon {
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--jf-secondary); display: flex; align-items: center; justify-content: center;
  transition: var(--jf-transition); flex-shrink: 0; color: var(--jf-text-mid);
}
.jf-faq-item.active .jf-faq-icon { background: var(--jf-primary); color: #fff; transform: rotate(45deg) }
.jf-faq-answer { max-height: 0; overflow: hidden; transition: max-height .35s ease }
.jf-faq-item.active .jf-faq-answer { max-height: 200px }
.jf-faq-answer p { padding: 0 20px 18px; font-size: .86rem; color: var(--jf-text-mid); line-height: 1.7 }

/* ═══ Contact — Professional form ═══ */
.jf-contact { background: var(--jf-background) }
.jf-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start }
.jf-contact-channels { display: flex; flex-direction: column; gap: 10px; margin-top: 28px }
.jf-contact-channel {
  display: flex; align-items: center; gap: 12px; padding: 14px;
  border: 1px solid var(--jf-border); border-radius: var(--jf-radius-sm);
  transition: var(--jf-transition); background: var(--jf-white);
}
.jf-contact-channel:hover { border-color: var(--jf-primary) }
[data-lang="ar"] .jf-contact-channel:hover { transform: translateX(-2px) }
[data-lang="en"] .jf-contact-channel:hover { transform: translateX(2px) }
.jf-channel-icon {
  width: 40px; height: 40px; border-radius: var(--jf-radius-sm);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.jf-channel-whatsapp { background: #25D366 }
.jf-channel-instagram { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888) }
.jf-channel-tiktok { background: #010101 }
.jf-contact-channel strong { display: block; font-size: .82rem; color: var(--jf-text) }
.jf-contact-channel span { font-size: .76rem; color: var(--jf-text-light) }

.jf-contact-form-wrapper { background: var(--jf-white); border: 1px solid var(--jf-border); border-radius: var(--jf-radius); padding: 32px }
.jf-form-group { margin-bottom: 16px }
.jf-form-group label { display: block; font-size: .8rem; font-weight: 500; color: var(--jf-text-mid); margin-bottom: 5px }
.jf-form-group input, .jf-form-group textarea {
  width: 100%; padding: 12px 14px; background: var(--jf-background);
  border: 1px solid var(--jf-border); border-radius: var(--jf-radius-sm);
  font-family: inherit; font-size: .88rem; color: var(--jf-text);
  transition: var(--jf-transition); outline: none;
}
.jf-form-group input:focus, .jf-form-group textarea:focus { border-color: var(--jf-primary) }
.jf-form-group textarea { resize: vertical; min-height: 90px }
.jf-form-status { margin-top: 14px; padding: 12px; border-radius: var(--jf-radius-sm); font-size: .85rem; text-align: center }
.jf-form-status.success { background: #f0faf4; color: #2F855A; border: 1px solid #c6f6d5 }
.jf-form-status.error { background: #fef2f2; color: #C53030; border: 1px solid #fed7d7 }

/* ═══ Footer — Clean, professional ═══ */
.jf-footer { background: var(--jf-secondary); padding: 52px 0 0; border-top: 1px solid var(--jf-border) }
.jf-footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 36px }
.jf-footer-tagline { font-size: .82rem; color: var(--jf-text-light); margin-top: 10px }
.jf-footer-col h4 { font-size: .8rem; font-weight: 600; margin-bottom: 12px; color: var(--jf-text); letter-spacing: .03em; text-transform: uppercase }
.jf-footer-col ul { display: flex; flex-direction: column; gap: 6px }
.jf-footer-col a { font-size: .82rem; color: var(--jf-text-light); display: flex; align-items: center; gap: 6px; transition: var(--jf-transition) }
.jf-footer-col a:hover { color: var(--jf-primary) }
/* ═══ Footer Social — Professional branded icons ═══ */
.jf-social-links { display: flex; gap: 10px }
.jf-social-link {
  width: 38px; height: 38px; border-radius: 10px;
  border: 1px solid var(--jf-border); background: var(--jf-white);
  display: flex; align-items: center; justify-content: center;
  color: var(--jf-text-light); transition: all .25s cubic-bezier(.4,.0,.2,1);
  position: relative; overflow: hidden;
}
.jf-social-link::before {
  content: ''; position: absolute; inset: 0;
  border-radius: inherit; opacity: 0; transition: opacity .25s ease;
}
.jf-social-link:hover { border-color: transparent; color: #fff; transform: translateY(-2px); box-shadow: var(--jf-shadow) }
.jf-social-link:hover::before { opacity: 1 }
.jf-social-link svg { position: relative; z-index: 1 }

/* Instagram branded */
.jf-social-instagram::before { background: linear-gradient(135deg, #833ab4, #fd1d1d, #fcb045) }
.jf-social-instagram:hover { border-color: transparent }

/* TikTok branded */
.jf-social-tiktok::before { background: #010101 }
.jf-social-tiktok:hover { border-color: transparent }

/* WhatsApp branded */
.jf-social-whatsapp::before { background: #25D366 }
.jf-social-whatsapp:hover { border-color: transparent }

.jf-footer-bottom { text-align: center; padding: 20px 0; margin-top: 36px; border-top: 1px solid var(--jf-border); font-size: .75rem; color: var(--jf-text-light) }
.jf-footer-credit { margin-top: 6px; font-size: .72rem; color: var(--jf-text-light); opacity: .7 }
.jf-footer-credit a { color: var(--jf-primary); font-weight: 600; text-decoration: none; transition: var(--jf-transition) }
.jf-footer-credit a:hover { color: var(--jf-text); opacity: 1 }

/* ═══ Floating WhatsApp — Elegant Brand Circle ═══ */
.jf-whatsapp-float {
  position: fixed; bottom: 28px; right: 28px; z-index: 999;
  width: 52px; height: 52px;
  background: var(--jf-primary);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  box-shadow: 0 4px 20px rgba(183,110,121,.3), 0 1px 4px rgba(0,0,0,.06);
  transition: all .35s cubic-bezier(.16,1,.3,1);
  text-decoration: none;
}
[data-lang="ar"] .jf-whatsapp-float { right: auto; left: 28px }
.jf-whatsapp-float::before {
  content: ''; position: absolute; inset: -4px;
  border-radius: 50%; border: 2px solid var(--jf-primary);
  opacity: 0; animation: waRing 2.5s ease-in-out infinite;
}
@keyframes waRing {
  0% { opacity: 0; transform: scale(.9) }
  40% { opacity: .3 }
  100% { opacity: 0; transform: scale(1.4) }
}
.jf-whatsapp-float:hover {
  transform: translateY(-3px) scale(1.06);
  box-shadow: 0 8px 32px rgba(183,110,121,.35), 0 2px 8px rgba(0,0,0,.08);
  background: var(--jf-primary-dark);
}
.jf-wa-tooltip {
  position: absolute; right: 62px; top: 50%; transform: translateY(-50%) translateX(6px);
  background: var(--jf-white); color: var(--jf-text);
  font-size: .74rem; font-weight: 500; white-space: nowrap;
  padding: 6px 14px; border-radius: 8px;
  box-shadow: 0 4px 16px rgba(0,0,0,.08);
  opacity: 0; pointer-events: none;
  transition: all .3s cubic-bezier(.16,1,.3,1);
}
[data-lang="ar"] .jf-wa-tooltip { right: auto; left: 62px; transform: translateY(-50%) translateX(-6px) }
.jf-whatsapp-float:hover .jf-wa-tooltip {
  opacity: 1; transform: translateY(-50%) translateX(0);
}

/* ═══ Back to Top ═══ */
.jf-back-top {
  position: fixed; bottom: 24px; right: 24px; z-index: 998;
  width: 40px; height: 40px; border-radius: 10px;
  background: var(--jf-white); border: 1px solid var(--jf-border);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  color: var(--jf-text-mid); opacity: 0; visibility: hidden;
  transform: translateY(10px); transition: var(--jf-transition);
}
/* When WhatsApp is visible, position back-to-top above it */
.jf-back-top.visible { opacity: 1; visibility: visible; transform: translateY(0); bottom: 78px }
[data-lang="ar"] .jf-back-top { right: auto; left: 24px }
.jf-back-top:hover { border-color: var(--jf-primary); color: var(--jf-primary); background: var(--jf-secondary) }

/* ═══ Reveal Animations — Subtle, not dramatic ═══ */
/* ═══ Framer Motion–style Reveal Animations ═══ */
.jf-reveal { opacity: 0; transform: translateY(40px); transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1), filter .7s cubic-bezier(.16,1,.3,1); filter: blur(4px); will-change: opacity, transform, filter }
.jf-reveal.visible { opacity: 1; transform: translateY(0); filter: blur(0) }
.jf-reveal-left { opacity: 0; transform: translateX(-40px); transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1), filter .7s cubic-bezier(.16,1,.3,1); filter: blur(4px) }
.jf-reveal-left.visible { opacity: 1; transform: translateX(0); filter: blur(0) }
.jf-reveal-right { opacity: 0; transform: translateX(40px); transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1), filter .7s cubic-bezier(.16,1,.3,1); filter: blur(4px) }
.jf-reveal-right.visible { opacity: 1; transform: translateX(0); filter: blur(0) }
.jf-reveal-scale { opacity: 0; transform: scale(.92); transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1), filter .7s cubic-bezier(.16,1,.3,1); filter: blur(4px) }
.jf-reveal-scale.visible { opacity: 1; transform: scale(1); filter: blur(0) }
/* Stagger delays — Framer Motion spring timing */
.jf-reveal-delay-1 { transition-delay: .1s }
.jf-reveal-delay-2 { transition-delay: .2s }
.jf-reveal-delay-3 { transition-delay: .3s }
.jf-reveal-delay-4 { transition-delay: .4s }
.jf-reveal-delay-5 { transition-delay: .5s }
.jf-reveal-delay-6 { transition-delay: .6s }

/* ═══ Footer Accordion — Desktop defaults ═══ */
.jf-footer-chevron { display: none }
.jf-footer-toggle { cursor: default }

/* ═══ Responsive ═══ */
@media (max-width: 1024px) {
  .jf-about-grid, .jf-contact-grid { grid-template-columns: 1fr; gap: 36px }
  .jf-footer-grid { grid-template-columns: 1fr 1fr; gap: 20px }
  .jf-testimonial-card { flex: 0 0 calc(50% - 10px) }
}
@media (max-width: 768px) {
  .jf-nav-links { display: none }
  .jf-menu-toggle { display: flex }
  .jf-hero-stats { flex-wrap: wrap; justify-content: center; gap: 8px 0 }
  .jf-hero-stat { padding: 8px 20px }
  .jf-programs-grid { grid-template-columns: 1fr }
  .jf-features-grid { grid-template-columns: 1fr 1fr }
  .jf-testimonial-card { flex: 0 0 100% }
  .jf-trust-grid { grid-template-columns: 1fr }
  .jf-section { padding: 56px 0 }
  .jf-about-float-card { right: 8px; bottom: 12px }
  [data-lang="ar"] .jf-about-float-card { left: 8px; right: auto }

  /* Apple-style footer accordion */
  .jf-footer-grid { grid-template-columns: 1fr; gap: 0 }
  .jf-footer-brand { padding-bottom: 20px; border-bottom: 1px solid var(--jf-border) }
  .jf-footer-accordion { border-bottom: 1px solid var(--jf-border) }
  .jf-footer-toggle {
    cursor: pointer; display: flex; align-items: center; justify-content: space-between;
    padding: 16px 0; margin-bottom: 0;
  }
  .jf-footer-chevron {
    display: block; flex-shrink: 0;
    transition: transform .3s ease; color: var(--jf-text-light);
  }
  .jf-footer-accordion.open .jf-footer-chevron { transform: rotate(180deg) }
  .jf-footer-col-content {
    display: none;
  }
  .jf-footer-accordion.open .jf-footer-col-content {
    display: block; padding-bottom: 16px;
  }
}
@media (max-width: 480px) {
  .jf-features-grid { grid-template-columns: 1fr }
  .jf-hero-content { padding: 100px 16px 40px }
  .jf-hero-cta { flex-direction: column; align-items: stretch }
  .jf-btn { justify-content: center }
  .jf-hero-stat { padding: 6px 16px }
  .jf-stat-number, .jf-stat-number-text { font-size: 1.8rem }
}
