/* إصلاح ألوان أزرار وأيقونات عمود الإجراءات في الجداول */
.actions-cell .btn,
.actions-cell .btn i,
.actions-cell .btn span {
    color: inherit !important;
    background: none !important;
    border-color: inherit !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: inline !important;
}

/* =========================================================================
   متغيرات نظام التصميم الموحد (Injaz Unified Design Variables)
   ========================================================================= */
:root {
    --primary-color: #5600a4;
    --on-primary: #ffffff;
    --primary-container: #F3E8FF;
    --on-primary-container: #dabdff;
    --secondary-color: #6e49b1;
    --on-secondary: #ffffff;
    --secondary-container: #b892ff;
    --on-secondary-container: #4a228b;
    --tertiary-color: #5d3300;
    --on-tertiary: #ffffff;
    --tertiary-container: #7e4700;
    --on-tertiary-container: #ffbb7c;
    --surface: #F4F4F9;
    --on-surface: #1e1a22;
    --surface-variant: #F4F4F9;
    --on-surface-variant: #4b4453;
    --surface-dim: #e0d7e3;
    --surface-bright: #F4F4F9;
    --surface-container-lowest: #ffffff;
    --surface-container-low: #faf0fd;
    --surface-container: #f4ebf7;
    --surface-container-high: #eee5f2;
    --surface-container-highest: #e8dfec;
    --inverse-surface: #332f38;
    --inverse-on-surface: #f7eefa;
    --inverse-primary: #d8b9ff;
    --bg-color: #F4F4F9;
    --body-bg: #F4F4F9;
    --card-bg: #ffffff;
    --text-color: #1e1a22;
    --text-muted: #4b4453;
    --border-color: #E0E0E0;
    --outline: #E0E0E0;
    --outline-variant: #cec3d5;
    --surface-tint: #7a3ac8;
    --error-color: #BA1A1A;
    --on-error: #ffffff;
    --error-container: #ffdad6;
    --on-error-container: #93000a;
    --success-color: #28a745;
    --warning-color: #ffc107;
    --danger-color: #dc3545;
    --info-color: #17a2b8;
    --shadow: rgba(86, 0, 164, 0.04);
    
    /* الألوان الثابتة (Fixed Colors) */
    --primary-fixed: #eedcff;
    --primary-fixed-dim: #d8b9ff;
    --on-primary-fixed: #290054;
    --on-primary-fixed-variant: #6018ae;
    --secondary-fixed: #ebdcff;
    --secondary-fixed-dim: #d4bbff;
    --on-secondary-fixed: #260059;
    --on-secondary-fixed-variant: #552f97;
    --tertiary-fixed: #ffdcbf;
    --tertiary-fixed-dim: #ffb874;
    --on-tertiary-fixed: #2d1600;
    --on-tertiary-fixed-variant: #6a3b00;
    
    /* الخطوط المعتمدة */
    --font-family: 'Tajawal', sans-serif;
    --font-family-traditional: 'Amiri', serif;
    
    /* الحواف والتباعد والقياسات */
    --border-radius-sm: 4px;
    --border-radius-default: 6px;
    --border-radius-lg: 8px;
    --border-radius-full: 9999px;
    
    /* نظام التباعد والحشو من system-design.md */
    --spacing-unit: 4px;
    --padding-xs: 4px;
    --padding-sm: 8px;
    --padding-md: 12px;
    --padding-lg: 16px;
    --gutter: 16px;
    --margin-mobile: 16px;
    --margin-desktop: 24px;
    --button-icon-gap: 8px;
    --button-icon-size: 18px;
    
    --navbar-height: 60px;
    --sidebar-width: 250px;
    --sidebar-collapsed-width: 60px;
    --transition-speed: 0.3s;
}

/* الوضع الداكن الموحد */
[data-theme="dark"] {
    --primary-color: #D0BCFF;
    --on-primary: #381E72;
    --primary-container: #4f378b;
    --on-primary-container: #e9ddff;
    --secondary-color: #b892ff;
    --tertiary-color: #ffb874;
    --on-tertiary: #4a2800;
    --tertiary-container: #6a3b00;
    --on-tertiary-container: #ffdcbf;
    --surface: #1e1a22;
    --on-surface: #ffffff;
    --surface-variant: #2d2d2d;
    --on-surface-variant: #c8c5d0;
    --surface-dim: #151218;
    --surface-bright: #3b383e;
    --surface-container-lowest: #0f0d11;
    --surface-container-low: #1d1a20;
    --surface-container: #211e24;
    --surface-container-high: #2c2830;
    --surface-container-highest: #37333b;
    --inverse-surface: #e8dfec;
    --inverse-on-surface: #1e1a22;
    --inverse-primary: #5600a4;
    --bg-color: #1e1a22;
    --body-bg: #1e1a22;
    --card-bg: #2d2d2d;
    --text-color: #ffffff;
    --text-muted: #c8c5d0;
    --border-color: #49454F;
    --outline: #49454F;
    --shadow: rgba(255, 255, 255, 0.04);
    --error-color: #FFB4AB;
    --on-error: #690005;
}

/* تطبيق الخطوط الموحدة للواجهات والنصوص */
body, button, input, select, textarea, .btn, .form-control, .form-select {
    font-family: var(--font-family) !important;
}

/* فئات الطباعة الموحدة (Unified Typography Classes) */
.headline-lg {
    font-family: var(--font-family) !important;
    font-size: 28px !important;
    font-weight: 800 !important;
    line-height: 36px !important;
}
.headline-md {
    font-family: var(--font-family) !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    line-height: 28px !important;
}
.headline-sm {
    font-family: var(--font-family) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    line-height: 24px !important;
}
.body-lg {
    font-family: var(--font-family) !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 24px !important;
}
.body-md {
    font-family: var(--font-family) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    line-height: 20px !important;
}
.label-md {
    font-family: var(--font-family) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    line-height: 16px !important;
}
.btn-typography {
    font-family: var(--font-family) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    line-height: 20px !important;
}
.traditional-text {
    font-family: var(--font-family-traditional) !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    line-height: 1.5 !important;
}

/* توحيد الأيقونات وجميع أزرار Bootstrap مع نظام التصميم الموحد */
.btn {
    font-family: var(--font-family) !important;
    font-size: var(--btn-typography-font-size, 14px) !important;
    font-weight: 500 !important;
    border-radius: var(--border-radius-default, 6px) !important;
    padding: 0.5rem 1rem !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--button-icon-gap, 8px) !important;
    white-space: nowrap !important;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
    text-decoration: none !important;
    cursor: pointer !important;
}

.btn i, .btn svg {
    font-size: var(--button-icon-size, 18px) !important;
    line-height: 1 !important;
    margin: 0 !important; /* إزالة أي هوامش قد تسبب خللاً بالمحاذاة */
    color: inherit !important;
}

