/* ============================================================
   LawBridge Qatar — Unified Service Page Design System
   Applied to all 12 EN + 12 AR service pages
   ============================================================ */

/* ----------------------------------------------------------
   1. GLOBAL COLOR TOKENS
   ---------------------------------------------------------- */
:root {
  --color-bg-primary: #0A1628;
  --color-bg-secondary: #0D1B2A;
  --color-bg-card: #112240;
  --color-gold: #C9A84C;
  --color-gold-muted: rgba(201, 168, 76, 0.15);
  --color-text-primary: #FFFFFF;
  --color-text-secondary: #A0AEC0;
  --color-text-muted: #6B7A99;
  --color-divider: rgba(201, 168, 76, 0.3);
  --color-cta-green: #4CAF72;
}

/* ----------------------------------------------------------
   2. TYPOGRAPHY SYSTEM — Google Fonts loaded via mu-plugin
   ---------------------------------------------------------- */
:root {
  --font-heading: 'Marcellus', serif;
  --font-body: 'Inter', sans-serif;
}

/* ----------------------------------------------------------
   3. BASE — applied to all service pages via body class
   ---------------------------------------------------------- */
body.lb-service-page {
  background-color: var(--color-bg-primary) !important;
}

body.lb-service-page .elementor {
  font-family: var(--font-body) !important;
  color: var(--color-text-secondary) !important;
}

/* ----------------------------------------------------------
   4. SECTION WRAPPER — shared across all sections
   ---------------------------------------------------------- */
body.lb-service-page .lb-section-wrap {
  padding: 60px 0 !important;
}

body.lb-service-page .lb-section-wrap > .e-con-boxed,
body.lb-service-page .lb-section-wrap > .e-con-boxed > .e-con-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}

/* Alternating section backgrounds */
body.lb-service-page .lb-hero {
  background-color: var(--color-bg-primary) !important;
}

body.lb-service-page .lb-content-section:nth-of-type(even) {
  background-color: var(--color-bg-secondary) !important;
}

body.lb-service-page .lb-content-section:nth-of-type(odd) {
  background-color: var(--color-bg-primary) !important;
}

body.lb-service-page .lb-process {
  background-color: var(--color-bg-primary) !important;
}

body.lb-service-page .lb-faq {
  background-color: var(--color-bg-primary) !important;
}

body.lb-service-page .lb-cta-section {
  background-color: var(--color-bg-secondary) !important;
}

body.lb-service-page .lb-footer-section {
  background-color: var(--color-bg-primary) !important;
}

/* ----------------------------------------------------------
   4b. GLOBAL SPACING NORMALIZATION
   ---------------------------------------------------------- */

/* Eliminate default Elementor spacer bloat */
body.lb-service-page .elementor-widget-spacer {
  height: auto !important;
}

body.lb-service-page .elementor-widget-spacer .elementor-spacer {
  height: auto !important;
}

/* Tighten divider widget default margins */
body.lb-service-page .elementor-widget-divider {
  margin-top: 12px !important;
  margin-bottom: 12px !important;
}

/* Heading → paragraph tight coupling */
body.lb-service-page .lb-section-label + .elementor-widget-heading {
  margin-top: 0 !important;
}

/* Divider → grid/content gap */
body.lb-service-page .elementor-widget-divider + .e-con {
  margin-top: 32px !important;
}

/* Flush section stacking — no gap between sections */
body.lb-service-page .lb-section-wrap + .lb-section-wrap,
body.lb-service-page .lb-hero + .lb-section-wrap,
body.lb-service-page .lb-section-wrap + .lb-cta-section {
  margin-top: 0 !important;
}

/* ----------------------------------------------------------
   5. HERO SECTION
   ---------------------------------------------------------- */
body.lb-service-page .lb-hero {
  padding: 60px 24px 40px !important;
  min-height: auto !important;
  text-align: center !important;
}

body.lb-service-page .lb-hero > .e-con-boxed,
body.lb-service-page .lb-hero > .e-con-boxed > .e-con-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}

/* Hero Label */
body.lb-service-page .lb-label .elementor-heading-title {
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  color: var(--color-gold) !important;
  margin-bottom: 10px !important;
}

/* Hero Badge — trophy icon + text inline pill */
body.lb-service-page .lb-hero-badge {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px !important;
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(201, 168, 76, 0.25) !important;
  border-radius: 999px !important;
  padding: 10px 22px !important;
  margin-bottom: 20px !important;
}

body.lb-service-page .lb-hero-badge .elementor-icon {
  width: 22px !important;
  height: 22px !important;
  font-size: 22px !important;
  color: var(--color-gold) !important;
  flex-shrink: 0 !important;
}

body.lb-service-page .lb-hero-badge .elementor-icon svg {
  width: 22px !important;
  height: 22px !important;
  fill: var(--color-gold) !important;
}

body.lb-service-page .lb-hero-badge .elementor-heading-title {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--color-gold) !important;
  white-space: nowrap !important;
  letter-spacing: 0.04em !important;
}

/* Hero H1 */
body.lb-service-page .lb-hero-title .elementor-heading-title {
  font-family: var(--font-heading) !important;
  font-size: 48px !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  color: var(--color-text-primary) !important;
  max-width: 720px !important;
  margin: 0 auto 16px !important;
  text-align: center !important;
  line-height: 1.2 !important;
}

/* Hero Divider */
body.lb-service-page .lb-hero-divider .elementor-divider-separator {
  border-color: var(--color-gold) !important;
}

/* Hero Description */
body.lb-service-page .lb-hero-desc .elementor-widget-container {
  font-family: var(--font-body) !important;
  font-size: 16px !important;
  color: var(--color-text-secondary) !important;
  max-width: 580px !important;
  margin: 12px auto 0 !important;
  line-height: 1.75 !important;
  text-align: center !important;
}

body.lb-service-page .lb-hero-desc .elementor-widget-container p {
  color: var(--color-text-secondary) !important;
}

body.lb-service-page .lb-hero-desc .elementor-widget-container p strong {
  color: #FFFFFF !important;
  font-weight: 600 !important;
}

/* Hero CTA buttons container */
body.lb-service-page .lb-hero-buttons {
  gap: 12px !important;
  justify-content: center !important;
  margin-top: 8px !important;
}

/* Hero primary CTA — green */
body.lb-service-page .lb-hero-cta .elementor-button {
  background: var(--color-cta-green) !important;
  color: #FFFFFF !important;
  border: none !important;
}

body.lb-service-page .lb-hero-cta .elementor-button:hover {
  background: #429E65 !important;
}

/* Hero stats panel */
body.lb-service-page .lb-hero-stats {
  border-radius: 12px !important;
}

/* ----------------------------------------------------------
   6. SECTION HEADING BLOCK — identical on every section
   ---------------------------------------------------------- */
body.lb-service-page .lb-section-label .elementor-heading-title {
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: var(--color-gold) !important;
  text-align: center !important;
  margin-bottom: 10px !important;
}

body.lb-service-page .lb-section-title .elementor-heading-title {
  font-family: var(--font-heading) !important;
  font-size: 36px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  color: var(--color-text-primary) !important;
  text-align: center !important;
  margin-bottom: 12px !important;
  line-height: 1.25 !important;
}

body.lb-service-page .lb-section-divider .elementor-divider-separator {
  border-color: var(--color-gold) !important;
}

body.lb-service-page .lb-section-desc .elementor-widget-container {
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  color: var(--color-text-secondary) !important;
  line-height: 1.75 !important;
  text-align: center !important;
}

body.lb-service-page .lb-section-desc .elementor-widget-container p {
  color: var(--color-text-secondary) !important;
}

