/* ثيم الموقع العام — فاتح ملكي عصري (لا يُطبَّق على تسجيل الدخول أو لوحات الإدارة/التاجر) */
body.landing-body.public-site,
body.landing-body.public-marketing-page {
  --ps-font-body: "IBM Plex Sans Arabic", "Alexandria", "Segoe UI", Tahoma, sans-serif;
  --ps-font-display: "Alexandria", "IBM Plex Sans Arabic", "Segoe UI", sans-serif;
  font-family: var(--ps-font-body);
  /* خلفية الصفحة = نفس درجة أسفل كاروسيل الهيرو (--ps-bg-soft) */
  --ps-bg: #f0f0f2;
  --ps-bg-soft: #f0f0f2;
  --ps-bg-warm: #f0f0f2;
  --ps-surface: #ffffff;
  --ps-surface-2: #fafafa;
  --ps-border: rgba(91, 33, 182, 0.14);
  --ps-border-strong: rgba(91, 33, 182, 0.24);
  --ps-text: #1e1b4b;
  --ps-text-secondary: #475569;
  --ps-text-muted: #64748b;
  --ps-royal: #5b21b6;
  --ps-royal-mid: #7c3aed;
  --ps-royal-light: #a78bfa;
  --ps-gold: #b8860b;
  --ps-gold-mid: #d4a853;
  --ps-gold-soft: #fef3c7;
  --ps-teal: #0d9488;
  --ps-teal-soft: #ccfbf1;
  --ps-success: #059669;
  --ps-warning: #d97706;
  --ps-danger: #dc2626;
  --ps-shadow-sm: 0 8px 24px rgba(91, 33, 182, 0.08);
  --ps-shadow-md: 0 18px 48px rgba(91, 33, 182, 0.12);
  --ps-shadow-lg: 0 28px 70px rgba(30, 27, 75, 0.14);
  --ps-radius: 18px;
  --ps-radius-lg: 28px;
  --ps-header-h: 76px;

  background-color: var(--ps-bg);
  background-image: none;
  color: var(--ps-text);
}

/* منطقة المحتوى تحت الهيرو — نفس اللون دون انقطاع بصري */
body.landing-body.public-site .public-page-flow,
body.landing-body.public-marketing-page .public-page-flow,
body.landing-body.public-site .public-top-stage,
body.landing-body.public-marketing-page .public-top-stage,
body.landing-body.public-site main,
body.landing-body.public-marketing-page .public-subpage-main {
  background-color: transparent;
  background-image: none;
}

/* تجاوز أدوات Bootstrap الداكنة */
body.public-site .text-white,
body.public-marketing-page .text-white {
  color: var(--ps-text) !important;
}
body.public-site .text-white-50,
body.public-marketing-page .text-white-50 {
  color: var(--ps-text-muted) !important;
}
body.public-site .text-secondary,
body.public-marketing-page .text-secondary {
  color: var(--ps-text-muted) !important;
}
body.public-site .text-success,
body.public-marketing-page .text-success {
  color: var(--ps-success) !important;
}
body.public-site .text-warning,
body.public-marketing-page .text-warning {
  color: var(--ps-warning) !important;
}
body.public-site .text-primary,
body.public-marketing-page .text-primary {
  color: var(--ps-royal-mid) !important;
}
body.public-site .link-light,
body.public-marketing-page .link-light {
  color: var(--ps-royal-mid) !important;
}
body.public-site .border-secondary,
body.public-marketing-page .border-secondary {
  border-color: var(--ps-border) !important;
}

.landing-text-muted {
  color: var(--ps-text-muted);
}

/* ——— الهيدر العريض ——— */
.public-top-stage {
  position: relative;
}

body.public-site .landing-header,
body.public-marketing-page .landing-header {
  position: sticky;
  top: 0;
  z-index: 1070;
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid var(--ps-border);
  box-shadow: 0 4px 24px rgba(91, 33, 182, 0.06);
  transition:
    background 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease;
}

@media (min-width: 992px) {
  body.public-marketing-page .landing-header {
    backdrop-filter: blur(16px) saturate(1.2);
    -webkit-backdrop-filter: blur(16px) saturate(1.2);
  }
  body.public-site:not(.public-has-hero-banner) .landing-header,
  body.public-site.public-header-solid .landing-header {
    backdrop-filter: blur(16px) saturate(1.2);
    -webkit-backdrop-filter: blur(16px) saturate(1.2);
  }
}

/* هيدر سينمائي شفاف فوق كاروسيل الهيرو (الصفحة الرئيسية فقط) */
body.public-site.public-has-hero-banner:not(.public-header-solid) .public-top-stage .landing-header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  background: linear-gradient(
    180deg,
    rgba(10, 8, 28, 0.78) 0%,
    rgba(10, 8, 28, 0.42) 45%,
    rgba(10, 8, 28, 0.08) 75%,
    transparent 100%
  );
  border-bottom: none;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

