/*
 * Premium Polish Layer
 * ---------------------
 * لایهٔ افزایشی برای ظاهر پریمیوم‌تر، بدون بازنویسی فایل‌های موجود.
 * فقط جزئیات بصری (سایه، گردی، فاصله، ترنزیشن، فوکوس) را ارتقا می‌دهد و
 * از متغیرها و کلاس‌های موجود Bootstrap/تم استفاده می‌کند. آخر از همه لود می‌شود.
 */

:root {
    /* شعاع‌های یکدست و نرم */
    --pp-radius-sm: 0.5rem;
    --pp-radius: 0.75rem;
    --pp-radius-lg: 1rem;
    --pp-radius-pill: 999px;

    /* سایه‌های لایه‌ای و ظریف */
    --pp-shadow-xs: 0 1px 2px rgba(15, 23, 42, 0.04), 0 1px 3px rgba(15, 23, 42, 0.06);
    --pp-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.04), 0 2px 6px rgba(15, 23, 42, 0.06);
    --pp-shadow-md: 0 4px 12px rgba(15, 23, 42, 0.08), 0 2px 4px rgba(15, 23, 42, 0.04);
    --pp-shadow-lg: 0 12px 32px rgba(15, 23, 42, 0.12), 0 4px 10px rgba(15, 23, 42, 0.06);

    /* هالهٔ فوکوس بر پایهٔ رنگ اصلی */
    --pp-focus-ring: 0 0 0 0.2rem rgba(var(--color-student-rgb, 59, 130, 246), 0.22);

    --pp-transition: 0.18s cubic-bezier(0.4, 0, 0.2, 1);
    --pp-border: rgba(15, 23, 42, 0.08);
}

[data-bs-theme="dark"] {
    --pp-shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.30);
    --pp-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.35);
    --pp-shadow-md: 0 4px 14px rgba(0, 0, 0, 0.40);
    --pp-shadow-lg: 0 14px 36px rgba(0, 0, 0, 0.50);
    --pp-border: rgba(255, 255, 255, 0.10);
}

/* ---------- پس‌زمینهٔ نرم‌تر ---------- */
body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

/* ---------- کارت‌ها ---------- */
.card {
    border: 1px solid var(--pp-border);
    border-radius: var(--pp-radius);
    box-shadow: var(--pp-shadow-sm);
    transition: box-shadow var(--pp-transition), transform var(--pp-transition);
}
.card:hover {
    box-shadow: var(--pp-shadow-md);
}
/* لیفت ملایم فقط برای کارت‌های تعاملی/کلیک‌پذیر */
a > .card:hover,
.card.card-hover:hover,
.card[role="button"]:hover {
    transform: translateY(-2px);
}
.card > .card-header:first-child {
    border-top-left-radius: var(--pp-radius);
    border-top-right-radius: var(--pp-radius);
}
.card > .card-footer:last-child {
    border-bottom-left-radius: var(--pp-radius);
    border-bottom-right-radius: var(--pp-radius);
}
.card-header {
    border-bottom: 1px solid var(--pp-border);
    background-clip: padding-box;
}

/* ---------- دکمه‌ها ---------- */
.btn {
    border-radius: var(--pp-radius-sm);
    font-weight: 500;
    transition: transform var(--pp-transition), box-shadow var(--pp-transition),
        background-color var(--pp-transition), border-color var(--pp-transition), color var(--pp-transition);
}
.btn:hover {
    transform: translateY(-1px);
}
.btn:active {
    transform: translateY(0);
}
.btn-primary,
.btn-success,
.btn-danger,
.btn-warning,
.btn-info,
.btn-secondary {
    box-shadow: 0 2px 5px rgba(15, 23, 42, 0.12);
}
.btn-primary:hover,
.btn-success:hover,
.btn-danger:hover,
.btn-warning:hover,
.btn-info:hover,
.btn-secondary:hover {
    box-shadow: 0 5px 14px rgba(15, 23, 42, 0.18);
}
.btn:focus-visible,
.btn.focus {
    box-shadow: var(--pp-focus-ring) !important;
}
.btn-sm {
    border-radius: calc(var(--pp-radius-sm) - 0.15rem);
}
.btn-lg {
    border-radius: var(--pp-radius);
}

