@charset "UTF-8";

/*
|--------------------------------------------------------------------------
| الملف: public_html/assets/css/shared/tokens.css
| الوصف:
|   ملف Design Tokens المركزي للمنصة.
|
| الهدف:
|   - توحيد الألوان، الخطوط، المسافات، الأحجام، الحواف، الظلال، الطبقات.
|   - منع القيم العشوائية داخل ملفات الصفحات أو المكونات.
|   - جعل الهوية البصرية قابلة للتوسعة والصيانة بسهولة.
|   - دعم بناء واجهات متجاوبة بشكل احترافي عبر Tokens واضحة للشاشات المختلفة.
|
| القواعد:
|   - لا توضع هنا أي تنسيقات مباشرة لعناصر HTML.
|   - لا توضع هنا أي أنماط مكونات مثل الأزرار أو النماذج.
|   - هذا الملف يحتوي متغيرات CSS فقط.
|   - أي قيمة تصميمية متكررة يجب أن تُعرّف هنا أولًا قبل استعمالها.
|
| ملاحظات:
|   - اللغة الأساسية للمنصة العربية، والواجهة RTL افتراضيًا.
|   - الخط الأساسي الحالي: Cairo.
|   - تم تجهيز الملف ليدعم responsive design بشكل تدريجي ومنظم.
|   - يمكن لاحقًا إضافة سمات إضافية مثل الوضع الداكن دون كسر البنية.
|--------------------------------------------------------------------------
*/

