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

/* Xfatora brand overrides */
:root {
  /* Brand */
  --color-primary: #5E17EB;
  --color-primary-200: #e2d5fb;
  --color-primary-300: #b08ef5;
  --color-primary-500: #773bee;
  --color-primary-700: #4f11ca;
  --color-primary-800: #410ea6;

  --color-accent: #FF5757;
  --color-accent-700: #e64b4b;
}

/* Accent helpers */
.text-accent { color: var(--color-accent) !important; }
.bg-accent { background-color: var(--color-accent) !important; }
.bg-accent-700 { background-color: var(--color-accent-700) !important; }
.border-accent { border-color: var(--color-accent) !important; }

/* Soft accent backgrounds (no Tailwind opacity suffix needed) */
.bg-accent-soft { background-color: rgba(255, 87, 87, 0.12) !important; }

/* Brand gradient helpers */
.bg-xfatora-gradient {
  background: radial-gradient(1200px circle at 20% 20%, rgba(94, 23, 235, 0.35), transparent 55%),
              radial-gradient(900px circle at 80% 0%, rgba(255, 87, 87, 0.22), transparent 45%),
              radial-gradient(900px circle at 70% 80%, rgba(94, 23, 235, 0.18), transparent 50%),
              linear-gradient(180deg, rgba(94, 23, 235, 0.10) 0%, transparent 60%);
}

/* Nice selection */
::selection {
  background: rgba(94, 23, 235, 0.25);
}

/* Fix logo image crispness */
.logo img {
  image-rendering: -webkit-optimize-contrast;
}

/* Better focus rings */
:focus-visible {
  outline: 3px solid rgba(94, 23, 235, 0.35);
  outline-offset: 3px;
}

/* Buttons */
.btn-primary {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}
.btn-primary:hover {
  background-color: var(--color-primary-700);
  border-color: var(--color-primary-700);
}

.btn-accent {
  background-color: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}
.btn-accent:hover {
  background-color: var(--color-accent-700);
  border-color: var(--color-accent-700);
}

/* Subtle card shadow improvements */
.card-hover {
  transition: transform .25s ease, box-shadow .25s ease;
}
.card-hover:hover {
  transform: translateY(-2px);
}

/* ===== Layout fix: Tailwind v4 container widths (desktop) =====
   The shipped CSS sets containers too small (e.g., 2xl = 42rem).
   Override to standard desktop-friendly widths. */
:root {
  --container-sm: 40rem;   /* 640px */
  --container-md: 48rem;   /* 768px */
  --container-lg: 64rem;   /* 1024px */
  --container-xl: 80rem;   /* 1280px */
  --container-2xl: 96rem;  /* 1536px */
}

/* Optional: slightly more breathing room on wide screens */
.container {
  padding-left: 1rem;
  padding-right: 1rem;
}
@media (min-width: 1024px) {
  .container { padding-left: 1.5rem; padding-right: 1.5rem; }
}

/* ===== English desktop polish (hero, feature spacing, CTA emphasis) ===== */
html[lang="en"] section.bg-xfatora-gradient > .container > .grid {
  padding-top: 4rem;
  padding-bottom: 5rem;
}

html[lang="en"] section.bg-xfatora-gradient h1 {
  font-size: clamp(2.25rem, 4.2vw, 4.5rem);
  line-height: 1.1;
  max-width: 16ch;
}

html[lang="en"] section.bg-xfatora-gradient p {
  max-width: 60ch;
}

html[lang="en"] section.bg-xfatora-gradient .btn-primary,
html[lang="en"] section.bg-xfatora-gradient a[href$="contact.php"],
html[lang="en"] section.bg-xfatora-gradient a[href$="modules.php"] {
  font-size: 1rem;
  padding: 0.85rem 1.6rem;
  min-height: 3rem;
  box-shadow: 0 8px 24px rgba(94, 23, 235, 0.22);
  transition: transform .25s ease, box-shadow .25s ease, background-color .25s ease, border-color .25s ease, color .25s ease;
}

html[lang="en"] section.bg-xfatora-gradient .btn-primary:hover,
html[lang="en"] section.bg-xfatora-gradient a[href$="contact.php"]:hover,
html[lang="en"] section.bg-xfatora-gradient a[href$="modules.php"]:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(94, 23, 235, 0.28);
}

html[lang="en"] .hub-card .group,
html[lang="en"] .hub-card > a,
html[lang="en"] .hub-card > article {
  height: 100%;
}

html[lang="en"] section[data-group] + section[data-group] {
  margin-top: 2.5rem;
}

@media (min-width: 768px) {
  html[lang="en"] section.bg-xfatora-gradient > .container > .grid {
    padding-top: 6rem;
    padding-bottom: 8rem;
  }

  html[lang="en"] section.bg-xfatora-gradient .btn-primary,
  html[lang="en"] section.bg-xfatora-gradient a[href$="contact.php"],
  html[lang="en"] section.bg-xfatora-gradient a[href$="modules.php"] {
    font-size: 1.1rem;
    padding: 1rem 2rem;
  }

  html[lang="en"] section[data-group] + section[data-group] {
    margin-top: 3rem;
  }
}

/* ===== Header nav alignment & color behavior ===== */
@media (min-width: 992px) {
  #topnav .navigation-menu > li > .sub-menu-item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  #topnav .navigation-menu.nav-light > li > a.sub-menu-item,
  #topnav .navigation-menu.nav-light > li > button.sub-menu-item {
    color: var(--color-primary) !important;
  }

  #topnav.nav-sticky .navigation-menu.nav-light > li > a.sub-menu-item,
  #topnav.nav-sticky .navigation-menu.nav-light > li > button.sub-menu-item {
    color: var(--color-slate-900) !important;
  }

  #topnav.nav-sticky .navigation-menu > li > .sub-menu-item.active,
  #topnav .navigation-menu > li:hover > .sub-menu-item,
  #topnav .navigation-menu > li > .sub-menu-item.active {
    color: var(--color-primary) !important;
  }
}

html[lang="ar"] body,
.font-arabic {
  font-family: 'Cairo', 'Tahoma', 'Arial', sans-serif !important;
  letter-spacing: 0;
  line-height: 1.8;
}