/* ----------------------------------------------------------
   7. CARD GRID — Cases, Why Choose, Features
   ---------------------------------------------------------- */
body.lb-service-page .lb-grid {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 24px !important;
  justify-content: center !important;
}

body.lb-service-page .lb-card {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-divider) !important;
  border-radius: 12px !important;
  padding: 28px 24px !important;
  flex: 0 0 calc(33.333% - 16px) !important;
  max-width: calc(33.333% - 16px) !important;
  box-sizing: border-box !important;
  transition: border-color 200ms ease, transform 200ms ease !important;
}

body.lb-service-page .lb-card:hover {
  border-color: var(--color-gold) !important;
  transform: translateY(-2px) !important;
}

/* Card Icon */
body.lb-service-page .lb-card-icon .elementor-icon {
  color: var(--color-gold) !important;
  fill: var(--color-gold) !important;
  font-size: 24px !important;
  margin-bottom: 12px !important;
}

body.lb-service-page .lb-card-icon .elementor-icon i {
  color: var(--color-gold) !important;
  font-size: 24px !important;
}

body.lb-service-page .lb-card-icon svg {
  width: 24px !important;
  height: 24px !important;
  fill: var(--color-gold) !important;
}

/* Card Title */
body.lb-service-page .lb-card-title .elementor-heading-title {
  font-family: var(--font-heading) !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  letter-spacing: 0.03em !important;
  color: var(--color-text-primary) !important;
  margin-bottom: 8px !important;
  line-height: 1.35 !important;
}

/* Card Description */
body.lb-service-page .lb-card-desc .elementor-widget-container {
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  color: var(--color-text-secondary) !important;
  line-height: 1.75 !important;
}

body.lb-service-page .lb-card-desc .elementor-widget-container p {
  color: var(--color-text-secondary) !important;
}

/* 2-column variant for wider cards */
body.lb-service-page .lb-grid-2col .lb-card {
  flex: 0 0 calc(50% - 12px) !important;
  max-width: calc(50% - 12px) !important;
}

/* ----------------------------------------------------------
   7b. ABOUT — Who We Are 2-column layout + stat cards
   ---------------------------------------------------------- */

/* Stat cards inside the stats column — override grid card sizing */
body.lb-service-page .lb-stats-col .lb-stat-card {
  flex: none !important;
  max-width: 100% !important;
  width: 100% !important;
  padding: 20px 24px !important;
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-divider) !important;
  border-radius: 12px !important;
  text-align: center !important;
}

body.lb-service-page .lb-stats-col .lb-stat-card .elementor-heading-title {
  font-family: 'Marcellus', serif !important;
  font-size: 40px !important;
  font-weight: 700 !important;
  color: var(--color-gold) !important;
  line-height: 1 !important;
  margin-bottom: 4px !important;
}

body.lb-service-page .lb-stats-col .lb-stat-card .elementor-widget-container p {
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  color: var(--color-text-secondary) !important;
  line-height: 1.4 !important;
  margin-top: 8px !important;
  margin-bottom: 0 !important;
  text-align: center !important;
}

/* Left text column */
body.lb-service-page .lb-whoweare-text .elementor-widget-container p {
  font-size: 15px !important;
  line-height: 1.8 !important;
  color: var(--color-text-secondary) !important;
  margin-bottom: 20px !important;
}

body.lb-service-page .lb-whoweare-text {
  max-width: 560px !important;
}

/* ----------------------------------------------------------
   8. PROCESS STEPS — 4/5-column cards
   ---------------------------------------------------------- */
body.lb-service-page .lb-process {
  padding: 80px 0 !important;
}

body.lb-service-page .lb-process > .e-con-boxed,
body.lb-service-page .lb-process > .e-con-boxed > .e-con-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}

body.lb-service-page .lb-step-grid {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 24px !important;
  justify-content: center !important;
}

body.lb-service-page .lb-step {
  flex: 0 0 calc(25% - 18px) !important;
  max-width: calc(25% - 18px) !important;
  text-align: center !important;
  padding: 24px 16px !important;
  box-sizing: border-box !important;
}

/* 5-step layout */
body.lb-service-page .lb-step-grid-5 .lb-step {
  flex: 0 0 calc(20% - 20px) !important;
  max-width: calc(20% - 20px) !important;
}

/* Step Number */
body.lb-service-page .lb-step-num .elementor-heading-title {
  font-family: var(--font-heading) !important;
  font-size: 72px !important;
  font-weight: 700 !important;
  color: var(--color-gold) !important;
  line-height: 1 !important;
  margin-bottom: 12px !important;
}

/* Step Title */
body.lb-service-page .lb-step-title .elementor-heading-title {
  font-family: var(--font-heading) !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  color: var(--color-text-primary) !important;
  letter-spacing: 0.03em !important;
  margin-bottom: 8px !important;
  line-height: 1.35 !important;
}

/* Step Description */
body.lb-service-page .lb-step-desc .elementor-widget-container {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  color: var(--color-text-secondary) !important;
  line-height: 1.6 !important;
  letter-spacing: 0.02em !important;
}

body.lb-service-page .lb-step-desc .elementor-widget-container p {
  color: var(--color-text-secondary) !important;
}

/* ----------------------------------------------------------
   9. FAQ SECTION
   ---------------------------------------------------------- */
body.lb-service-page .lb-faq {
  padding: 80px 0 !important;
}

body.lb-service-page .lb-faq > .e-con-boxed,
body.lb-service-page .lb-faq > .e-con-boxed > .e-con-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}

body.lb-service-page .lb-faq-item {
  border-bottom: 1px solid var(--color-divider) !important;
  padding: 24px 0 !important;
  background: transparent !important;
}

body.lb-service-page .lb-faq-q .elementor-heading-title {
  font-family: var(--font-heading) !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  color: var(--color-text-primary) !important;
  line-height: 1.5 !important;
}

body.lb-service-page .lb-faq-a .elementor-widget-container {
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  color: var(--color-text-secondary) !important;
  line-height: 1.75 !important;
  margin-top: 8px !important;
}

body.lb-service-page .lb-faq-a .elementor-widget-container p {
  color: var(--color-text-secondary) !important;
}

/* ----------------------------------------------------------
   10. BOTTOM CTA BANNER
   ---------------------------------------------------------- */
body.lb-service-page .lb-cta-section {
  padding: 60px 24px !important;
  text-align: center !important;
}

body.lb-service-page .lb-cta-section > .e-con-boxed,
body.lb-service-page .lb-cta-section > .e-con-boxed > .e-con-inner,
body.lb-service-page .lb-cta-section > .e-con {
  max-width: 800px !important;
  margin: 0 auto !important;
}

/* CTA heading — force white regardless of Elementor inline */
body.lb-service-page .lb-cta-section .elementor-heading-title {
  font-family: var(--font-heading) !important;
  font-size: 36px !important;
  font-weight: 700 !important;
  color: #FFFFFF !important;
  margin-bottom: 12px !important;
  line-height: 1.3 !important;
  opacity: 1 !important;
}

/* CTA body text — force visible */
body.lb-service-page .lb-cta-section .elementor-widget-text-editor .elementor-widget-container,
body.lb-service-page .lb-cta-section .elementor-widget-text-editor .elementor-widget-container p {
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  color: #A0AEC0 !important;
  line-height: 1.75 !important;
  opacity: 1 !important;
}

/* CTA buttons — force visible */
body.lb-service-page .lb-cta-section .elementor-button {
  opacity: 1 !important;
  padding: 14px 32px !important;
  border-radius: 8px !important;
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  text-transform: none !important;
  letter-spacing: 0.03em !important;
}