body.public-site.public-has-hero-banner.public-header-solid .landing-header,
body.public-site.public-has-hero-banner.public-nav-open .landing-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  background: rgba(255, 255, 255, 0.97);
  border-bottom: 1px solid var(--ps-border);
  box-shadow: 0 8px 32px rgba(91, 33, 182, 0.1);
  backdrop-filter: blur(14px) saturate(1.15);
  -webkit-backdrop-filter: blur(14px) saturate(1.15);
}

body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .landing-brand,
body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .landing-brand-text {
  color: #fff;
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.55);
}

body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .landing-nav-links a:not(.btn) {
  color: rgba(255, 255, 255, 0.94);
  text-shadow: 0 1px 10px rgba(0, 0, 0, 0.5);
}

body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .landing-nav-links a:not(.btn):hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.14);
}

body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .landing-btn-ghost {
  border-color: rgba(255, 255, 255, 0.5) !important;
  color: #fff !important;
  background: rgba(255, 255, 255, 0.1);
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.2);
}

body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .landing-btn-ghost:hover {
  background: rgba(255, 255, 255, 0.2) !important;
  border-color: rgba(255, 255, 255, 0.7) !important;
}

body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .landing-btn-login {
  box-shadow: 0 6px 22px rgba(0, 0, 0, 0.35);
}

body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .public-nav-toggle {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.4);
  color: #fff;
}

body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .landing-text-muted,
body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .landing-auth-username {
  color: rgba(255, 255, 255, 0.88) !important;
}

/* شعار على خلفية داكنة */
body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .landing-brand-mark:has(.site-logo-img),
body.public-site.public-has-hero-banner:not(.public-header-solid):not(.public-nav-open) .landing-header .landing-brand-mark:has(img) {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.25);
}

.landing-nav-shell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem 1.25rem;
  padding: 0.85rem 0;
  min-height: var(--ps-header-h);
}

.public-nav-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: 1rem;
  position: relative;
  z-index: 1060;
}

@media (min-width: 992px) {
  .landing-nav-shell {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 1rem 1.5rem;
  }
  .public-nav-bar {
    width: auto;
    flex: 0 0 auto;
  }
}

body.public-site .landing-brand,
body.public-marketing-page .landing-brand {
  color: var(--ps-text);
  font-size: clamp(1rem, 2.5vw, 1.15rem);
  font-weight: 800;
  font-family: var(--ps-font-display);
}

body.public-site .landing-title,
body.public-site .landing-section-title,
body.public-site .landing-eyebrow,
body.public-marketing-page .public-page-hero h1,
body.public-marketing-page h1,
body.public-marketing-page h2 {
  font-family: var(--ps-font-display);
}

/* ——— كاروسيل الهيرو بعرض كامل ——— */
body.public-site.public-has-hero-banner .public-hero-carousel {
  margin-top: 0;
}

.public-hero-carousel {
  width: 100vw;
  max-width: 100vw;
  margin: 0;
  margin-inline: calc(50% - 50vw);
  padding: 0;
  position: relative;
  overflow: hidden;
  background: var(--ps-bg-soft);
  isolation: isolate;
  z-index: 1;
}

/* مقاسات مرفوعة موصى بها: 2100×800 أو 1920×732 (نسبة ≈ 21:8) */
.public-hero-carousel-viewport {
  position: relative;
  width: 100%;
  aspect-ratio: 21 / 8;
  /* ارتفاع يتناسب مع العرض — بدون سقف 640px الذي كان يقطّع الصورة على الشاشات الكبيرة */
  max-height: 85vh;
  min-height: clamp(180px, 22vw, 320px);
  height: auto;
  background: var(--ps-bg-soft);
}

.public-hero-carousel-track {
  position: absolute;
  inset: 0;
}

.public-hero-carousel-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.85s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.85s;
  z-index: 1;
  background: var(--ps-bg-soft);
  display: flex;
  align-items: center;
  justify-content: center;
}
.public-hero-carousel-slide.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 2;
}

.public-hero-carousel-slide img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  display: block;
}

/* شاشات عريضة جداً: حافظ على النسبة دون قص — إن ضاق الارتفاع بـ 85vh تبقى الصورة كاملة */
@media (min-width: 1600px) {
  .public-hero-carousel-viewport {
    max-height: min(85vh, calc(100vw * 8 / 21));
  }
}

.public-hero-carousel-caption {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  padding: clamp(1.25rem, 4vw, 3rem);
  background: linear-gradient(0deg, rgba(30, 27, 75, 0.72) 0%, rgba(30, 27, 75, 0.08) 55%, transparent 100%);
  pointer-events: none;
  z-index: 3;
}

