/* Google Fonts (محسّنة بدون تكرار) */
@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@400;600;700;900&family=Roboto:wght@300;400;500;700&display=swap');

/* إعداد القيم الافتراضية */
:root {
  --font-base: 'Roboto', 'Cairo', sans-serif;
  --color-bg: #fbfbfb;
  --color-surface: #ffffff;
  --color-text: #1f2d3d;
  --color-muted: #6b7a8c;
  --color-border: #dfe4ea;
  --color-primary: #39add1;
  --color-accent: #ff7a18;
  --color-contrast: #ffffff;
  --radius-sm: 6px;
  --radius-md: 12px;
  --transition-base: 0.3s ease;
  --gap-md: 1rem;
  --col-padding: 15px;
  --focus-ring: 0 0 0 3px rgba(57, 173, 209, 0.35);
  font-size: 12px;
}

/* القواعد العامة */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  font: 400 1rem/1.6 var(--font-base);
  background: var(--color-bg);
  color: var(--color-text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-base), opacity var(--transition-base);
}

a:hover,
a:focus-visible {
  color: var(--color-accent);
  opacity: 0.85;
}

input,
select,
textarea,
button {
  font: inherit;
  color: inherit;
  background: transparent;
  border: 0;
}

input:focus-visible,
select:focus-visible,
textarea:focus-visible,
button:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
  border-radius: var(--radius-sm);
}

/* شريط التمرير الجانبي */
.lx-main-leftside {
  scrollbar-width: thin;
  scrollbar-color: rgba(102, 112, 121, 1) #2f4050;
}

.lx-main-leftside::-webkit-scrollbar {
  width: 10px;
}

.lx-main-leftside::-webkit-scrollbar-track {
  background: #2f4050;
}

.lx-main-leftside::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0);
  border-radius: 10px;
}

.lx-main-leftside:hover::-webkit-scrollbar-thumb {
  background: rgba(102, 112, 121, 1);
}

/* مربّع اختيار مخصص */
.lx-checkbox {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  cursor: pointer;
  user-select: none;
  font-weight: 500;
  color: var(--color-text);
}

.lx-checkbox input[type="checkbox"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  width: 20px;
  height: 20px;
  margin: 0;
  cursor: inherit;
}

.lx-checkbox .checkmark {
  position: relative;
  flex: 0 0 20px;
  width: 20px;
  height: 20px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  transition: background var(--transition-base), border-color var(--transition-base), transform 0.2s ease;
}

.lx-checkbox input[type="checkbox"]:focus-visible + .checkmark {
  box-shadow: var(--focus-ring);
}

.lx-checkbox:hover .checkmark {
  background: #f1f5f8;
}

.lx-checkbox input[type="checkbox"]:checked + .checkmark {
  border-color: var(--color-primary);
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
}

.lx-checkbox .checkmark::after {
  content: "";
  position: absolute;
  inset: 4px 6px 4px 7px;
  border: solid var(--color-contrast);
  border-width: 0 3px 3px 0;
  transform: rotate(45deg) scale(0.6);
  transform-origin: center;
  opacity: 0;
  transition: transform var(--transition-base), opacity var(--transition-base);
}

.lx-checkbox input[type="checkbox"]:checked + .checkmark::after {
  opacity: 1;
  transform: rotate(45deg) scale(0.95);
}

.lx-checkbox .label-text {
  line-height: 1.4;
}

/* مُصفّي العرض */
.lx-clear-fix::after {
  content: "";
  display: table;
  clear: both;
}

/* نظام الشبكة */
[class^="lx-g"],
[class*=" lx-g"] {
  position: relative;
  float: left;
  width: var(--col-width, 100%);
  max-width: var(--col-width, 100%);
  padding: var(--col-padding);
  opacity: 1;
  transition: opacity 0.8s ease, transform 0.3s ease;
}

[class^="lx-g"]:hover,
[class*=" lx-g"]:hover {
  transform: translateY(-4px);
}

[class$="-f"] {
  padding: 0;
}

/* نسب الأعمدة */
.lx-g1,
.lx-g1-f { --col-width: 100%; }

.lx-g2,
.lx-g2-f { --col-width: 50%; }

.lx-g3,
.lx-g3-f { --col-width: 33.3333%; }

.lx-g3-2,
.lx-g3-2-f { --col-width: 66.6667%; }

.lx-g4,
.lx-g4-f { --col-width: 25%; }

.lx-g4-3,
.lx-g4-3-f { --col-width: 75%; }

.lx-g5,
.lx-g5-f { --col-width: 20%; }

.lx-g5-2,
.lx-g5-2-f { --col-width: 40%; }

.lx-g5-3,
.lx-g5-3-f { --col-width: 60%; }

.lx-g5-4,
.lx-g5-4-f { --col-width: 80%; }

.lx-g6,
.lx-g6-f { --col-width: 16.6667%; }

.lx-g6-5,
.lx-g6-5-f { --col-width: 83.3333%; }

.lx-g8,
.lx-g8-f { --col-width: 12.5%; }

.lx-g8-7,
.lx-g8-7-f { --col-width: 87.5%; }

/* دعم Flex الحديثة إن وُجد حاوية مناسبة */
@supports (display: flex) {
  .lx-row,
  .lx-layout,
  .lx-grid {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-md);
  }

  .lx-row > [class^="lx-g"],
  .lx-layout > [class^="lx-g"],
  .lx-grid > [class^="lx-g"],
  .lx-row > [class*=" lx-g"],
  .lx-layout > [class*=" lx-g"],
  .lx-grid > [class*=" lx-g"] {
    float: none;
    flex: 0 0 var(--col-width, 100%);
    max-width: var(--col-width, 100%);
  }
}

/* تنسيق الشاشات الصغيرة */
@media (max-width: 768px) {
  :root {
    --gap-md: 0.75rem;
  }

  [class^="lx-g"],
  [class*=" lx-g"] {
    --col-width: 100% !important;
    padding: clamp(10px, 3vw, 15px);
  }

  [class$="-f"] {
    padding: 0 !important;
  }
}