/*
Template Name: Velzon - Admin & Dashboard Template
Author: Themesbrand
Website: https://themesbrand.com/
Contact: support@themesbrand.com
File: Custom Css File
*/

/* Sidebar Text Color Override */
[data-layout="vertical"] .navbar-menu .navbar-nav .nav-link,
[data-layout="vertical"] .navbar-menu .navbar-nav .menu-title,
[data-layout="vertical"] .navbar-menu .navbar-nav .nav-link i,
[data-layout="vertical"] .navbar-menu .navbar-nav .nav-link span,
[data-layout="vertical"] .navbar-menu .navbar-nav .menu-title span,
[data-layout="semibox"] .navbar-menu .navbar-nav .nav-link,
[data-layout="semibox"] .navbar-menu .navbar-nav .menu-title,
[data-layout="semibox"] .navbar-menu .navbar-nav .nav-link i,
[data-layout="semibox"] .navbar-menu .navbar-nav .nav-link span,
[data-layout="semibox"] .navbar-menu .navbar-nav .menu-title span,
[data-layout="twocolumn"] .navbar-menu .navbar-nav .nav-link,
[data-layout="twocolumn"] .navbar-menu .navbar-nav .menu-title,
[data-layout="twocolumn"] .navbar-menu .navbar-nav .nav-link i,
[data-layout="twocolumn"] .navbar-menu .navbar-nav .nav-link span,
[data-layout="twocolumn"] .navbar-menu .navbar-nav .menu-title span {
    color: #ffffff !important;
}

[data-layout="vertical"] .navbar-menu .navbar-nav .nav-link:hover,
[data-layout="vertical"] .navbar-menu .navbar-nav .nav-link.active,
[data-layout="vertical"] .navbar-menu .navbar-nav .nav-sm .nav-link:hover,
[data-layout="vertical"] .navbar-menu .navbar-nav .nav-sm .nav-link.active,
[data-layout="semibox"] .navbar-menu .navbar-nav .nav-link:hover,
[data-layout="semibox"] .navbar-menu .navbar-nav .nav-link.active,
[data-layout="semibox"] .navbar-menu .navbar-nav .nav-sm .nav-link:hover,
[data-layout="semibox"] .navbar-menu .navbar-nav .nav-sm .nav-link.active,
[data-layout="twocolumn"] .navbar-menu .navbar-nav .nav-link:hover,
[data-layout="twocolumn"] .navbar-menu .navbar-nav .nav-link.active,
[data-layout="twocolumn"] .navbar-menu .navbar-nav .nav-sm .nav-link:hover,
[data-layout="twocolumn"] .navbar-menu .navbar-nav .nav-sm .nav-link.active {
    color: #ffffff !important;
}

[data-layout="vertical"] .navbar-menu .navbar-nav .nav-sm .nav-link,
[data-layout="semibox"] .navbar-menu .navbar-nav .nav-sm .nav-link,
[data-layout="twocolumn"] .navbar-menu .navbar-nav .nav-sm .nav-link {
    color: #ffffff !important;
}

/* Remove Login Background Image */
.auth-one-bg {
    background-image: none !important;
}

/* Form Validation Shake Animation */
@keyframes shake-animation {

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

    10%,
    30%,
    50%,
    70%,
    90% {
        transform: translateX(-4px);
    }

    20%,
    40%,
    60%,
    80% {
        transform: translateX(4px);
    }
}

.shake-animation {
    animation: shake-animation 0.82s cubic-bezier(.36, .07, .19, .97) both;
}

/* Improve invalid field visibility */
.form-control.is-invalid,
.form-select.is-invalid {
    border-color: #dc3545 !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
}

/* Entry card error styling */
.time-entry-row.entry-has-error {
    border-color: #dc3545 !important;
    border-width: 2px !important;
    box-shadow: 0 0 0 0.15rem rgba(220, 53, 69, 0.2) !important;
}

.time-entry-row.entry-has-error .card-header {
    background-color: rgba(220, 53, 69, 0.1) !important;
}

/* Validation error list in modal */
.validation-error-list>div:hover {
    background-color: rgba(220, 53, 69, 0.1);
}

/* Activity tags container error state */
.activity-tags-container.is-invalid {
    border-color: #dc3545 !important;
    background-color: rgba(220, 53, 69, 0.05) !important;
}

/* Valid field styling (success state) */
.form-control.is-valid,
.form-select.is-valid {
    border-color: #198754 !important;
    box-shadow: 0 0 0 0.15rem rgba(25, 135, 84, 0.15) !important;
}

/* Progress container styling */
#form-progress-container {
    transition: all 0.3s ease;
}

#form-progress-container .progress-bar {
    transition: width 0.4s ease-in-out, background-color 0.3s ease;
}

/* Validation feedback animation */
.validation-feedback {
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-5px);
    }

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

/* Pulse animation for scroll target entry */
.time-entry-row.scroll-target {
    animation: pulse-border 1.5s ease-in-out;
}

@keyframes pulse-border {

    0%,
    100% {
        box-shadow: 0 0 0 0.15rem rgba(220, 53, 69, 0.2);
    }

    50% {
        box-shadow: 0 0 0 0.4rem rgba(220, 53, 69, 0.4);
    }
}