.public-hero-carousel-caption-inner {
  max-width: min(720px, 92vw);
}

.public-hero-carousel-caption p {
  margin: 0;
  font-family: var(--ps-font-display);
  font-size: clamp(1.35rem, 3.8vw, 2.65rem);
  font-weight: 700;
  line-height: 1.35;
  color: #fff;
  text-shadow: 0 4px 28px rgba(0, 0, 0, 0.35);
}

.public-hero-carousel-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 48px;
  height: 48px;
  border: none;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--ps-royal);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: var(--ps-shadow-md);
  transition: transform 0.2s ease, background 0.2s ease;
}
.public-hero-carousel-btn:hover {
  transform: translateY(-50%) scale(1.06);
  background: #fff;
}
.public-hero-carousel-btn--prev {
  inset-inline-start: clamp(0.75rem, 2vw, 1.5rem);
}
.public-hero-carousel-btn--next {
  inset-inline-end: clamp(0.75rem, 2vw, 1.5rem);
}

.public-hero-carousel-dots {
  position: absolute;
  bottom: clamp(0.85rem, 2.5vw, 1.35rem);
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
  display: flex;
  gap: 0.45rem;
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.55);
  backdrop-filter: blur(8px);
}

.public-hero-carousel-dot {
  width: 10px;
  height: 10px;
  padding: 0;
  border: none;
  border-radius: 999px;
  background: rgba(91, 33, 182, 0.28);
  cursor: pointer;
  transition: width 0.25s ease, background 0.25s ease;
}
.public-hero-carousel-dot.is-active {
  width: 28px;
  background: linear-gradient(90deg, var(--ps-royal-mid), var(--ps-gold-mid));
}

@media (max-width: 575.98px) {
  .public-hero-carousel-btn {
    width: 40px;
    height: 40px;
    font-size: 1.1rem;
  }
}

body.public-site .landing-brand-mark:not(:has(.site-logo-img)):not(:has(img)),
body.public-marketing-page .landing-brand-mark:not(:has(.site-logo-img)):not(:has(img)) {
  background: linear-gradient(135deg, var(--ps-gold-mid), var(--ps-royal-mid));
  box-shadow: 0 6px 20px rgba(124, 58, 237, 0.25);
}

body.public-site .landing-header .landing-brand-mark:has(.site-logo-img),
body.public-site .landing-header .landing-brand-mark:has(img),
body.public-marketing-page .landing-header .landing-brand-mark:has(.site-logo-img),
body.public-marketing-page .landing-header .landing-brand-mark:has(img) {
  background: var(--ps-surface-2);
  border: 1px solid var(--ps-border);
  border-radius: 12px;
}

body.public-site .landing-nav-links,
body.public-marketing-page .landing-nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.35rem 0.15rem;
}

body.public-site .landing-nav-links a:not(.btn),
body.public-marketing-page .landing-nav-links a:not(.btn) {
  color: var(--ps-text-secondary);
  font-weight: 600;
  font-size: 0.92rem;
  padding: 0.45rem 0.85rem;
  border-radius: 999px;
  transition: color 0.18s ease, background 0.18s ease;
}

body.public-site .landing-nav-links a:not(.btn):hover,
body.public-marketing-page .landing-nav-links a:not(.btn):hover {
  color: var(--ps-royal);
  background: rgba(124, 58, 237, 0.08);
}

.public-nav-auth {
  margin-inline-start: 0.35rem;
}

/* زر الهامبرغر */
.public-nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  padding: 0;
  border: 1px solid var(--ps-border-strong);
  border-radius: 14px;
  background: var(--ps-surface);
  color: var(--ps-royal);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  flex-shrink: 0;
}
.public-nav-toggle:hover {
  background: var(--ps-surface-2);
  box-shadow: var(--ps-shadow-sm);
}
.public-nav-toggle-icon {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 22px;
}
.public-nav-toggle-line {
  display: block;
  height: 2.5px;
  width: 100%;
  border-radius: 2px;
  background: currentColor;
  transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.2s ease, width 0.2s ease;
}
body.public-nav-open .public-nav-toggle-line:nth-child(1) {
  transform: translateY(7.5px) rotate(45deg);
}
body.public-nav-open .public-nav-toggle-line:nth-child(2) {
  opacity: 0;
  width: 0;
}
body.public-nav-open .public-nav-toggle-line:nth-child(3) {
  transform: translateY(-7.5px) rotate(-45deg);
}