/* CTA green call button */
body.lb-service-page .lb-cta-section .elementor-widget-button:first-child .elementor-button {
  background-color: var(--color-cta-green) !important;
  color: #FFFFFF !important;
  border: none !important;
}

body.lb-service-page .lb-cta-section .elementor-widget-button:first-child .elementor-button:hover {
  background-color: #3d9a62 !important;
}

/* CTA gold outline WhatsApp button */
body.lb-service-page .lb-cta-section .elementor-widget-button:last-child .elementor-button {
  background-color: transparent !important;
  color: var(--color-gold) !important;
  border: 1px solid var(--color-gold) !important;
}

body.lb-service-page .lb-cta-section .elementor-widget-button:last-child .elementor-button:hover {
  background-color: var(--color-gold) !important;
  color: var(--color-bg-primary) !important;
}

/* ----------------------------------------------------------
   11. BUTTONS
   ---------------------------------------------------------- */

/* Primary CTA — Gold */
body.lb-service-page .lb-btn-primary .elementor-button {
  background-color: var(--color-gold) !important;
  color: var(--color-bg-primary) !important;
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  padding: 14px 32px !important;
  border-radius: 8px !important;
  border: none !important;
  transition: background-color 200ms ease, transform 200ms ease !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

body.lb-service-page .lb-btn-primary .elementor-button:hover {
  background-color: #D4B55A !important;
  transform: translateY(-1px) !important;
}

body.lb-service-page .lb-btn-primary .elementor-button .elementor-button-text {
  color: var(--color-bg-primary) !important;
}

/* Call CTA — Green (extends .lb-call-btn from mu-plugin) */
body.lb-service-page .lb-btn-call .elementor-button {
  background-color: var(--color-cta-green) !important;
  color: var(--color-text-primary) !important;
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  padding: 14px 32px !important;
  border-radius: 8px !important;
  border: none !important;
  max-width: 260px !important;
  transition: background-color 200ms ease, box-shadow 200ms ease !important;
}

body.lb-service-page .lb-btn-call .elementor-button:hover {
  background-color: #429E65 !important;
  box-shadow: 0 4px 16px rgba(76, 175, 114, 0.3) !important;
}

body.lb-service-page .lb-btn-call .elementor-button .elementor-button-text {
  color: var(--color-text-primary) !important;
}

/* ----------------------------------------------------------
   12. FOOTER SECTION
   ---------------------------------------------------------- */
body.lb-service-page .lb-footer-section {
  padding: 40px 0 !important;
  background-color: var(--color-bg-primary) !important;
}

body.lb-service-page .lb-footer-section > .e-con-boxed,
body.lb-service-page .lb-footer-section > .e-con-boxed > .e-con-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}

/* 12a. Footer grid — 4 columns, wider for Find Us & Contact */
body.lb-service-page .lb-footer-grid {
  display: grid !important;
  grid-template-columns: 1.2fr 1.2fr 1fr 1fr !important;
  gap: 40px !important;
  align-items: start !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 60px 24px !important;
  /* Override Elementor flex row */
  flex-wrap: nowrap !important;
}

/* Force grid children to fill their cell */
body.lb-service-page .lb-footer-grid > .e-con {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  flex-basis: auto !important;
  flex-grow: 0 !important;
  flex-shrink: 1 !important;
}

/* 12b. Footer headings */
body.lb-service-page .lb-footer-section .elementor-heading-title {
  font-family: var(--font-heading) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: var(--color-gold) !important;
  margin-bottom: 20px !important;
  letter-spacing: 0.02em !important;
}

/* 12c. Footer body text */
body.lb-service-page .lb-footer-section .elementor-widget-text-editor .elementor-widget-container {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  color: var(--color-text-secondary) !important;
  line-height: 1.7 !important;
}

body.lb-service-page .lb-footer-section .elementor-widget-text-editor .elementor-widget-container p {
  color: var(--color-text-secondary) !important;
}

/* 12d. Footer links */
body.lb-service-page .lb-footer-section .elementor-widget-text-editor .elementor-widget-container a {
  color: var(--color-text-secondary) !important;
  text-decoration: none !important;
  transition: color 200ms ease !important;
}

body.lb-service-page .lb-footer-section .elementor-widget-text-editor .elementor-widget-container a:hover {
  color: var(--color-gold) !important;
}

/* Quick links column — block links with spacing */
body.lb-service-page .lb-footer-links-col .elementor-widget-text-editor .elementor-widget-container a {
  display: block !important;
  margin-bottom: 10px !important;
}

/* 12e. Social icons — single row, no wrapping, inside Contact column */
body.lb-service-page .lb-footer-social {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 16px !important;
  flex-wrap: nowrap !important;
  margin-top: 16px !important;
  /* NOT a grid — override any inherited grid */
  grid-template-columns: none !important;
}

body.lb-service-page .lb-footer-social > .elementor-widget-icon {
  flex-shrink: 0 !important;
  width: auto !important;
}

body.lb-service-page .lb-footer-social .elementor-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  background: rgba(201, 168, 76, 0.08) !important;
  color: var(--color-text-muted) !important;
  transition: color 200ms ease, background 200ms ease !important;
}

body.lb-service-page .lb-footer-social .elementor-icon:hover {
  color: var(--color-gold) !important;
  background: rgba(201, 168, 76, 0.15) !important;
}

/* Non-social icons in footer */
body.lb-service-page .lb-footer-section .elementor-icon {
  color: var(--color-text-muted) !important;
  transition: color 200ms ease !important;
}

body.lb-service-page .lb-footer-section .elementor-icon:hover {
  color: var(--color-gold) !important;
}

/* 12f. Areas We Serve — 2-column grid inside column */
body.lb-service-page .lb-footer-areas-col .elementor-widget-text-editor .elementor-widget-container p {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 6px 8px !important;
  margin-top: 0 !important;
  list-style: none !important;
  padding: 0 !important;
}

body.lb-service-page .lb-footer-areas-col .elementor-widget-text-editor .elementor-widget-container a,
body.lb-service-page .lb-footer-areas-col .elementor-widget-text-editor .elementor-widget-container span {
  display: block !important;
  font-size: 13px !important;
  color: var(--color-text-secondary) !important;
  white-space: nowrap !important;
  line-height: 1.6 !important;
  margin-bottom: 0 !important;
}

body.lb-service-page .lb-footer-areas-col .elementor-widget-text-editor .elementor-widget-container br {
  display: none !important;
}

/* Dividers in footer */
body.lb-service-page .lb-footer-section .elementor-divider-separator {
  border-color: var(--color-divider) !important;
}

/* Copyright / language line */
body.lb-service-page .lb-footer-section .e-con-inner > .elementor-widget-text-editor:last-of-type .elementor-widget-container {
  font-size: 13px !important;
  color: var(--color-text-muted) !important;
  text-align: center !important;
}

/* 12g. Footer responsive */
@media (max-width: 768px) {
  body.lb-service-page .lb-footer-grid {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
    padding: 32px 16px !important;
  }

  body.lb-service-page .lb-footer-areas-col .elementor-widget-text-editor .elementor-widget-container p {
    grid-template-columns: 1fr 1fr !important;
  }

  body.lb-service-page .lb-footer-social {
    gap: 12px !important;
  }

  body.lb-service-page .lb-footer-section {
    padding: 24px 0 !important;
  }

  /* Footer map iframe */
  body.lb-service-page .lb-footer-section iframe {
    height: 200px !important;
  }
}

/* ----------------------------------------------------------
   13. PILL TAGS — About page expertise grid
   ---------------------------------------------------------- */