/* الأزرار الممتلئة (Filled Buttons) */
.btn-primary, .btn-details {
    background-color: var(--primary-color) !important;
    border: 1px solid var(--primary-color) !important;
    color: var(--on-primary, #ffffff) !important;
}
.btn-primary:hover, .btn-primary:focus, .btn-details:hover {
    background-color: var(--secondary-color) !important;
    border-color: var(--secondary-color) !important;
    color: var(--on-secondary, #ffffff) !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 8px var(--shadow);
}

.btn-secondary {
    background-color: var(--secondary-color) !important;
    border: 1px solid var(--secondary-color) !important;
    color: var(--on-secondary, #ffffff) !important;
}
.btn-secondary:hover, .btn-secondary:focus {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: var(--on-primary, #ffffff) !important;
    transform: translateY(-1px);
}

.btn-success {
    background-color: var(--success-color, #28a745) !important;
    border: 1px solid var(--success-color, #28a745) !important;
    color: #ffffff !important;
}
.btn-success:hover, .btn-success:focus {
    background-color: #218838 !important;
    border-color: #1e7e34 !important;
    transform: translateY(-1px);
}

.btn-danger {
    background-color: var(--danger-color, #dc3545) !important;
    border: 1px solid var(--danger-color, #dc3545) !important;
    color: #ffffff !important;
}
.btn-danger:hover, .btn-danger:focus {
    background-color: #c82333 !important;
    border-color: #bd2130 !important;
    transform: translateY(-1px);
}

.btn-warning, .btn-payment {
    background-color: var(--warning-color, #ffc107) !important;
    border: 1px solid var(--warning-color, #ffc107) !important;
    color: #1e1a22 !important;
}
.btn-warning:hover, .btn-warning:focus, .btn-payment:hover {
    background-color: #e0a800 !important;
    border-color: #d39e00 !important;
    transform: translateY(-1px);
}

.btn-info, .btn-status {
    background-color: var(--info-color, #17a2b8) !important;
    border: 1px solid var(--info-color, #17a2b8) !important;
    color: #ffffff !important;
}
.btn-info:hover, .btn-info:focus, .btn-status:hover {
    background-color: #138496 !important;
    border-color: #117a8b !important;
    transform: translateY(-1px);
}

/* أزرار الحدود (Outline Buttons) */
.btn-outline-primary {
    border: 1px solid var(--primary-color) !important;
    color: var(--primary-color) !important;
    background-color: transparent !important;
}
.btn-outline-primary:hover, .btn-outline-primary:focus {
    background-color: var(--primary-color) !important;
    color: var(--on-primary, #ffffff) !important;
    border-color: var(--primary-color) !important;
}

/* =========================================================================
   توحيد عناصر النماذج (Inputs, Selects, Textareas)
   ========================================================================= */
.form-control, .form-select {
    font-family: var(--font-family) !important;
    font-size: 14px !important;
    height: 36px !important; /* الارتفاع المعتمد 36px */
    border: 1px solid var(--border-color, #E0E0E0) !important;
    border-radius: var(--border-radius-default, 6px) !important;
    background-color: var(--card-bg, #ffffff) !important;
    color: var(--text-color, #1e1a22) !important;
    padding: 0.375rem 0.75rem !important;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out !important;
}

/* استثناء الـ textarea والـ select المتعدد من الارتفاع الثابت */
textarea.form-control {
    height: auto !important;
    min-height: 80px !important;
}

.form-control:focus, .form-select:focus {
    border-color: var(--primary-color, #5600a4) !important;
    box-shadow: 0 0 0 0.2rem rgba(86, 0, 164, 0.20) !important; /* توهج بنفسجي ناعم بنسبة 20% */
    outline: 0 !important;
}

.form-control-sm, .form-select-sm {
    height: 32px !important; /* الارتفاع المعتمد 32px للوضع المضغوط */
    font-size: 12px !important;
    padding: 0.25rem 0.5rem !important;
}

/* الوضع الداكن لعناصر النماذج */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
    background-color: var(--card-bg, #2d2d2d) !important;
    border-color: var(--border-color, #49454F) !important;
    color: var(--text-color, #ffffff) !important;
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
    border-color: var(--primary-color, #D0BCFF) !important;
    box-shadow: 0 0 0 0.2rem rgba(208, 188, 255, 0.20) !important;
}

/* =========================================================================
   توحيد قوائم البحث والإكمال التلقائي والقوائم المنسدلة (Autocomplete & Dropdowns)
   ========================================================================= */
.autocomplete-list, .dropdown-menu {
    background-color: var(--card-bg, #ffffff) !important;
    border: 1px solid var(--border-color, #E0E0E0) !important;
    border-radius: var(--border-radius-default, 6px) !important;
    box-shadow: 0 4px 12px rgba(86, 0, 164, 0.08) !important;
    z-index: 1050 !important;
    padding: 4px 0 !important;
}

.autocomplete-list .list-group-item, .dropdown-item {
    color: var(--text-color, #1e1a22) !important;
    font-size: 13px !important;
    padding: 8px 16px !important;
    border: none !important;
    background: transparent !important;
    transition: background-color 0.2s ease !important;
    cursor: pointer;
}

.autocomplete-list .list-group-item:hover, .dropdown-item:hover, .dropdown-item:focus {
    background-color: var(--primary-container, #F3E8FF) !important;
    color: var(--primary-color, #5600a4) !important;
}

[data-theme="dark"] .autocomplete-list,
[data-theme="dark"] .dropdown-menu {
    background-color: var(--card-bg, #2d2d2d) !important;
    border-color: var(--border-color, #49454F) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .autocomplete-list .list-group-item:hover,
[data-theme="dark"] .dropdown-item:hover {
    background-color: var(--primary-container, #4f378b) !important;
    color: var(--primary-color, #D0BCFF) !important;
}

/* =========================================================================
   توحيد الكروت والبطاقات (Cards)
   ========================================================================= */
.card {
    background-color: var(--card-bg, #ffffff) !important;
    border: 1px solid var(--border-color, #E0E0E0) !important;
    border-radius: var(--border-radius-lg, 8px) !important;
    box-shadow: 0 4px 20px var(--shadow, rgba(86, 0, 164, 0.04)) !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
}

.card:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 30px rgba(86, 0, 164, 0.08) !important;
}

[data-theme="dark"] .card {
    background-color: var(--card-bg, #2d2d2d) !important;
    border-color: var(--border-color, #49454F) !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2) !important;
}

[data-theme="dark"] .card:hover {
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3) !important;
}

/* أزرار مخصصة متوافقة مع ألوان وأحجام النظام الموحد */
.btn-outline-theme {
    background: transparent !important;
    border: 1px solid var(--primary-color) !important;
    color: var(--primary-color) !important;
    border-radius: var(--border-radius-default) !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
    padding: 8px 16px !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    transition: all 0.2s ease !important;
    text-decoration: none !important;
    cursor: pointer !important;
}

.btn-outline-theme i {
    color: var(--primary-color) !important;
    font-size: 18px !important;
}

.btn-outline-theme:hover,
.btn-outline-theme:focus {
    background: rgba(86, 0, 164, 0.05) !important;
    border-color: var(--primary-color) !important;
    color: var(--primary-color) !important;
    transform: translateY(-1px) !important;
}



/* Ø±ÙˆØ§Ø¨Ø· Ø¨ÙŠØ¶Ø§Ø¡ Ù�ÙŠ Ø«ÙŠÙ… Ø¥Ù†Ø¬Ø§Ø² (Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø§Ù�ØªØ±Ø§Ø¶ÙŠ) */
/* Ø±ÙˆØ§Ø¨Ø· Ø¹Ø§Ù…Ø© Ù�ÙŠ Ø«ÙŠÙ… Ø¥Ù†Ø¬Ø§Ø² (Ø®Ø§Ø±Ø¬ Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ ÙˆØ§Ù„Ø¨Ø·Ø§Ù‚Ø§Øª) */
[data-theme="light"] a,
[data-theme="light"] .card-header-theme a {
    color: #fff !important;
    font-weight: 500;
    text-decoration: underline;
    transition: all 0.2s;
}

[data-theme="light"] a:hover,
[data-theme="light"] .card-header-theme a:hover {
    color: #fff !important;
    font-weight: bold;
    transform: translateY(-2px);
    text-decoration: underline;
}

/* Ø±ÙˆØ§Ø¨Ø· Ø¯Ø§Ø®Ù„ Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ Ù�ÙŠ Ø«ÙŠÙ… Ø¥Ù†Ø¬Ø§Ø² ØªØ£Ø®Ø° Ù„ÙˆÙ† Ø§Ù„Ù†Øµ Ø§Ù„Ø¹Ø§Ø¯ÙŠ Ù„Ù„Ø¬Ø¯ÙˆÙ„ */
[data-theme="light"] .table a,
[data-theme="light"] .table-header-theme a {
    color: var(--text-color) !important;
    font-weight: 500;
    text-decoration: underline;
    transition: all 0.2s;
}

[data-theme="light"] .table a:hover,
[data-theme="light"] .table-header-theme a:hover {
    color: var(--primary-color) !important;
    font-weight: bold;
    transform: translateY(-2px);
    text-decoration: underline;
}

/* ØªÙˆØ­ÙŠØ¯ Ù„ÙˆÙ† Ø§Ù„Ø±ÙˆØ§Ø¨Ø· Ù…Ø¹ Ù„ÙˆÙ† Ø§Ù„Ù†Øµ Ø§Ù„Ø±Ø¦ÙŠØ³ÙŠ Ù�ÙŠ Ø§Ù„Ø«ÙŠÙ… */
a,
a:visited,
a:active {
    color: var(--text-color);
    text-decoration: underline;
    transition: color 0.2s;
}

a:hover,
a:focus {
    color: var(--primary-color);
    text-decoration: underline;
}

/* Ø±ÙˆØ§Ø¨Ø· Ø§Ù„Ù�Ù„ØªØ±Ø© Ø£Ùˆ Ø§Ù„Ø±ÙˆØ§Ø¨Ø· Ø¯Ø§Ø®Ù„ Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ */
.table a,
.card a,
.table-header-theme a,
.card-header-theme a {
    color: var(--text-color) !important;
    text-decoration: underline;
    font-weight: 500;
}

.table a:hover,
.card a:hover,
.table-header-theme a:hover,
.card-header-theme a:hover {
    color: var(--primary-color) !important;
}

/* Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ†ØŒ Ø§Ù„Ø±ÙˆØ§Ø¨Ø· ØªØ£Ø®Ø° Ù„ÙˆÙ† Ø£Ø¨ÙŠØ¶ Ø£Ùˆ Ù„ÙˆÙ† Ø§Ù„Ù†Øµ */
[data-theme="dark"] a,
[data-theme="dark"] .table a,
[data-theme="dark"] .card a {
    color: #fff !important;
}

[data-theme="dark"] a:hover,
[data-theme="dark"] .table a:hover,
[data-theme="dark"] .card a:hover {
    color: var(--primary-color) !important;
}

/* Ø±Ø¤ÙˆØ³ Ø§Ù„Ø¨Ø·Ø§Ù‚Ø§Øª ÙˆØ§Ù„Ø¬Ø¯Ø§ÙˆÙ„ Ø­Ø³Ø¨ Ø§Ù„Ø«ÙŠÙ… */
.card-header-theme {
    background: var(--primary-color) !important;
    color: var(--card-header-text, #fff) !important;
    border-bottom: 2px solid var(--secondary-color, #6e49b1);
    font-weight: bold;
    font-size: 1.05rem;
    letter-spacing: 0.5px;
}

.table-header-theme th,
.table-header-theme td {
    background: var(--primary-color) !important;
    color: var(--card-header-text, #fff) !important;
    border-bottom: 2px solid var(--secondary-color, #6e49b1);
    font-weight: bold;
    font-size: 1rem;
    letter-spacing: 0.5px;
}

/* ØªÙˆØ­ÙŠØ¯ Ù„ÙˆÙ† Ø±Ø¤ÙˆØ³ Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ - Ø¥Ø¬Ø¨Ø§Ø± Ø¬Ù…ÙŠØ¹ Ø§Ù„Ø¹Ù†Ø§ØµØ± Ø¹Ù„Ù‰ Ø§Ù„Ù„ÙˆÙ† Ø§Ù„Ø±Ø¦ÙŠØ³ÙŠ */
.table-header-theme th *,
.table-header-theme td *,
.table-header-theme th a,
.table-header-theme td a,
.table-header-theme th a:hover,
.table-header-theme td a:hover,
.table-header-theme th a:focus,
.table-header-theme td a:focus,
.table-header-theme th a:visited,
.table-header-theme td a:visited,
.table-header-theme th .btn,
.table-header-theme td .btn,
.table-header-theme th .btn:hover,
.table-header-theme td .btn:hover,
.table-header-theme th i,
.table-header-theme td i,
.table-header-theme th .fas,
.table-header-theme td .fas,
.table-header-theme th .fa,
.table-header-theme td .fa {
    color: var(--card-header-text, #fff) !important;
    background: transparent !important;
    border-color: transparent !important;
    text-decoration: none !important;
    font-weight: bold !important;
}

/* Ø£Ø²Ø±Ø§Ø± Ø§Ø®ØªÙŠØ§Ø± Ø§Ù„Ø«ÙŠÙ…Ø§Øª - Ù„ÙˆÙ† Ø§Ù„Ø²Ø± Ø­Ø³Ø¨ Ø§Ù„Ø«ÙŠÙ… */
.theme-btn {
    font-weight: bold;
    border-radius: 1.5rem;
    font-size: 0.9rem;
    padding: 0.5rem 1.2rem;
    margin-bottom: 0.5rem;
    border: 2px solid transparent;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}



/* Ø±Ù‚Ù… Ø§Ù„Ø¬ÙˆØ§Ù„ Ù�ÙŠ Ù‚Ø§Ø¦Ù…Ø© Ø§Ù„Ø¹Ù…Ù„Ø§Ø¡ ÙˆØ£ÙŠ Ù…ÙƒØ§Ù† ÙŠØ³ØªØ®Ø¯Ù… Ø§Ù„ÙƒÙ„Ø§Ø³ */
.client-phone-text {
    color: var(--text-color) !important;
    font-weight: bold;
    letter-spacing: 1px;
}

.client-phone-link {
    color: var(--text-color) !important;
}

/* Ù�ÙŠ Ø§Ù„Ø«ÙŠÙ… Ø§Ù„Ø¯Ø§ÙƒÙ†ØŒ Ø§Ø¬Ø¹Ù„ Ø±Ù‚Ù… Ø§Ù„Ø¬ÙˆØ§Ù„ Ø£Ø¨ÙŠØ¶ Ø¯Ø§Ø¦Ù…Ø§Ù‹ */
.theme-dark .client-phone-text,
.theme-dark .client-phone-link {
    color: #fff !important;
}

/* ============================================
   Ù†Ø¸Ø§Ù… Ø§Ù„Ù…ØªØºÙŠØ±Ø§Øª CSS Ù„Ù„Ø«ÙŠÙ…Ø§Øª Ø§Ù„Ù…ØªØ¹Ø¯Ø¯Ø©
   ============================================ */
/* Ø´Ø±ÙŠØ· Ø§Ù„ØªÙ…Ø±ÙŠØ± Ù…ØªÙˆØ§Ù�Ù‚ Ù…Ø¹ Ø§Ù„Ø«ÙŠÙ…Ø§Øª */
html::-webkit-scrollbar,
body::-webkit-scrollbar {
    width: 10px;
    background: var(--bg-color);
}

html::-webkit-scrollbar-thumb,
body::-webkit-scrollbar-thumb {
    background: var(--primary-color);
    border-radius: 8px;
    border: 2px solid var(--bg-color);
}

html::-webkit-scrollbar-track,
body::-webkit-scrollbar-track {
    background: var(--bg-color);
}

/* Ø¯Ø¹Ù… Firefox */
html,
body {
    scrollbar-color: var(--primary-color) var(--bg-color);
    scrollbar-width: thin;
}

input[type="date"] {
    direction: rtl;
    text-align: right;
}

input[type="date"]::placeholder {
    direction: rtl;
    text-align: right;
    unicode-bidi: plaintext;
}

:root {
    /* Ø§Ù„Ø®Ø·ÙˆØ· ÙˆØ§Ù„Ù†ØµÙˆØµ */
    --font-family: 'IBM Plex Sans Arabic', 'Tajawal', Arial, sans-serif;
    --font-family-headings: 'Tajawal', 'IBM Plex Sans Arabic', Arial, sans-serif;
    --card-header-text: #fff;

    /* Ø§Ù„Ø£Ø¨Ø¹Ø§Ø¯ ÙˆØ§Ù„ØªØ®Ø·ÙŠØ· */
    --navbar-height: 60px;
    --sidebar-width: 250px;
    --sidebar-collapsed-width: 60px;
    --transition-speed: 0.3s;

    /* Ø£Ø¨Ø¹Ø§Ø¯ Ø§Ù„Ø¹Ù†Ø§ØµØ± Ø§Ù„ØªÙ�Ø§Ø¹Ù„ÙŠØ© Ø§Ù„Ù…ÙˆØ­Ø¯Ø© */
    --form-element-height: 2.2rem;
    --form-element-padding: 0.4rem 0.75rem;
    --form-element-border-radius: 0.375rem;
    --form-element-font-size: 0.875rem;
    --form-element-line-height: 1.4;

    /* Ø£Ø¨Ø¹Ø§Ø¯ Ø§Ù„Ø£Ø²Ø±Ø§Ø± Ø§Ù„Ù…ÙˆØ­Ø¯Ø© */
    --btn-height: 2.2rem;
    --btn-padding: 0.4rem 0.875rem;
    --btn-font-size: 0.875rem;

    /* Ø£Ø¨Ø¹Ø§Ø¯ Ù…Ù†Ø§Ø·Ù‚ Ø§Ù„Ù†Øµ */
    --textarea-min-height: 2.2rem;

    /* Ø§Ù„Ø£Ù„ÙˆØ§Ù† Ø§Ù„Ø£Ø³Ø§Ø³ÙŠØ© */
    --primary-color: #D44759;
    --primary-hover: #b33948;
    --primary-bg: rgba(212, 71, 89, 0.1);
    --secondary-color: #F37D47;
    --secondary-hover: #e0663c;
    --secondary-bg: rgba(243, 125, 71, 0.1);

    /* Ø£Ù„ÙˆØ§Ù† Ø§Ù„Ø­Ø§Ù„Ø© */
    --success-color: #28a745;
    --success-hover: #218838;
    --success-bg: rgba(40, 167, 69, 0.1);
    --danger-color: #dc3545;
    --danger-hover: #c82333;
    --danger-bg: rgba(220, 53, 69, 0.1);
    --warning-color: #ffc107;
    --warning-hover: #e0a800;
    --warning-bg: rgba(255, 193, 7, 0.1);
    --info-color: #17a2b8;
    --info-hover: #138496;
    --info-bg: rgba(23, 162, 184, 0.1);

    /* Ø£Ù„ÙˆØ§Ù† Ø§Ù„Ø®Ù„Ù�ÙŠØ© ÙˆØ§Ù„Ù†ØµÙˆØµ */
    --bg-color: #fff;
    --body-bg: #fff;
    --card-bg: #fff;
    --text-color: #222;
    --text-muted: #888;
    --border-color: #e0e0e0;
    --shadow: rgba(0, 0, 0, 0.06);

    /* Ø£Ù„ÙˆØ§Ù† Ø§Ù„ØªÙ†Ù‚Ù„ */
    --navbar-bg: #fff;
    --navbar-text: #222;
    --sidebar-bg: #fff;
    --sidebar-text: #222;
    --sidebar-hover: #f7f7f7;

    /* Ø£Ù„ÙˆØ§Ù† Ø¥Ø¶Ø§Ù�ÙŠØ© Ù„Ù„ØªÙ�Ø§Ø¹Ù„ */
    --hover-bg: #f8f9fa;
    --secondary-bg: #f7f7f7;
    --secondary-text: #6c757d;

    /* Ø£Ù„ÙˆØ§Ù† Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ */
    --table-bg: #fff;
    --table-header-bg: #f7f7f7;
    --table-header-text: #222;
    --table-border: #e0e0e0;
    --table-striped-bg: #fafafa;
    --table-hover-bg: #f5f5f5;
    --table-text: #222;

    /* Ø£Ù„ÙˆØ§Ù† Ø­Ø§Ù„Ø§Øª Ø§Ù„Ø·Ù„Ø¨Ø§Øª */
    --status-design: #4caf50;
    --status-execution: #ff9800;
    --status-ready: #2196f3;
    --status-completed: #9c27b0;
    --status-cancelled: #f44336;
}

/* ============================================
   Ø§Ù„ØªØ®Ø·ÙŠØ· Ø§Ù„Ø£Ø³Ø§Ø³ÙŠ Ù„Ù„ØµÙ�Ø­Ø©
   ============================================ */
* {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Smooth transitions Ù„Ù„Ø¹Ù†Ø§ØµØ± Ø§Ù„ØªÙ�Ø§Ø¹Ù„ÙŠØ© */
a,
button,
.btn,
.nav-link,
.card,
.form-control,
.badge {
    transition: all var(--transition-speed) ease;
}

/* Fade in Ù„Ù„ØµÙ�Ø­Ø© */
body {
    opacity: 0;
    animation: fadeIn 0.3s ease-in forwards;
}

body.loaded {
    opacity: 1;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

body {
    background: var(--bg-color);
    font-family: var(--font-family, 'Tajawal', Arial, sans-serif);
    color: var(--text-color);
    font-size: 0.85rem;
    padding-top: var(--navbar-height);
    margin: 0;
}

/* ============================================
   Ø§Ù„Ø¹Ù†Ø§ÙˆÙŠÙ†
   ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: bold;
    color: var(--primary-color);
    margin-bottom: 1rem;
}

h1 {
    font-size: 1.5rem;
}

h2 {
    font-size: 1.3rem;
}

/* Ensure all headings are visible in all themes */
h1,
h2,
h3,
h4,
h5,
h6 {
    color: var(--text-color);
}

/* ============================================
   Ø£Ù†Ù…Ø§Ø· Ù…Ø®ØµØµØ© Ù„Ù„Ø¥Ø´Ø¹Ø§Ø±Ø§Øª ÙˆØ§Ù„Ø¹Ù†Ø§ØµØ±
   ============================================ */
.navbar-subtitle {
    font-size: 14px;
    font-weight: normal;
    opacity: 0.9;
    color: var(--navbar-text);
    margin-right: 0.5rem;
}

.notification-badge {
    font-size: 0.65rem;
    padding: 0.2em 0.4em;
    line-height: 1;
    min-width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--danger-color);
    color: white;
    border-radius: 0;
    border: 1px solid white;
    margin-right: 0.25rem;
    position: absolute;
    top: -5px;
    left: -5px;
}

.notification-dropdown {
    min-width: 450px !important;
    max-width: 500px !important;
    max-height: 500px;
    overflow-y: auto;
    background-color: #fff;
    z-index: 1200 !important;
    left: auto !important;
    right: 0 !important;
    transform: none !important;
    /* Ø¯Ø¹Ù… Ø§ØªØ¬Ø§Ù‡ Ø§Ù„ØµÙ�Ø­Ø©: Ø¥Ø°Ø§ ÙƒØ§Ù†Øª RTL Ø§Ø¬Ø¹Ù„Ù‡Ø§ ØªÙ„ØªØµÙ‚ Ø¨Ø§Ù„ÙŠÙ…ÙŠÙ†ØŒ Ø¥Ø°Ø§ LTR ØªÙ„ØªØµÙ‚ Ø¨Ø§Ù„ÙŠØ³Ø§Ø± */
    inset-inline-end: 0 !important;
    inset-inline-start: auto !important;
    direction: rtl;
}

[data-theme="dark"] .notification-dropdown {
    background-color: #2d2d2d !important;
    border-color: #444 !important;
}

.notification-item {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.4;
    transition: background-color 0.2s;
    color: #000;
}

[data-theme="dark"] .notification-item {
    color: #fff !important;
    border-bottom-color: #444 !important;
}

.notification-item:hover {
    background-color: rgba(0, 0, 0, 0.05);
}

[data-theme="dark"] .notification-item:hover {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

.notification-icon {
    width: 35px;
    height: 35px;
    background: none;
    border-radius: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.notification-message {
    font-weight: 500;
    color: var(--text-color);
    margin-bottom: 0.25rem;
    font-size: 0.85rem;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

[data-theme="dark"] .notification-message {
    color: #fff !important;
}

.notification-time {
    color: var(--text-muted);
    font-size: 0.7rem;
}

[data-theme="dark"] .notification-time {
    color: rgba(255, 255, 255, 0.6) !important;
}

/* Ø§Ø¬Ø¹Ù„ Ø§Ù„Ù†ØµÙˆØµ Ø§Ù„Ø£Ø³Ø§Ø³ÙŠØ© Ù�ÙŠ Ø§Ù„Ø«ÙŠÙ… Ø§Ù„Ù…Ø¸Ù„Ù… Ø¨Ø§Ù„Ù„ÙˆÙ† Ø§Ù„Ø£Ø¨ÙŠØ¶ - Ø¨Ø¯ÙˆÙ† input/select/textarea */
[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6,
[data-theme="dark"] p,
[data-theme="dark"] label,
[data-theme="dark"] th,
[data-theme="dark"] td,
[data-theme="dark"] thead,
[data-theme="dark"] tbody,
[data-theme="dark"] tr,
[data-theme="dark"] li {
    color: #fff !important;
}

/* placeholder Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† - Ù„ÙˆÙ† Ø±Ù…Ø§Ø¯ÙŠ ÙˆØ§Ø¶Ø­ */
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder,
[data-theme="dark"] select::placeholder {
    color: rgba(255, 255, 255, 0.5) !important;
    opacity: 1 !important;
}

/* Ø§Ù„Ø­Ù‚ÙˆÙ„ Ù†Ù�Ø³Ù‡Ø§ ØªØ­ØªØ§Ø¬ Ù„ÙˆÙ† Ø£Ø¨ÙŠØ¶ Ù„Ù„Ù†Øµ Ø§Ù„Ù…Ø¯Ø®Ù„ */
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea,
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
    color: #fff !important;
    background-color: #2d2d2d !important;
    border-color: #444 !important;
}

[data-theme="dark"] input:focus,
[data-theme="dark"] select:focus,
[data-theme="dark"] textarea:focus,
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
    background-color: #333 !important;
    border-color: var(--primary-color) !important;
    color: #fff !important;
}

/* Ø§Ù„Ø£Ø²Ø±Ø§Ø± Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† */
[data-theme="dark"] .btn {
    border-color: #444 !important;
}

[data-theme="dark"] .btn-light {
    background-color: #3d3d3d !important;
    border-color: #555 !important;
    color: #fff !important;
}

[data-theme="dark"] .btn-light:hover {
    background-color: #4d4d4d !important;
}

/* Badge Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† */
[data-theme="dark"] .badge.bg-light {
    background-color: #3d3d3d !important;
    color: #fff !important;
}

[data-theme="dark"] .badge.text-dark {
    color: #fff !important;
}

/* Card Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† */
[data-theme="dark"] .card {
    background-color: var(--card-bg) !important;
    border-color: #444 !important;
}

[data-theme="dark"] .card-header {
    background-color: #2d2d2d !important;
    border-bottom-color: #444 !important;
}

[data-theme="dark"] .card-body {
    background-color: var(--card-bg) !important;
}

/* Alert Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† */
[data-theme="dark"] .alert {
    border-color: #444 !important;
}

[data-theme="dark"] .alert-info {
    background-color: rgba(23, 162, 184, 0.2) !important;
    color: #7dd3fc !important;
}

[data-theme="dark"] .alert-success {
    background-color: rgba(40, 167, 69, 0.2) !important;
    color: #86efac !important;
}

[data-theme="dark"] .alert-warning {
    background-color: rgba(255, 193, 7, 0.2) !important;
    color: #fde047 !important;
}

[data-theme="dark"] .alert-danger {
    background-color: rgba(220, 53, 69, 0.2) !important;
    color: #fca5a5 !important;
}

/* Ø§Ù„Ø±ÙˆØ§Ø¨Ø· Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† */
[data-theme="dark"] a:not(.btn):not(.nav-link):not(.dropdown-item) {
    color: #60a5fa !important;
}

[data-theme="dark"] a:not(.btn):not(.nav-link):not(.dropdown-item):hover {
    color: #93c5fd !important;
}

/* text-primary, text-success, etc Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† */
[data-theme="dark"] .text-primary {
    color: #60a5fa !important;
}

[data-theme="dark"] .text-success {
    color: #4ade80 !important;
}

[data-theme="dark"] .text-danger {
    color: #f87171 !important;
}

[data-theme="dark"] .text-warning {
    color: #fbbf24 !important;
}

[data-theme="dark"] .text-info {
    color: #38bdf8 !important;
}

[data-theme="dark"] .text-muted {
    color: rgba(255, 255, 255, 0.6) !important;
}

[data-theme="dark"] .text-secondary {
    color: #9ca3af !important;
}

/* bg-light Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† */
[data-theme="dark"] .bg-light {
    background-color: #2d2d2d !important;
}

[data-theme="dark"] .table-secondary {
    background-color: rgba(108, 117, 125, 0.2) !important;
}

/* Dropdown Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† */
[data-theme="dark"] .dropdown-menu {
    background-color: #2d2d2d !important;
    border-color: #444 !important;
}

[data-theme="dark"] .dropdown-item {
    color: #fff !important;
}

[data-theme="dark"] .dropdown-item:hover,
[data-theme="dark"] .dropdown-item:focus {
    background-color: #3d3d3d !important;
    color: #fff !important;
}

[data-theme="dark"] .dropdown-divider {
    border-top-color: #444 !important;
}

[data-theme="dark"] .dropdown-header {
    color: rgba(255, 255, 255, 0.7) !important;
}

/* Modal Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† */
[data-theme="dark"] .modal-content {
    background-color: #2d2d2d !important;
    border-color: #444 !important;
}

[data-theme="dark"] .modal-header {
    background-color: #2d2d2d !important;
    border-bottom-color: #444 !important;
}

[data-theme="dark"] .modal-body {
    background-color: #2d2d2d !important;
}

[data-theme="dark"] .modal-footer {
    background-color: #2d2d2d !important;
    border-top-color: #444 !important;
}

[data-theme="dark"] .modal-title {
    color: #fff !important;
}

[data-theme="dark"] .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

.page-title {
    color: var(--primary-color);
}

/* ============================================
   Ø£Ù†Ù…Ø§Ø· Ù…Ø³Ø§Ø¹Ø¯Ø© Ù…ÙˆØ­Ø¯Ø© (Utility Classes)
   ============================================ */

/* Ø§Ù„Ù†ØµÙˆØµ Ø§Ù„ØµØºÙŠØ±Ø© Ø§Ù„Ù…Ù�Ø®Ù�ØªØ© */
.text-muted-small {
    font-size: 0.75rem;
    color: var(--text-muted);
}

/* Ø­Ø§ÙˆÙŠØ© Login */
.login-container {
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    padding: 10px 20px 0;
    gap: 12px;
    overflow: hidden;
    max-width: 600px;
    margin: 0 auto;
}

/* Ø¹Ù†ÙˆØ§Ù† Ø§Ù„ØµÙ�Ø­Ø© Ø§Ù„Ù…Ù„ÙˆÙ† */
.page-heading {
    color: var(--primary-color);
    font-weight: bold;
}

/* Ø£Ø²Ø±Ø§Ø± Ø§Ù„Ø¥Ø¬Ø±Ø§Ø¡Ø§Øª Ø§Ù„Ø±Ø¦ÙŠØ³ÙŠØ© */
.btn-primary-custom {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: white !important;
}

/* Ø²Ø± outline Ø´Ù�Ø§Ù� Ù…ØªÙˆØ§Ù�Ù‚ Ù…Ø¹ Ø§Ù„Ø«ÙŠÙ…Ø§Øª */
.btn-outline-theme {
    background: transparent !important;
    border: 2px solid var(--primary-color, #E91E63) !important;
    color: var(--primary-color, #E91E63) !important;
    border-radius: 1.5rem !important;
    font-weight: 600;
    font-size: 1rem;
    padding: 0.6rem 1.5rem;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: border-color 0.2s, color 0.2s, background 0.2s, box-shadow 0.2s;
    box-shadow: none;
}

.btn-outline-theme:hover,
.btn-outline-theme:focus {
    background: var(--primary-color, #E91E63) !important;
    color: #fff !important;
    border-color: var(--secondary-color, #2196F3) !important;
    box-shadow: 0 2px 8px rgba(33, 150, 243, 0.10);
}

.btn-outline-theme:hover i,
.btn-outline-theme:focus i {
    color: #fff !important;
    background: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    padding: 0 !important;
}

/* Ø¯Ø¹Ù… Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† */
[data-theme="dark"] .btn-outline-theme {
    background: transparent !important;
    border-color: #E91E63 !important;
    color: #E91E63 !important;
}

[data-theme="dark"] .btn-outline-theme:hover,
[data-theme="dark"] .btn-outline-theme:focus {
    background: #E91E63 !important;
    color: #fff !important;
    border-color: #2196F3 !important;
}

[data-theme="dark"] .btn-outline-theme i {
    color: #E91E63 !important;
}

[data-theme="dark"] .btn-outline-theme:hover i,
[data-theme="dark"] .btn-outline-theme:focus i {
    color: #fff !important;
}

.btn-outline-theme i {
    background: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    padding: 0 !important;
}

[data-theme="dark"] .btn-outline-theme:hover i,
[data-theme="dark"] .btn-outline-theme:focus i {
    color: #2196F3 !important;
}

.btn-primary-custom:hover {
    background-color: var(--secondary-color) !important;
    border-color: var(--secondary-color) !important;
}

/* Ø§Ù„Ø­Ø¯ÙˆØ¯ Ø§Ù„Ù…Ù„ÙˆÙ†Ø© */
.border-primary-custom {
    border: 1px solid var(--primary-color) !important;
}

.border-primary-custom-2 {
    border: 2px solid var(--primary-color) !important;
}

/* Ø§Ù„Ø¨Ø·Ø§Ù‚Ø§Øª Ø§Ù„Ø¨ÙŠØ¶Ø§Ø¡ */
.card-white {
    background-color: white;
    border: 1px solid var(--border-color);
}

/* Ø±Ø£Ø³ Ø§Ù„Ø¨Ø·Ø§Ù‚Ø© Ø§Ù„Ù…Ù„ÙˆÙ† */
.card-header-custom {
    background-color: white;
    color: var(--primary-color);
    border-bottom: 2px solid var(--primary-color);
}

/* ØªØµÙ…ÙŠÙ… Ø§Ù„Ø¬Ø¯ÙˆÙ„ Ø§Ù„Ù…ÙˆØ­Ø¯ */
.table-fixed-layout {
    width: 100%;
    table-layout: fixed;
}

/* Ù‚Ø§Ø¦Ù…Ø© Ø§Ù„Ø¥ÙƒÙ…Ø§Ù„ Ø§Ù„ØªÙ„Ù‚Ø§Ø¦ÙŠ */
.autocomplete-list {
    position: absolute;
    z-index: 1000;
    max-height: 300px;
    overflow-y: auto;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    width: 100%;
}

/* Ø£Ù†Ù…Ø§Ø· list-group Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø¯Ø§ÙƒÙ† */
[data-theme="dark"] .list-group-item {
    background-color: #2d2d2d !important;
    border-color: #444 !important;
    color: #fff !important;
}

[data-theme="dark"] .list-group-item:hover {
    background-color: #3d3d3d !important;
}

[data-theme="dark"] .list-group-item h6,
[data-theme="dark"] .list-group-item .fw-bold,
[data-theme="dark"] .list-group-item .text-dark {
    color: #fff !important;
}

[data-theme="dark"] .list-group-item small,
[data-theme="dark"] .list-group-item .text-muted {
    color: rgba(255, 255, 255, 0.7) !important;
}

[data-theme="dark"] .list-group-item .text-success {
    color: #4ade80 !important;
}

[data-theme="dark"] .list-group-item .text-primary {
    color: var(--primary-color) !important;
}

/* Ø£ÙŠÙ‚ÙˆÙ†Ø© Ø§Ù„Ù‚Ù�Ù„ */
.lock-icon {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    display: none;
    color: var(--text-muted);
}

/* Ù…Ù†Ø·Ù‚Ø© Ø§Ù„Ù†Øµ Ø§Ù„Ù…Ø­Ø¯ÙˆØ¯Ø© */
.textarea-limited {
    max-width: 400px;
    min-width: 200px;
    display: inline-block;
}

/* Ø£Ø´Ø±Ø·Ø© Ø§Ù„ØªÙ‚Ø¯Ù… Ø§Ù„Ø­Ø¯ÙŠØ«Ø© */
.progress-bar-modern {
    height: 100%;
    border-radius: inherit;
    transition: width 0.3s ease;
}

/* Ù…Ù†Ø·Ù‚Ø© Ù‚Ø§Ø¨Ù„Ø© Ù„Ù„ØªÙ…Ø±ÙŠØ± */
.scrollable-area {
    max-height: 70vh;
    overflow-y: auto;
    padding-right: 10px;
}

/* ØµÙ†Ø¯ÙˆÙ‚ Ø£Ø¨ÙŠØ¶ Ù…Ø¹ Ø¸Ù„ */
.white-box {
    background: white;
    padding: 15px;
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

.white-box-mb {
    margin-bottom: 10px;
}

/* Ù†ØµÙˆØµ Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ Ø§Ù„ØµØºÙŠØ±Ø© */
.table-small-text {
    font-size: 11px;
    padding: 8px;
}

/* Ø´Ø§Ø±Ø§Øª ØµØºÙŠØ±Ø© */
.badge {
    transition: all 0.3s ease;
}

.badge:hover {
    transform: scale(1.1);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.badge-small {
    font-size: 9px;
}

/* Timeline Report Utility Classes */
.text-xs {
    font-size: 0.75rem;
}

.text-muted-gray {
    color: #6c757d;
}

.link-bold {
    text-decoration: none;
    font-weight: bold;
}

.timeline-date-time {
    font-size: 0.75rem;
}

.timeline-date-time div {
    line-height: 1.4;
}

.full-width-form {
    width: 100%;
}

.th-width-8 {
    width: 8%;
}

.th-width-10 {
    width: 10%;
}

.th-width-12 {
    width: 12%;
}

/* Ø­Ø§ÙˆÙŠØ© Ù…Ø­ØªÙˆÙ‰ Ù…Ø±ÙƒØ²ÙŠØ© */
.centered-content {
    text-align: center;
    margin-top: 50px;
}

/* Ø±Ø³Ø§Ù„Ø© ØªØ­Ø°ÙŠØ± Ù…Ø±ÙƒØ²ÙŠØ© */
.alert-centered {
    margin: 20px;
    padding: 20px;
}

/* Ù†Ù…ÙˆØ°Ø¬ ØªØ³Ø¬ÙŠÙ„ Ø§Ù„Ø¯Ø®ÙˆÙ„ */
.login-card {
    min-width: 400px;
    max-width: 450px;
}

/* Ø¹Ù†ÙˆØ§Ù† ØªØ±Ø­ÙŠØ¨ÙŠ */
.welcome-header {
    max-width: 500px;
}

/* Ù†Øµ Ø«Ø§Ù†ÙˆÙŠ */
.text-secondary-custom {
    color: #666;
    font-size: 14px;
}

/* ============================================
   ØµÙ�Ø­Ø© ØªØ³Ø¬ÙŠÙ„ Ø§Ù„Ø¯Ø®ÙˆÙ„ (Login Page)
   ============================================ */

/* Ø®Ù„Ù�ÙŠØ© ØµÙ�Ø­Ø© Login */
body.login-page {
    font-family: 'Tajawal', Arial, sans-serif;
    background: var(--bg-color);
    height: 100vh;
    margin: 0;
    padding: 0;
    overflow: hidden;
}

html {
    margin: 0;
    padding: 0;
}

/* Ø±Ø£Ø³ Ø§Ù„ØªØ±Ø­ÙŠØ¨ */
.welcome-header {
    background: var(--card-bg);
    backdrop-filter: blur(10px);
    border-radius: 20px;
    padding: 18px 25px;
    text-align: center;
    box-shadow: 0 8px 32px var(--shadow);
    border: 1px solid var(--border-color);
    max-width: 500px;
    animation: slideDown 0.6s ease-out;
}

.welcome-header h2 {
    font-size: 1.4rem;
    margin-bottom: 0.4rem;
}

.welcome-header p {
    margin-bottom: 0;
    font-size: 0.85rem;
    line-height: 1.4;
}

/* Ø¨Ø·Ø§Ù‚Ø© ØªØ³Ø¬ÙŠÙ„ Ø§Ù„Ø¯Ø®ÙˆÙ„ */
.login-card {
    background: var(--card-bg);
    backdrop-filter: blur(10px);
    border-radius: 20px;
    padding: 28px;
    box-shadow: 0 15px 35px var(--shadow);
    border: 1px solid var(--border-color);
    min-width: 400px;
    max-width: 450px;
    animation: slideUp 0.6s ease-out;
}

.login-card h3 {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
}

.login-card .mb-3 {
    margin-bottom: 0.7rem !important;
}

.login-card .mb-4 {
    margin-bottom: 0.9rem !important;
}

.login-card .text-center {
    margin-bottom: 1rem;
}

/* Ø¹Ù†Ø§ØµØ± Login Ø¥Ø¶Ø§Ù�ÙŠØ© */
.login-logo {
    height: 50px;
    margin-bottom: 0.5rem;
}

.login-label {
    color: var(--text-color) !important;
    font-size: 0.88rem;
    margin-bottom: 0.4rem;
}

.login-footer-text {
    color: var(--text-muted);
}

.login-page-footer {
    margin-top: 15px;
    padding: 10px;
    text-align: center;
    color: var(--text-muted);
    font-size: 0.8rem;
}

/* Ø­Ù‚ÙˆÙ„ Ø§Ù„Ù†Ù…ÙˆØ°Ø¬ Ù�ÙŠ Login */
.login-card .form-control {
    border-radius: 12px;
    border: 2px solid var(--border-color);
    padding: 10px 15px;
    transition: all 0.3s ease;
    background: var(--card-bg);
    color: var(--text-color);
    font-size: 0.95rem;
}

.login-card .form-control:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 0.2rem rgba(86, 0, 164, 0.25);
    background: var(--card-bg);
}

/* Ø²Ø± ØªØ³Ø¬ÙŠÙ„ Ø§Ù„Ø¯Ø®ÙˆÙ„ */
.btn-login {
    background: linear-gradient(45deg, var(--primary-color), var(--secondary-color));
    border: none;
    border-radius: 12px;
    padding: 10px 12px;
    font-weight: bold;
    transition: all 0.3s ease;
    color: white !important;
    font-size: 0.95rem;
}

.btn-login:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(86, 0, 164, 0.4);
    background: linear-gradient(45deg, var(--secondary-color), var(--primary-color));
}

/* Animations Ù„ØµÙ�Ø­Ø© Login */
@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-30px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Responsive Ù„Ù„Ù€ Login */
@media (max-width: 576px) {
    .login-container {
        padding: 20px 20px 15px;
        gap: 10px;
    }

    .login-card {
        min-width: 100%;
        max-width: 100%;
        padding: 20px;
    }

    .welcome-header {
        padding: 15px;
    }

    .welcome-header h2 {
        font-size: 1.2rem;
    }

    .login-logo {
        height: 45px;
    }
}

transform: translateY(-1px);
box-shadow: 0 2px 4px var(--shadow);
}

.btn-primary {
    background: var(--primary-color);
    border: none;
    color: white;
}

.btn-primary:hover,
.btn-primary:focus {
    background: var(--secondary-color);
}

.btn-success {
    background: var(--secondary-color);
    border: none;
    color: white;
}

.btn-success:hover,
.btn-success:focus {
    background: var(--primary-color);
}

/* ============================================
   Ø´Ø±ÙŠØ· Ø§Ù„ØªÙ†Ù‚Ù„ Ø§Ù„Ø¹Ù„ÙˆÙŠ (Navbar)
   ============================================ */
.navbar,
.main-navbar {
    background: var(--navbar-bg);
    color: var(--navbar-text);
    padding: 0.5rem 1rem;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1100;
    height: var(--navbar-height);
    box-shadow: 0 2px 10px var(--shadow);
}

.main-navbar .navbar-brand {
    color: var(--navbar-text);
    font-weight: bold;
}

.main-navbar img {
    height: 40px;
}

.navbar .navbar-brand,
.main-navbar .navbar-brand {
    color: #fff !important;
    font-weight: bold;
    font-size: 1.1rem;
}

.navbar img,
.main-navbar img {
    height: 35px;
}

/* ØªÙˆØ§Ø²ÙŠ Ø§Ù„Ù„ÙˆØ¬Ùˆ Ù…Ø¹ Ø§Ù„Ø´Ø±ÙŠØ· Ø§Ù„Ø¬Ø§Ù†Ø¨ÙŠ */
.navbar-logo-section {
    width: var(--sidebar-width);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    padding-right: 1rem;
    border-left: 1px solid rgba(255, 255, 255, 0.1);
}

.navbar-logo-section .navbar-brand {
    color: #fff !important;
}

.navbar-logo-section .navbar-brand div,
.navbar-logo-section .navbar-brand span {
    color: #fff !important;
}

.navbar-content-section {
    flex: 1;
    display: flex;
    align-items: center;
    padding-left: 1.5rem;
}

.page-title-navbar {
    display: flex;
    align-items: center;
    color: var(--navbar-text);
    font-size: 1rem;
    background: rgba(255, 255, 255, 0.1);
    padding: 0.4rem 1rem;
    border-radius: 8px;
    backdrop-filter: blur(10px);
}

.navbar-subtitle {
    font-size: 14px;
    font-weight: normal;
    opacity: 0.9;
    color: var(--navbar-text);
}

/* === Ø§Ù„Ø£Ø²Ø±Ø§Ø± ÙˆØ§Ù„Ù†Ù…Ø§Ø°Ø¬ === */

.card {
    border-radius: 1rem !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    margin-bottom: 1rem;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.card-body {
    padding: 1rem;
}

/* Card Header Theme */
.card-header-theme {
    background-color: var(--primary-color);
    color: #fff;
    padding: 0.75rem 1rem;
    font-size: 0.9rem;
    font-weight: 600;
    border-top-left-radius: 1rem !important;
    border-top-right-radius: 1rem !important;
}

.card-header-theme h5 {
    font-size: 0.95rem;
    margin-bottom: 0;
    color: #fff !important;
}

/* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ */
.table {
    font-size: 0.75rem;
    margin-bottom: 0;
    background-color: var(--table-bg);
    color: var(--table-text);
    border-collapse: collapse;
    width: 100%;
    display: table;
}

.table thead {
    display: table-header-group;
}

.table tbody {
    display: table-row-group;
}

.table tr {
    display: table-row;
}

/* Ø¥Ø²Ø§Ù„Ø© Ø§Ù„Ø®Ù„Ù�ÙŠØ© Ù…Ù† Ø§Ù„Ø´Ø§Ø±Ø§Øª ÙˆØ¬Ø¹Ù„ Ø§Ù„Ù†Øµ Ù�Ù‚Ø· */
.badge,
.badge,
.badge-theme-primary,
.badge-theme-success,
.badge-theme-danger,
.badge-theme-warning,
.badge-theme-info,
.badge-theme-secondary {
    display: inline-block;
    padding: 0.35em 0.7em;
    font-size: 0.95em;
    font-weight: normal;
    color: var(--primary-color) !important;
    background: none !important;
    border-radius: 0.2em;
    letter-spacing: 1px;
    box-shadow: none !important;
    transition: color 0.2s;
}

/* Ù…Ø­Ø§Ø°Ø§Ø© Ø®Ø§ØµØ© Ù„Ù„Ù†ØµÙˆØµ */
.table td.text-start,
.table th.text-start {
    text-align: right !important;
}

.table td.text-end,
.table th.text-end {
    text-align: left !important;
}

.table tbody tr {
    transition: all 0.2s ease;
}

.table tbody tr:hover {
    background-color: var(--table-hover-bg) !important;
    transform: translateX(2px);
}

/* ============================================
   Ø£Ø²Ø±Ø§Ø± Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ Ø§Ù„Ù…ÙˆØ­Ø¯Ø© (Table Buttons)
   ============================================ */
/* Ø§Ù„Ø²Ø± Ø§Ù„Ø£Ø³Ø§Ø³ÙŠ Ù„Ù„Ø¬Ø¯Ø§ÙˆÙ„ - Ø¨Ø¯ÙˆÙ† Ø¥Ø·Ø§Ø± */
.btn-table-outline {
    padding: 4px 8px;
    font-size: 0.75rem;
    border-radius: 6px;
    border: none;
    background: transparent;
    font-weight: 500;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin: 0 2px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    min-height: 26px;
    line-height: 1;
    text-decoration: none;
    color: var(--primary-color);
}

.btn-table-outline:hover {
    transform: translateY(-2px);
    background: var(--primary-color);
    color: white;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.2);
    text-decoration: none;
}

/* Ø§Ù„Ø£ÙŠÙ‚ÙˆÙ†Ø§Øª - Ø¨Ø¯ÙˆÙ† Ø¥Ø·Ø§Ø± - Ù„ÙˆÙ† Ù…ÙˆØ­Ø¯ Ù…Ø¹ Ø§Ù„Ø«ÙŠÙ… */
.btn-table-outline i {
    font-size: 0.9rem;
    transition: all 0.2s ease;
    color: inherit;
}

.btn-table-outline:hover i {
    transform: scale(1.1);
    color: white;
}

/* Ø§Ù„Ù†Øµ */
.btn-table-outline span {
    font-weight: 500;
    white-space: nowrap;
    font-size: 0.75rem;
}

/* Ø£Ù†ÙˆØ§Ø¹ Ø§Ù„Ø£Ø²Ø±Ø§Ø± - Ø£Ù„ÙˆØ§Ù† Ø«Ø§Ù†ÙˆÙŠØ© Ù�Ù‚Ø· */
.btn-table-view {
    color: var(--primary-color);
}

.btn-table-view:hover {
    background: var(--primary-color);
    color: white;
}

.btn-table-edit {
    color: var(--secondary-color);
}

.btn-table-edit:hover {
    background: var(--secondary-color);
    color: white;
}

.btn-table-settings {
    color: #fd7e14;
}

.btn-table-settings:hover {
    background: #fd7e14;
    color: white;
}

.btn-table-delete {
    color: #dc3545;
}

.btn-table-delete:hover {
    background: #dc3545;
    color: white;
}

.btn-table-download {
    color: #28a745;
}

.btn-table-download:hover {
    background: #28a745;
    color: white;
}

.btn-table-whatsapp {
    color: #25D366;
}

.btn-table-whatsapp:hover {
    background: #25D366;
    color: white;
}

/* ØªÙˆØ­ÙŠØ¯ Ø£Ø²Ø±Ø§Ø± Bootstrap Ø¯Ø§Ø®Ù„ Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ */
.table .btn-group .btn,
.table .btn-sm {
    border: none;
    padding: 4px 8px;
    font-size: 0.75rem;
    border-radius: 6px;
    transition: all 0.2s ease;
    min-height: 26px;
}

.table .btn-group .btn:hover,
.table .btn-sm:hover {
    transform: translateY(-2px);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.2);
}

/* dropdown Ù�ÙŠ Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ */
.table .dropdown-toggle {
    border: none;
    background: transparent;
    color: var(--primary-color);
    padding: 4px 8px;
}

.table .dropdown-toggle:hover {
    background: var(--primary-color);
    color: white;
}

.table .dropdown-menu {
    border: none;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    border-radius: 8px;
}

.table .dropdown-item {
    padding: 8px 16px;
    transition: all 0.2s ease;
    color: var(--text-color);
}

.table .dropdown-item:hover {
    background: var(--primary-color);
    color: white;
    transform: translateX(5px);
}

/* ============================================
   ØªØ­Ø³ÙŠÙ†Ø§Øª Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ Ø§Ù„Ù…ØªÙ‚Ø¯Ù…Ø©
   ============================================ */
/* Table Responsive - Ø¥ØµÙ„Ø§Ø­ Ø§Ù„Ù…Ø­Ø§Ø°Ø§Ø© */
.table-responsive {
    position: relative;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    width: 100%;
}

.table-responsive>.table {
    margin-bottom: 0;
}

/* Sticky Header - Ø±Ø£Ø³ Ø«Ø§Ø¨Øª (Ø§Ø®ØªÙŠØ§Ø±ÙŠ) */
.table-responsive.sticky-header {
    max-height: 70vh;
    overflow-y: auto;
}

.table-responsive.sticky-header .table thead th {
    position: sticky;
    top: 0;
    z-index: 10;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* ØªØ­Ø³ÙŠÙ† Hover Ù„Ù„ØµÙ�ÙˆÙ� - Ø­Ø±ÙƒØ© Ø¬Ù…ÙŠÙ„Ø© Ù…ÙˆØ­Ø¯Ø© */
.table tbody tr {
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
}

.table tbody tr:hover {
    background-color: var(--table-hover-bg) !important;
    transform: translateX(5px);
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08);
    border-right: 3px solid var(--primary-color);
}

/* Zebra Stripes - Ø£Ø¨ÙŠØ¶ ÙˆÙ„ÙˆÙ† Ø§Ù„Ø«ÙŠÙ… (Ù…Ø¹ÙƒÙˆØ³Ø©) */
.table-striped>tbody>tr:nth-of-type(odd)>*,
.table tbody tr:nth-of-type(odd),
.table tbody tr:nth-of-type(odd) td,
.table tbody tr:nth-of-type(odd) th {
    background-color: var(--table-striped-bg) !important;
}

.table-striped>tbody>tr:nth-of-type(even)>*,
.table tbody tr:nth-of-type(even),
.table tbody tr:nth-of-type(even) td,
.table tbody tr:nth-of-type(even) th {
    background-color: var(--table-bg) !important;
}

/* Ø¥Ù„ØºØ§Ø¡ Ø§Ù„Ù„ÙˆÙ† Ø§Ù„Ø±Ù…Ø§Ø¯ÙŠ Ø§Ù„Ø§Ù�ØªØ±Ø§Ø¶ÙŠ Ù…Ù† Bootstrap */
.table-striped>tbody>tr:nth-of-type(odd)>* {
    --bs-table-accent-bg: var(--table-striped-bg) !important;
    --bs-table-bg: var(--table-striped-bg) !important;
}

.table-striped>tbody>tr:nth-of-type(even)>* {
    --bs-table-accent-bg: transparent !important;
    --bs-table-bg: var(--table-bg) !important;
}

/* Text overflow Ù„Ù„Ø£Ø¹Ù…Ø¯Ø© Ø§Ù„Ø·ÙˆÙŠÙ„Ø© */
.table td.text-truncate {
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.table td.text-start,
.table th.text-start {
    white-space: normal;
}

/* Loading Skeleton Ù„Ù„Ø¬Ø¯Ø§ÙˆÙ„ */
.table-loading {
    position: relative;
    pointer-events: none;
    opacity: 0.6;
}

.table-loading::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(90deg,
            transparent 0%,
            rgba(255, 255, 255, 0.3) 50%,
            transparent 100%);
    animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
    0% {
        transform: translateX(-100%);
    }

    100% {
        transform: translateX(100%);
    }
}

/* Sortable indicators - Ø£ÙŠÙ‚ÙˆÙ†Ø§Øª Ø§Ù„ØªØ±ØªÙŠØ¨ */
.table thead th[data-sortable] {
    cursor: pointer;
    user-select: none;
    position: relative;
    padding-left: 1.5rem;
}

.table thead th[data-sortable]::after {
    content: "â‡…";
    position: absolute;
    left: 0.5rem;
    opacity: 0.3;
    font-size: 0.8rem;
}

.table thead th[data-sortable].sorted-asc::after {
    content: "â†‘";
    opacity: 1;
    color: var(--primary-color);
}

.table thead th[data-sortable].sorted-desc::after {
    content: "â†“";
    opacity: 1;
    color: var(--primary-color);
}

/* ØªØ­Ø³ÙŠÙ† Ø¬Ø¯Ø§ÙˆÙ„ Ø§Ù„Ø·Ù„Ø¨Ø§Øª - Fixed layout */
#ordersMainTable {
    width: 100% !important;
    table-layout: fixed !important;
}

#ordersMainTable th,
#ordersMainTable td {
    word-wrap: break-word !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#ordersMainTable .btn-group {
    flex-wrap: nowrap !important;
    white-space: nowrap !important;
}

#ordersMainTable .btn-group .btn {
    flex-shrink: 0 !important;
    min-width: auto !important;
}

/* ØªØ­Ø³ÙŠÙ† Ø­Ù‚ÙˆÙ„ Ø§Ù„ØªØ§Ø±ÙŠØ® RTL */
.date-input-rtl {
    /* Ù†Øµ Ø£Ø®Ø¶Ø± ØºØ§Ù…Ù‚ Ø¹Ù„Ù‰ Ø®Ù„Ù�ÙŠØ© Ù�Ø§ØªØ­Ø© */
    border-radius: 20px;
    padding: 4px 12px;
    font-size: 0.75rem;
    font-weight: 600;
}

.status-execution {
    background-color: var(--status-execution) !important;
    color: #fff !important;
    border-radius: 20px;
    padding: 4px 12px;
    font-size: 0.75rem;
    font-weight: 600;
}

.status-ready {
    background-color: var(--status-ready) !important;
    color: #fff !important;
    border-radius: 20px;
    padding: 4px 12px;
    font-size: 0.75rem;
    font-weight: 600;
}

.status-completed {
    background-color: var(--status-completed) !important;
    color: #fff !important;
    border-radius: 20px;
    padding: 4px 12px;
    font-size: 0.75rem;
    font-weight: 600;
}

.status-cancelled {
    background-color: var(--status-cancelled) !important;
    color: #fff !important;
    border-radius: 20px;
    padding: 4px 12px;
    font-size: 0.75rem;
    font-weight: 600;
}

.status-default {
    background-color: #f8f9fa !important;
    color: #000 !important;
    border: 1px solid var(--border-color);
    border-radius: 20px;
    padding: 4px 12px;
    font-size: 0.75rem;
    font-weight: 600;
}

.btn.status-design,
.btn.status-execution,
.btn.status-ready,
.btn.status-completed,
.btn.status-cancelled,
.btn.status-default {
    border-color: transparent !important;
}

/* ØªØ·Ø¨ÙŠÙ‚ Ø§Ù„ØªØ¯Ø±Ø¬ Ø§Ù„Ø£Ø®Ø¶Ø± Ø¹Ù„Ù‰ Ø£Ø²Ø±Ø§Ø± ØªØºÙŠÙŠØ± Ø§Ù„Ø­Ø§Ù„Ø© Ù�ÙŠ Ø§Ù„Ø¨Ø·Ø§Ù‚Ø§Øª */
.btn.status-design {
    background-color: var(--status-design) !important;
    color: #2e7d32 !important;
    border: none !important;
}

.btn.status-execution {
    background-color: var(--status-execution) !important;
    color: #fff !important;
    border: none !important;
}

.btn.status-ready {
    background-color: var(--status-ready) !important;
    color: #fff !important;
    border: none !important;
}

.btn.status-completed {
    background-color: var(--status-completed) !important;
    color: #fff !important;
    border: none !important;
}

.btn.status-cancelled {
    background-color: var(--status-cancelled) !important;
    color: #fff !important;
    border: none !important;
}

/* ØªØ£Ø«ÙŠØ±Ø§Øª hover Ù„Ù„Ø£Ø²Ø±Ø§Ø± */
.btn.status-design:hover {
    background-color: #a5d6a7 !important;
    color: #1b5e20 !important;
}

.btn.status-execution:hover {
    background-color: #4caf50 !important;
}

.btn.status-ready:hover {
    background-color: #2e7d32 !important;
}

.btn.status-completed:hover {
    background-color: #1b5e20 !important;
}

/* ============================================
   Ø§Ù„Ø¥Ø´Ø¹Ø§Ø±Ø§Øª (Notifications)
   ============================================ */
/* Notification styles ØªÙ… Ø¯Ù…Ø¬Ù‡Ø§ Ù�ÙŠ Ø§Ù„Ø£Ø¹Ù„Ù‰ - Ù„Ø§ Ø­Ø§Ø¬Ø© Ù„Ù„ØªÙƒØ±Ø§Ø± */

.notification-pulse {
    animation: bellPulse 1s ease-in-out 3;
}

@keyframes bellPulse {
    0% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.2);
        color: var(--secondary-color) !important;
    }

    100% {
        transform: scale(1);
    }
}

@keyframes slideInNotification {
    from {
        opacity: 0;
        transform: translateX(20px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

#notificationDropdown {
    cursor: pointer !important;
    pointer-events: auto !important;
    position: relative !important;
    transition: all 0.3s ease;
}

#notificationDropdown:hover {
    transform: scale(1.1);
}

.dropdown-menu {
    border: none;
    border-radius: 15px;
    box-shadow: 0 4px 20px var(--shadow);
    animation: dropdownSlideIn 0.3s ease-out;
    transform-origin: top;
}

@keyframes dropdownSlideIn {
    from {
        opacity: 0;
        transform: translateY(-10px) scale(0.95);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.dropdown-item {
    transition: all 0.2s ease;
}

.dropdown-item:hover {
    transform: translateX(-5px);
    background-color: var(--hover-bg) !important;
}

.dropdown-header {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color)) !important;
    color: white !important;
    border-radius: 15px 15px 0 0 !important;
}

.dropdown-header h6 {
    color: white !important;
}

/* ============================================
   Ø§Ù„Ù‚Ø§Ø¦Ù…Ø© Ø§Ù„Ø¬Ø§Ù†Ø¨ÙŠØ© (Sidebar)
   ============================================ */
.layout-container {
    display: flex;
    min-height: 100vh;
}


.sidebar {
    background: var(--sidebar-bg);
    box-shadow: 2px 0 10px var(--shadow);
    transition: width var(--transition-speed) cubic-bezier(0.4, 0, 0.2, 1), background var(--transition-speed), box-shadow var(--transition-speed);
    position: fixed;
    top: var(--navbar-height);
    right: 0;
    z-index: 1100;
    width: var(--sidebar-width);
    height: calc(100vh - var(--navbar-height));
    display: flex;
    flex-direction: column;
    border-radius: 0 0 0 18px;
    overflow-x: hidden;
    overflow-y: auto;
    box-sizing: border-box;
}

.sidebar.collapsed {
    width: var(--sidebar-collapsed-width);
}


.main-content {
    margin-right: var(--sidebar-width);
    transition: margin-right var(--transition-speed) cubic-bezier(0.4, 0, 0.2, 1), width var(--transition-speed) cubic-bezier(0.4, 0, 0.2, 1), background var(--transition-speed);
    background: var(--bg-color);
    padding: 1.5rem;
    min-height: calc(100vh - var(--navbar-height));
    width: calc(100% - var(--sidebar-width));
    box-sizing: border-box;
    overflow-x: auto;
}


.sidebar.collapsed~.main-content,
.sidebar-collapsed .main-content,
html.sidebar-collapsed .main-content {
    margin-right: var(--sidebar-collapsed-width);
    width: calc(100% - var(--sidebar-collapsed-width));
}

@media (max-width: 991.98px) {
    .main-content {
        margin-right: 0;
        width: 100%;
        padding: 1rem;
    }

    .sidebar {
        position: fixed;
        right: 0;
        top: var(--navbar-height);
        z-index: 1200;
    }

    .sidebar.collapsed~.main-content {
        margin-right: 0;
        width: 100%;
    }
}

/* Ø²Ø± Ø§Ù„ØªØ­ÙƒÙ… Ù�ÙŠ Ø§Ù„Ù‚Ø§Ø¦Ù…Ø© Ø§Ù„Ø¬Ø§Ù†Ø¨ÙŠØ© */

#sidebarToggle {
    background: transparent !important;
    color: var(--sidebar-text) !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 8px 10px !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    transition: background var(--transition-speed), color var(--transition-speed);
    display: flex !important;
    align-items: center !important;
    gap: 8px;
    width: auto !important;
    margin: 0 !important;
    text-decoration: none !important;
    box-shadow: none !important;
}

#sidebarToggle:hover,
#sidebarToggle:focus {
    background: var(--sidebar-hover) !important;
    color: var(--primary-color) !important;
}

#sidebarToggle i {
    transition: transform var(--transition-speed);
    margin-left: 0;
    font-size: 18px;
}

.toggle-text {
    transition: opacity var(--transition-speed), width var(--transition-speed);
    white-space: nowrap;
    overflow: hidden;
}

.sidebar.collapsed .toggle-text {
    opacity: 0;
    width: 0;
    pointer-events: none;
}

.sidebar.collapsed #sidebarToggle i {
    transform: rotate(180deg);
}

/* روابط القائمة الجانبية */

.sidebar .nav-link {
    color: var(--sidebar-text) !important;
    padding: 10px 14px !important;
    border-radius: 12px !important;
    margin: 4px 8px !important;
    transition: background var(--transition-speed), color var(--transition-speed), box-shadow var(--transition-speed), transform 0.2s ease;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important; /* تباعد متناسق وبديل عن الهوامش اليدوية لتفادي بتر الأيقونات */
    font-weight: 500 !important;
    font-size: 14px !important;
    text-decoration: none !important;
    position: relative !important;
    overflow: hidden !important;
}

.sidebar .nav-link:hover,
.sidebar .nav-link:focus {
    background: var(--sidebar-hover, rgba(86, 0, 164, 0.05)) !important;
    color: var(--primary-color, #5600a4) !important;
}

.sidebar .nav-link.active {
    background: var(--primary-container, #F3E8FF) !important;
    color: var(--primary-color, #5600a4) !important;
    font-weight: 700 !important;
    box-shadow: 0 2px 8px rgba(86, 0, 164, 0.08) !important;
}

.sidebar .nav-link i {
    width: 20px !important;
    text-align: center !important;
    font-size: 18px !important;
    flex-shrink: 0 !important;
    transition: transform var(--transition-speed);
    margin: 0 !important; /* تصفير الهوامش العشوائية لضمان المحاذاة الهندسية المنتظمة */
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.sidebar .nav-link span {
    transition: opacity var(--transition-speed), width var(--transition-speed);
    white-space: nowrap;
    overflow: hidden;
}

.sidebar.collapsed .nav-link span {
    opacity: 0;
    width: 0;
    pointer-events: none;
}

.sidebar.collapsed .nav-link {
    justify-content: center !important;
    padding: 10px !important;
    margin: 4px !important;
}

.sidebar.collapsed .nav-link i {
    margin: 0 !important;
}

.sidebar .nav-link:hover i {
    transform: scale(1.1);
}


/* Ø´Ø±ÙŠØ· Ø§Ù„ØªÙ…Ø±ÙŠØ± Ø§Ù„Ù…Ø®ØµØµ Ù„Ù„sidebar */
.sidebar::-webkit-scrollbar {
    width: 4px;
}

.sidebar::-webkit-scrollbar-track {
    background: var(--bg-color);
}

.sidebar::-webkit-scrollbar-thumb {
    background: var(--primary-color);
    border-radius: 2px;
}

.sidebar::-webkit-scrollbar-thumb:hover {
    background: var(--secondary-color);
}

/* Responsive sidebar: different behavior for tablet and mobile */
@media (max-width: 991.98px) {
    .sidebar {
        position: fixed;
        right: 0;
        top: var(--navbar-height);
        height: calc(100vh - var(--navbar-height));
        border-radius: 0 0 0 18px;
        box-shadow: 0 4px 32px rgba(0, 0, 0, 0.18);
        z-index: 1200;
        transition: width var(--transition-speed), right var(--transition-speed);
    }

    /* Tablet: 768px - 991px */
    @media (min-width: 768px) and (max-width: 991px) {
        .sidebar {
            width: var(--sidebar-width);
        }

        .sidebar.collapsed {
            width: var(--sidebar-collapsed-width);
        }
    }

    /* Mobile: up to 767px */
    @media (max-width: 767px) {
        .sidebar {
            width: 280px;
            transform: translateX(100%);
            visibility: hidden;
            z-index: 1300;
        }

        .sidebar.show {
            transform: translateX(0);
            visibility: visible;
        }

        .sidebar.collapsed {
            width: 280px;
        }

        /* Overlay for mobile sidebar */
        .sidebar-overlay {
            position: fixed;
            top: var(--navbar-height);
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.5);
            z-index: 1250;
            opacity: 0;
            visibility: hidden;
            transition: opacity 0.3s ease, visibility 0.3s ease;
        }

        .sidebar.show~.sidebar-overlay {
            opacity: 1;
            visibility: visible;
        }
    }
}

/* ============================================
   Ø§Ù„ÙƒØ±ÙˆØª ÙˆØ§Ù„Ø¨Ø·Ø§Ù‚Ø§Øª
   ============================================ */
.card {
    background: var(--card-bg);
    color: var(--text-color);
    border-color: var(--border-color);
    box-shadow: 0 2px 10px var(--shadow);
}

.content-card {
    background: var(--card-bg);
    color: var(--text-color);
    border-color: var(--border-color);
    box-shadow: 0 2px 10px var(--shadow);
}

.text-muted {
    color: var(--text-muted) !important;
}

/* ============================================
   Ø§Ù„Ø§Ø³ØªØ¬Ø§Ø¨Ø© Ù„Ù„Ø´Ø§Ø´Ø§Øª Ø§Ù„Ù…Ø®ØªÙ„Ù�Ø©
   ============================================ */
@media (max-width: 992px) {
    .sidebar {
        width: 200px;
    }

    .sidebar.collapsed {
        width: 55px;
    }
}

@media (max-width: 768px) {
    .navbar-logo-section {
        width: auto;
        border-left: none;
        padding-right: 0.5rem;
    }

    .navbar-content-section {
        padding-left: 0.5rem;
    }

    .layout-container {
        flex-direction: column;
    }

    .sidebar {
        width: 100% !important;
        height: auto !important;
        order: 2;
        position: static !important;
    }

    .sidebar.collapsed {
        height: 60px !important;
        overflow: hidden !important;
    }

    .main-content {
        order: 1;
        padding: 1rem;
    }

    .sidebar .nav {
        display: flex;
        flex-wrap: wrap;
    }

    .sidebar.collapsed .nav {
        display: none;
    }

    .sidebar.collapsed #sidebarToggle {
        display: flex !important;
    }
}

footer,
.app-footer {
    background: var(--card-bg);
    color: var(--primary-color);
    letter-spacing: 1px;
    font-weight: bold;
    font-size: 0.9rem;
    padding: 1rem 0;
    border-top: 1px solid var(--border-color);
    transition: background 0.3s, color 0.3s;
}

.alert-success {
    background: #dbffe2 !important;
    color: #195d35 !important;
    border-color: #b9efc6 !important;
    font-weight: bold;
    font-size: 0.85rem;
}

.alert-danger {
    background: #ffeaea !important;
    color: #d44759 !important;
    border-color: #ffb3b3 !important;
    font-weight: bold;
    font-size: 0.85rem;
}

/* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ø¨Ø·Ø§Ù‚Ø§Øª Ù„Ù„Ø¹Ø±Ø¶ Ø§Ù„Ù…Ø·Ù„ÙˆØ¨ */
@media (min-width: 992px) {
    .dashboard-cards .col-lg-3 {
        flex: 0 0 25%;
        max-width: 25%;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .dashboard-cards .col-md-6 {
        flex: 0 0 50%;
        max-width: 50%;
    }
}

/* ✅ تصميم شريط التمرير الجديد الكبير والواضح */
::-webkit-scrollbar {
    width: 13px !important;
    height: 13px !important;
    background: var(--body-bg, #f8f9fa) !important;
}

::-webkit-scrollbar-thumb {
    background: var(--primary-color, #E91E63) !important;
    border-radius: 7px !important;
    border: 3px solid var(--body-bg, #f8f9fa) !important;
    transition: all 0.2s ease !important;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--primary-hover, #c2185b) !important;
    border: 2px solid var(--body-bg, #f8f9fa) !important;
}

::-webkit-scrollbar-track {
    background: var(--body-bg, #f8f9fa) !important;
    border-radius: 0 !important;
}

::-webkit-scrollbar-button {
    background: var(--primary-color, #E91E63) !important;
    border-radius: 3px !important;
    height: 13px !important;
    width: 13px !important;
    border: 2px solid var(--body-bg, #f8f9fa) !important;
}

::-webkit-scrollbar-button:hover {
    background: var(--primary-hover, #c2185b) !important;
}

::-webkit-scrollbar-corner {
    background: var(--body-bg, #f8f9fa) !important;
}

/* ✅ دعم Firefox */
html,
body {
    scrollbar-color: var(--primary-color) var(--bg-color);
    scrollbar-width: auto;
}

/* ØªØ­Ø³ÙŠÙ†Ø§Øª Ø¥Ø¶Ø§Ù�ÙŠØ© Ù„Ù„Ù…Ø³Ø§Ø­Ø© */
.container-fluid {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.row {
    margin-left: -0.5rem;
    margin-right: -0.5rem;
}

.col,
.col-md-2,
.col-md-10 {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

/* ============================================
   Modal Ùˆ Alert Animations
   ============================================ */
.modal {
    animation: fadeIn 0.3s ease-in;
}

.modal.show .modal-dialog {
    animation: slideInModal 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

@keyframes slideInModal {
    from {
        transform: translateY(-50px) scale(0.9);
        opacity: 0;
    }

    to {
        transform: translateY(0) scale(1);
        opacity: 1;
    }
}

.alert {
    animation: slideInAlert 0.4s ease-out;
}

@keyframes slideInAlert {
    from {
        transform: translateX(100%);
        opacity: 0;
    }

    to {
        transform: translateX(0);
        opacity: 1;
    }
}

/* === ØªØ­Ø³ÙŠÙ†Ø§Øª Ø§Ù„Ø¨Ø·Ø§Ù‚Ø§Øª ÙˆØ§Ù„Ø¬Ø¯Ø§ÙˆÙ„ === */

/* Financial Report Classes */
.border-bottom-primary {
    border-bottom: 2px solid var(--primary-color) !important;
}

.border-primary {
    border-color: var(--primary-color) !important;
}

.fw-semibold {
    font-weight: 600;
}

/* ============================================
   Responsive Design - Mobile & Tablet
   ============================================ */

/* Extra Small Mobile (320px - 374px) - Ù„Ù„Ù‡ÙˆØ§ØªÙ� Ø§Ù„Ù‚Ø¯ÙŠÙ…Ø© */
@media (max-width: 374px) {

    /* ØªØµØºÙŠØ± ÙƒÙ„ Ø´ÙŠØ¡ Ù„Ù„Ø´Ø§Ø´Ø§Øª Ø§Ù„ØµØºÙŠØ±Ø© Ø¬Ø¯Ø§Ù‹ */
    body {
        font-size: 0.8rem;
    }

    .card {
        margin-bottom: 0.5rem;
    }

    .card-body {
        padding: 0.5rem;
    }

    .btn {
        font-size: 0.7rem;
        padding: 0.3rem 0.5rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ù‚ÙˆØ§Ø¦Ù… Ø§Ù„Ù…Ù†Ø³Ø¯Ù„Ø© */
    .dropdown-menu {
        max-width: 90vw;
        font-size: 0.75rem;
    }

    .dropdown-item {
        padding: 0.4rem 0.7rem;
        white-space: normal;
    }
}

/* Small Mobile Devices (375px - 575px) */
@media (max-width: 575px) {

    /* ØªÙ‚Ù„ÙŠÙ„ Ø­Ø¬Ù… Ø§Ù„Ø®Ø· Ù„Ù„Ø¬Ø¯Ø§ÙˆÙ„ */
    .table-sm {
        font-size: 0.7rem;
    }

    .table-sm th,
    .table-sm td {
        padding: 0.3rem 0.4rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ø¨Ø·Ø§Ù‚Ø§Øª */
    .card-body {
        padding: 0.75rem;
    }

    .card-header h5 {
        font-size: 0.9rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ø£Ø²Ø±Ø§Ø± */
    .btn-sm {
        padding: 0.25rem 0.5rem;
        font-size: 0.7rem;
    }

    .btn-group {
        flex-wrap: wrap;
        gap: 0.25rem;
    }

    /* Ø¥Ø®Ù�Ø§Ø¡ Ø¨Ø¹Ø¶ Ø§Ù„Ø£Ø¹Ù…Ø¯Ø© Ù�ÙŠ Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ Ø§Ù„ÙƒØ¨ÙŠØ±Ø© */
    .table-responsive {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        max-height: none;
        border-radius: 8px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    }

    /* ØªØ­Ø³ÙŠÙ† Ø¹Ø±Ø¶ Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ Ø¹Ù„Ù‰ Mobile */
    .table {
        font-size: 0.65rem;
        min-width: 600px;
    }

    .table th,
    .table td {
        padding: 0.25rem 0.3rem !important;
        white-space: nowrap;
    }

    /* ØªØµØºÙŠØ± Ø£Ø²Ø±Ø§Ø± Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ Ø¹Ù„Ù‰ Mobile */
    .btn-table-outline {
        padding: 2px 5px;
        font-size: 0.65rem;
        min-height: 22px;
        gap: 2px;
    }

    .btn-table-outline i {
        font-size: 0.75rem;
    }

    .btn-table-outline span {
        font-size: 0.65rem;
    }

    /* ØªÙ‚Ù„ÙŠÙ„ hover effect Ø¹Ù„Ù‰ Mobile */
    .table tbody tr:hover {
        transform: translateX(2px);
    }

    /* Ø¥Ø®Ù�Ø§Ø¡ Sticky header Ø¹Ù„Ù‰ Mobile */
    .table thead th {
        position: relative;
        top: auto;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ù†Ù…Ø§Ø°Ø¬ */
    .form-control,
    .form-select {
        font-size: 0.85rem;
        padding: 0.5rem;
    }

    .form-label {
        font-size: 0.8rem;
        margin-bottom: 0.3rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ù‚ÙˆØ§Ø¦Ù… Ø§Ù„Ù…Ù†Ø³Ø¯Ù„Ø© Ø¹Ù„Ù‰ Mobile */
    .dropdown-menu {
        max-width: 95vw;
        font-size: 0.85rem;
        border-radius: 8px;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    }

    .dropdown-item {
        padding: 0.6rem 1rem;
        white-space: normal;
        word-wrap: break-word;
    }

    .dropdown-item i {
        min-width: 20px;
    }

    /* ØªØ­Ø³ÙŠÙ† Sidebar Ø¹Ù„Ù‰ Mobile */
    .sidebar {
        font-size: 0.85rem;
        width: 240px !important;
    }

    .sidebar .nav-link {
        padding: 0.6rem 0.8rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Navbar */
    .navbar {
        padding: 0.5rem 0.75rem;
    }

    .navbar-brand {
        font-size: 1rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Modal Ø¹Ù„Ù‰ Mobile */
    .modal-dialog {
        margin: 0.5rem;
        max-width: calc(100% - 1rem);
    }

    .modal-header,
    .modal-footer {
        padding: 0.75rem;
    }

    .modal-body {
        padding: 1rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Badges */
    .badge {
        font-size: 0.7rem;
        padding: 0.3em 0.5em;
    }

    /* ØªØ­Ø³ÙŠÙ† Pagination */
    .pagination {
        font-size: 0.8rem;
    }

    .page-link {
        padding: 0.4rem 0.6rem;
    }
}

/* Tablet Devices (576px - 991px) */
@media (min-width: 576px) and (max-width: 991px) {

    /* ØªØ­Ø³ÙŠÙ† Ø¹Ø±Ø¶ Ø§Ù„Ø¨Ø·Ø§Ù‚Ø§Øª */
    .card-deck .card {
        margin-bottom: 1rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ */
    .table-sm {
        font-size: 0.8rem;
    }

    .table-sm th,
    .table-sm td {
        padding: 0.4rem 0.5rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ù…Ø³Ø§Ù�Ø§Øª */
    .container-fluid {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ù‚ÙˆØ§Ø¦Ù… Ø§Ù„Ù…Ù†Ø³Ø¯Ù„Ø© */
    .dropdown-menu {
        max-width: 85vw;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ù†Ù…Ø§Ø°Ø¬ */
    .form-control,
    .form-select {
        font-size: 0.9rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ø£Ø²Ø±Ø§Ø± */
    .btn {
        font-size: 0.875rem;
    }

    /* ØªØ­Ø³ÙŠÙ† Sidebar */
    .sidebar {
        width: 220px;
    }
}

/* Desktop & Large Screens (992px+) */
@media (min-width: 992px) {

    /* ØªØ­Ø³ÙŠÙ† Layout Ø¹Ù„Ù‰ Ø§Ù„Ø´Ø§Ø´Ø§Øª Ø§Ù„ÙƒØ¨ÙŠØ±Ø© */
    .container-fluid {
        max-width: 1400px;
        margin: 0 auto;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø¹Ø±Ø¶ Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ */
    .table-responsive {
        overflow-x: visible;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ù‚ÙˆØ§Ø¦Ù… Ø§Ù„Ù…Ù†Ø³Ø¯Ù„Ø© */
    .dropdown-menu {
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    }
}

/* Touch Devices - ØªØ­Ø³ÙŠÙ†Ø§Øª Ù„Ù„Ø£Ø¬Ù‡Ø²Ø© Ø§Ù„Ù„Ù…Ø³ÙŠØ© */
@media (hover: none) and (pointer: coarse) {

    /* Ø²ÙŠØ§Ø¯Ø© Ø­Ø¬Ù… Ø§Ù„Ø£Ø²Ø±Ø§Ø± Ø§Ù„Ù‚Ø§Ø¨Ù„Ø© Ù„Ù„Ù†Ù‚Ø± */
    .btn,
    .nav-link,
    .dropdown-item {
        min-height: 44px;
        display: flex;
        align-items: center;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„ØªÙ�Ø§Ø¹Ù„ Ù…Ø¹ Ø§Ù„Ø¬Ø¯Ø§ÙˆÙ„ */
    .table tbody tr {
        cursor: pointer;
    }

    /* Ø¥Ø²Ø§Ù„Ø© hover effects Ø¹Ù„Ù‰ Touch */
    .table tbody tr:hover {
        transform: none;
    }

    /* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ù‚ÙˆØ§Ø¦Ù… Ø§Ù„Ù…Ù†Ø³Ø¯Ù„Ø© */
    .dropdown-menu {
        font-size: 1rem;
    }

    .dropdown-item {
        padding: 0.75rem 1rem;
    }

    /* ØªØ­Ø³ÙŠÙ† form inputs */
    .form-control,
    .form-select {
        min-height: 44px;
        font-size: 16px;
        /* Ù„Ù…Ù†Ø¹ zoom Ø¹Ù„Ù‰ iOS */
    }
}

/* Landscape Orientation - Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø£Ù�Ù‚ÙŠ */
@media (max-width: 991px) and (orientation: landscape) {

    /* ØªÙ‚Ù„ÙŠÙ„ Ø§Ø±ØªÙ�Ø§Ø¹ Ø§Ù„Ø¹Ù†Ø§ØµØ± Ù�ÙŠ Ø§Ù„ÙˆØ¶Ø¹ Ø§Ù„Ø£Ù�Ù‚ÙŠ */
    .navbar {
        padding: 0.4rem 0.75rem;
    }

    .card-header {
        padding: 0.6rem 1rem;
    }

    .modal-dialog {
        max-height: 90vh;
    }

    .modal-body {
        max-height: calc(90vh - 120px);
        overflow-y: auto;
    }
}

/* Print Styles */
@media print {

    .sidebar,
    .navbar,
    .btn,
    .card-header .dropdown,
    .no-print {
        display: none !important;
    }

    .main-content {
        margin-left: 0 !important;
        padding: 0 !important;
    }

    .card {
        border: 1px solid #dee2e6 !important;
        box-shadow: none !important;
    }

    .table {
        font-size: 0.8rem;
    }

    body {
        background: white !important;
        color: black !important;
    }
}

/* ============================================
   Theme-Aware Badge Classes
   ============================================ */
.badge-theme-success {
    background-color: var(--success-color) !important;
    color: white !important;
    padding: 0.35em 0.65em !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    border-radius: 0.25rem !important;
    display: inline-block !important;
}

.badge-theme-warning {
    background-color: var(--warning-color) !important;
    color: #333 !important;
    padding: 0.35em 0.65em !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    border-radius: 0.25rem !important;
    display: inline-block !important;
}

.badge-theme-danger {
    background-color: var(--danger-color) !important;
    color: white !important;
    padding: 0.35em 0.65em !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    border-radius: 0.25rem !important;
    display: inline-block !important;
}

.badge-theme-info {
    background-color: var(--info-color) !important;
    color: white !important;
    padding: 0.35em 0.65em !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    border-radius: 0.25rem !important;
    display: inline-block !important;
}

.badge-theme-primary {
    background-color: var(--primary-color) !important;
    color: white !important;
    padding: 0.35em 0.65em !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    border-radius: 0.25rem !important;
    display: inline-block !important;
}

.badge-theme-secondary {
    background-color: var(--text-muted) !important;
    color: white !important;
    padding: 0.35em 0.65em !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    border-radius: 0.25rem !important;
    display: inline-block !important;
}

/* Badge variations for order status */
.badge-status-design {
    background-color: var(--status-design) !important;
    color: #2e7d32 !important;
    /* Ù†Øµ Ø£Ø®Ø¶Ø± ØºØ§Ù…Ù‚ Ø¹Ù„Ù‰ Ø®Ù„Ù�ÙŠØ© Ù�Ø§ØªØ­Ø© */
    padding: 0.35em 0.65em !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    border-radius: 0.25rem !important;
    display: inline-block !important;
}

.badge-status-execution {
    background-color: var(--status-execution) !important;
    color: white !important;
    padding: 0.35em 0.65em !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    border-radius: 0.25rem !important;
    display: inline-block !important;
}

.badge-status-ready {
    background-color: var(--status-ready) !important;
    color: white !important;
    padding: 0.35em 0.65em !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    border-radius: 0.25rem !important;
    display: inline-block !important;
}

.badge-status-completed {
    background-color: var(--status-completed) !important;
    color: white !important;
    padding: 0.35em 0.65em !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    border-radius: 0.25rem !important;
    display: inline-block !important;
}

.badge-status-cancelled {
    background-color: var(--status-cancelled) !important;
    color: white !important;
    padding: 0.35em 0.65em !important;
    font-size: 0.75em !important;
    font-weight: 600 !important;
    border-radius: 0.25rem !important;
    display: inline-block !important;
}

/* Ensure card-header text color is applied correctly */
.card-header {
    color: var(--card-header-text) !important;
}

/* Adjust text color for dark themes */
body.dark-theme {
    --text-color: #fff;
}

/* ============================================
   ï¿½ï¿½ï¿½ï¿½ï¿½ ï¿½ï¿½ï¿½ ï¿½ï¿½ï¿½ï¿½ï¿½ ï¿½ï¿½ï¿½ï¿½ï¿½ï¿½ï¿½
   ============================================ */
.order-files-section {
    padding: 8px;
    background: var(--bs-body-bg);
    border-radius: 6px;
}

.order-files-section .files-list {
    scrollbar-width: thin;
    scrollbar-color: var(--bs-secondary) var(--bs-light);
}

.order-files-section .files-list::-webkit-scrollbar {
    width: 4px;
}

.order-files-section .files-list::-webkit-scrollbar-track {
    background: var(--bs-light);
}

.order-files-section .files-list::-webkit-scrollbar-thumb {
    background: var(--bs-secondary);
    border-radius: 2px;
}

.order-files-section .file-item {
    transition: all 0.2s ease;
}

.order-files-section .file-item:hover {
    background: var(--primary-bg) !important;
}

.order-files-section .file-info {
    overflow: hidden;
}

/* ==============================================
   File System Styles - Ù†Ø¸Ø§Ù… Ø¥Ø¯Ø§Ø±Ø© Ø§Ù„Ù…Ù„Ù�Ø§Øª
   Compatible with all themes
   ============================================== */

/* === Ù…Ù†Ø·Ù‚Ø© Ø§Ù„Ø³Ø­Ø¨ ÙˆØ§Ù„Ø¥Ù�Ù„Ø§Øª (Drop Zone) === */
.drop-zone {
    border: 3px dashed var(--primary-color);
    border-radius: 12px;
    padding: 3rem 2rem;
    text-align: center;
    background: var(--card-bg);
    transition: all 0.3s ease;
    cursor: pointer;
}

.drop-zone:hover {
    border-color: var(--primary-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px var(--shadow);
    background: var(--primary-bg);
}

.drop-zone-active {
    border-color: var(--success-color) !important;
    background: var(--primary-bg) !important;
    transform: scale(1.02);
}

.drop-zone i {
    animation: fileBounce 2s infinite;
    color: var(--primary-color);
}

.drop-zone h5 {
    color: var(--text-color);
}

.drop-zone .text-muted {
    color: var(--text-muted) !important;
}

@keyframes fileBounce {

    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-10px);
    }
}

/* === Ù…Ù†Ø·Ù‚Ø© Ø±Ù�Ø¹ Ø§Ù„Ù…Ù„Ù�Ø§Øª Ù�ÙŠ ØµÙ�Ø­Ø© Ø¥Ø¶Ø§Ù�Ø© Ø·Ù„Ø¨ === */
.file-drop-zone {
    border: 2px dashed var(--border-color);
    padding: 30px;
    text-align: center;
    border-radius: 8px;
    background: var(--card-bg);
    cursor: pointer;
    transition: all 0.3s ease;
}

.file-drop-zone:hover {
    border-color: var(--primary-color);
    background: var(--primary-bg);
}

.file-drop-zone.drag-over {
    border-color: var(--success-color);
    background: var(--primary-bg);
}

/* === Ù‚Ø§Ø¦Ù…Ø© Ø§Ù„Ù…Ù„Ù�Ø§Øª Ø§Ù„Ù…Ø¹Ø§ÙŠÙ†Ø© === */
#selectedFilesPreview .list-group-item,
#newOrderFilesList .list-group-item {
    border-left: 4px solid var(--primary-color);
    transition: all 0.2s ease;
    background-color: var(--card-bg);
    color: var(--text-color);
    border-color: var(--border-color);
}

#selectedFilesPreview .list-group-item:hover,
#newOrderFilesList .list-group-item:hover {
    background-color: var(--primary-bg);
    transform: translateX(-5px);
}

/* === Ù†ÙˆØ§Ù�Ø° Ø§Ù„Ø¹Ø±Ø¶ Ø§Ù„Ù…Ù†Ø¨Ø«Ù‚Ø© === */
#orderFilesModal .modal-content,
#uploadFilesModal .modal-content,
#addFilesModal .modal-content {
    background: var(--card-bg);
    color: var(--text-color);
}

#orderFilesModal .modal-header,
#uploadFilesModal .modal-header,
#addFilesModal .modal-header {
    background: var(--primary-color);
    color: var(--card-header-text);
}

#orderFilesModal .modal-body,
#uploadFilesModal .modal-body,
#addFilesModal .modal-body {
    background: var(--card-bg);
    color: var(--text-color);
}

#orderFilesModal .modal-footer,
#uploadFilesModal .modal-footer,
#addFilesModal .modal-footer {
    background: var(--card-bg);
    border-top-color: var(--border-color);
}

/* === Ù†Ø§Ù�Ø°Ø© Ù…Ø¹Ø§ÙŠÙ†Ø© Ø§Ù„ØµÙˆØ±Ø© === */
#imagePreviewModal .modal-body {
    background: var(--bg-color);
}

#imagePreviewModal .modal-content {
    background: transparent;
}

[data-theme="dark"] #imagePreviewModal .modal-body {
    background: #1a1a1a;
}

#imagePreviewModal img {
    max-height: 75vh;
    border-radius: 8px;
    box-shadow: 0 4px 20px var(--shadow);
}

/* === Ø²Ø± Ø¹Ø±Ø¶ Ø§Ù„Ù…Ù„Ù�Ø§Øª === */
.view-order-files-btn {
    font-weight: 500;
    transition: all 0.3s ease;
}

.view-order-files-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px var(--shadow);
}

/* === Ø£ÙŠÙ‚ÙˆÙ†Ø§Øª Ø§Ù„Ù…Ù„Ù�Ø§Øª === */
.fa-file-pdf {
    color: var(--danger-color);
}

.fa-file-word {
    color: var(--info-color);
}

.fa-file-image {
    color: var(--success-color);
}

.fa-file-alt {
    color: var(--warning-color);
}

/* === ØªØ­Ø³ÙŠÙ†Ø§Øª Ù„Ù„Ø«ÙŠÙ… Ø§Ù„Ù…Ø¸Ù„Ù… === */
[data-theme="dark"] .file-drop-zone {
    background: var(--card-bg);
    border-color: var(--border-color);
}

[data-theme="dark"] .file-drop-zone:hover {
    background: var(--primary-bg);
    border-color: var(--primary-color);
}

[data-theme="dark"] .drop-zone {
    background: var(--card-bg);
}

[data-theme="dark"] .drop-zone:hover {
    background: var(--primary-bg);
}

/* === Responsive === */
@media (max-width: 768px) {

    .file-drop-zone,
    .drop-zone {
        padding: 20px 15px;
    }

    #orderFilesModal .modal-body {
        min-height: 300px;
    }
}

/* ============================================
   Ø£Ù†Ù…Ø§Ø· Ø§Ù„ØªØ¨ÙˆÙŠØ¨Ø§Øª - Dashboard Tabs
   ============================================ */
.tab-container {
    width: 100%;
    background-color: var(--card-bg);
    border-radius: 8px;
    overflow: hidden;
    margin: 0;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.tab-buttons {
    overflow: hidden;
    border-bottom: 1px solid var(--border-color);
    background-color: var(--secondary-bg);
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: row;
}

.tab-buttons button {
    background-color: transparent;
    border: none;
    outline: none;
    cursor: pointer;
    padding: 8px 16px;
    transition: all 0.3s ease;
    font-size: 14px;
    color: var(--secondary-text);
    min-width: 100px;
    border-bottom: 2px solid transparent;
}

.tab-buttons button:hover {
    background-color: var(--hover-bg);
    color: var(--text-color);
}

.tab-buttons button.active {
    background-color: var(--primary-color);
    font-weight: 600;
    color: #ffffff;
    border-bottom: 2px solid var(--primary-color);
}

.tab-content {
    display: none !important;
    padding: 15px;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.tab-content.active {
    display: block !important;
    width: 100% !important;
}

#tasks-container .spinner-border {
    width: 3rem;
    height: 3rem;
}

/* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ø¨Ø·Ø§Ù‚Ø§Øª Ù„Ù„ØªÙˆØ³Ø¹ Ø§Ù„ÙƒØ§Ù…Ù„ */
.dashboard-cards {
    margin: 0 !important;
    width: 100% !important;
}

.dashboard-cards .col-md-6,
.dashboard-cards .col-lg-4 {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

/* ØªØ­Ø³ÙŠÙ† Ø§Ù„Ù†Ù…Ø§Ø°Ø¬ Ù„Ù„ØªÙˆØ³Ø¹ */
#filter-form {
    margin: 0 0 20px 0 !important;
    padding: 15px !important;
    width: 100%;
    max-width: 100%;
}

/* ØªØ­Ø³ÙŠÙ† ØªØµÙ…ÙŠÙ… Ø§Ù„Ù‚ÙˆØ§Ø¦Ù… Ø§Ù„Ù…Ù†Ø³Ø¯Ù„Ø© Ø§Ù„Ø¹Ø§Ø¯ÙŠØ© (select dropdowns) */
select.form-select {
    background: var(--card-bg) !important;
    border: 2px solid var(--border-color) !important;
    border-radius: 12px !important;
    padding: 0.6rem 1rem !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    color: var(--text-color) !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e") !important;
    background-position: left 0.75rem center !important;
    background-repeat: no-repeat !important;
    background-size: 1.5em 1.5em !important;
    padding-left: 2.5rem !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04) !important;
}

select.form-select:focus {
    border-color: var(--primary-color) !important;
    box-shadow: 0 0 0 0.2rem rgba(212, 71, 89, 0.15) !important;
    background-color: var(--card-bg) !important;
    transform: translateY(-1px) !important;
}

select.form-select:hover {
    border-color: var(--primary-hover, #b33948) !important;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.08) !important;
}

/* ØªØ­Ø³ÙŠÙ† Ø®ÙŠØ§Ø±Ø§Øª Ø§Ù„Ù‚Ø§Ø¦Ù…Ø© Ø§Ù„Ù…Ù†Ø³Ø¯Ù„Ø© */
select.form-select option {
    padding: 0.5rem 1rem !important;
    background: var(--card-bg) !important;
    color: var(--text-color) !important;
    font-weight: 500 !important;
}

/* Ø¥Ø²Ø§Ù„Ø© Ø§Ù„Ø¯Ø§Ø¦Ø±Ø© (focus ring) Ù…Ù† Ø¬Ù…ÙŠØ¹ Ø§Ù„Ø¹Ù†Ø§ØµØ± - Ø¨Ø£ÙˆÙ„ÙˆÙŠØ© Ø¹Ø§Ù„ÙŠØ© Ø¬Ø¯Ø§Ù‹ */
*:focus,
*:focus-visible,
button:focus,
button:focus-visible,
.btn:focus,
.btn:focus-visible,
.card:focus,
.card:focus-visible,
a:focus,
a:focus-visible,
.nav-link:focus,
.nav-link:focus-visible,
.sidebar .nav-link:focus,
.sidebar .nav-link:focus-visible,
input:focus,
input:focus-visible,
select:focus,
select:focus-visible,
textarea:focus,
textarea:focus-visible {
    outline: 0 !important;
    outline: none !important;
    box-shadow: none !important;
    border-color: inherit !important;
}

/* Ø¥Ø²Ø§Ù„Ø© Ø£ÙŠ ØªØ£Ø«ÙŠØ±Ø§Øª Bootstrap Ø§Ù„Ø§Ù�ØªØ±Ø§Ø¶ÙŠØ© */
.btn:focus,
.btn:focus-visible,
.btn.focus,
.btn:active:focus {
    outline: 0 !important;
    box-shadow: none !important;
}

/* ========================================
   Ù„ÙˆØ­Ø© Ø§Ù„Ø¥Ø¹Ø¯Ø§Ø¯Ø§Øª Ø§Ù„Ø´Ø®ØµÙŠØ©
   ======================================== */

/* Ø²Ø± Ù�ØªØ­ Ø§Ù„Ø¥Ø¹Ø¯Ø§Ø¯Ø§Øª */
.settings-button {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 50px;
    height: 50px;
    border-radius: 8px;
    background: var(--primary-color, #007bff);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
    z-index: 999;
}

.settings-button:hover {
    transform: scale(1.1) rotate(45deg);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.3);
}

/* Ø§Ù„Ù„ÙˆØ­Ø© Ù†Ù�Ø³Ù‡Ø§ */
.preferences-panel {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    display: none;
}

.preferences-panel.active {
    display: flex;
    align-items: center;
    justify-content: center;
}

.preferences-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
}

.preferences-content {
    position: relative;
    background: white;
    border-radius: 16px;
    width: 90%;
    max-width: 700px;
    max-height: 85vh;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    display: flex;
    flex-direction: column;
}

/* Ø±Ø£Ø³ Ø§Ù„Ù„ÙˆØ­Ø© */
.preferences-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    border-bottom: 1px solid #e0e0e0;
    background: linear-gradient(135deg, var(--primary-color, #007bff) 0%, var(--secondary-color, #6c757d) 100%);
    color: white;
}

.preferences-header h3 {
    margin: 0;
    font-size: 20px;
    font-weight: 600;
}

.preferences-close {
    background: rgba(255, 255, 255, 0.2);
    border: none;
    color: white;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    font-size: 20px;
    cursor: pointer;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.preferences-close:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: rotate(90deg);
}

/* Ù…Ø­ØªÙˆÙ‰ Ø§Ù„Ù„ÙˆØ­Ø© */
.preferences-body {
    flex: 1;
    overflow-y: auto;
    padding: 24px;
}

.preference-section {
    margin-bottom: 32px;
}

.preference-section h4 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 16px;
    color: var(--primary-color, #007bff);
    border-bottom: 2px solid var(--primary-color, #007bff);
    padding-bottom: 8px;
}

.preference-item {
    margin-bottom: 16px;
}

.preference-item label {
    display: block;
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 8px;
    color: #333;
}

.preference-item input[type="checkbox"] {
    margin-right: 8px;
    transform: scale(1.2);
    cursor: pointer;
}

.preference-item input[type="range"] {
    width: 100%;
    margin: 8px 0;
}

.volume-display {
    display: inline-block;
    font-size: 14px;
    font-weight: 600;
    color: var(--primary-color, #007bff);
    margin-right: 8px;
}

/* Ø´Ø¨ÙƒØ© Ø§Ù„Ø«ÙŠÙ…Ø§Øª */
.theme-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 12px;
    margin-top: 12px;
}

.theme-option {
    border: 2px solid #e0e0e0;
    border-radius: 12px;
    padding: 12px;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s;
}

.theme-option:hover {
    border-color: var(--primary-color, #007bff);
    transform: translateY(-4px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.theme-option.active {
    border-color: var(--primary-color, #007bff);
    background: rgba(0, 123, 255, 0.05);
}

.theme-preview {
    width: 100%;
    height: 60px;
    border-radius: 8px;
    margin-bottom: 8px;
}

.theme-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.theme-icon {
    font-size: 24px;
}

.theme-name {
    font-size: 12px;
    font-weight: 500;
}

/* Ø£Ø²Ø±Ø§Ø± Ø§Ù„Ø§Ø®ØªØ¨Ø§Ø± */
.test-buttons {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.test-btn {
    flex: 1;
    min-width: 150px;
    padding: 10px 16px;
    border: 2px solid var(--primary-color, #007bff);
    background: white;
    color: var(--primary-color, #007bff);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}

.test-btn:hover {
    background: var(--primary-color, #007bff);
    color: white;
}

/* Ø°ÙŠÙ„ Ø§Ù„Ù„ÙˆØ­Ø© */
.preferences-footer {
    display: flex;
    gap: 12px;
    padding: 20px 24px;
    border-top: 1px solid #e0e0e0;
    background: #f8f9fa;
}

.preferences-footer button {
    flex: 1;
    padding: 10px;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}

.btn-reset {
    background: #dc3545;
    color: white;
}

.btn-reset:hover {
    background: #c82333;
}

.btn-export,
.btn-import {
    background: #6c757d;
    color: white;
}

.btn-export:hover,
.btn-import:hover {
    background: #5a6268;
}

.btn-save {
    background: #28a745;
    color: white;
}

.btn-save:hover {
    background: #218838;
}

/* Ø±Ø³Ø§Ø¦Ù„ Ø§Ù„ØªØ£ÙƒÙŠØ¯ */
.preferences-message {
    position: fixed;
    top: 20px;
    left: 50%;
    transform: translateX(-50%) translateY(-100px);
    background: white;
    padding: 16px 24px;
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
    font-size: 14px;
    font-weight: 500;
    opacity: 0;
    transition: all 0.3s ease;
    z-index: 10001;
}

.preferences-message.show {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

.preferences-message.success {
    background: #d4edda;
    color: #155724;
    border-left: 4px solid #28a745;
}

.preferences-message.error {
    background: #f8d7da;
    color: #721c24;
    border-left: 4px solid #dc3545;
}

.preferences-message.info {
    background: #d1ecf1;
    color: #0c5460;
    border-left: 4px solid #17a2b8;
}

/* ============================================
   Ø£Ù†Ù…Ø§Ø· Ù„ÙˆØ­Ø© Ø§Ù„Ø¥Ø¹Ø¯Ø§Ø¯Ø§Øª Ø§Ù„Ø´Ø®ØµÙŠØ© - Ù…Ù† preferences.css
   ============================================ */

/* Ø²Ø± Ø§Ù„Ø¥Ø¹Ø¯Ø§Ø¯Ø§Øª */
.settings-button {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 1050;
    background: var(--card-bg, #ffffff);
    border: 2px solid var(--border-color, #dee2e6);
    border-radius: 50%;
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 1.8rem;
    box-shadow: 0 4px 20px var(--shadow, rgba(0, 0, 0, 0.1));
    transition: all 0.3s ease;
    animation: settingsGlow 3s infinite;
}

.settings-button:hover {
    transform: scale(1.1) rotate(90deg);
    box-shadow: 0 6px 30px var(--shadow, rgba(0, 0, 0, 0.2));
}

@keyframes settingsGlow {

    0%,
    100% {
        box-shadow: 0 4px 20px var(--shadow, rgba(0, 0, 0, 0.1));
    }

    50% {
        box-shadow: 0 4px 25px var(--primary-color, #D44759);
    }
}

/* Ù„ÙˆØ­Ø© Ø§Ù„Ø¥Ø¹Ø¯Ø§Ø¯Ø§Øª */
.preferences-panel {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.preferences-panel.active {
    opacity: 1;
    visibility: visible;
}

.preferences-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(5px);
}

.preferences-content {
    position: relative;
    background: var(--card-bg, #ffffff);
    border-radius: 20px;
    width: 90%;
    max-width: 700px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    transform: scale(0.9) translateY(50px);
    transition: all 0.3s ease;
}

.preferences-panel.active .preferences-content {
    transform: scale(1) translateY(0);
}

/* Ø±Ø£Ø³ Ø§Ù„Ù„ÙˆØ­Ø© */
.preferences-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 25px;
    border-bottom: 2px solid var(--border-color, #dee2e6);
    background: linear-gradient(135deg, var(--primary-color, #D44759), var(--secondary-color, #F37D47));
    color: white;
    border-radius: 20px 20px 0 0;
}

.preferences-header h3 {
    margin: 0;
    font-size: 1.5rem;
    font-weight: bold;
}

.preferences-close {
    background: transparent;
    border: none;
    font-size: 1.5rem;
    color: white;
    cursor: pointer;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.preferences-close:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: rotate(90deg);
}

/* Ù…Ø­ØªÙˆÙ‰ Ø§Ù„Ù„ÙˆØ­Ø© */
.preferences-body {
    flex: 1;
    overflow-y: auto;
    padding: 20px 25px;
    color: var(--text-color, #333333);
}

.preference-section {
    margin-bottom: 25px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--border-color, #dee2e6);
}

.preference-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
}

.preference-section h4 {
    color: var(--primary-color, #D44759);
    margin-bottom: 15px;
    font-size: 1.2rem;
    font-weight: bold;
    display: flex;
    align-items: center;
    gap: 8px;
}

.preference-item {
    margin-bottom: 15px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.preference-item label {
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    color: var(--text-color, #333333);
}

.preference-item input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--primary-color, #D44759);
}

.preference-item input[type="range"] {
    width: 100%;
    height: 6px;
    background: var(--border-color, #dee2e6);
    border-radius: 3px;
    outline: none;
    accent-color: var(--primary-color, #D44759);
}

.volume-display {
    background: var(--primary-color, #D44759);
    color: white;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 0.85rem;
    font-weight: bold;
    min-width: 40px;
    text-align: center;
}

/* Ø´Ø¨ÙƒØ© Ø§Ù„Ø«ÙŠÙ…Ø§Øª */
.theme-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 15px;
    margin-top: 10px;
}

.theme-option {
    border: 2px solid var(--border-color, #dee2e6);
    border-radius: 12px;
    padding: 12px;
    cursor: pointer;
    transition: all 0.2s ease;
    background: var(--card-bg, #ffffff);
}

.theme-option:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px var(--shadow, rgba(0, 0, 0, 0.1));
}

.theme-option.active {
    border-color: var(--primary-color, #D44759);
    background: var(--primary-color, #D44759);
    color: white;
}

.theme-preview {
    width: 100%;
    height: 30px;
    border-radius: 6px;
    margin-bottom: 8px;
}

.theme-info {
    display: flex;
    align-items: center;
    gap: 6px;
}

.theme-icon {
    font-size: 1.2rem;
}

.theme-name {
    font-size: 0.9rem;
    font-weight: 500;
}

/* Ø£Ø²Ø±Ø§Ø± Ø§Ù„Ø§Ø®ØªØ¨Ø§Ø± */
.test-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.test-btn {
    background: var(--info-color, #17a2b8);
    color: white;
    border: none;
    padding: 8px 15px;
    border-radius: 20px;
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 500;
    transition: all 0.2s ease;
}

.test-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 3px 10px rgba(23, 162, 184, 0.3);
}

/* ØªØ°ÙŠÙŠÙ„ Ø§Ù„Ù„ÙˆØ­Ø© */
.preferences-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 25px;
    border-top: 2px solid var(--border-color, #dee2e6);
    background: var(--bg-color, #faf6f4);
    border-radius: 0 0 20px 20px;
    flex-wrap: wrap;
    gap: 10px;
}

.preferences-footer button {
    padding: 10px 20px;
    border: none;
    border-radius: 25px;
    cursor: pointer;
    font-weight: 500;
    transition: all 0.2s ease;
    font-size: 0.9rem;
}

.btn-reset {
    background: var(--warning-color, #ffc107);
    color: #000;
}

.btn-export {
    background: var(--info-color, #17a2b8);
    color: white;
}

.btn-import {
    background: var(--success-color, #28a745);
    color: white;
}

.btn-save {
    background: var(--primary-color, #D44759);
    color: white;
}

.preferences-footer button:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

/* Ø±Ø³Ø§Ø¦Ù„ Ø§Ù„ØªØ£ÙƒÙŠØ¯ */
.preferences-message {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 3000;
    padding: 15px 20px;
    border-radius: 10px;
    color: white;
    font-weight: 500;
    transform: translateX(100%);
    transition: all 0.3s ease;
    max-width: 300px;
}

.preferences-message.show {
    transform: translateX(0);
}

.preferences-message.success {
    background: var(--success-color, #28a745);
}

.preferences-message.error {
    background: var(--danger-color, #dc3545);
}

.preferences-message.info {
    background: var(--info-color, #17a2b8);
}

/* Ø§Ø³ØªØ¬Ø§Ø¨Ø© Ù„Ù„Ø´Ø§Ø´Ø§Øª Ø§Ù„ØµØºÙŠØ±Ø© */
@media (max-width: 768px) {
    .preferences-content {
        width: 95%;
        max-height: 95vh;
        margin: 10px;
    }

    .preferences-header,
    .preferences-body,
    .preferences-footer {
        padding: 15px 20px;
    }

    .theme-grid {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }

    .preferences-footer {
        flex-direction: column;
        align-items: stretch;
    }

    .preferences-footer button {
        width: 100%;
        margin: 2px 0;
    }

    .settings-button {
        bottom: 15px;
        right: 15px;
        width: 50px;
        height: 50px;
        font-size: 1.5rem;
    }
}

/* ØªØ­Ø³ÙŠÙ†Ø§Øª Ø¥Ø¶Ø§Ù�ÙŠØ© Ù„Ù„Ù…Ø¸Ù‡Ø± Ø§Ù„Ù…Ø¸Ù„Ù… */
[data-theme="dark"] .preferences-content {
    box-shadow: 0 20px 60px rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .theme-preview {
    border: 1px solid var(--border-color, #343a40);
}

/* ØªØ£Ø«ÙŠØ±Ø§Øª Ø¥Ø¶Ø§Ù�ÙŠØ© */
.preference-item:hover {
    background: var(--sidebar-hover, rgba(0, 0, 0, 0.02));
    padding: 8px;
    margin: 0 -8px 15px -8px;
    border-radius: 8px;
    transition: all 0.2s ease;
}

.preferences-body::-webkit-scrollbar {
    width: 6px;
}

.preferences-body::-webkit-scrollbar-track {
    background: var(--border-color, #dee2e6);
    border-radius: 3px;
}

.preferences-body::-webkit-scrollbar-thumb {
    background: var(--primary-color, #D44759);
    border-radius: 3px;
}

/* ØªØ°ÙŠÙŠÙ„ Ø§Ù„Ù„ÙˆØ­Ø© */
.preferences-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 25px;
    border-top: 2px solid var(--border-color, #dee2e6);
    background: var(--bg-color, #faf6f4);
    border-radius: 0 0 20px 20px;
    flex-wrap: wrap;
    gap: 10px;
}

.preferences-footer button {
    padding: 10px 20px;
    border: none;
    border-radius: 25px;
    cursor: pointer;
    font-weight: 500;
    transition: all 0.2s ease;
    font-size: 0.9rem;
}

.btn-reset {
    background: var(--warning-color, #ffc107);
    color: #000;
}

.btn-export {
    background: var(--info-color, #17a2b8);
    color: white;
}

.btn-import {
    background: var(--success-color, #28a745);
    color: white;
}

.btn-save {
    background: var(--primary-color, #D44759);
    color: white;
}

.preferences-footer button:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

/* Ø±Ø³Ø§Ø¦Ù„ Ø§Ù„ØªØ£ÙƒÙŠØ¯ */
.preferences-message {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 3000;
    padding: 15px 20px;
    border-radius: 10px;
    color: white;
    font-weight: 500;
    transform: translateX(100%);
    transition: all 0.3s ease;
    max-width: 300px;
}

.preferences-message.show {
    transform: translateX(0);
}

.preferences-message.success {
    background: var(--success-color, #28a745);
}

.preferences-message.error {
    background: var(--danger-color, #dc3545);
}

.preferences-message.info {
    background: var(--info-color, #17a2b8);
}

/* Ø§Ø³ØªØ¬Ø§Ø¨Ø© Ù„Ù„Ø´Ø§Ø´Ø§Øª Ø§Ù„ØµØºÙŠØ±Ø© */
@media (max-width: 768px) {
    .preferences-content {
        width: 95%;
        max-height: 95vh;
        margin: 10px;
    }

    .preferences-header,
    .preferences-body,
    .preferences-footer {
        padding: 15px 20px;
    }

    .theme-grid {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }

    .preferences-footer {
        flex-direction: column;
        align-items: stretch;
    }

    .preferences-footer button {
        width: 100%;
        margin: 2px 0;
    }

    .settings-button {
        bottom: 15px;
        right: 15px;
        width: 50px;
        height: 50px;
        font-size: 1.5rem;
    }
}

/* ØªØ­Ø³ÙŠÙ†Ø§Øª Ø¥Ø¶Ø§Ù�ÙŠØ© Ù„Ù„Ù…Ø¸Ù‡Ø± Ø§Ù„Ù…Ø¸Ù„Ù… */
[data-theme="dark"] .preferences-content {
    box-shadow: 0 20px 60px rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .theme-preview {
    border: 1px solid var(--border-color, #343a40);
}

/* ØªØ£Ø«ÙŠØ±Ø§Øª Ø¥Ø¶Ø§Ù�ÙŠØ© */
.preference-item:hover {
    background: var(--sidebar-hover, rgba(0, 0, 0, 0.02));
    padding: 8px;
    margin: 0 -8px 15px -8px;
    border-radius: 8px;
    transition: all 0.2s ease;
}

.preferences-body::-webkit-scrollbar {
    width: 6px;
}

.preferences-body::-webkit-scrollbar-track {
    background: var(--border-color, #dee2e6);
    border-radius: 3px;
}

.preferences-body::-webkit-scrollbar-thumb {
    background: var(--primary-color, #D44759);
    border-radius: 3px;
}

.preferences-body::-webkit-scrollbar-thumb:hover {
    background: var(--secondary-color, #F37D47);
}

/* ============================================
   ØªÙˆØ­ÙŠØ¯ Ø­Ù‚ÙˆÙ„ Ø§Ù„Ø¥Ø¯Ø®Ø§Ù„ (Form Controls)
   ============================================ */

/* Ø­Ù‚ÙˆÙ„ Ø§Ù„Ø¥Ø¯Ø®Ø§Ù„ Ø§Ù„Ø£Ø³Ø§Ø³ÙŠØ© */
.form-control,
.form-select,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="url"],
input[type="search"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
textarea,
select {
    width: 100%;
    height: var(--form-element-height);
    padding: var(--form-element-padding);
    font-size: var(--form-element-font-size);
    font-weight: 500;
    line-height: var(--form-element-line-height);
    color: var(--text-color);
    background-color: var(--card-bg);
    border: 2px solid var(--border-color);
    border-radius: var(--form-element-border-radius);
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04);
}

.form-control:focus,
.form-select:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
input[type="date"]:focus,
input[type="time"]:focus,
input[type="datetime-local"]:focus,
textarea:focus,
select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 0.2rem rgba(212, 71, 89, 0.15);
    background-color: var(--card-bg);
    transform: translateY(-1px);
    outline: none;
}

.form-control:hover,
.form-select:hover,
input[type="text"]:hover,
input[type="email"]:hover,
input[type="password"]:hover,
input[type="number"]:hover,
input[type="tel"]:hover,
input[type="url"]:hover,
input[type="search"]:hover,
input[type="date"]:hover,
input[type="time"]:hover,
input[type="datetime-local"]:hover,
textarea:hover,
select:hover {
    border-color: var(--primary-hover);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.08);
}

/* Ø­Ù‚ÙˆÙ„ Ø§Ù„Ø¥Ø¯Ø®Ø§Ù„ Ø§Ù„ØµØºÙŠØ±Ø© */
.form-control-sm,
.form-select-sm {
    height: calc(var(--form-element-height) * 0.875);
    padding: calc(var(--form-element-padding) * 0.75);
    font-size: calc(var(--form-element-font-size) * 0.875);
}

/* Ø­Ù‚ÙˆÙ„ Ø§Ù„Ø¥Ø¯Ø®Ø§Ù„ Ø§Ù„ÙƒØ¨ÙŠØ±Ø© */
.form-control-lg,
.form-select-lg {
    height: calc(var(--form-element-height) * 1.125);
    padding: calc(var(--form-element-padding) * 1.25);
    font-size: calc(var(--form-element-font-size) * 1.125);
}

/* Ù…Ù†Ø§Ø·Ù‚ Ø§Ù„Ù†Øµ */
textarea {
    min-height: var(--textarea-min-height);
    resize: vertical;
}

/* Ø­Ù‚ÙˆÙ„ Ø§Ù„Ø¥Ø¯Ø®Ø§Ù„ Ø§Ù„Ù…Ø¹Ø·Ù„Ø© */
.form-control:disabled,
.form-select:disabled,
input:disabled,
textarea:disabled,
select:disabled {
    background-color: var(--secondary-bg);
    border-color: var(--border-color);
    color: var(--text-muted);
    cursor: not-allowed;
    opacity: 0.6;
}

/* Ø­Ù‚ÙˆÙ„ Ø§Ù„Ø¥Ø¯Ø®Ø§Ù„ Ù„Ù„Ù‚Ø±Ø§Ø¡Ø© Ù�Ù‚Ø· */
.form-control[readonly],
input[readonly],
textarea[readonly] {
    background-color: var(--secondary-bg);
    border-color: var(--border-color);
    color: var(--text-muted);
    cursor: not-allowed;
}

/* Ø­Ù‚ÙˆÙ„ Ø§Ù„Ø¥Ø¯Ø®Ø§Ù„ Ù…Ø¹ Ø£Ø®Ø·Ø§Ø¡ */
.form-control.is-invalid,
.form-select.is-invalid {
    border-color: var(--danger-color);
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.15);
}

.form-control.is-invalid:focus,
.form-select.is-invalid:focus {
    border-color: var(--danger-color);
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.15);
}

/* Ø­Ù‚ÙˆÙ„ Ø§Ù„Ø¥Ø¯Ø®Ø§Ù„ ØµØ­ÙŠØ­Ø© */
.form-control.is-valid,
.form-select.is-valid {
    border-color: var(--success-color);
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.15);
}

.form-control.is-valid:focus,
.form-select.is-valid:focus {
    border-color: var(--success-color);
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.15);
}

/* ============================================
   ØªÙˆØ­ÙŠØ¯ Ø§Ù„Ø£Ø²Ø±Ø§Ø± (Buttons)
   ============================================ */

/* Ø§Ù„Ø£Ø²Ø±Ø§Ø± Ø§Ù„Ø£Ø³Ø§Ø³ÙŠØ© */
.btn {
    height: var(--btn-height);
    padding: var(--btn-padding);
    font-size: var(--btn-font-size);
    font-weight: 600;
    border-radius: 1rem;
    border: 2px solid transparent;
    cursor: pointer;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    text-decoration: none;
    white-space: nowrap;
    position: relative;
    overflow: hidden;
}

/* Ø£Ø²Ø±Ø§Ø± Bootstrap Ø§Ù„Ù…Ø¹Ø§Ø¯ ØªØ¹Ø±ÙŠÙ�Ù‡Ø§ */
.btn-primary {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
}

.btn-primary:hover,
.btn-primary:focus {
    background: var(--primary-hover);
    border-color: var(--primary-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(212, 71, 89, 0.3);
}

.btn-secondary {
    background: var(--secondary-color);
    border-color: var(--secondary-color);
    color: white;
}

.btn-secondary:hover,
.btn-secondary:focus {
    background: var(--secondary-hover);
    border-color: var(--secondary-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(243, 125, 71, 0.3);
}

.btn-success {
    background: var(--success-color);
    border-color: var(--success-color);
    color: white;
}

.btn-success:hover,
.btn-success:focus {
    background: var(--success-hover);
    border-color: var(--success-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(40, 167, 69, 0.3);
}

.btn-danger {
    background: var(--danger-color);
    border-color: var(--danger-color);
    color: white;
}

.btn-danger:hover,
.btn-danger:focus {
    background: var(--danger-hover);
    border-color: var(--danger-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(220, 53, 69, 0.3);
}

.btn-warning {
    background: var(--warning-color);
    border-color: var(--warning-color);
    color: #000;
}

.btn-warning:hover,
.btn-warning:focus {
    background: var(--warning-hover);
    border-color: var(--warning-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(255, 193, 7, 0.3);
}

.btn-info {
    background: var(--info-color);
    border-color: var(--info-color);
    color: white;
}

.btn-info:hover,
.btn-info:focus {
    background: var(--info-hover);
    border-color: var(--info-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(23, 162, 184, 0.3);
}

.btn-light {
    background: var(--secondary-bg);
    border-color: var(--border-color);
    color: var(--text-color);
}

.btn-light:hover,
.btn-light:focus {
    background: var(--hover-bg);
    border-color: var(--border-color);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.btn-dark {
    background: #222;
    border-color: #222;
    color: white;
}

.btn-dark:hover,
.btn-dark:focus {
    background: #111;
    border-color: #111;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
}

/* Ø£Ø²Ø±Ø§Ø± Outline */
.btn-outline-primary {
    background: transparent;
    border-color: var(--primary-color);
    color: var(--primary-color);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(212, 71, 89, 0.3);
}

.btn-outline-secondary {
    background: transparent;
    border-color: var(--secondary-color);
    color: var(--secondary-color);
}

.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
    background: var(--secondary-color);
    border-color: var(--secondary-color);
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(243, 125, 71, 0.3);
}

/* Ø£Ø²Ø±Ø§Ø± Ø¨Ø­Ø¬Ù… ØµØºÙŠØ± */
.btn-sm {
    height: calc(var(--btn-height) * 0.875);
    padding: calc(var(--btn-padding) * 0.75);
    font-size: calc(var(--btn-font-size) * 0.875);
}

/* Ø£Ø²Ø±Ø§Ø± Ø¨Ø­Ø¬Ù… ÙƒØ¨ÙŠØ± */
.btn-lg {
    height: calc(var(--btn-height) * 1.125);
    padding: calc(var(--btn-padding) * 1.25);
    font-size: calc(var(--btn-font-size) * 1.125);
}

/* Ø£Ø²Ø±Ø§Ø± Ù…Ø¹Ø·Ù„Ø© */
.btn:disabled,
.btn.disabled {
    background: var(--secondary-bg);
    border-color: var(--border-color);
    color: var(--text-muted);
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* Ø£Ø²Ø±Ø§Ø± Ø§Ù„ØªØ­Ù…ÙŠÙ„ */
.btn-loading {
    position: relative;
    color: transparent;
}

.btn-loading::after {
    content: "";
    position: absolute;
    width: 16px;
    height: 16px;
    top: 50%;
    left: 50%;
    margin-left: -8px;
    margin-top: -8px;
    border: 2px solid transparent;
    border-top: 2px solid currentColor;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

/* ============================================
   ØªØ®ØµÙŠØµ Ø§Ù„Ø®Ø·ÙˆØ· Ø­Ø³Ø¨ Ø§Ù„Ø§Ù‚ØªØ±Ø§Ø­
   ============================================ */

/* Tajawal Ù„Ù„Ø¹Ù†Ø§ÙˆÙŠÙ† ÙˆØ§Ù„Ù†ØµÙˆØµ Ø§Ù„Ø¨Ø§Ø±Ø²Ø© */
h1,
h2,
h3,
h4,
h5,
h6,
.card-header,
.table-header-theme,
.navbar-brand,
.page-title,
.btn,
.nav-link,
.badge,
.alert h4,
.modal-title {
    font-family: var(--font-family-headings);
}

/* IBM Plex Sans Arabic Ù„Ù„Ù†ØµÙˆØµ Ø§Ù„Ø¹Ø§Ø¯ÙŠØ© ÙˆØ§Ù„Ù…Ø­ØªÙˆÙ‰ */
body,
p,
div,
span,
.form-control,
.form-select,
.table td,
.table th,
.card-body,
.modal-body,
.preferences-body,
.sidebar {
    font-family: var(--font-family);
}

/* Fix Modal Z-Index Issue */
.modal {
    z-index: 10000 !important;
    /* Ensure modal is above navbar */
}

.modal-backdrop {
    z-index: 9999 !important;
    /* Ensure backdrop is just below modal */
}

/* ============================================
   ÊÍÓíäÇÊ äãæÐÌ ÇáØáÈ - ÊÎØíØ ãÖÛæØ
   ============================================ */

/* ÊÕÛíÑ ÍÌã ÇáÎØ ÇáÚÇã ááäãæÐÌ */
#order-form {
    font-size: 0.875rem;
}

/* ÊÕÛíÑ ÇáÚäÇæíä æÇáÊÓãíÇÊ */
#order-form .form-label {
    font-size: 0.8rem;
    margin-bottom: 0.25rem;
    font-weight: 500;
}

/* ÊÕÛíÑ ÇáÍÞæá */
#order-form .form-control,
#order-form .form-select {
    padding: 0.4rem 0.6rem;
    font-size: 0.85rem;
    height: auto;
    min-height: 2rem;
}

/* ÊÕÛíÑ textarea */
#order-form textarea.form-control {
    min-height: 50px;
    padding: 0.4rem 0.6rem;
}

/* ÊÕÛíÑ fieldset */
#order-form fieldset {
    padding: 0.75rem !important;
    margin-bottom: 0.75rem !important;
}

#order-form fieldset legend {
    font-size: 0.9rem !important;
    padding: 0 0.5rem !important;
    margin-bottom: 0.5rem;
}

/* ÊÕÛíÑ ÈäæÏ ÇáØáÈ */
#order-form .order-item {
    padding: 0.75rem !important;
    margin-bottom: 0.75rem !important;
}

/* ÊÕÛíÑ ÇáÃÒÑÇÑ */
#order-form .btn {
    padding: 0.45rem 1rem;
    font-size: 0.85rem;
}

#order-form .btn-lg {
    padding: 0.55rem 1.25rem;
    font-size: 0.9rem;
}

/* ÊÞáíá ÇáãÓÇÝÇÊ Èíä ÇáÕÝæÝ */
#order-form .row.g-3 {
    --bs-gutter-y: 0.75rem;
    --bs-gutter-x: 0.75rem;
}

/* ÊÕÛíÑ ÇáÃíÞæäÇÊ */
#order-form .fas,
#order-form .bi {
    font-size: 0.85rem;
}



/* ============================================
   ÊÎØíØ ÃÝÞí áäãæÐÌ ÇáØáÈ (ÇáÚäæÇä íãíä + ÇáÊÝÇÕíá íÓÇÑ)
   ============================================ */

/* ÊÍæíá fieldset Åáì grid ÃÝÞí */
#order-form fieldset {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 1rem;
    align-items: start;
    border: none !important;
    border-bottom: 1px solid var(--border-color) !important;
    border-radius: 0 !important;
    padding: 1rem 0 !important;
    margin-bottom: 0 !important;
}

/* ÇáÚäæÇä (legend) Úáì Çáíãíä */
#order-form fieldset legend {
    float: none !important;
    width: auto !important;
    padding: 0.5rem 0 !important;
    margin: 0 !important;
    font-weight: 600;
    color: var(--text-color);
    font-size: 0.95rem !important;
    grid-column: 1;
    text-align: right;
}

/* ÇáãÍÊæì Úáì ÇáíÓÇÑ */
#order-form fieldset>div:not(legend),
#order-form fieldset>.row {
    grid-column: 2;
}

/* ÅÒÇáÉ ÇáÍÏæÏ ãä ÂÎÑ fieldset */
#order-form fieldset:last-of-type {
    border-bottom: none !important;
}


/* ãÍÇÐÇÉ ÇáÚäÇæíä ãÚ ÇáÍÞæá ÚãæÏíÇð */
#order-form fieldset {
    align-items: center !important;
}

/* ÌÚá ÇáÚäæÇä íÊæÓØ ãÚ ÇáãÍÊæì */
#order-form fieldset legend {
    align-self: center !important;
    padding-top: 0 !important;
}


/* ÅÚÇÏÉ ÖÈØ ÇáãÍÇÐÇÉ - ÇáÚäæÇä íÍÇÐí ãÚ Ãæá ÍÞá */
#order-form fieldset {
    align-items: start !important;
}

/* ÑÝÚ ÇáÚäæÇä áíÍÇÐí ãÚ Ãæá label */
#order-form fieldset legend {
    padding-top: 0.5rem !important;
    line-height: 1.5;
}

/* ÊÞáíá ÇáãÓÇÝÉ ÝæÞ Ãæá label Ýí ßá fieldset */
#order-form fieldset .row>div:first-child .form-label:first-of-type {
    margin-top: 0;
}


/* ÇáÍá ÇáäåÇÆí: ãÍÇÐÇÉ ÇáÚäæÇä ãÚ Ãæá ÍÞá ÅÏÎÇá */
#order-form fieldset legend {
    padding-top: 1.8rem !important;
    /* ÇÑÊÝÇÚ label + margin */
    align-self: start !important;
}

/* ÅÐÇ ßÇä fieldset íÍÊæí Úáì row ãÈÇÔÑÉ */
#order-form fieldset>.row {
    margin-top: 0;
}

/* ÅÒÇáÉ margin ãä Ãæá ÚäÕÑ */
#order-form fieldset .row>div:first-child {
    margin-top: 0;
}


/* ÅÚÇÏÉ ÊÕãíã ÇáÊÎØíØ ÈÇÓÊÎÏÇã Flexbox ááãÍÇÐÇÉ ÇáÃÝÖá */
#order-form fieldset {
    display: flex !important;
    flex-direction: row !important;
    gap: 1.5rem !important;
    align-items: flex-start !important;
    grid-template-columns: unset !important;
}

/* ÇáÚäæÇä: ÚÑÖ ËÇÈÊ Úáì Çáíãíä */
#order-form fieldset legend {
    flex: 0 0 180px !important;
    width: 180px !important;
    padding-top: 0.6rem !important;
    /* ãÍÇÐÇÉ ãÚ Ãæá input */
    text-align: right !important;
}

/* ÇáãÍÊæì: ãÑä Úáì ÇáíÓÇÑ */
#order-form fieldset>div,
#order-form fieldset>.row {
    flex: 1 !important;
    grid-column: unset !important;
}
    
/* ============================================
   أنماط أزرار التحكم في الملفات الموحدة - احترافية ومتوافقة مع الثيمات
   ============================================ */
.btn-file-action {
    border-radius: 50px !important;
    padding: 5px 15px !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
    border: none !important;
    box-shadow: 0 2px 5px rgba(0,0,0,0.12) !important;
    text-decoration: none !important;
    cursor: pointer !important;
}

.btn-file-action:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 5px 12px rgba(0,0,0,0.2) !important;
    filter: brightness(1.1) !important;
    color: #fff !important;
}

.btn-file-view { 
    background: var(--primary-color) !important; 
    color: #fff !important; 
}

.btn-file-download { 
    background: var(--success-color, #28a745) !important; 
    color: #fff !important; 
}

.btn-file-delete { 
    background: var(--danger-color, #dc3545) !important; 
    color: #fff !important; 
}

.btn-file-action i {
    font-size: 0.9rem !important;
    color: #fff !important;
}

/* ضمان وضوح النصوص في جميع الثيمات للأزرار */
[data-theme="dark"] .btn-file-action,
[data-theme="white"] .btn-file-action {
    color: #fff !important;
}

/* ============================================
   أنماط كبسولات الإجراءات - الأزرار التفاعلية
   Action Capsules - Interactive Buttons
   ============================================ */
body.action-style-2 .task-actions .btn,
body.action-style-2 .task-actions .btn-group>.btn {
    border-radius: var(--border-radius-lg, 12px) !important;
    height: 40px !important;
    font-size: 12px;
    background: var(--card-bg, #fff) !important;
    color: var(--text-color, #000) !important; 
    border: 1px solid var(--border-color, #000) !important; 
    box-shadow: none !important;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.25s ease;
}

body.action-style-2 .task-actions .btn i { 
    font-size: 16px; 
    color: var(--c, var(--text-muted, #333)) !important; /* الأيقونة فقط ملونة */
    margin-inline-end: 6px;
}

/* تحديد ألوان متغير --c للأيقونات */
body.action-style-2 .task-actions .btn.btn-outline-primary,
body.action-style-2 .task-actions .btn.btn-details { --c: var(--primary-color, #0d6efd); }
body.action-style-2 .task-actions .btn.btn-warning,
body.action-style-2 .task-actions .btn.btn-payment { --c: var(--warning-color, #f7b731); }
body.action-style-2 .task-actions .btn.btn-info,
body.action-style-2 .task-actions .btn.btn-status { --c: var(--info-color, #17a2b8); }
body.action-style-2 .task-actions .btn.btn-success,
body.action-style-2 .task-actions .btn.btn-delivery { --c: var(--success-color, #198754); }
body.action-style-2 .task-actions .btn.btn-primary { --c: var(--primary-color, #0d6efd); }
body.action-style-2 .task-actions .btn.btn-danger { --c: var(--danger-color, #dc3545); }
body.action-style-2 .task-actions .btn.btn-outline-secondary { --c: var(--text-muted, #6c757d); }
body.action-style-2 .task-actions .btn.btn-whatsapp { --c: #25D366; }

/* واتساب (لون خاص) */
body.action-style-2 .task-actions .btn.btn-whatsapp { 
    color: var(--text-color, #000) !important; 
    border-color: var(--border-color, #000) !important; 
}
body.action-style-2 .task-actions .btn.btn-whatsapp i { color: #25D366 !important; }

/* أزرار معطلة */
body.action-style-2 .task-actions .btn.disabled,
body.action-style-2 .task-actions .btn:disabled { 
    --c: var(--text-muted, #6c757d); 
    background: var(--bg-color, #f8f9fa) !important; 
    color: var(--text-muted, #6c757d) !important; 
    border: 1px solid var(--border-color, #dee2e6) !important; 
}
body.action-style-2 .task-actions .btn.disabled i,
body.action-style-2 .task-actions .btn:disabled i { color: var(--text-muted, #6c757d) !important; }

/* التأثير عند الحوم (Hover) */
body.action-style-2 .task-actions .btn:hover { 
    background: var(--primary-color, #000) !important; 
    color: var(--on-primary, #fff) !important; 
    border-color: var(--primary-color, #000) !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 8px var(--shadow, rgba(0,0,0,0.15));
}
body.action-style-2 .task-actions .btn:hover i { color: var(--on-primary, #fff) !important; }

/* تنسيق الصف لشبكة 2×2 مرتبة */
body.action-style-2 .task-actions .actions-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
body.action-style-2 .task-actions .actions-row .action-cell {
    flex: 1 1 calc(50% - 3px);
    min-width: calc(50% - 3px);
    max-width: calc(50% - 3px);
}
body.action-style-2 .task-actions .actions-row .action-cell .btn {
    width: 100%;
}

/* إزالة الحواف المزدوجة لمنطقة dropdown */
body.action-style-2 .task-actions .btn-group .dropdown-toggle { border-radius: var(--border-radius-lg, 12px) !important; }

/* تحسين تراكب قائمة الحالة فوق النمط */
body.action-style-2 .task-actions .dropdown-menu { border-radius: var(--border-radius-lg, 12px); font-size: 13px; }
body.action-style-2 .task-actions .dropdown-item { padding: .4rem .75rem; }

/* ============================================
   تخصيص أيقونة Caret في عناصر select - كبسولات شفافة صغيرة
   ============================================ */
.form-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23999999' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m1 6 7 7 7-7'/%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right 0.5rem center !important;
    background-size: 12px 8px !important;
    padding-right: 2rem !important;
    position: relative;
}

.form-select::after {
    content: '';
    position: absolute;
    right: 0.3rem;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    background: rgba(255, 255, 255, 0.7);
    border-radius: 50%;
    backdrop-filter: blur(2px);
    border: 1px solid rgba(0, 0, 0, 0.1);
    pointer-events: none;
    z-index: 1;
}

.form-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23666666' stroke-linecap='round' stroke-linejoin='round' stroke-width='2.5' d='m4 6 4 4 4-4'/%3e%3c/svg%3e") !important;
    background-size: 10px 6px !important;
    background-position: right 0.65rem center !important;
}

.form-select-sm {
    background-size: 9px 5px !important;
    background-position: right 0.5rem center !important;
    padding-right: 1.8rem !important;
}

.form-select-sm::after {
    width: 16px;
    height: 16px;
    right: 0.25rem;
}

.form-select:hover::after {
    background: rgba(255, 255, 255, 0.9);
    border-color: rgba(0, 0, 0, 0.2);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.form-select:focus::after {
    background: rgba(255, 255, 255, 1);
    border-color: var(--primary-color, #0d6efd);
    box-shadow: 0 0 0 2px rgba(13, 110, 253, 0.2);
}

/* بنر الترحيب الموحد */
.welcome-onboarding-banner {
    background: linear-gradient(135deg, rgba(86, 0, 164, 0.15) 0%, rgba(110, 73, 177, 0.15) 100%) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-radius: 16px;
    border: 1px solid var(--border-color, rgba(255, 255, 255, 0.12)) !important;
}

/* أنماط بطاقات المهام الموحدة */
.priority-indicator-card {
    border-width: 4px !important;
    border-style: solid !important;
    border-top: 0 !important;
    border-right: 0 !important;
    border-bottom: 0 !important;
}

.task-card-meta {
    font-size: 0.8rem;
    line-height: 1.5;
}

.text-theme-primary {
    color: var(--primary-color) !important;
}

.task-card-duration {
    font-size: 0.7rem;
}

.order-id-badge {
    font-size: 0.7rem;
    vertical-align: middle;
}

/* زر إضافة طلب وبحث مخصص */
.add-order-btn-custom {
    background: var(--card-bg, #ffffff) !important;
    color: var(--primary-color, #5600a4) !important;
    border-color: var(--primary-color, #5600a4) !important;
    transition: all 0.2s ease !important;
}

.add-order-btn-custom:hover {
    background: var(--primary-color, #5600a4) !important;
    color: var(--on-primary, #ffffff) !important;
}

.add-order-btn-custom i {
    color: inherit !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: inline-block !important;
    transition: transform 0.2s;
}

.btn-reset-filters {
    min-width: 115px !important;
    background: var(--danger-color, #dc3545) !important;
    border-color: var(--danger-color, #dc3545) !important;
    color: #ffffff !important;
    opacity: 1 !important;
}