/* خلفية التعتيم — تحت الهيدر/اللوحة (لا blur حتى لا تُضبَب القائمة) */
.public-nav-backdrop {
  position: fixed;
  inset: 0;
  z-index: 1030;
  background: rgba(30, 27, 75, 0.52);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.28s ease, visibility 0.28s;
  pointer-events: none;
}
body.public-nav-open .public-nav-backdrop {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* عند فتح القائمة: الهيدر واللوحة فوق طبقة التعتيم */
@media (max-width: 991.98px) {
  body.public-nav-open .landing-header.public-site-header,
  body.public-nav-open .landing-header.public-marketing-page {
    z-index: 1060;
  }
}

body.public-nav-scroll-lock {
  overflow: hidden;
  touch-action: none;
}

/* لوحة الجوال — خارج الهيدر، تنزلق من يمين الشاشة (مناسب لـ RTL) */
.landing-nav-panel {
  box-sizing: border-box;
}

.public-nav-drawer-head {
  display: none;
}

.public-nav-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid var(--ps-border);
  border-radius: 12px;
  background: var(--ps-surface);
  color: var(--ps-royal);
  font-size: 1.65rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.public-nav-close:hover {
  background: var(--ps-surface-2);
  border-color: var(--ps-royal-light);
}

@media (max-width: 991.98px) {
  .public-nav-toggle {
    display: inline-flex;
  }

  .public-nav-drawer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 1rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid var(--ps-border);
  }

  .public-nav-drawer-title {
    font-family: var(--ps-font-display);
    font-weight: 700;
    font-size: 1.05rem;
    color: var(--ps-text);
  }

  .landing-nav-panel {
    position: fixed;
    top: 0;
    right: 0;
    left: auto;
    width: min(88vw, 320px);
    max-width: 100%;
    height: 100dvh;
    height: 100svh;
    z-index: 2;
    margin: 0;
    padding: 1rem 1.15rem 2rem;
    background: #ffffff;
    background: #ffffff;
    border-left: 1px solid var(--ps-border);
    box-shadow: -16px 0 48px rgba(91, 33, 182, 0.18);
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    transform: translate3d(110%, 0, 0);
    visibility: hidden;
    pointer-events: none;
    filter: none;
    -webkit-filter: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    transition:
      transform 0.32s cubic-bezier(0.4, 0, 0.2, 1),
      visibility 0.32s;
  }

  html[dir="rtl"] .landing-nav-panel {
    right: 0;
    left: auto;
    border-left: 1px solid var(--ps-border);
    border-right: none;
    box-shadow: -16px 0 48px rgba(91, 33, 182, 0.18);
    transform: translate3d(110%, 0, 0);
  }

  body.public-nav-open .landing-nav-panel {
    transform: translate3d(0, 0, 0);
    visibility: visible;
    pointer-events: auto;
  }

  body.public-site .landing-nav-links,
  body.public-marketing-page .landing-nav-links {
    flex-direction: column;
    align-items: stretch;
    gap: 0.2rem;
  }

  body.public-site .landing-nav-links a:not(.btn),
  body.public-marketing-page .landing-nav-links a:not(.btn) {
    display: block !important;
    padding: 0.72rem 1rem;
    font-size: 1rem;
    border-radius: 12px;
  }

  body.public-site .landing-nav-links a:not(.btn):hover,
  body.public-marketing-page .landing-nav-links a:not(.btn):hover {
    background: rgba(124, 58, 237, 0.08);
  }

  body.public-site .landing-nav-links .btn,
  body.public-marketing-page .landing-nav-links .btn {
    width: 100%;
    margin-top: 0.35rem;
    justify-content: center;
    display: inline-flex;
  }

  .public-nav-auth {
    margin-inline-start: 0 !important;
    width: 100%;
    flex-direction: column !important;
    align-items: stretch !important;
  }
}

/* إلغاء إخفاء الروابط من app.css على الموبايل */
@media (max-width: 991.98px) {
  body.public-site .landing-nav-panel .landing-nav-links a:not(.btn),
  body.public-marketing-page .landing-nav-panel .landing-nav-links a:not(.btn) {
    display: block !important;
  }
}

/* سطح المكتب — الروابط داخل صف الهيدر */
@media (min-width: 992px) {
  .public-nav-drawer-head {
    display: none !important;
  }

  .landing-nav-panel {
    position: static;
    display: flex;
    flex: 1 1 auto;
    justify-content: center;
    align-items: center;
    width: auto;
    height: auto;
    padding: 0;
    margin: 0;
    background: transparent;
    border: none;
    box-shadow: none;
    transform: none;
    visibility: visible;
    pointer-events: auto;
    overflow: visible;
  }

  .landing-nav-panel-body {
    width: 100%;
    display: flex;
    justify-content: center;
  }

  body.public-site .landing-nav-links a.d-none,
  body.public-marketing-page .landing-nav-links a.d-none {
    display: none !important;
  }
}