body.lb-service-page .lb-pills-grid {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  justify-content: center !important;
}

body.lb-service-page .lb-pill {
  display: inline-block !important;
  background: var(--color-gold-muted) !important;
  border: 1px solid var(--color-gold) !important;
  color: var(--color-gold) !important;
  border-radius: 999px !important;
  padding: 8px 20px !important;
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0.05em !important;
  text-decoration: none !important;
  transition: background-color 200ms ease, color 200ms ease !important;
  white-space: nowrap !important;
}

body.lb-service-page .lb-pill:hover {
  background: var(--color-gold) !important;
  color: var(--color-bg-primary) !important;
}

/* ----------------------------------------------------------
   13b. CONTACT FORM — WPForms dark theme
   ---------------------------------------------------------- */
body.lb-service-page .lb-contact-form .wpforms-container {
  max-width: 100% !important;
  margin: 0 !important;
}

body.lb-service-page .lb-contact-form .wpforms-container .wpforms-form {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
}

body.lb-service-page .lb-contact-form .wpforms-field-label {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--color-text-secondary) !important;
  letter-spacing: 0.03em !important;
  margin-bottom: 8px !important;
}

body.lb-service-page .lb-contact-form .wpforms-field input,
body.lb-service-page .lb-contact-form .wpforms-field textarea,
body.lb-service-page .lb-contact-form .wpforms-field select {
  background: var(--color-bg-card) !important;
  border: 1px solid var(--color-divider) !important;
  border-radius: 8px !important;
  padding: 14px 16px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  color: #FFFFFF !important;
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
  transition: border-color 200ms ease !important;
}

body.lb-service-page .lb-contact-form .wpforms-field input:focus,
body.lb-service-page .lb-contact-form .wpforms-field textarea:focus,
body.lb-service-page .lb-contact-form .wpforms-field select:focus {
  border-color: var(--color-gold) !important;
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(201, 168, 76, 0.15) !important;
}

body.lb-service-page .lb-contact-form .wpforms-field input::placeholder,
body.lb-service-page .lb-contact-form .wpforms-field textarea::placeholder {
  color: var(--color-text-muted) !important;
}

body.lb-service-page .lb-contact-form .wpforms-field select option {
  background: var(--color-bg-card) !important;
  color: #FFFFFF !important;
}

body.lb-service-page .lb-contact-form .wpforms-submit-container button {
  background: var(--color-cta-green) !important;
  color: #FFFFFF !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 14px 32px !important;
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: 0.03em !important;
  cursor: pointer !important;
  transition: background 200ms ease, transform 200ms ease !important;
  width: 100% !important;
}

body.lb-service-page .lb-contact-form .wpforms-submit-container button:hover {
  background: #3d9a62 !important;
  transform: translateY(-1px) !important;
}

body.lb-service-page .lb-contact-form .wpforms-required-label {
  color: var(--color-gold) !important;
}

body.lb-service-page .lb-contact-form .wpforms-field {
  margin-bottom: 20px !important;
}

body.lb-service-page .lb-contact-form .wpforms-field textarea {
  min-height: 120px !important;
  resize: vertical !important;
}

/* Form context info lines */
body.lb-service-page .lb-form-contact-info p {
  margin-bottom: 0 !important;
  color: var(--color-text-secondary) !important;
}

body.lb-service-page .lb-form-contact-info a:hover {
  color: var(--color-gold) !important;
}

/* ----------------------------------------------------------
   13c. MAP EMBED — dark theme
   ---------------------------------------------------------- */
body.lb-service-page .elementor-widget-google_maps iframe {
  border: none !important;
  border-radius: 12px !important;
  display: block !important;
  width: 100% !important;
}

body.lb-service-page .elementor-widget-google_maps .elementor-widget-container {
  max-width: 1200px !important;
  margin: 0 auto !important;
  border-radius: 12px !important;
  overflow: hidden !important;
}

/* Contact map section — constrained width with label */
body.lb-service-page .lb-contact-map {
  padding: 0 0 60px !important;
}

body.lb-service-page .lb-contact-map > .e-con-boxed,
body.lb-service-page .lb-contact-map > .e-con-boxed > .e-con-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 24px !important;
}

body.lb-service-page .lb-contact-map-embed .elementor-widget-container {
  border-radius: 12px !important;
  overflow: hidden !important;
}

body.lb-service-page .lb-contact-map-embed iframe {
  height: 400px !important;
}

@media (max-width: 768px) {
  body.lb-service-page .lb-contact-map-embed iframe {
    height: 300px !important;
  }
}

/* ----------------------------------------------------------
   14. GOLD ACCENTS — universal
   ---------------------------------------------------------- */
body.lb-service-page .elementor-divider-separator {
  border-color: var(--color-divider) !important;
}

/* Spacer normalization moved to section 4b */

body.lb-service-page .lb-hero .elementor-widget-spacer .elementor-spacer {
  height: 12px !important;
}

/* ----------------------------------------------------------
   15. RESPONSIVE — Tablet ≤ 768px
   ---------------------------------------------------------- */