:root {
  /* -----------------------------------------------------------------------
   * Typography / Fonts
   * --------------------------------------------------------------------- */
  --font-family-base: "Cairo", Tahoma, Arial, sans-serif;
  --font-family-heading: "Cairo", Tahoma, Arial, sans-serif;
  --font-family-mono: "Cascadia Code", "Consolas", "Courier New", monospace;

  --font-weight-light: 300;
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semi-bold: 600;
  --font-weight-bold: 700;
  --font-weight-extra-bold: 800;

  /*
   * Base font scale
   * ملاحظة:
   * هذه القيم هي المرجع الثابت.
   * سنربط بها لاحقًا القيم المرنة الخاصة بالعرض بحسب حجم الشاشة.
   */
  --font-size-2xs: 0.6875rem; /* 11px */
  --font-size-xs: 0.75rem;    /* 12px */
  --font-size-sm: 0.875rem;   /* 14px */
  --font-size-md: 1rem;       /* 16px */
  --font-size-lg: 1.125rem;   /* 18px */
  --font-size-xl: 1.25rem;    /* 20px */
  --font-size-2xl: 1.5rem;    /* 24px */
  --font-size-3xl: 1.875rem;  /* 30px */
  --font-size-4xl: 2.25rem;   /* 36px */
  --font-size-5xl: 3rem;      /* 48px */
  --font-size-6xl: 3.75rem;   /* 60px */

  /*
   * Responsive typography tokens
   * تستخدم مباشرة في الواجهات بدل القيم الخام قدر الإمكان.
   */
  --font-size-body-sm: var(--font-size-sm);
  --font-size-body-md: var(--font-size-md);
  --font-size-body-lg: var(--font-size-lg);

  --font-size-heading-1: clamp(2rem, 1.45rem + 2vw, 3rem);
  --font-size-heading-2: clamp(1.75rem, 1.35rem + 1.4vw, 2.25rem);
  --font-size-heading-3: clamp(1.5rem, 1.2rem + 1vw, 1.875rem);
  --font-size-heading-4: clamp(1.25rem, 1.1rem + 0.6vw, 1.5rem);
  --font-size-heading-5: clamp(1.125rem, 1.02rem + 0.35vw, 1.25rem);
  --font-size-heading-6: clamp(1rem, 0.96rem + 0.2vw, 1.125rem);

  --line-height-tight: 1.25;
  --line-height-snug: 1.4;
  --line-height-normal: 1.6;
  --line-height-relaxed: 1.8;
  --line-height-loose: 2;

  /* -----------------------------------------------------------------------
   * Brand Colors
   * --------------------------------------------------------------------- */
  --color-brand-50: #eef6ff;
  --color-brand-100: #d9ebff;
  --color-brand-200: #b7d8ff;
  --color-brand-300: #85bcff;
  --color-brand-400: #4e9bff;
  --color-brand-500: #1f7aff;
  --color-brand-600: #0f62db;
  --color-brand-700: #0d4daa;
  --color-brand-800: #103f82;
  --color-brand-900: #143765;

  /* -----------------------------------------------------------------------
   * Neutral Colors
   * --------------------------------------------------------------------- */
  --color-white: #ffffff;
  --color-black: #000000;

  --color-gray-50: #f8fafc;
  --color-gray-100: #f1f5f9;
  --color-gray-200: #e2e8f0;
  --color-gray-300: #cbd5e1;
  --color-gray-400: #94a3b8;
  --color-gray-500: #64748b;
  --color-gray-600: #475569;
  --color-gray-700: #334155;
  --color-gray-800: #1e293b;
  --color-gray-900: #0f172a;

  /* -----------------------------------------------------------------------
   * Semantic Colors
   * --------------------------------------------------------------------- */
  --color-success-50: #ecfdf3;
  --color-success-100: #d1fadf;
  --color-success-200: #a6f4c5;
  --color-success-300: #6ce9a6;
  --color-success-400: #32d583;
  --color-success-500: #12b76a;
  --color-success-600: #039855;
  --color-success-700: #027a48;
  --color-success-800: #05603a;
  --color-success-900: #054f31;

  --color-warning-50: #fffaeb;
  --color-warning-100: #fef0c7;
  --color-warning-200: #fedf89;
  --color-warning-300: #fec84b;
  --color-warning-400: #fdb022;
  --color-warning-500: #f79009;
  --color-warning-600: #dc6803;
  --color-warning-700: #b54708;
  --color-warning-800: #93370d;
  --color-warning-900: #7a2e0e;

  --color-danger-50: #fef3f2;
  --color-danger-100: #fee4e2;
  --color-danger-200: #fecdca;
  --color-danger-300: #fda29b;
  --color-danger-400: #f97066;
  --color-danger-500: #f04438;
  --color-danger-600: #d92d20;
  --color-danger-700: #b42318;
  --color-danger-800: #912018;
  --color-danger-900: #7a271a;

  --color-info-50: #eff8ff;
  --color-info-100: #d1e9ff;
  --color-info-200: #b2ddff;
  --color-info-300: #84caff;
  --color-info-400: #53b1fd;
  --color-info-500: #2e90fa;
  --color-info-600: #1570ef;
  --color-info-700: #175cd3;
  --color-info-800: #1849a9;
  --color-info-900: #194185;

  /* -----------------------------------------------------------------------
   * Text Colors
   * --------------------------------------------------------------------- */
  --color-text-primary: var(--color-gray-900);
  --color-text-secondary: var(--color-gray-700);
  --color-text-muted: var(--color-gray-500);
  --color-text-disabled: var(--color-gray-400);
  --color-text-inverse: var(--color-white);
  --color-text-link: var(--color-brand-600);
  --color-text-link-hover: var(--color-brand-700);

  /* -----------------------------------------------------------------------
   * Background Colors
   * --------------------------------------------------------------------- */
  --color-bg-page: #f5f7fb;
  --color-bg-body: var(--color-bg-page);
  --color-bg-surface: var(--color-white);
  --color-bg-surface-muted: var(--color-gray-50);
  --color-bg-surface-soft: #f8fbff;
  --color-bg-overlay: rgba(15, 23, 42, 0.55);

  --color-bg-brand: var(--color-brand-600);
  --color-bg-brand-hover: var(--color-brand-700);
  --color-bg-brand-soft: var(--color-brand-50);

  --color-bg-success: var(--color-success-50);
  --color-bg-warning: var(--color-warning-50);
  --color-bg-danger: var(--color-danger-50);
  --color-bg-info: var(--color-info-50);

  /* -----------------------------------------------------------------------
   * Border Colors
   * --------------------------------------------------------------------- */
  --color-border-default: var(--color-gray-200);
  --color-border-soft: var(--color-gray-100);
  --color-border-strong: var(--color-gray-300);
  --color-border-brand: var(--color-brand-300);
  --color-border-success: var(--color-success-300);
  --color-border-warning: var(--color-warning-300);
  --color-border-danger: var(--color-danger-300);
  --color-border-info: var(--color-info-300);

  /* -----------------------------------------------------------------------
   * Icon Colors
   * --------------------------------------------------------------------- */
  --color-icon-primary: var(--color-gray-700);
  --color-icon-muted: var(--color-gray-500);
  --color-icon-inverse: var(--color-white);
  --color-icon-brand: var(--color-brand-600);
  --color-icon-success: var(--color-success-600);
  --color-icon-warning: var(--color-warning-600);
  --color-icon-danger: var(--color-danger-600);
  --color-icon-info: var(--color-info-600);

  /* -----------------------------------------------------------------------
   * Spacing Scale
   * --------------------------------------------------------------------- */
  --space-0: 0;
  --space-1: 0.25rem;   /* 4px */
  --space-2: 0.5rem;    /* 8px */
  --space-3: 0.75rem;   /* 12px */
  --space-4: 1rem;      /* 16px */
  --space-5: 1.25rem;   /* 20px */
  --space-6: 1.5rem;    /* 24px */
  --space-7: 1.75rem;   /* 28px */
  --space-8: 2rem;      /* 32px */
  --space-10: 2.5rem;   /* 40px */
  --space-12: 3rem;     /* 48px */
  --space-14: 3.5rem;   /* 56px */
  --space-16: 4rem;     /* 64px */
  --space-20: 5rem;     /* 80px */
  --space-24: 6rem;     /* 96px */
  --space-28: 7rem;     /* 112px */
  --space-32: 8rem;     /* 128px */

  /*
   * Responsive spacing tokens
   * تستعمل في المقاطع والبلوكات بحسب حجم الشاشة.
   */
  --section-padding-y: clamp(2.5rem, 1.8rem + 2vw, 5rem);
  --section-padding-y-sm: clamp(1.5rem, 1.2rem + 1vw, 2.5rem);
  --section-padding-y-lg: clamp(3rem, 2rem + 3vw, 6rem);

  --page-gap: clamp(1rem, 0.8rem + 1vw, 2rem);
  --stack-gap-sm: var(--space-3);
  --stack-gap-md: var(--space-4);
  --stack-gap-lg: var(--space-6);
  --stack-gap-xl: var(--space-8);

  /* -----------------------------------------------------------------------
   * Radius
   * --------------------------------------------------------------------- */
  --radius-none: 0;
  --radius-xs: 0.25rem;   /* 4px */
  --radius-sm: 0.375rem;  /* 6px */
  --radius-md: 0.5rem;    /* 8px */
  --radius-lg: 0.75rem;   /* 12px */
  --radius-xl: 1rem;      /* 16px */
  --radius-2xl: 1.5rem;   /* 24px */
  --radius-3xl: 2rem;     /* 32px */
  --radius-full: 9999px;

  /* -----------------------------------------------------------------------
   * Shadows
   * --------------------------------------------------------------------- */
  --shadow-xs: 0 1px 2px rgba(15, 23, 42, 0.05);
  --shadow-sm: 0 1px 3px rgba(15, 23, 42, 0.10), 0 1px 2px rgba(15, 23, 42, 0.06);
  --shadow-md: 0 4px 8px rgba(15, 23, 42, 0.08), 0 2px 4px rgba(15, 23, 42, 0.06);
  --shadow-lg: 0 12px 24px rgba(15, 23, 42, 0.10), 0 4px 8px rgba(15, 23, 42, 0.06);
  --shadow-xl: 0 20px 40px rgba(15, 23, 42, 0.14), 0 8px 16px rgba(15, 23, 42, 0.08);
  --shadow-focus-brand: 0 0 0 4px rgba(31, 122, 255, 0.16);
  --shadow-focus-danger: 0 0 0 4px rgba(240, 68, 56, 0.16);

  /* -----------------------------------------------------------------------
   * Borders
   * --------------------------------------------------------------------- */
  --border-width-0: 0;
  --border-width-1: 1px;
  --border-width-2: 2px;
  --border-width-4: 4px;

  /* -----------------------------------------------------------------------
   * Responsive Breakpoints
   * --------------------------------------------------------------------- */
  /*
   * ملاحظة مهمة:
   * لا يمكن استخدام CSS variables مباشرة داخل @media في كل البيئات بشكل موثوق،
   * لكن نُبقيها هنا كمرجع توثيقي مركزي لتوحيد الفريق.
   */
  --breakpoint-xs: 0;
  --breakpoint-sm: 480px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 1024px;
  --breakpoint-xl: 1280px;
  --breakpoint-2xl: 1440px;

  /* -----------------------------------------------------------------------
   * Layout / Containers
   * --------------------------------------------------------------------- */
  --container-xs: 480px;
  --container-sm: 640px;
  --container-md: 768px;
  --container-lg: 1024px;
  --container-xl: 1200px;
  --container-2xl: 1320px;
  --container-fluid: 100%;

  --content-max-width: var(--container-xl);
  --content-narrow-width: 860px;
  --content-reading-width: 720px;
  --content-wide-width: var(--container-2xl);

  /*
   * Responsive container paddings
   * هذه من أهم إضافات التوافق مع الجوال والتابلت وسطح المكتب.
   */
  --container-padding-x: 1rem;
  --container-padding-x-sm: 1rem;
  --container-padding-x-md: 1.25rem;
  --container-padding-x-lg: 1.5rem;
  --container-padding-x-xl: 2rem;
  --container-padding-x-2xl: 2.5rem;

  /*
   * Common layout sizing
   */
  --header-height: 4rem;            /* 64px - mobile default */
  --header-height-lg: 4.5rem;       /* 72px - larger screens */
  --topbar-height: 0;
  --footer-min-height: 5rem;        /* 80px */
  --sidebar-width: 17.5rem;         /* 280px */
  --sidebar-width-collapsed: 5rem;  /* 80px */

  /*
   * Grid helpers as tokens
   */
  --grid-gap-sm: var(--space-3);
  --grid-gap-md: var(--space-4);
  --grid-gap-lg: var(--space-6);
  --grid-gap-xl: var(--space-8);

  --grid-columns-1: 1;
  --grid-columns-2: 2;
  --grid-columns-3: 3;
  --grid-columns-4: 4;
  --grid-columns-6: 6;
  --grid-columns-12: 12;

  /* -----------------------------------------------------------------------
   * Z-Index Scale
   * --------------------------------------------------------------------- */
  --z-index-base: 1;
  --z-index-dropdown: 1000;
  --z-index-sticky: 1020;
  --z-index-fixed: 1030;
  --z-index-overlay: 1040;
  --z-index-modal: 1050;
  --z-index-popover: 1060;
  --z-index-tooltip: 1070;
  --z-index-toast: 1080;

  /* -----------------------------------------------------------------------
   * Motion
   * --------------------------------------------------------------------- */
  --duration-fast: 120ms;
  --duration-normal: 200ms;
  --duration-slow: 320ms;

  --easing-default: ease;
  --easing-in: ease-in;
  --easing-out: ease-out;
  --easing-in-out: ease-in-out;

  /* -----------------------------------------------------------------------
   * Form Controls
   * --------------------------------------------------------------------- */
  --input-height-sm: 2.25rem;   /* 36px */
  --input-height-md: 2.75rem;   /* 44px */
  --input-height-lg: 3.25rem;   /* 52px */

  /*
   * Responsive input paddings
   */
  --input-padding-x: var(--space-4);
  --input-padding-y: var(--space-3);
  --input-padding-x-sm: var(--space-3);
  --input-padding-x-md: var(--space-4);
  --input-padding-x-lg: var(--space-5);

  /* -----------------------------------------------------------------------
   * Buttons
   * --------------------------------------------------------------------- */
  --button-height-sm: 2.25rem;  /* 36px */
  --button-height-md: 2.75rem;  /* 44px */
  --button-height-lg: 3.25rem;  /* 52px */

  --button-padding-x-sm: var(--space-3);
  --button-padding-x-md: var(--space-4);
  --button-padding-x-lg: var(--space-5);

  --button-gap-sm: var(--space-2);
  --button-gap-md: var(--space-3);
  --button-gap-lg: var(--space-4);

  /* -----------------------------------------------------------------------
   * Tables
   * --------------------------------------------------------------------- */
  --table-cell-padding-x: var(--space-4);
  --table-cell-padding-y: var(--space-3);
  --table-row-min-height: 3.5rem; /* 56px */

  /*
   * للجداول المتجاوبة لاحقًا
   */
  --table-cell-padding-x-sm: var(--space-3);
  --table-cell-padding-y-sm: var(--space-2);

  /* -----------------------------------------------------------------------
   * Cards / Panels
   * --------------------------------------------------------------------- */
  --card-padding: var(--space-6);
  --card-padding-sm: var(--space-4);
  --card-padding-lg: var(--space-8);

  --card-gap: var(--space-4);
  --card-gap-lg: var(--space-6);

  --card-radius: var(--radius-xl);
  --card-shadow: var(--shadow-sm);
  --card-border-color: var(--color-border-default);
  --card-bg: var(--color-bg-surface);

  /* -----------------------------------------------------------------------
   * Alerts / Messages
   * --------------------------------------------------------------------- */
  --alert-padding-x: var(--space-4);
  --alert-padding-y: var(--space-4);
  --alert-radius: var(--radius-lg);

  /* -----------------------------------------------------------------------
   * Hero / Banner / Large Sections
   * --------------------------------------------------------------------- */
  --hero-padding-y: clamp(3rem, 2.2rem + 3vw, 7rem);
  --hero-title-max-width: 16ch;
  --hero-text-max-width: 60ch;
  --hero-media-max-width: 42rem;

  /* -----------------------------------------------------------------------
   * Navigation
   * --------------------------------------------------------------------- */
  --nav-item-height: 2.75rem;
  --nav-mobile-panel-width: min(85vw, 22rem);
  --nav-mobile-backdrop-blur: 4px;

  /* -----------------------------------------------------------------------
   * Focus
   * --------------------------------------------------------------------- */
  --focus-ring-width: 3px;
  --focus-ring-color: rgba(31, 122, 255, 0.28);
  --focus-ring-offset: 2px;

  /* -----------------------------------------------------------------------
   * Opacity
   * --------------------------------------------------------------------- */
  --opacity-disabled: 0.55;
  --opacity-muted: 0.75;
  --opacity-overlay: 0.6;
}

/*
|--------------------------------------------------------------------------
| Breakpoint-specific token overrides
| الهدف:
|   - إبقاء القيم المرنة داخل التوكنز نفسها.
|   - تقليل الحاجة لتكرار أرقام جديدة داخل ملفات المكونات والصفحات.
|--------------------------------------------------------------------------
*/

@media (min-width: 480px) {
  :root {
    --container-padding-x: var(--container-padding-x-sm);
  }
}

@media (min-width: 768px) {
  :root {
    --container-padding-x: var(--container-padding-x-md);
    --header-height: 4.25rem; /* 68px */
    --card-padding: var(--card-padding);
  }
}

@media (min-width: 1024px) {
  :root {
    --container-padding-x: var(--container-padding-x-lg);
    --header-height: var(--header-height-lg);
  }
}

@media (min-width: 1280px) {
  :root {
    --container-padding-x: var(--container-padding-x-xl);
  }
}

@media (min-width: 1440px) {
  :root {
    --container-padding-x: var(--container-padding-x-2xl);
  }
}

/*
|--------------------------------------------------------------------------
| Theme Hooks
| يمكن لاحقًا توسيعها لسمات إضافية مثل:
| [data-theme="dark"] { ... }
|--------------------------------------------------------------------------
*/