/* أزرار */
body.public-site .landing-btn-login,
body.public-marketing-page .landing-btn-login {
  background: linear-gradient(135deg, var(--ps-royal-mid), var(--ps-royal));
  color: #fff !important;
  border: none;
  border-radius: 999px;
  font-weight: 700;
  box-shadow: 0 8px 22px rgba(124, 58, 237, 0.28);
}
body.public-site .landing-btn-login:hover,
body.public-marketing-page .landing-btn-login:hover {
  filter: brightness(1.06);
  color: #fff !important;
}

body.public-site .landing-btn-primary,
body.public-marketing-page .landing-btn-primary {
  background: linear-gradient(135deg, var(--ps-gold-mid), var(--ps-gold));
  color: #1a1408 !important;
  border: none;
  font-weight: 800;
  border-radius: 14px;
  box-shadow: 0 10px 28px rgba(184, 134, 11, 0.28);
}
body.public-site .landing-btn-primary:hover,
body.public-marketing-page .landing-btn-primary:hover {
  filter: brightness(1.05);
  color: #1a1408 !important;
}

body.public-site .landing-btn-ghost,
body.public-marketing-page .landing-btn-ghost {
  border: 1.5px solid var(--ps-border-strong);
  color: var(--ps-royal) !important;
  background: var(--ps-surface);
  border-radius: 14px;
  font-weight: 700;
}
body.public-site .landing-btn-ghost:hover,
body.public-marketing-page .landing-btn-ghost:hover {
  background: rgba(124, 58, 237, 0.06);
  color: var(--ps-royal) !important;
  border-color: var(--ps-royal-light);
}

body.public-site .landing-btn-cta,
body.public-marketing-page .landing-btn-cta {
  background: linear-gradient(135deg, var(--ps-royal-mid), var(--ps-royal));
  color: #fff !important;
  border-radius: 999px;
  font-weight: 800;
  border: none;
  box-shadow: var(--ps-shadow-md);
}
body.public-site .landing-btn-cta:hover,
body.public-marketing-page .landing-btn-cta:hover {
  filter: brightness(1.06);
  color: #fff !important;
}

body.public-site .btn-link.text-white-50,
body.public-marketing-page .btn-link {
  color: var(--ps-royal-mid) !important;
  text-decoration: none;
  font-weight: 600;
}
body.public-site .btn-link:hover,
body.public-marketing-page .btn-link:hover {
  color: var(--ps-royal) !important;
}

/* الهيرو: public_hero.css */

/* أقسام */
body.public-site .landing-section {
  padding: clamp(3rem, 6vw, 5rem) 0;
}
body.public-site .landing-section-alt {
  background: transparent;
  border-block: none;
}
body.public-site .landing-section-title {
  color: var(--ps-text);
  font-weight: 800;
}
body.public-site .landing-section-sub {
  color: var(--ps-text-secondary);
}