@media (max-width: 768px) {
  /* Prevent horizontal scroll without breaking sticky header */
  body.lb-service-page {
    overflow-x: clip !important;
  }

  /* ── HERO ── */
  body.lb-service-page .lb-hero {
    padding: 36px 20px 32px !important;
    min-height: auto !important;
    text-align: left !important;
  }

  body.lb-service-page .lb-hero .e-con-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  /* Hero: left-align all children */
  body.lb-service-page .lb-hero .elementor-widget-container {
    text-align: left !important;
  }

  body.lb-service-page .lb-hero .elementor-heading-title {
    text-align: left !important;
  }

  /* Hero badge — keep inline-flex, smaller on mobile */
  body.lb-service-page .lb-hero-badge {
    padding: 8px 16px !important;
    gap: 8px !important;
    margin-bottom: 16px !important;
    margin-left: 0 !important;
    margin-right: auto !important;
  }

  body.lb-service-page .lb-hero-badge .elementor-icon,
  body.lb-service-page .lb-hero-badge .elementor-icon svg {
    width: 18px !important;
    height: 18px !important;
    font-size: 18px !important;
  }

  body.lb-service-page .lb-hero-badge .elementor-heading-title {
    font-size: 12px !important;
  }

  /* Hero label — gold uppercase tag */
  body.lb-service-page .lb-label .elementor-heading-title {
    font-size: 13px !important;
    letter-spacing: 0.15em !important;
    margin-bottom: 12px !important;
    text-align: left !important;
  }

  /* Hero H1 — readable mobile size, left-aligned */
  body.lb-service-page .lb-hero-title .elementor-heading-title {
    font-size: 28px !important;
    max-width: 100% !important;
    line-height: 1.3 !important;
    letter-spacing: -0.01em !important;
    text-align: left !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    margin-bottom: 16px !important;
  }

  /* Hero description — left-aligned, readable */
  body.lb-service-page .lb-hero-desc .elementor-widget-container {
    font-size: 15px !important;
    max-width: 100% !important;
    line-height: 1.75 !important;
    text-align: left !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    margin-bottom: 20px !important;
  }

  body.lb-service-page .lb-hero-desc .elementor-widget-container p strong {
    color: #FFFFFF !important;
  }

  /* Hero CTA buttons — stack vertically, full width */
  body.lb-service-page .lb-hero-buttons {
    flex-direction: column !important;
    gap: 12px !important;
    align-items: stretch !important;
  }

  /* Hero primary CTA — green, full width */
  body.lb-service-page .lb-hero-cta .elementor-button {
    background: var(--color-cta-green) !important;
    color: #FFFFFF !important;
    border: none !important;
    width: 100% !important;
    padding: 16px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    text-align: center !important;
    justify-content: center !important;
  }

  /* All hero buttons full width */
  body.lb-service-page .lb-hero .elementor-widget-button {
    width: 100% !important;
  }

  body.lb-service-page .lb-hero .elementor-widget-button .elementor-button {
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 14px 20px !important;
    font-size: 15px !important;
  }

  /* Hero stats panel — 2×2 grid on mobile */
  body.lb-service-page .lb-hero-stats {
    margin-top: 24px !important;
    padding: 20px 16px !important;
  }

  /* Stats row container → 2×2 grid */
  body.lb-service-page .lb-hero-stats > .e-con {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 20px 16px !important;
    flex-wrap: unset !important;
  }

  /* Each stat item — consistent sizing, no borders */
  body.lb-service-page .lb-hero-stats > .e-con > .e-con {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: transparent !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 4px !important;
  }

  /* Stat number */
  body.lb-service-page .lb-hero-stats > .e-con > .e-con > .elementor-widget-heading:first-child .elementor-heading-title {
    font-size: 28px !important;
    font-weight: 700 !important;
    color: var(--color-gold) !important;
    line-height: 1 !important;
  }

  /* Stat label */
  body.lb-service-page .lb-hero-stats > .e-con > .e-con > .elementor-widget-heading:last-child .elementor-heading-title {
    font-size: 11px !important;
    font-weight: 600 !important;
    color: var(--color-text-secondary) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    line-height: 1.3 !important;
  }

  /* Hero divider */
  body.lb-service-page .lb-hero-divider {
    margin: 12px 0 !important;
  }

  /* ── SECTION HEADINGS ── */
  /* Gold section label (e.g. "OUR SERVICES", "HOW IT WORKS") */
  body.lb-service-page .lb-section-label .elementor-heading-title {
    font-size: 14px !important;
    letter-spacing: 0.14em !important;
    margin-bottom: 10px !important;
  }

  /* Section title (white, large) */
  body.lb-service-page .lb-section-title .elementor-heading-title {
    font-size: 28px !important;
    line-height: 1.3 !important;
  }

  /* Section description text */
  body.lb-service-page .lb-section-desc .elementor-widget-container {
    font-size: 16px !important;
    line-height: 1.7 !important;
  }

  /* CTA headings */
  body.lb-service-page .lb-cta-title .elementor-heading-title,
  body.lb-service-page .lb-cta-section .elementor-heading-title {
    font-size: 28px !important;
    line-height: 1.3 !important;
  }

  /* CTA body text */
  body.lb-service-page .lb-cta-section .elementor-widget-text-editor .elementor-widget-container,
  body.lb-service-page .lb-cta-section .elementor-widget-text-editor .elementor-widget-container p {
    font-size: 16px !important;
  }

  /* ── CARDS ── */
  body.lb-service-page .lb-card {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    padding: 20px 16px !important;
    margin: 0 !important;
  }

  body.lb-service-page .lb-grid-2col .lb-card {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }

  /* Tight card grid gap */
  body.lb-service-page .lb-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
  }

  /* Card icon — compact */
  body.lb-service-page .lb-card-icon .elementor-icon,
  body.lb-service-page .lb-card-icon .elementor-icon i {
    font-size: 28px !important;
    margin-bottom: 10px !important;
  }

  body.lb-service-page .lb-card-icon svg {
    width: 28px !important;
    height: 28px !important;
  }

  body.lb-service-page .lb-card-icon {
    margin-bottom: 0 !important;
  }

  /* Card title */
  body.lb-service-page .lb-card-title .elementor-heading-title {
    font-size: 17px !important;
    margin-bottom: 6px !important;
  }

  /* Card description */
  body.lb-service-page .lb-card-desc .elementor-widget-container,
  body.lb-service-page .lb-card-desc .elementor-widget-container p {
    font-size: 14px !important;
    line-height: 1.65 !important;
    margin-bottom: 0 !important;
  }

  /* ── STEPS ── */
  body.lb-service-page .lb-step {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }

  body.lb-service-page .lb-step-grid-5 .lb-step {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }

  body.lb-service-page .lb-step-grid {
    gap: 16px !important;
  }

  body.lb-service-page .lb-step-num .elementor-heading-title {
    font-size: 52px !important;
  }

  body.lb-service-page .lb-step-title .elementor-heading-title {
    font-size: 20px !important;
  }

  body.lb-service-page .lb-step-desc .elementor-widget-container,
  body.lb-service-page .lb-step-desc .elementor-widget-container p {
    font-size: 15px !important;
    line-height: 1.7 !important;
  }

  /* ── SECTION PADDING ── */
  body.lb-service-page .lb-section-wrap {
    padding: 48px 0 !important;
  }

  body.lb-service-page .lb-section-wrap .e-con-inner,
  body.lb-service-page .lb-section-wrap > .e-con-boxed > .e-con-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  body.lb-service-page .lb-process {
    padding: 48px 0 !important;
  }

  body.lb-service-page .lb-process .e-con-inner,
  body.lb-service-page .lb-process > .e-con-boxed > .e-con-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  body.lb-service-page .lb-faq {
    padding: 48px 0 !important;
  }

  body.lb-service-page .lb-faq .e-con-inner,
  body.lb-service-page .lb-faq > .e-con-boxed > .e-con-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  /* ── CTA SECTION ── */
  body.lb-service-page .lb-cta-section {
    padding: 48px 20px !important;
  }

  body.lb-service-page .lb-cta-section .elementor-button {
    padding: 14px 28px !important;
    font-size: 15px !important;
    width: 100% !important;
    max-width: 320px !important;
    text-align: center !important;
  }

  /* ── STATS ── */
  body.lb-service-page .lb-stats-col {
    flex-direction: column !important;
    gap: 12px !important;
  }

  body.lb-service-page .lb-stats-col .lb-stat-card {
    flex: 0 0 100% !important;
    width: 100% !important;
    padding: 20px 24px !important;
  }

  body.lb-service-page .lb-stats-col .lb-stat-card .elementor-heading-title {
    font-size: 36px !important;
  }

  body.lb-service-page .lb-stats-col .lb-stat-card .elementor-widget-container p {
    font-size: 13px !important;
  }

  body.lb-service-page .lb-whoweare-text {
    max-width: 100% !important;
  }

  body.lb-service-page .lb-whoweare-text .elementor-widget-container p {
    font-size: 16px !important;
  }

  /* ── FAQ ── */
  body.lb-service-page .lb-faq-q .elementor-heading-title {
    font-size: 18px !important;
    line-height: 1.4 !important;
  }

  body.lb-service-page .lb-faq-a .elementor-widget-container {
    font-size: 15px !important;
    line-height: 1.7 !important;
  }

  body.lb-service-page .lb-faq-item {
    padding: 20px 0 !important;
  }

  /* ── BUTTONS ── */
  body.lb-service-page .lb-btn-primary .elementor-button,
  body.lb-service-page .lb-btn-call .elementor-button {
    padding: 14px 28px !important;
    font-size: 15px !important;
    width: 100% !important;
    max-width: 320px !important;
    display: flex !important;
    justify-content: center !important;
  }

  body.lb-service-page .lb-card .elementor-button {
    padding: 12px 24px !important;
    font-size: 14px !important;
  }

  /* ── CONTACT ── */
  body.lb-service-page .lb-contact-form {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  body.lb-service-page .lb-contact-map > .e-con-boxed,
  body.lb-service-page .lb-contact-map > .e-con-boxed > .e-con-inner {
    padding: 0 20px !important;
  }

  body.lb-service-page .lb-contact-map {
    padding: 0 0 40px !important;
  }

  /* ── PILL TAGS ── */
  body.lb-service-page .lb-pill {
    padding: 8px 16px !important;
    font-size: 13px !important;
  }

  body.lb-service-page .lb-pills-grid {
    gap: 10px !important;
  }

  /* ── PRIVACY ── */
  body.lb-service-page .lb-privacy-content {
    padding: 28px 20px 40px !important;
  }

  body.lb-service-page .lb-privacy-body .elementor-widget-container h2 {
    font-size: 20px !important;
    margin-top: 32px !important;
  }

  body.lb-service-page .lb-privacy-body .elementor-widget-container p {
    font-size: 16px !important;
  }

  body.lb-service-page .lb-privacy-body .elementor-widget-container ul li {
    font-size: 16px !important;
  }

  /* ── FOOTER ── */
  body.lb-service-page .lb-footer-section .elementor-heading-title {
    font-size: 18px !important;
    margin-bottom: 16px !important;
  }

  body.lb-service-page .lb-footer-section .elementor-widget-text-editor .elementor-widget-container {
    font-size: 14px !important;
    line-height: 1.7 !important;
  }

  body.lb-service-page .lb-footer-areas-col .elementor-widget-text-editor .elementor-widget-container a,
  body.lb-service-page .lb-footer-areas-col .elementor-widget-text-editor .elementor-widget-container span {
    font-size: 14px !important;
  }

  /* ── MISC ── */
  body.lb-service-page .elementor-widget-divider + .e-con {
    margin-top: 24px !important;
  }

  body.lb-service-page .elementor-widget-spacer .elementor-spacer {
    height: 8px !important;
  }
}