/* Validation error list item clickable style */
.validation-error-item {
    transition: background-color 0.2s ease;
    border-radius: 4px;
    padding: 4px 8px;
    margin: 2px 0;
}

.validation-error-item:hover {
    background-color: rgba(220, 53, 69, 0.1);
    text-decoration: underline;
}

/* Entry error highlight animation */
.time-entry-row.entry-has-error {
    animation: entry-error-flash 0.5s ease-in-out;
}

@keyframes entry-error-flash {

    0%,
    100% {
        background-color: inherit;
    }

    50% {
        background-color: rgba(220, 53, 69, 0.1);
    }
}

/* ===== Sidebar Independent Scrolling ===== */
/* Sidebar'ın sayfa içeriğinden bağımsız kaydırılabilmesi - Sadece dikey layoutlar için */
[data-layout="vertical"] .app-menu.navbar-menu,
[data-layout="semibox"] .app-menu.navbar-menu {
    display: flex;
    flex-direction: column;
    height: 100vh;
    overflow: hidden;
}

[data-layout="vertical"] .app-menu.navbar-menu .navbar-brand-box,
[data-layout="semibox"] .app-menu.navbar-menu .navbar-brand-box {
    flex-shrink: 0;
}

[data-layout="vertical"] .app-menu.navbar-menu #scrollbar,
[data-layout="semibox"] .app-menu.navbar-menu #scrollbar {
    flex: 1;
    /* overflow-y: auto; */
    /* overflow-x: hidden; */
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.3) transparent;
}

/* WebKit scrollbar styling for sidebar */
.app-menu.navbar-menu #scrollbar::-webkit-scrollbar {
    width: 6px;
}

.app-menu.navbar-menu #scrollbar::-webkit-scrollbar-track {
    background: transparent;
}

.app-menu.navbar-menu #scrollbar::-webkit-scrollbar-thumb {
    background-color: rgba(255, 255, 255, 0.3);
    border-radius: 3px;
}

.app-menu.navbar-menu #scrollbar::-webkit-scrollbar-thumb:hover {
    background-color: rgba(255, 255, 255, 0.5);
}

/* SimpleBar override for sidebar - ensure it takes full height */
[data-layout="vertical"] .app-menu.navbar-menu #scrollbar .simplebar-content-wrapper,
[data-layout="semibox"] .app-menu.navbar-menu #scrollbar .simplebar-content-wrapper {
    height: 100% !important;
    /* overflow-y: auto !important; */
}

[data-layout="vertical"] .app-menu.navbar-menu #scrollbar .simplebar-mask,
[data-layout="semibox"] .app-menu.navbar-menu #scrollbar .simplebar-mask,
[data-layout="vertical"] .app-menu.navbar-menu #scrollbar .simplebar-offset,
[data-layout="semibox"] .app-menu.navbar-menu #scrollbar .simplebar-offset {
    height: 100% !important;
}

/* Ensure sidebar content wrapper respects the scroll area */
[data-layout="vertical"] .app-menu.navbar-menu #scrollbar>.container-fluid,
[data-layout="semibox"] .app-menu.navbar-menu #scrollbar>.container-fluid {
    min-height: 100%;
}

/* ===== Table Horizontal Scrollbar - Always Visible ===== */
/* Yatay scroll bar'ın üstte de görünmesi için */
.table-responsive {
    overflow-x: auto;
    overflow-y: visible;
    position: relative;
}

/* Scrollbar'ı her zaman göster */
.table-responsive::-webkit-scrollbar {
    height: 10px;
    background-color: #f1f1f1;
}

.table-responsive::-webkit-scrollbar-thumb {
    background-color: #c1c1c1;
    border-radius: 5px;
}

.table-responsive::-webkit-scrollbar-thumb:hover {
    background-color: #a8a8a8;
}

/* Firefox için scrollbar */
.table-responsive {
    scrollbar-width: thin;
    scrollbar-color: #c1c1c1 #f1f1f1;
}

/* Sticky scrollbar wrapper - tablo üstünde sürekli görünür scrollbar */
.table-scroll-top {
    overflow-x: auto;
    overflow-y: hidden;
    height: 12px;
    margin-bottom: -1px;
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    border-bottom: none;
    border-radius: 4px 4px 0 0;
}

.table-scroll-top::-webkit-scrollbar {
    height: 10px;
    background-color: #f1f1f1;
}

.table-scroll-top::-webkit-scrollbar-thumb {
    background-color: #c1c1c1;
    border-radius: 5px;
}

.table-scroll-top::-webkit-scrollbar-thumb:hover {
    background-color: #a8a8a8;
}

.table-scroll-top-content {
    height: 1px;
}

/* DataTables scrollbar visibility improvement */
.dataTables_wrapper .dataTables_scroll .dataTables_scrollBody {
    overflow-x: auto !important;
}

/* Card içindeki tablolar için max-height ve scroll */
.card-body .table-responsive {
    max-height: 70vh;
    overflow-y: auto;
}

/* Horizontal Mode Fixes */
[data-layout="horizontal"] .navbar-menu .navbar-nav .menu-title {
    display: none !important;
}

[data-layout="horizontal"] .navbar-menu {
    height: auto !important;
    min-height: auto !important;
}