/* ---------- فرم‌ها ---------- */
.form-control,
.form-select,
.input-group-text {
    border-radius: var(--pp-radius-sm);
    transition: border-color var(--pp-transition), box-shadow var(--pp-transition);
}
.form-control:focus,
.form-select:focus,
.form-check-input:focus {
    border-color: var(--bs-primary, #3b82f6);
    box-shadow: var(--pp-focus-ring);
}
.form-check-input:checked {
    background-color: var(--bs-primary, #3b82f6);
    border-color: var(--bs-primary, #3b82f6);
}
.input-group > .form-control,
.input-group > .form-select {
    border-radius: var(--pp-radius-sm);
}

/* Select2 برای هماهنگی با فرم‌ها */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
    border-radius: var(--pp-radius-sm) !important;
    border-color: var(--bs-border-color, #dee2e6) !important;
    transition: border-color var(--pp-transition), box-shadow var(--pp-transition);
}
.select2-container--default.select2-container--focus .select2-selection {
    border-color: var(--bs-primary, #3b82f6) !important;
    box-shadow: var(--pp-focus-ring);
}
.select2-dropdown {
    border-radius: var(--pp-radius-sm) !important;
    border-color: var(--pp-border) !important;
    box-shadow: var(--pp-shadow-md);
}

/* ---------- جدول‌ها ---------- */
.card > .table:last-child,
.table-responsive {
    border-radius: var(--pp-radius);
}
.table > thead th {
    font-weight: 600;
    letter-spacing: 0.01em;
    border-bottom-width: 1px;
}
.table-hover > tbody > tr {
    transition: background-color var(--pp-transition);
}

/* ---------- بَج‌ها ---------- */
.badge {
    font-weight: 600;
    letter-spacing: 0.01em;
    border-radius: var(--pp-radius-pill);
    padding: 0.4em 0.7em;
}

/* ---------- دراپ‌داون / مودال / آف‌کانواس ---------- */
.dropdown-menu {
    border-radius: var(--pp-radius);
    border: 1px solid var(--pp-border);
    box-shadow: var(--pp-shadow-md);
    padding: 0.4rem;
}
.dropdown-item {
    border-radius: var(--pp-radius-sm);
    transition: background-color var(--pp-transition), color var(--pp-transition);
}
.modal-content,
.offcanvas {
    border-radius: var(--pp-radius-lg);
    border: 1px solid var(--pp-border);
    box-shadow: var(--pp-shadow-lg);
}
.offcanvas {
    border-radius: 0;
}
.modal-header,
.modal-footer {
    border-color: var(--pp-border);
}

/* ---------- تب‌ها / پیل‌ها ---------- */
.nav-pills .nav-link {
    border-radius: var(--pp-radius-sm);
    transition: background-color var(--pp-transition), color var(--pp-transition);
}
.nav-tabs .nav-link {
    transition: color var(--pp-transition), border-color var(--pp-transition);
}

/* ---------- آلرت‌ها ---------- */
.alert {
    border-radius: var(--pp-radius);
    border: 1px solid var(--pp-border);
}

/* ---------- لیست‌گروه ---------- */
.list-group {
    border-radius: var(--pp-radius);
}
.list-group-item {
    transition: background-color var(--pp-transition);
}

/* ---------- اسکرول‌بار سفارشی ---------- */
* {
    scrollbar-width: thin;
    scrollbar-color: rgba(var(--color-student-rgb, 59, 130, 246), 0.35) transparent;
}
*::-webkit-scrollbar {
    width: 9px;
    height: 9px;
}
*::-webkit-scrollbar-track {
    background: transparent;
}
*::-webkit-scrollbar-thumb {
    background: rgba(var(--color-student-rgb, 59, 130, 246), 0.3);
    border-radius: var(--pp-radius-pill);
    border: 2px solid transparent;
    background-clip: content-box;
}
*::-webkit-scrollbar-thumb:hover {
    background: rgba(var(--color-student-rgb, 59, 130, 246), 0.55);
    background-clip: content-box;
}

/* ---------- آیکون‌ها: هم‌ترازی عمودی بهتر با متن ---------- */
.btn .ti,
.nav-link .ti,
.dropdown-item .ti,
.badge .ti {
    vertical-align: -0.125em;
}

/* ---------- صفحه‌بندی (Pagination) ---------- */
.pagination {
    gap: 0.25rem;
}
.pagination .page-link {
    border-radius: var(--pp-radius-sm);
    border: 1px solid var(--pp-border);
    min-width: 2.25rem;
    text-align: center;
    transition: background-color var(--pp-transition), color var(--pp-transition),
        border-color var(--pp-transition), box-shadow var(--pp-transition);
}
.pagination .page-link:hover {
    background-color: rgba(var(--color-student-rgb, 59, 130, 246), 0.08);
    border-color: rgba(var(--color-student-rgb, 59, 130, 246), 0.35);
}
.pagination .page-item.active .page-link {
    box-shadow: 0 2px 6px rgba(var(--color-student-rgb, 59, 130, 246), 0.35);
}
.pagination .page-link:focus {
    box-shadow: var(--pp-focus-ring);
}

/* ---------- بردکرامب ---------- */
.breadcrumb {
    background: transparent;
    padding: 0;
}
.breadcrumb-item + .breadcrumb-item::before {
    opacity: 0.5;
}

/* ---------- نوار پیشرفت ---------- */
.progress {
    border-radius: var(--pp-radius-pill);
    background-color: rgba(var(--color-student-rgb, 59, 130, 246), 0.10);
    overflow: hidden;
}
.progress-bar {
    border-radius: var(--pp-radius-pill);
}

/* ---------- سوییچ‌ها ---------- */
.form-switch .form-check-input {
    cursor: pointer;
    transition: background-color var(--pp-transition), border-color var(--pp-transition),
        background-position 0.15s ease-in-out;
}

/* ---------- تولتیپ / پاپ‌اوور ---------- */
.tooltip-inner {
    border-radius: var(--pp-radius-sm);
    box-shadow: var(--pp-shadow-md);
    padding: 0.4rem 0.65rem;
}
.popover {
    border-radius: var(--pp-radius);
    border: 1px solid var(--pp-border);
    box-shadow: var(--pp-shadow-lg);
}

/* ---------- تیترها: وزن و فاصله‌گذاری یکدست‌تر ---------- */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    letter-spacing: -0.01em;
}

/* ---------- کارت‌های هدر صفحه (الگوی پرتکرار bg-*-subtle) ---------- */
.card.bg-info-subtle,
.card.bg-primary-subtle,
.card.bg-light-subtle {
    border: 1px solid var(--pp-border);
}

/* ---------- آواتارها / تصاویر گرد ---------- */
.rounded-circle {
    box-shadow: var(--pp-shadow-xs);
}

/* ---------- اعمال فونت IRANYekanX در همه‌جا ----------
 * قانون سراسری بدون !important: آیکون‌فونت‌ها (Tabler با !important و
 * FontAwesome با specificity کلاس) دست‌نخورده می‌مانند و فقط متن عادی فونت می‌گیرد.
 */
* {
    font-family: IRANYekanX, sans-serif;
}

/* ویجت‌های third-party که فونت اختصاصی خودشان را دارند → اجبار با !important
 * (این کانتینرها متنی‌اند و از آیکون‌فونت استفاده نمی‌کنند، پس امن است) */
.select2-container,
.select2-container *,
.select2-dropdown,
.select2-results__option,
.select2-selection__rendered,
.select2-search__field,
.swal2-popup,
.swal2-popup *,
#toast-container,
#toast-container *,
.tooltip,
.popover,
.dropdown-menu,
.modal,
.offcanvas,
.daterangepicker,
.flatpickr-calendar,
.jdp-container,
.jdp-container *,
.bootstrap-datetimepicker-widget,
.datepicker,
.dataTables_wrapper,
.note-editor,
.toast,
.tox .tox-button,
.tox .tox-tbtn {
    font-family: IRANYekanX, sans-serif !important;
}

/* اطمینان مجدد: عناصر آیکون هرگز فونت متن نگیرند (محافظ در برابر هر تداخل) */
.ti,
.ti::before,
[class^="ti-"]::before,
[class*=" ti-"]::before {
    font-family: "tabler-icons" !important;
}

/* ====================================================================
 * پولیش chrome داشبورد (تاپ‌بار / سایدبار) — هماهنگ با تم Spike
 * فقط ظرافت بصری؛ عرض/چیدمان/رفتار mini-sidebar دست‌نخورده می‌ماند.
 * ==================================================================== */

/* ---------- تاپ‌بار: شیشه‌ای (glassmorphism) ---------- */
.topbar {
    background: rgba(var(--bs-body-bg-rgb, 255, 255, 255), 0.82) !important;
    backdrop-filter: saturate(180%) blur(10px);
    -webkit-backdrop-filter: saturate(180%) blur(10px);
    box-shadow: 0 4px 18px rgba(15, 23, 42, 0.07) !important;
    border: 1px solid var(--pp-border);
}
[data-bs-theme="dark"] .topbar {
    box-shadow: 0 4px 18px rgba(0, 0, 0, 0.45) !important;
}
.topbar .nav-icon-hover {
    transition: color var(--pp-transition);
}

/* ---------- سایدبار: لینک‌ها ---------- */
.left-sidebar .sidebar-nav .sidebar-item > .sidebar-link {
    border-radius: var(--pp-radius-sm);
    transition: background-color var(--pp-transition), color var(--pp-transition),
        box-shadow var(--pp-transition);
}
.left-sidebar .sidebar-nav .sidebar-item > .sidebar-link:hover {
    background-color: rgba(var(--color-student-rgb, 59, 130, 246), 0.08);
}
/* لینک فعال: فقط افزودن گردی و سایهٔ ظریف (رنگ/پس‌زمینهٔ تم حفظ می‌شود) */
.left-sidebar .sidebar-nav .sidebar-item > .sidebar-link.active {
    border-radius: var(--pp-radius-sm);
    box-shadow: 0 4px 10px rgba(var(--color-student-rgb, 59, 130, 246), 0.28);
}

/* ---------- سرفصل بخش‌های منو ---------- */
.nav-small-cap {
    letter-spacing: 0.04em;
    font-weight: 600;
    opacity: 0.75;
}

/* ---------- مودال: بلور ظریف پس‌زمینه ---------- */
.modal-backdrop.show {
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
}

/* ---------- SweetAlert2 ---------- */
.swal2-popup {
    border-radius: var(--pp-radius-lg) !important;
    box-shadow: var(--pp-shadow-lg) !important;
    font-family: IRANYekanX, sans-serif !important;
}
.swal2-styled {
    border-radius: var(--pp-radius-sm) !important;
    font-weight: 500 !important;
    box-shadow: none !important;
    transition: transform var(--pp-transition), box-shadow var(--pp-transition) !important;
}
.swal2-styled:hover {
    transform: translateY(-1px);
}
.swal2-styled:focus {
    box-shadow: var(--pp-focus-ring) !important;
}
.swal2-title {
    font-weight: 700 !important;
}

/* ---------- Toastr ---------- */
#toast-container > div {
    border-radius: var(--pp-radius) !important;
    box-shadow: var(--pp-shadow-lg) !important;
    opacity: 1 !important;
    font-family: IRANYekanX, sans-serif !important;
}

/* ====================================================================
 * UX و تعامل — حس «پرداخت‌شده» و دسترسی‌پذیری
 * ==================================================================== */

/* اسکرول نرم + جا برای تاپ‌بار چسبان هنگام پرش به anchor */
html { scroll-behavior: smooth; }
:target { scroll-margin-top: 90px; }

/* حلقهٔ فوکوس برند برای ناوبری با کیبورد (دسترسی‌پذیری) */
a:focus-visible,
button:focus-visible,
.btn:focus-visible,
.form-control:focus-visible,
.form-select:focus-visible,
.form-check-input:focus-visible,
.page-link:focus-visible,
.dropdown-item:focus-visible,
.nav-link:focus-visible,
[tabindex]:focus-visible {
    outline: none;
    box-shadow: var(--pp-focus-ring);
    border-radius: var(--pp-radius-sm);
}

/* بازخورد لمسی هنگام فشار دکمه */
.btn:active {
    transform: scale(0.97);
}

/* لینک‌ها: ترنزیشن رنگ نرم */
a {
    transition: color var(--pp-transition);
}

/* نشانگر دست برای عناصر تعاملی */
.nav-link,
[data-bs-toggle],
[role="button"],
.page-link,
summary,
label[for] {
    cursor: pointer;
}

/* عناصر غیرفعال: نشانگر مناسب */
.btn:disabled,
.btn.disabled,
.form-control:disabled,
.form-select:disabled,
fieldset:disabled {
    cursor: not-allowed;
}

/* placeholder ملایم و یکدست */
::placeholder {
    color: rgba(var(--bs-emphasis-color-rgb, 30, 41, 59), 0.45) !important;
    opacity: 1;
}

/* رنگ انتخاب متن با ته‌رنگ برند */
::selection {
    background: rgba(var(--color-student-rgb, 59, 130, 246), 0.22);
}

/* انیمیشن ورود نرم محتوای صفحه */
@keyframes pp-fade-in {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}
.body-wrapper > .container-fluid,
.body-wrapper > .container-xl,
.body-wrapper > .container-xxl {
    animation: pp-fade-in 0.4s ease both;
}

/* حالت‌های اعتبارسنجی فرم: واضح‌تر */
.form-control.is-invalid:focus,
.was-validated .form-control:invalid:focus {
    box-shadow: 0 0 0 0.2rem rgba(var(--bs-danger-rgb, 239, 68, 68), 0.22);
}
.form-control.is-valid:focus,
.was-validated .form-control:valid:focus {
    box-shadow: 0 0 0 0.2rem rgba(var(--bs-success-rgb, 16, 185, 129), 0.22);
}

/* احترام به کاهش حرکت */
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    .card,
    .btn,
    .card:hover,
    .btn:hover,
    .btn:active,
    a > .card:hover,
    .card.card-hover:hover,
    .pagination .page-link,
    .left-sidebar .sidebar-nav .sidebar-item > .sidebar-link,
    .body-wrapper > .container-fluid,
    .body-wrapper > .container-xl,
    .body-wrapper > .container-xxl {
        transition: none !important;
        transform: none !important;
        animation: none !important;
    }
}