/* ----------------------------------------------------------
   16a. RESPONSIVE — Small Mobile ≤ 480px
   ---------------------------------------------------------- */
@media (max-width: 480px) {
  body.lb-service-page .lb-hero {
    padding: 28px 14px 24px !important;
  }

  body.lb-service-page .lb-hero-title .elementor-heading-title {
    font-size: 24px !important;
  }

  body.lb-service-page .lb-section-title .elementor-heading-title {
    font-size: 24px !important;
  }

  body.lb-service-page .lb-cta-title .elementor-heading-title,
  body.lb-service-page .lb-cta-section .elementor-heading-title {
    font-size: 24px !important;
  }

  body.lb-service-page .lb-section-wrap .e-con-inner,
  body.lb-service-page .lb-section-wrap > .e-con-boxed > .e-con-inner,
  body.lb-service-page .lb-process .e-con-inner,
  body.lb-service-page .lb-process > .e-con-boxed > .e-con-inner,
  body.lb-service-page .lb-faq .e-con-inner,
  body.lb-service-page .lb-faq > .e-con-boxed > .e-con-inner {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  body.lb-service-page .lb-cta-section {
    padding: 36px 14px !important;
  }

  body.lb-service-page .lb-step-num .elementor-heading-title {
    font-size: 44px !important;
  }

  body.lb-service-page .lb-footer-grid {
    padding: 28px 14px !important;
    gap: 28px !important;
  }
}

/* ----------------------------------------------------------
   16b. PRIVACY POLICY — long-form document layout
   ---------------------------------------------------------- */
/* Privacy content column */
body.lb-service-page .lb-privacy-content {
  max-width: 800px !important;
  margin: 0 auto !important;
  padding: 40px 24px 60px !important;
  gap: 0 !important;
}

/* Kill Elementor default gaps on privacy containers */
body.lb-service-page .lb-privacy-content.e-con,
body.lb-service-page .lb-privacy-content > .e-con {
  gap: 0 !important;
  --container-default-padding-top: 0px !important;
  --container-default-padding-bottom: 0px !important;
}

body.lb-service-page .lb-privacy-body {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding: 0 !important;
}

/* Section headings */
body.lb-service-page .lb-privacy-body .elementor-widget-container h2 {
  font-family: var(--font-heading) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: #FFFFFF !important;
  margin-top: 40px !important;
  margin-bottom: 14px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid var(--color-divider) !important;
}

body.lb-service-page .lb-privacy-body .elementor-widget-container h2:first-child {
  margin-top: 0 !important;
}

/* Body text */
body.lb-service-page .lb-privacy-body .elementor-widget-container p {
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  color: #A0AEC0 !important;
  line-height: 1.8 !important;
  margin-bottom: 14px !important;
  margin-top: 0 !important;
}

/* Bullet lists */
body.lb-service-page .lb-privacy-body .elementor-widget-container ul {
  padding-left: 20px !important;
  margin-bottom: 14px !important;
  margin-top: 0 !important;
  list-style-type: disc !important;
}

body.lb-service-page .lb-privacy-body .elementor-widget-container ul li {
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  color: #A0AEC0 !important;
  line-height: 1.8 !important;
  margin-bottom: 6px !important;
}

/* Links */
body.lb-service-page .lb-privacy-body .elementor-widget-container a {
  color: var(--color-gold) !important;
  text-decoration: none !important;
  transition: opacity 200ms ease !important;
}

body.lb-service-page .lb-privacy-body .elementor-widget-container a:hover {
  opacity: 0.8 !important;
}

/* Highlighted note box */
body.lb-service-page .lb-privacy-body .privacy-note {
  background: var(--color-bg-card) !important;
  border-left: 3px solid var(--color-gold) !important;
  border-radius: 0 8px 8px 0 !important;
  padding: 16px 20px !important;
  margin: 20px 0 !important;
  font-size: 14px !important;
  color: #A0AEC0 !important;
}

body.lb-service-page .lb-privacy-body .privacy-note p {
  font-size: 14px !important;
  margin-bottom: 8px !important;
}

body.lb-service-page .lb-privacy-body .privacy-note p:last-child {
  margin-bottom: 0 !important;
}

/* ----------------------------------------------------------
   17. RTL OVERRIDES — Arabic pages
   ---------------------------------------------------------- */
body.lb-service-page[dir="rtl"] .lb-hero-title .elementor-heading-title,
body.lb-service-page[dir="rtl"] .lb-section-title .elementor-heading-title,
body.lb-service-page[dir="rtl"] .lb-cta-title .elementor-heading-title {
  font-family: 'Noto Kufi Arabic', var(--font-heading) !important;
  letter-spacing: 0 !important;
}

body.lb-service-page[dir="rtl"] .lb-label .elementor-heading-title,
body.lb-service-page[dir="rtl"] .lb-section-label .elementor-heading-title {
  font-family: 'Noto Sans Arabic', var(--font-body) !important;
  letter-spacing: 0.04em !important;
}

body.lb-service-page[dir="rtl"] .lb-card-title .elementor-heading-title,
body.lb-service-page[dir="rtl"] .lb-step-title .elementor-heading-title,
body.lb-service-page[dir="rtl"] .lb-faq-q .elementor-heading-title {
  font-family: 'Noto Kufi Arabic', var(--font-heading) !important;
  letter-spacing: 0 !important;
}

body.lb-service-page[dir="rtl"] .elementor-widget-container,
body.lb-service-page[dir="rtl"] .elementor-widget-container p {
  font-family: 'Noto Sans Arabic', var(--font-body) !important;
}

body.lb-service-page[dir="rtl"] .lb-btn-primary .elementor-button,
body.lb-service-page[dir="rtl"] .lb-btn-call .elementor-button {
  font-family: 'Noto Sans Arabic', var(--font-body) !important;
}

body.lb-service-page[dir="rtl"] .lb-footer-section .elementor-heading-title {
  font-family: 'Noto Kufi Arabic', var(--font-heading) !important;
}

/* ----------------------------------------------------------
   18. PRINT — clean output
   ---------------------------------------------------------- */
@media print {
  body.lb-service-page .lb-footer-section,
  body.lb-service-page .lb-cta-section {
    display: none !important;
  }

  body.lb-service-page .lb-card {
    border: 1px solid #ccc !important;
    background: #fff !important;
  }

  body.lb-service-page .lb-card-title .elementor-heading-title,
  body.lb-service-page .lb-step-title .elementor-heading-title {
    color: #000 !important;
  }
}

/* ============================================================
   19. BLOG SYSTEM
   ============================================================ */

/* ── Layout container ─────────────────────────────────── */
.lb-blog-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding-left: 24px;
  padding-right: 24px;
}