/* بطاقات المزايا */
body.public-site .landing-feature-card {
  border: 1px solid var(--ps-border);
  box-shadow: var(--ps-shadow-sm);
}
body.public-site .landing-feature-card:hover {
  box-shadow: var(--ps-shadow-md);
}
body.public-site .landing-card-emerald {
  background: linear-gradient(155deg, #ecfdf5, #d1fae5);
  color: #064e3b;
}
body.public-site .landing-card-sapphire {
  background: linear-gradient(155deg, #eff6ff, #dbeafe);
  color: #1e3a8a;
}
body.public-site .landing-card-amethyst {
  background: linear-gradient(155deg, #f5f3ff, #ede9fe);
  color: #5b21b6;
}
body.public-site .landing-card-gold {
  background: linear-gradient(155deg, #fffbeb, #fef3c7);
  color: #78350f;
}
body.public-site .landing-feature-card .text-white-50,
body.public-site .landing-feature-card p {
  color: inherit !important;
  opacity: 0.82;
}

/* إحصائيات */
body.public-site .landing-stat-tile {
  background: var(--ps-surface);
  border: 1px solid var(--ps-border);
  box-shadow: var(--ps-shadow-sm);
}
body.public-site .landing-stat-num {
  background: linear-gradient(90deg, var(--ps-royal), var(--ps-gold));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
body.public-site .landing-stat-caption {
  color: var(--ps-text-muted);
}

/* CTA */
body.public-site .landing-cta {
  background: transparent;
  border-block: none;
}
body.public-site .landing-cta h2 {
  color: var(--ps-text) !important;
}

/* تذييل — عرض كامل (مثل الهيرو) */
body.public-site .landing-footer-shell,
body.public-marketing-page .landing-footer-shell {
  width: 100%;
  max-width: min(1720px, 100%);
  margin-inline: auto;
  padding-inline: clamp(1.15rem, 4.5vw, 4.5rem);
}

body.public-site .landing-footer,
body.public-marketing-page .landing-footer {
  background: transparent;
  background-image: none;
  border-top: 1px solid var(--ps-border);
  width: 100%;
}
body.public-site .landing-footer-list a,
body.public-marketing-page .landing-footer-list a {
  color: var(--ps-text-secondary);
}
body.public-site .landing-footer-list a:hover,
body.public-marketing-page .landing-footer-list a:hover {
  color: var(--ps-royal);
}
body.public-site .landing-footer-panel-title {
  color: var(--ps-gold);
}
body.public-site .landing-footer-tagline {
  color: var(--ps-text-muted) !important;
}
body.public-site .landing-footer-aside-card {
  background: var(--ps-surface);
  border: 1px solid var(--ps-border);
  box-shadow: var(--ps-shadow-sm);
}
body.public-site .landing-footer-dynamic {
  color: var(--ps-text-secondary);
}
body.public-site .landing-footer-dynamic a {
  color: var(--ps-royal-mid);
}
body.public-site .landing-footer-dynamic a:hover {
  color: var(--ps-royal);
}
body.public-site .landing-seo-keywords {
  background: transparent;
  border-top-color: var(--ps-border);
}
body.public-site .landing-seo-keywords-heading {
  color: var(--ps-text-muted);
}
body.public-site .landing-seo-keywords .landing-seo-kw {
  background: var(--ps-surface) !important;
  color: var(--ps-text-secondary) !important;
  border-color: var(--ps-border) !important;
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}
body.public-site .landing-seo-keywords a.landing-seo-kw:hover,
body.public-site .landing-seo-keywords a.landing-seo-kw:focus-visible {
  color: var(--ps-royal) !important;
  border-color: rgba(124, 58, 237, 0.45) !important;
  background: rgba(124, 58, 237, 0.08) !important;
}
body.public-site .landing-footer-bottom {
  color: var(--ps-text-muted) !important;
  border-top-color: var(--ps-border);
}

body.public-site .landing-seo-keywords-inner {
  max-width: none;
  margin-inline: 0;
  padding-inline: 0;
  text-align: center;
}

body.public-site .landing-footer-brand .fw-bold.text-white,
body.public-site .landing-footer-brand [data-site-name] {
  color: var(--ps-text) !important;
}

/* باقات / فيديوهات (landing inline → ثيم فاتح) */
body.public-site .landing-plan-card {
  border: 1px solid var(--ps-border);
  border-radius: var(--ps-radius-lg);
  padding: 28px;
  background: var(--ps-surface);
  box-shadow: var(--ps-shadow-md);
  color: var(--ps-text);
  backdrop-filter: none;
}
body.public-site .landing-plan-card h3,
body.public-site .landing-plan-card .h3 {
  color: var(--ps-text);
}
body.public-site .landing-plan-card .text-white-50,
body.public-site .landing-plan-card .landing-plan-price span {
  color: var(--ps-text-muted) !important;
}
body.public-site .landing-plan-card .landing-plan-price strong {
  color: var(--ps-text);
}
body.public-site .landing-plan-card:hover {
  border-color: var(--ps-royal-light);
  box-shadow: var(--ps-shadow-lg);
}
body.public-site .landing-plan-card--featured {
  border-color: var(--ps-royal-light);
  background: var(--ps-surface);
}
body.public-site .landing-plan-badge {
  border-color: var(--ps-border);
  color: var(--ps-gold);
  background: var(--ps-gold-soft);
}
body.public-site .landing-plan-limit {
  background: var(--ps-surface-2);
}
body.public-site .landing-plan-limit span {
  color: var(--ps-text-muted);
}
body.public-site .landing-plan-feature {
  color: var(--ps-text-secondary);
}
body.public-site .landing-plan-feature::before {
  background: var(--ps-teal-soft);
  color: var(--ps-teal);
}
body.public-site .landing-plan-empty {
  background: var(--ps-surface);
  color: var(--ps-text-secondary);
  border: 1px dashed var(--ps-border);
}

body.public-site .landing-billing-toggle {
  border-color: var(--ps-border);
  background: var(--ps-surface);
  box-shadow: var(--ps-shadow-sm);
}
body.public-site .landing-billing-toggle__btn {
  color: var(--ps-text-muted);
}
body.public-site .landing-billing-toggle__btn.is-active {
  color: #fff;
  background: linear-gradient(135deg, var(--ps-royal) 0%, var(--ps-royal-dark, #5b21b6) 100%);
}
body.public-site .landing-plan-equiv {
  color: var(--ps-text-muted);
}
body.public-site .landing-plan-save-badge {
  background: var(--ps-teal-soft);
  color: var(--ps-teal);
  border-color: rgba(13, 148, 136, 0.22);
}

body.public-site .landing-video-card {
  border: 1px solid var(--ps-border);
  background: var(--ps-surface);
  box-shadow: var(--ps-shadow-sm);
}
body.public-site .landing-video-card:hover {
  border-color: var(--ps-royal-light);
}
body.public-site .landing-video-card-link {
  color: var(--ps-text);
}
body.public-site .landing-video-card-link:hover {
  color: var(--ps-text);
}
body.public-site .landing-video-thumb-wrap {
  background: var(--ps-bg-soft);
}
body.public-site .landing-video-play {
  background: rgba(30, 27, 75, 0.25);
  color: #fff;
}
body.public-site .landing-tag {
  background: rgba(124, 58, 237, 0.1);
  color: var(--ps-royal);
}
body.public-site .landing-social-icon {
  border-color: var(--ps-border);
  background: var(--ps-surface);
  color: var(--ps-text-secondary);
}
body.public-site .landing-social-icon:hover {
  background: var(--ps-surface-2);
  color: var(--ps-royal);
}

body.public-site .site-logo-img {
  max-height: 40px;
  max-width: 160px;
}
body.public-site .landing-brand-mark .site-logo-img {
  max-height: 44px;
}
body.public-site .landing-footer-brand .site-logo-img {
  max-height: 36px;
}

/* صفحات المحتوى الفرعية — ثيم فاتح (public_pages.css = تخطيط فقط) */
body.public-marketing-page .public-page-hero {
  padding: clamp(2rem, 5vw, 3rem) 0 clamp(1.5rem, 4vw, 2.5rem);
  border-bottom: 1px solid var(--ps-border);
  background: #ffffff;
}
body.public-marketing-page .public-page-hero h1 {
  color: var(--ps-text);
}
body.public-marketing-page .public-page-hero .lead {
  color: var(--ps-text-secondary);
}
body.public-marketing-page .public-breadcrumb {
  color: var(--ps-text-muted);
}
body.public-marketing-page .public-breadcrumb a {
  color: var(--ps-royal-mid);
}
body.public-marketing-page .public-prose h2 {
  color: var(--ps-text);
  border-bottom-color: var(--ps-border);
}
body.public-marketing-page .public-prose h3 {
  color: var(--ps-text);
}
body.public-marketing-page .public-prose p,
body.public-marketing-page .public-prose li {
  color: var(--ps-text-secondary);
}
body.public-marketing-page .public-prose a {
  color: var(--ps-royal-mid);
}
body.public-marketing-page .public-prose a:hover {
  color: var(--ps-royal);
}
body.public-marketing-page .public-prose code {
  background: var(--ps-surface-2);
  border-color: var(--ps-border);
  color: var(--ps-gold);
}
body.public-marketing-page .public-callout {
  border-color: rgba(217, 119, 6, 0.35);
  background: #fffbeb;
  color: #92400e;
}
body.public-marketing-page .public-callout--info {
  border-color: rgba(124, 58, 237, 0.35);
  background: #ffffff;
  color: var(--ps-royal);
}
body.public-marketing-page .public-table-wrap {
  border-color: var(--ps-border);
}
body.public-marketing-page .public-prose table {
  color: var(--ps-text-secondary);
}
body.public-marketing-page .public-prose th {
  background: var(--ps-surface-2);
  color: var(--ps-text);
}
body.public-marketing-page .public-prose td {
  border-bottom-color: var(--ps-border);
}
body.public-marketing-page .blog-card-grid .card {
  border: 1px solid var(--ps-border);
  background: var(--ps-surface);
  box-shadow: var(--ps-shadow-sm);
}
body.public-marketing-page .blog-card-grid .card:hover {
  border-color: var(--ps-royal-light);
}
body.public-marketing-page .blog-card-grid .card-title,
body.public-marketing-page .blog-card-grid .card-title a {
  color: var(--ps-text) !important;
}
body.public-marketing-page .blog-card-grid .text-muted {
  color: var(--ps-text-muted) !important;
}

/* تجاوز app.css (الثيم الداكن القديم) — خلفية موحّدة + مكونات بيضاء */
body.landing-body.public-site main {
  background: transparent;
}

body.landing-body.public-site .landing-hero,
body.landing-body.public-site .landing-section,
body.landing-body.public-site .landing-section-alt,
body.landing-body.public-site .landing-cta,
body.landing-body.public-site .landing-footer,
body.landing-body.public-site .landing-seo-keywords {
  background: transparent !important;
  background-image: none !important;
}

body.landing-body.public-site .landing-section-title {
  color: var(--ps-text) !important;
}

body.landing-body.public-site .landing-section-sub {
  color: var(--ps-text-secondary) !important;
}

body.landing-body.public-site .landing-stat-tile {
  background: var(--ps-surface) !important;
  border: 1px solid var(--ps-border) !important;
  box-shadow: var(--ps-shadow-sm);
}

body.landing-body.public-site .landing-stat-caption {
  color: var(--ps-text-muted) !important;
}

body.landing-body.public-site .landing-plan-card,
body.landing-body.public-site .landing-plan-card--featured,
body.landing-body.public-site .landing-plan-empty {
  background: var(--ps-surface) !important;
  background-image: none !important;
  color: var(--ps-text);
  border-color: var(--ps-border);
}

body.landing-body.public-site .landing-footer {
  color: var(--ps-text-secondary);
}

body.landing-body.public-site .landing-footer-list a {
  color: var(--ps-text-secondary) !important;
}

body.landing-body.public-site .landing-footer-list a:hover {
  color: var(--ps-royal) !important;
}

body.landing-body.public-site .landing-footer-aside-card {
  background: var(--ps-surface) !important;
  background-image: none !important;
}

body.landing-body.public-site .landing-cta h2,
body.landing-body.public-site .landing-cta .text-white {
  color: var(--ps-text) !important;
}

body.landing-body.public-site .landing-cta .text-white-50 {
  color: var(--ps-text-secondary) !important;
}

body.landing-body.public-site .landing-seo-keywords {
  background: transparent !important;
  background-image: none !important;
  border-top-color: var(--ps-border) !important;
}

body.landing-body.public-site .landing-footer-dynamic,
body.landing-body.public-site .landing-footer-dynamic a {
  color: var(--ps-text-secondary) !important;
}

body.landing-body.public-site .landing-footer-dynamic a:hover {
  color: var(--ps-royal) !important;
}

/* خط موحّد — Cairo (مع Noto Kufi Arabic كاحتياطي) وتجاوز Tajawal من app.css */
body.landing-body.public-site,
body.landing-body.public-marketing-page {
  font-family: var(--ps-font-body) !important;
}

body.landing-body.public-site :where(
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  .landing-title,
  .landing-section-title,
  .landing-brand,
  .landing-brand-text,
  .landing-eyebrow,
  .public-page-hero h1,
  .public-page-hero-card h1
) {
  font-family: var(--ps-font-display) !important;
}

/* ——— بطاقات الصفحات الفرعية (موحّدة مع الرئيسية) ——— */
body.public-marketing-page .public-page-hero-card {
  position: relative;
  border-radius: 22px;
  padding: clamp(1.35rem, 3.2vw, 2.1rem) clamp(1.25rem, 3vw, 2rem);
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.98) 0%,
    rgba(245, 240, 255, 0.92) 48%,
    rgba(255, 251, 235, 0.88) 100%
  );
  border: 1px solid var(--ps-border);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.9) inset,
    0 18px 48px rgba(91, 33, 182, 0.08),
    0 4px 14px rgba(15, 23, 42, 0.04);
  overflow: hidden;
}

body.public-marketing-page .public-page-hero-card::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 5px;
  height: 100%;
  background: linear-gradient(180deg, var(--ps-royal), var(--ps-gold));
  border-radius: 22px 0 0 22px;
  opacity: 0.92;
}

body.public-marketing-page .public-page-hero-card h1 {
  color: var(--ps-text);
  margin-bottom: 0.65rem;
}

body.public-marketing-page .public-page-hero-card .lead {
  color: var(--ps-text-secondary);
}

body.public-marketing-page .public-page-hero-meta {
  color: var(--ps-text-muted) !important;
}

body.public-marketing-page .public-content-card {
  border-radius: 22px;
  background: var(--ps-surface);
  border: 1px solid var(--ps-border);
  box-shadow: var(--ps-shadow-sm);
}

body.public-marketing-page .public-content-card.public-prose {
  box-shadow:
    var(--ps-shadow-sm),
    0 22px 56px rgba(91, 33, 182, 0.06);
}

body.public-marketing-page .public-blog-panel .public-blog-card {
  background: var(--ps-surface);
  border: 1px solid var(--ps-border);
  box-shadow: 0 8px 28px rgba(91, 33, 182, 0.06);
}

body.public-marketing-page .public-blog-panel .public-blog-card:hover {
  border-color: rgba(124, 58, 237, 0.35);
  box-shadow: 0 16px 40px rgba(91, 33, 182, 0.12);
}

/* Language switcher — cookie-based ar/en */
.lang-switcher { display: inline-flex; align-items: center; }
.lang-switcher-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}
.lang-switcher-icon { font-size: 0.95rem; line-height: 1; }
.lang-switcher--merchant .lang-switcher-btn { border-color: rgba(148, 163, 184, 0.45); color: #e2e8f0; }
.lang-switcher--store .lang-switcher-btn { border-color: rgba(255, 255, 255, 0.22); color: inherit; }
[dir="ltr"] .login-back-link { direction: ltr; }
