/*
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;
}

/* Keep duration values readable in narrow entry columns. Bootstrap's
   validation icons overlap the selected hour/minute text on these selects. */
.duration-picker .form-select.is-valid,
.duration-picker .form-select.is-invalid {
    --vz-form-select-bg-icon: none;
    background-image: var(--vz-form-select-bg-img) !important;
    background-position: right 0.75rem center !important;
    background-size: 16px 12px !important;
    padding-right: 2.25rem !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;
}

/* ===== Dashboard KPI Sparkline Container (minimal override) ===== */
.kpi-sparkline-wrap {
    margin: 8px -12px -12px -12px;
}

/* Back-to-top button */
#back-to-top {
    right: 20px;
    bottom: 40px;
}

/* Regulatory maintenance page */
.reg-maintenance-hero { max-width: 760px; margin-inline: auto; }
.reg-maintenance-hero-text { color: #fff; display: inline-block; padding: 0.5rem 0.75rem; border-radius: 0.5rem; background-color: rgba(0,0,0,0.35); text-shadow: 0 1px 2px rgba(0,0,0,0.45); }
.reg-maintenance-card { border-radius: 0.75rem; }
.reg-maintenance-img { max-width: 320px; }
.reg-maintenance-support { background-color: var(--vz-light); }
[data-bs-theme="dark"] .reg-maintenance-support { background-color: rgba(var(--vz-light-rgb),0.06); border-color: rgba(var(--vz-light-rgb),0.2); }
@media (max-width: 575.98px) { .reg-maintenance-hero .display-6 { font-size: 1.75rem; } }
.patient-count-grid .form-label {
  align-items: flex-end;
  display: flex;
  line-height: 1.25;
  min-height: 2.5rem;
}

.study-info-grid .form-label {
  align-items: flex-end;
  display: flex;
  min-height: 1.25rem;
}

.study-info-grid small {
  min-height: 2.5rem;
}

.patient-count-grid small {
  min-height: 1.25rem;
}

@media (max-width: 575.98px) {
  .patient-count-grid .form-label,
  .patient-count-grid small,
  .study-info-grid .form-label,
  .study-info-grid small {
    min-height: auto;
  }
}

/* Expense list lifecycle reference bar */
.expense-lifecycle-flow-section {
  padding: 1.1rem;
  background: var(--vz-card-bg, #fff);
  border: 1px solid var(--vz-border-color, #e6e9ed);
  border-radius: 6px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03);
}

.expense-lifecycle-flow-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.1rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid var(--vz-border-color-translucent, #eef0f3);
}

.expense-lifecycle-kicker {
  display: block;
  margin-bottom: 0.18rem;
  color: var(--vz-muted, #6c757d);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

.expense-lifecycle-title {
  margin: 0;
  color: var(--vz-heading-color, #212529);
  font-size: 0.95rem;
  font-weight: 700;
  text-transform: uppercase;
}

.expense-lifecycle-summary {
  border: 1px solid var(--vz-border-color, #e6e9ed);
  font-weight: 700;
}

.expense-lifecycle-flow-track {
  display: grid;
  grid-template-columns: repeat(var(--step-count), minmax(118px, 1fr));
  gap: 0.65rem;
  margin-top: 0.35rem;
}

.expense-lifecycle-flow-step {
  position: relative;
  display: flex;
  align-items: center;
  flex-direction: column;
  min-width: 0;
  padding: 0 0.35rem;
  color: var(--vz-body-color, #212529);
  border-radius: 4px;
  text-align: center;
  text-decoration: none;
  transition: background-color 0.16s ease, border-color 0.16s ease;
}

.expense-lifecycle-flow-step:not(:last-child)::after {
  position: absolute;
  top: 1.2rem;
  left: calc(50% + 1.25rem);
  right: calc(-50% + 1.25rem);
  height: 1px;
  content: "";
  background: var(--vz-border-color, #dfe3e8);
}

.expense-lifecycle-flow-step:hover {
  color: var(--vz-body-color, #212529);
  background: var(--vz-light, #fafbfc);
}

.expense-lifecycle-marker {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  margin-bottom: 0.55rem;
  color: #495057;
  background: var(--vz-card-bg, #fff);
  border: 1px solid var(--vz-border-color, #dfe3e8);
  border-radius: 50%;
  font-size: 1rem;
  transition: border-color 0.16s ease, color 0.16s ease, background-color 0.16s ease;
}

.expense-lifecycle-flow-step:hover .expense-lifecycle-marker {
  color: #212529;
  background: var(--vz-light, #f8f9fa);
  border-color: #adb5bd;
}

.expense-lifecycle-flow-step.is-active .expense-lifecycle-marker {
  background: var(--vz-primary, #405189);
  border-color: var(--vz-primary, #405189);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(64, 81, 137, 0.11);
}

.workflow-step-warning .expense-lifecycle-marker,
.workflow-step-warning .expense-lifecycle-exception-icon { border-color: #f7b84b; color: #a66a00; }
.workflow-step-info .expense-lifecycle-marker,
.workflow-step-info .expense-lifecycle-exception-icon { border-color: #299cdb; color: #176d9d; }
.workflow-step-danger .expense-lifecycle-marker,
.workflow-step-danger .expense-lifecycle-exception-icon { border-color: #f06548; color: #b63f2b; }
.workflow-step-primary .expense-lifecycle-marker,
.workflow-step-primary .expense-lifecycle-exception-icon { border-color: #405189; color: #405189; }
.workflow-step-success .expense-lifecycle-marker,
.workflow-step-success .expense-lifecycle-exception-icon { border-color: #0ab39c; color: #087f70; }
.workflow-step-dark .expense-lifecycle-marker,
.workflow-step-dark .expense-lifecycle-exception-icon { border-color: #212529; color: #212529; }
.workflow-step-neutral .expense-lifecycle-marker,
.workflow-step-neutral .expense-lifecycle-exception-icon { border-color: #adb5bd; color: #6c757d; }

.workflow-step-warning.is-active .expense-lifecycle-marker,
.workflow-step-warning.is-active .expense-lifecycle-exception-icon { background: #f7b84b; border-color: #f7b84b; color: #fff; }
.workflow-step-info.is-active .expense-lifecycle-marker,
.workflow-step-info.is-active .expense-lifecycle-exception-icon { background: #299cdb; border-color: #299cdb; color: #fff; }
.workflow-step-danger.is-active .expense-lifecycle-marker,
.workflow-step-danger.is-active .expense-lifecycle-exception-icon { background: #f06548; border-color: #f06548; color: #fff; }
.workflow-step-primary.is-active .expense-lifecycle-marker,
.workflow-step-primary.is-active .expense-lifecycle-exception-icon { background: #405189; border-color: #405189; color: #fff; }
.workflow-step-success.is-active .expense-lifecycle-marker,
.workflow-step-success.is-active .expense-lifecycle-exception-icon { background: #0ab39c; border-color: #0ab39c; color: #fff; }

.expense-lifecycle-index {
  display: block;
  color: var(--vz-muted, #878a99);
  font-size: 0.66rem;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
}

.expense-lifecycle-name {
  display: block;
  margin: 0.32rem 0 0.25rem;
  color: var(--vz-heading-color, #212529);
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.25;
}

.expense-lifecycle-state {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 1.35rem;
  padding: 0 0.45rem;
  color: #495057;
  background: var(--vz-light, #f6f7f9);
  border: 1px solid var(--vz-border-color, #e6e9ed);
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1;
}

.expense-lifecycle-flow-step.is-active .expense-lifecycle-state,
.expense-lifecycle-exception-link.is-active .expense-lifecycle-state {
  color: var(--vz-primary, #405189);
  background: rgba(64, 81, 137, 0.08);
  border-color: rgba(64, 81, 137, 0.18);
}

.expense-lifecycle-exception-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--vz-border-color-translucent, #eef0f3);
}

.expense-lifecycle-exception-link {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.65rem;
  min-height: 58px;
  padding: 0.75rem 0.85rem;
  color: var(--vz-body-color, #212529);
  background: var(--vz-card-bg, #fff);
  border: 1px solid var(--vz-border-color, #e6e9ed);
  border-radius: 4px;
  text-decoration: none;
  transition: background-color 0.16s ease, border-color 0.16s ease;
}

.expense-lifecycle-exception-link:hover {
  color: var(--vz-body-color, #212529);
  background: var(--vz-light, #fafbfc);
  border-color: #cfd4da;
}

.expense-lifecycle-exception-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  background: var(--vz-light, #f6f7f9);
  border: 1px solid var(--vz-border-color, #e6e9ed);
  border-radius: 4px;
  font-size: 1rem;
}

@media (max-width: 1199.98px) {
  .expense-lifecycle-flow-track {
    grid-template-columns: repeat(var(--step-count), minmax(132px, 1fr));
    overflow-x: auto;
    padding-bottom: 0.35rem;
  }
}

@media (max-width: 767.98px) {
  .expense-lifecycle-flow-header {
    align-items: stretch;
    flex-direction: column;
  }

  .expense-lifecycle-flow-track {
    grid-template-columns: 1fr;
    overflow: visible;
    gap: 0.5rem;
  }

  .expense-lifecycle-flow-step {
    display: grid;
    grid-template-columns: 2.4rem 1fr auto;
    gap: 0.75rem;
    align-items: center;
    min-height: 58px;
    padding: 0.65rem 0.75rem;
    text-align: left;
    background: var(--vz-card-bg, #fff);
    border: 1px solid var(--vz-border-color, #e6e9ed);
    border-radius: 4px;
  }

  .expense-lifecycle-flow-step:not(:last-child)::after {
    top: 3.1rem;
    left: 1.95rem;
    right: auto;
    width: 1px;
    height: 0.65rem;
  }

  .expense-lifecycle-marker {
    margin-bottom: 0;
  }

  .expense-lifecycle-name {
    margin: 0.18rem 0 0;
  }

  .expense-lifecycle-exception-grid {
    grid-template-columns: 1fr;
  }
}