/* ── Blog Hero ────────────────────────────────────────── */
.lb-blog-hero {
  background: var(--color-bg-primary) !important;
  text-align: center;
  padding: 80px 24px 50px !important;
}
.lb-blog-label {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-gold);
  margin-bottom: 16px;
}
.lb-blog-h1 {
  font-family: var(--font-heading);
  font-size: 48px;
  font-weight: 700;
  color: #FFFFFF;
  line-height: 1.2;
  margin: 0 0 16px;
}
.lb-blog-subtitle {
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--color-text-secondary);
  line-height: 1.7;
  max-width: 600px;
  margin: 0 auto;
}

/* ── Category Filter Pills ────────────────────────────── */
.lb-blog-filters-wrap {
  background: var(--color-bg-secondary);
  border-top: 1px solid var(--color-gold-muted);
  border-bottom: 1px solid var(--color-gold-muted);
  padding: 16px 0;
}
.lb-blog-filters {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 4px;
}
.lb-blog-pill {
  display: inline-block;
  background: var(--color-gold-muted);
  border: 1px solid var(--color-gold);
  color: var(--color-gold);
  border-radius: 999px;
  padding: 8px 20px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: all 200ms ease;
  flex-shrink: 0;
}
.lb-blog-pill:hover,
.lb-blog-pill.active {
  background: var(--color-gold);
  color: #0A1628;
}

/* ── Featured Post ────────────────────────────────────── */
.lb-blog-featured {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-divider);
  border-radius: 12px;
  padding: 32px;
  margin-bottom: 40px;
  transition: border-color 200ms ease;
}
.lb-blog-featured:hover {
  border-color: var(--color-gold);
}
.lb-blog-featured-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 8px;
}
.lb-blog-img-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 220px;
  background: var(--color-bg-secondary);
  border-radius: 8px;
  font-size: 48px;
  color: var(--color-gold);
}
.lb-blog-featured-title {
  font-family: var(--font-heading);
  font-size: 28px;
  font-weight: 700;
  color: #FFFFFF;
  line-height: 1.3;
  margin: 12px 0 16px;
}
.lb-blog-featured-title a {
  color: #FFFFFF;
  text-decoration: none;
}
.lb-blog-featured-title a:hover {
  color: var(--color-gold);
}

/* ── Blog Grid ────────────────────────────────────────── */
.lb-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

/* ── Blog Card ────────────────────────────────────────── */
.lb-blog-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-divider);
  border-radius: 12px;
  padding: 0;
  overflow: hidden;
  transition: border-color 200ms ease, transform 200ms ease;
  display: flex;
  flex-direction: column;
}
.lb-blog-card:hover {
  border-color: var(--color-gold);
  transform: translateY(-2px);
}
.lb-blog-card-img img {
  width: 100%;
  height: 180px;
  object-fit: cover;
}
.lb-blog-card-img .lb-blog-img-placeholder {
  min-height: 180px;
  border-radius: 0;
}
.lb-blog-card-cat {
  display: inline-block;
  background: var(--color-gold-muted);
  border: 1px solid var(--color-gold);
  color: var(--color-gold);
  border-radius: 999px;
  padding: 4px 14px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 16px 20px 8px;
}
.lb-blog-card-title {
  font-family: var(--font-heading);
  font-size: 18px;
  font-weight: 700;
  color: #FFFFFF;
  line-height: 1.4;
  margin: 0 20px 8px;
}
.lb-blog-card-title a {
  color: #FFFFFF;
  text-decoration: none;
}
.lb-blog-card-title a:hover {
  color: var(--color-gold);
}
.lb-blog-card-excerpt {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--color-text-secondary);
  line-height: 1.7;
  margin: 0 20px 12px;
  flex-grow: 1;
}
.lb-blog-card-meta {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--color-text-muted);
  margin: 0 20px 8px;
  display: flex;
  gap: 6px;
}
.lb-blog-read-more {
  display: inline-block;
  color: var(--color-gold);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  margin: 0 20px 20px;
}
.lb-blog-read-more:hover {
  text-decoration: underline;
}

/* ── Pagination ───────────────────────────────────────── */
.lb-blog-pagination {
  text-align: center;
  margin-top: 48px;
  padding-bottom: 20px;
}
.lb-blog-pagination .page-numbers {
  display: inline-block;
  padding: 10px 16px;
  margin: 0 4px;
  border-radius: 8px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-divider);
  color: var(--color-text-secondary);
  font-family: var(--font-body);
  font-size: 14px;
  text-decoration: none;
  transition: all 200ms ease;
}
.lb-blog-pagination .page-numbers.current,
.lb-blog-pagination .page-numbers:hover {
  background: var(--color-gold);
  color: #0A1628;
  border-color: var(--color-gold);
}

/* ── CTA Section (blog) ──────────────────────────────── */
body.lb-blog-page .lb-cta-section {
  background: var(--color-bg-secondary);
  border-top: 1px solid var(--color-divider);
  padding: 60px 24px;
}
.lb-cta-h2 {
  font-family: var(--font-heading);
  font-size: 32px;
  font-weight: 700;
  color: #FFFFFF;
  margin: 0 0 12px;
}
.lb-cta-desc {
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--color-text-secondary);
  margin: 0;
}
.lb-btn-primary {
  display: inline-block;
  background: var(--color-cta-green);
  color: #FFFFFF;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 600;
  padding: 14px 32px;
  border-radius: 8px;
  text-decoration: none;
  transition: opacity 200ms ease;
}
.lb-btn-primary:hover {
  opacity: 0.9;
  color: #FFFFFF;
}

/* ── Breadcrumbs ──────────────────────────────────────── */
.lb-blog-breadcrumbs-wrap {
  background: var(--color-bg-primary);
  padding: 20px 0;
  border-bottom: 1px solid var(--color-gold-muted);
}
.lb-blog-breadcrumbs {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--color-text-muted);
}
.lb-blog-breadcrumbs a {
  color: var(--color-text-secondary);
  text-decoration: none;
}
.lb-blog-breadcrumbs a:hover {
  color: var(--color-gold);
}
.lb-blog-breadcrumbs span {
  margin: 0 6px;
}
.lb-blog-breadcrumbs .current {
  color: var(--color-gold);
  margin: 0;
}

/* ── Single Post Layout ──────────────────────────────── */
.lb-blog-layout {
  background: var(--color-bg-primary);
  padding: 60px 0;
}
.lb-blog-layout-inner {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 60px;
}

/* Post meta bar */
.lb-blog-post-meta {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 20px;
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--color-text-muted);
}
.lb-blog-post-cat {
  background: var(--color-gold-muted);
  border: 1px solid var(--color-gold);
  color: var(--color-gold);
  border-radius: 999px;
  padding: 4px 14px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
}

/* Post title */
.lb-blog-post-title {
  font-family: var(--font-heading);
  font-size: 36px;
  font-weight: 700;
  color: #FFFFFF;
  line-height: 1.3;
  margin: 0 0 24px;
}

/* Post featured image */
.lb-blog-post-img {
  margin-bottom: 32px;
  border-radius: 12px;
  overflow: hidden;
}
.lb-blog-post-img img {
  width: 100%;
  height: auto;
  display: block;
}

/* Post body content */
.lb-blog-post-body h2 {
  font-family: var(--font-heading);
  font-size: 22px;
  font-weight: 700;
  color: #FFFFFF;
  margin: 36px 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--color-divider);
}
.lb-blog-post-body h3 {
  font-family: var(--font-heading);
  font-size: 18px;
  font-weight: 700;
  color: #FFFFFF;
  margin: 28px 0 10px;
}
.lb-blog-post-body p {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--color-text-secondary);
  line-height: 1.85;
  margin-bottom: 20px;
}
.lb-blog-post-body ul,
.lb-blog-post-body ol {
  margin: 0 0 20px 20px;
  padding: 0;
}
.lb-blog-post-body li {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--color-text-secondary);
  line-height: 1.8;
  margin-bottom: 8px;
  padding-left: 8px;
}
.lb-blog-post-body a {
  color: var(--color-gold);
  text-decoration: underline;
}
.lb-blog-post-body blockquote,
.lb-blog-post-body .lb-post-note {
  background: var(--color-bg-card);
  border-left: 3px solid var(--color-gold);
  border-radius: 0 8px 8px 0;
  padding: 16px 20px;
  margin: 28px 0;
  font-size: 14px;
  color: var(--color-text-secondary);
}
.lb-blog-post-body strong {
  color: #FFFFFF;
}

/* Tags */
.lb-blog-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--color-divider);
}
.lb-blog-tag {
  background: var(--color-gold-muted);
  border: 1px solid var(--color-divider);
  color: var(--color-text-secondary);
  border-radius: 999px;
  padding: 4px 14px;
  font-family: var(--font-body);
  font-size: 12px;
}

/* ── Sidebar ──────────────────────────────────────────── */
.lb-blog-sidebar {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.lb-blog-sidebar-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-divider);
  border-radius: 12px;
  padding: 24px;
}
.lb-blog-sidebar-card h3 {
  font-family: var(--font-heading);
  font-size: 18px;
  font-weight: 700;
  color: #FFFFFF;
  margin: 0 0 16px;
}

/* CTA card */
.lb-blog-cta-card {
  border-color: var(--color-gold);
}
.lb-blog-cta-card p {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--color-text-secondary);
  line-height: 1.6;
  margin: 0 0 16px;
}
.lb-btn-blog-cta {
  display: block;
  text-align: center;
  margin-bottom: 10px;
  padding: 12px 20px;
  font-size: 14px;
}
.lb-btn-call-blog {
  display: block;
  text-align: center;
  background: transparent;
  border: 1px solid var(--color-gold);
  color: var(--color-gold);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  padding: 12px 20px;
  border-radius: 8px;
  text-decoration: none;
  transition: all 200ms ease;
}
.lb-btn-call-blog:hover {
  background: var(--color-gold);
  color: #0A1628;
}

/* Related + services lists */
.lb-blog-related-list,
.lb-blog-services-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.lb-blog-related-list li,
.lb-blog-services-list li {
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-gold-muted);
}
.lb-blog-related-list li:last-child,
.lb-blog-services-list li:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}
.lb-blog-related-list a,
.lb-blog-services-list a {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color 200ms ease;
}
.lb-blog-related-list a:hover,
.lb-blog-services-list a:hover {
  color: var(--color-gold);
}

/* ── Blog Mobile Responsive ──────────────────────────── */
@media (max-width: 768px) {
  .lb-blog-h1 {
    font-size: 32px !important;
  }
  .lb-blog-hero {
    padding: 60px 20px 40px !important;
  }
  .lb-blog-filters {
    overflow-x: auto;
    white-space: nowrap;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
  }
  .lb-blog-grid {
    grid-template-columns: 1fr !important;
  }
  .lb-blog-featured {
    grid-template-columns: 1fr !important;
    padding: 20px !important;
    gap: 20px !important;
  }
  .lb-blog-featured-title {
    font-size: 22px !important;
  }
  .lb-blog-layout-inner {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }
  .lb-blog-sidebar {
    order: 2;
  }
  .lb-blog-post-title {
    font-size: 26px !important;
  }
  .lb-blog-post-body h2 {
    font-size: 20px !important;
  }
  .lb-blog-breadcrumbs .current {
    display: inline;
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .lb-blog-card-cat {
    margin: 12px 16px 6px;
  }
  .lb-blog-card-title {
    margin: 0 16px 6px;
  }
  .lb-blog-card-excerpt {
    margin: 0 16px 10px;
  }
  .lb-blog-card-meta {
    margin: 0 16px 6px;
  }
  .lb-blog-read-more {
    margin: 0 16px 16px;
  }
}

@media (max-width: 480px) {
  .lb-blog-h1 {
    font-size: 26px !important;
  }
  .lb-blog-post-title {
    font-size: 22px !important;
  }
}

/* ----------------------------------------------------------
   20. ARABIC BLOG RTL OVERRIDES
   ---------------------------------------------------------- */
.lb-arabic-blog .lb-blog-main {
  direction: rtl;
  text-align: right;
}
.lb-arabic-blog .lb-blog-h1,
.lb-arabic-blog .lb-blog-featured-title,
.lb-arabic-blog .lb-blog-card-title,
.lb-arabic-blog .lb-blog-post-title,
.lb-arabic-blog .lb-cta-h2,
.lb-arabic-blog .lb-blog-sidebar-card h3 {
  font-family: 'Noto Kufi Arabic', 'Marcellus', serif;
}
.lb-arabic-blog .lb-blog-subtitle,
.lb-arabic-blog .lb-blog-card-excerpt,
.lb-arabic-blog .lb-blog-card-meta,
.lb-arabic-blog .lb-blog-post-body,
.lb-arabic-blog .lb-blog-post-meta,
.lb-arabic-blog .lb-blog-breadcrumbs,
.lb-arabic-blog .lb-blog-read-more,
.lb-arabic-blog .lb-blog-pill,
.lb-arabic-blog .lb-blog-tag,
.lb-arabic-blog .lb-cta-desc,
.lb-arabic-blog .lb-btn-primary,
.lb-arabic-blog .lb-btn-call-blog,
.lb-arabic-blog .lb-blog-sidebar-card p,
.lb-arabic-blog .lb-blog-sidebar-card li,
.lb-arabic-blog .lb-blog-sidebar-card a {
  font-family: 'Noto Sans Arabic', 'Inter', sans-serif;
}
.lb-arabic-blog .lb-blog-label {
  font-family: 'Noto Sans Arabic', 'Inter', sans-serif;
  letter-spacing: 0;
}
.lb-arabic-blog .lb-blog-hero,
.lb-arabic-blog .lb-cta-section {
  text-align: center;
}
.lb-arabic-blog .lb-blog-breadcrumbs {
  direction: rtl;
}
.lb-arabic-blog .lb-blog-layout-inner {
  direction: rtl;
}
.lb-arabic-blog .lb-blog-post-body {
  line-height: 1.9;
}
.lb-arabic-blog .lb-blog-post-body h2,
.lb-arabic-blog .lb-blog-post-body h3 {
  font-family: 'Noto Kufi Arabic', serif;
}
/* Phone number stays LTR */
.lb-arabic-blog .lb-btn-call-blog {
  direction: ltr;
  unicode-bidi: embed;
}
