/* ========================================================= */
.no-break {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.loader-wheel {
    animation: spin 0.6s infinite linear;
    border: 5px solid #0866C6;
    border-left: 5px solid #fff0;
    /* border-right: 5px solid #0866C6; */
    border-radius: 100%;
    height: 50px;
    margin-bottom: 10px;
    width: 50px;
    z-index: 999999;
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    /* width: 100px; */
    /* Need a specific value to work */
}

tr.custom_loading {
    background-image: linear-gradient(to right, transparent 50%, rgba(0, 0, 0, .05) 50%);
    background-size: 200% 100%;
    animation: custom_loading 2s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}

tr.custom_loading td {
    opacity: .45;
    pointer-events: none;
}

tr.tbl_row_error td {
    background-color: #dc354610;
}

.custom_loading2 {
    background-image: linear-gradient(to right, transparent 50%, rgba(0, 0, 0, .05) 50%);
    background-size: 200% 100%;
    animation: custom_loading2 2s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}

.custom_loading2 {
    opacity: .45;
    pointer-events: none;
}

@keyframes custom_loading2 {
    0% {
        background-position: 0;
    }
    50% {
        background-position: -30%;
    }
    80% {
        background-position: -100%;
    }
    100% {
        background-position: -200%;
    }
}

@keyframes custom_loading {
    0% {
        background-position: 0;
    }
    50% {
        background-position: -30%;
    }
    80% {
        background-position: -100%;
    }
    100% {
        background-position: -200%;
    }
}

.error-color {
    background-color:#ffdacf !important;
}

.error-bg {
    background-color:#ffdacf !important;
}












/* ========================================================= */


.tp-hero-spacing {
  padding-top: 100px;
  padding-bottom: 80px;
}

.article-content ul, .tp-project-details-content ul {
  color: var(--tp-grey-1);
  margin-left: 20px;
  margin-bottom: 15px;
}

/* .tp-project-details-content table {
  border: 1px solid;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
} */



.article-content ul, .tp-project-details-content ul {
  color: var(--tp-grey-1);
  margin-left: 20px;
  margin-bottom: 15px;
}

.tp-project-details-content table {
  width: 100%;
  border-collapse: collapse;
  font-size: 16px;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  color: #333;
  background-color: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
  margin: 1rem 0;
  overflow-x: auto;
}

.tp-project-details-content table th,
.tp-project-details-content table td {
  border: 1px solid #e0e0e0;
  padding: 12px 16px;
  text-align: left;
  vertical-align: top;
}

.tp-project-details-content table th {
  background-color: #f8f9fa;
  font-weight: 600;
  color: #222;
}

.tp-project-details-content table tbody tr:nth-child(even) {
  background-color: #fafafa;
}

.tp-project-details-content table tbody tr:hover {
  background-color: #f0f8ff;
  transition: background-color 0.2s ease-in-out;
}

@media screen and (max-width: 768px) {
  .tp-project-details-content table,
  .tp-project-details-content table thead,
  .tp-project-details-content table tbody,
  .tp-project-details-content table th,
  .tp-project-details-content table td,
  .tp-project-details-content table tr {
    display: block;
    width: 100%;
  }

  .tp-project-details-content table thead {
    display: none;
  }

  .tp-project-details-content table tr {
    margin-bottom: 1rem;
    border: 1px solid #ddd;
    padding: 10px;
    background-color: #fff;
  }

  .tp-project-details-content table td {
    position: relative;
    padding-left: 50%;
    border: none;
    border-bottom: 1px solid #eee;
  }

  .tp-project-details-content table td::before {
    position: absolute;
    top: 12px;
    left: 16px;
    width: 45%;
    padding-right: 10px;
    white-space: nowrap;
    font-weight: bold;
    color: #555;
    content: attr(data-label);
  }
}


.page-item.active {
  background-color: var(--tp-grey-1) !important;
}


.img-container {
  position: relative;
  width: 100%;
  height: 400px; /* or any specific height */
  overflow: hidden;
}

.img-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.article-content {
  color: var(--tp-grey-1) !important;
  all: unset;
  display: revert;
}




/* Reset and style tables inside article-content */
.article-content table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
  min-width: 600px; /* ensures scroll if screen is narrower */
  overflow-x: auto;
  display: block;
}


/* Cell styling */
.article-content th,
.article-content td {
  border: 1px solid #ccc;
  padding: 8px 12px;
  text-align: left;
  /* font-size: 0.95rem; */
  /* white-space: nowrap; */
}

.article-content thead {
  background-color: #f9f9f9;
}




.article-content tr:nth-child(even) {
  background-color: #f2f2f2;
}

/* .article-content table, */
.article-content ul,
.article-content ol,
.article-content blockquote,
.article-content h1,
.article-content h2,
.article-content h3,
.article-content p {
  display: revert;
  margin: revert;
  padding: revert;
  border: revert;
  font: revert;
  color: revert;
}

.table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 1.5rem;
}

/* Optional scrollbar styling */
.table-scroll::-webkit-scrollbar {
  height: 6px;
}

.table-scroll::-webkit-scrollbar-thumb {
  background: #ccc;
  border-radius: 3px;
}




/* OTP SCREENS */

    .otp-input {
      width: 3rem;
      height: 3rem;
      text-align: center;
      font-size: 1.5rem;
      margin: 0 0.25rem;
      background-color: #eee;
    }

    .spinner-border-sm {
      width: 1rem;
      height: 1rem;
      border-width: 0.15em;
    }

/* Force vertical scrollbar to always be visible */
#scroll1 {
    position: relative;
    max-height: 400px; /* or whatever height you want */
    overflow: hidden; /* required by PerfectScrollbar */
}

/* Show the custom scrollbar always */
.ps__rail-y {
    opacity: 1 !important;
    display: block !important;
}

/* Optional: style scrollbar thumb if needed */
.ps__thumb-y {
    background-color: rgba(0, 0, 0, 0.4); /* darker for visibility */
}

.card-header {

  background-color: #f8f9fc;

}


.monitoring {
  background-color: #f8f9fc;
}

.alert-indicator .new {
  position: relative;
}

.alert-indicator .new::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 7px;
  height: 7px;
  background-color: #dc3545;
  box-shadow: 0 0 0 2px #fff;
  border-radius: 100%;
}



/* ======================================================
    Off-canvas Responsive Width/Height Utilities
    ====================================================== */

    /* xs (default) */
    .offcanvas-w-xs { --bs-offcanvas-width: 320px; }
    .offcanvas-h-xs { --bs-offcanvas-height: 40vh; }

    /* sm ≥576px */
    @media (min-width: 576px) {
      .offcanvas-w-sm { --bs-offcanvas-width: 300px; }
      .offcanvas-h-sm { --bs-offcanvas-height: 50vh; }
    }

    /* md ≥768px */
    @media (min-width: 768px) {
      .offcanvas-w-md { --bs-offcanvas-width: 360px; }
      .offcanvas-h-md { --bs-offcanvas-height: 60vh; }
    }

    /* lg ≥992px */
    @media (min-width: 992px) {
      .offcanvas-w-lg { --bs-offcanvas-width: 420px; }
      .offcanvas-h-lg { --bs-offcanvas-height: 70vh; }
    }

    /* xl ≥1200px */
    @media (min-width: 1200px) {
      .offcanvas-w-xl { --bs-offcanvas-width: 480px; }
      .offcanvas-h-xl { --bs-offcanvas-height: 80vh; }
    }

    /* xxl ≥1400px */
    @media (min-width: 1400px) {
      .offcanvas-w-xxl { --bs-offcanvas-width: 540px; }
      .offcanvas-h-xxl { --bs-offcanvas-height: 90vh; }
    }

    /* ======================================================
       Animation Variants
       ====================================================== */
    /* Push */
    .offcanvas-push { transition: transform .4s ease-in-out; z-index: 4045; }
    .offcanvas-push.offcanvas-start.show ~ .page-content { transform: translateX(var(--bs-offcanvas-width)); }
    .offcanvas-push.offcanvas-end.show   ~ .page-content { transform: translateX(calc(-1 * var(--bs-offcanvas-width))); }
    .offcanvas-push.offcanvas-top.show   ~ .page-content { transform: translateY(var(--bs-offcanvas-height)); }
    .offcanvas-push.offcanvas-bottom.show~ .page-content { transform: translateY(calc(-1 * var(--bs-offcanvas-height))); }

    /* Reveal */
    .offcanvas-reveal { z-index: 4035; }
    .offcanvas-reveal.offcanvas-start    { transform: translateX(-100%); }
    .offcanvas-reveal.offcanvas-end      { transform: translateX(100%); }
    .offcanvas-reveal.offcanvas-top      { transform: translateY(-100%); }
    .offcanvas-reveal.offcanvas-bottom   { transform: translateY(100%); }
    .offcanvas-reveal.show { transform: none; }
    .offcanvas-reveal,
    .page-content { transition: transform .4s ease-in-out; }
    .offcanvas-reveal.offcanvas-start.show ~ .page-content { transform: translateX(var(--bs-offcanvas-width)); }
    .offcanvas-reveal.offcanvas-end.show   ~ .page-content { transform: translateX(calc(-1 * var(--bs-offcanvas-width))); }
    .offcanvas-reveal.offcanvas-top.show   ~ .page-content { transform: translateY(var(--bs-offcanvas-height)); }
    .offcanvas-reveal.offcanvas-bottom.show~ .page-content { transform: translateY(calc(-1 * var(--bs-offcanvas-height))); }

    .offcanvas-header {
      box-shadow: 0 0.7px 4px rgba(0,0,0,0.2);
    }

    /* Submenu support for Bootstrap 5 */
    .dropdown-submenu {
      position: relative;
    }

    .dropdown-submenu > .dropdown-menu {
      top: 0;
      left: 100%;
      margin-top: -5px;
    }

    .scroll-wrapper {
      overflow-x: auto;
      -webkit-overflow-scrolling: touch; /* Smooth scroll on iOS */
    }

    .scroll-wrapper .nav {
      flex-wrap: nowrap !important; /* Prevent line breaks */
      white-space: nowrap;
    }

    div.content.ht-100v {
      overflow-y:hidden !important;
      overflow-x:hidden !important;
    }



    /* APPOINTMENT IN PROGRESS */
    .appointment-in_progress {
        border-left: 3px solid #0c8842;
        background-color: rgba(12, 136, 66, 0.1) !important;
    }

    .appointment-in_progress a.btn {
        /* border-left: 3px solid #0c8842 !important; */
        background-color: #0c8842 !important;
        color: #fff !important;
    }

    .appointment-in_progress span.badge.status {
      background-color: rgba(12, 136, 66, 0.1) !important;
      color: #0c8842 !important;
    }


    /* APPOINTMENT CONFIRMED */
    .appointment-confirmed {
        border-left: 3px solid #0168fa;
        background-color: rgba(1, 104, 250, 0.1) !important;
    }

    .appointment-confirmed span.badge.status {
      background-color: rgba(1, 104, 250, 0.1) !important;
      color: #0168fa !important;
    }

    .appointment-confirmed a.btn {
      background-color: #0168fa !important;
      color: #fff !important;
    }



    /* APPOINTMENT COMPLETED */
    .appointment-completed {
        border-left: 3px solid #0168fa;
        background-color: rgba(1, 104, 250, 0.1) !important;
    }

    .appointment-completed span.badge.status {
      background-color: rgba(1, 104, 250, 0.1) !important;
      color: rgba(1, 104, 250) !important;
    }

    .appointment-completed a.btn {
      background-color: #4d596e !important;
      color: #fff !important;
    }



    /* APPOINTMENT MISSED / NO SHOW */
    .appointment-no_show, .appointment-missed {
        border-left: 3px solid #f10075;
        background-color: rgba(241, 0, 117, 0.1) !important;
    }

    .appointment-no_show span.badge.status, .appointment-missed span.badge.status {
      background-color: rgba(241, 0, 117, 0.1) !important;
      color: #f10075 !important;
    }

    .appointment-no_show a.btn {
      background-color: #f10075 !important;
      color: #fff !important;
    }



    /* APPOINTMENT PENDING */
    .appointment-pending {
        border-left: 3px solid #fd7e14;
        background-color: rgba(253, 126, 20, 0.1) !important;
    }

    .appointment-pending span.badge.status {
      background-color: rgba(253, 126, 20, 0.1) !important;
      color: #fd7e14 !important;
    }

    .appointment-pending a.btn {
      background-color: #fd7e14 !important;
      color: #fff !important;
    }

    /* APPOINTMENT PENDING */
    .appointment-cancelled {
        border-left: 3px solid #4d596e;
        background-color: rgba(0, 0, 0, 0.1) !important;
    }

    .appointment-cancelled span.badge.status {
      background-color: rgba(0, 0, 0, 0.1) !important;
      color: #4d596e !important;
    }

    .appointment-cancelled a.btn {
      background-color: #fff !important;
      border: 2px solid #4d596e !important;
      color: #4d596e !important;
    }

    .appointment-content-header2 {
        background-color: #fff;
        width:100%;
        top: 0;
        /* left: 0; */
        /* right: 0; */
        height: 55px;
        border-bottom: 1px solid rgba(72, 94, 144, 0.16);
        display: flex;
        align-items: center;
        padding: 0 20px;
    }

    .appointment-content-header {
      display: flex;
      align-items: center;
      width:100%;
      justify-content: space-between;
      background: #fff;
      border-bottom: 1px solid rgba(72, 94, 144, 0.16);
      position: sticky;   /* sticky on scroll */
      top: 0;
      /* z-index: 1050; */
    }

    .appointment-content {
      /* display: flex; */
      align-items: center;
      width:100% !important;
      /* justify-content: space-between; */
      /* background: #fff; */
      border-bottom: 1px solid rgba(72, 94, 144, 0.16);
      /* z-index: 1050; */
    }

    .vitals-content {
      background: #f8f9fc;
    }

    .appointment-details {
      flex: 1;
      min-width: 0; /* prevents overflow */
    }
    .appointment-details h5,
    .appointment-details small {
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis; /* truncate if too long */
    }
    .appointment-actions {
      display: flex;
      align-items: center;
      gap: 15px;
      flex-shrink: 0;
    }
    .appointment-actions a {
      color: #6b7280;
      text-decoration: none;
    }
    .appointment-actions a:hover {
      color: #111827;
    }







    /* custom badge */
    .custom-badge-success {
      background-color: rgba(12, 136, 66, 0.1) !important;
      color: #0c8842 !important;
    }

    .custom-badge-primary {
      background-color: rgba(1, 104, 250, 0.1) !important;
      color: #0168fa !important;
    }

    .custom-badge-danger {
      background-color: rgba(241, 0, 117, 0.1) !important;
      color: #f10075 !important;
    }

    .custom-badge-warning {
      background-color: rgba(253, 126, 20, 0.1) !important;
      color: #fd7e14 !important;
    }

    .custom-badge-secondary {
      background-color: rgba(0, 0, 0, 0.1) !important;
      color: #4d596e !important;
    }


    /* custom button */
    .custom-btn-primary {
      background-color: #0168fa !important;
      color: #fff !important;
    }

    .custom-btn-secondary {
      background-color: #4d596e !important;
      color: #fff !important;
    }

    .custom-btn-danger {
      background-color: #f10075 !important;
      color: #fff !important;
    }

    .custom-btn-warning {
      background-color: #fd7e14 !important;
      color: #fff !important;
    }

    .custom-btn-success {
      background-color: #0c8842;
      color: #fff !important;
    }




    /* CUSTOM CARD */
    .custom-card-primary {
        border-left: 3px solid #0168fa;
        background-color: rgba(1, 104, 250, 0.1) !important;
    }

    .custom-card-secondary {
        border-left: 3px solid #4d596e;
        background-color: rgba(0, 0, 0, 0.1) !important;
    }

    .custom-card-danger {
        border-left: 3px solid #f10075;
        background-color: rgba(241, 0, 117, 0.1) !important;
    }

    .custom-card-warning {
        border-left: 3px solid #fd7e14;
        background-color: rgba(253, 126, 20, 0.1) !important;
    }

    .custom-card-success {
        border-left: 3px solid #0c8842;
        background-color: rgba(12, 136, 66, 0.1) !important;
    }

    /* Make sure dropdown floats above offcanvas */
    .select2-container {
      z-index: 2000 !important; /* higher than Bootstrap offcanvas (1055) */
      color:#000 !important;
    }
    .select2-dropdown {
      z-index: 2001 !important;
      color:#000 !important;
    }
    .offcanvas-body {
      color: #000 !important;
    }
    /* Make sure Swal is properly positioned in offcanvas */
    .swal2-container {
      position: absolute !important;
      z-index: 9999999;
    }


    /* Highlight effect */
    .highlight {
        animation: highlightFade 3s ease-in-out;
        /* background-color: orange !important; */
        box-shadow: 0 0 15px rgba(255, 165, 0, 0.8);
        border-radius: 8px;
    }

    /* Keyframes: strong orange → fade out */
    @keyframes highlightFade {
        0% {
            background-color: rgba(255, 165, 0, 0.3);
        }
        50% {
            background-color: rgba(255, 165, 0, 0.15);
        }
        100% {
            background-color: transparent;
        }
    }


.custom-hidden {

  display:none;

}

@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes slideOutRight {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateX(100%);
  }
}

.slide-in-left {
  animation: slideInLeft 0.4s ease forwards;
}

.slide-out-right {
  animation: slideOutRight 0.4s ease forwards;
}

@keyframes flashHighlight {
  0% { background-color: #fff8d1; }   /* soft yellow */
  50% { background-color: #ffe066; } /* brighter yellow */
  100% { background-color: transparent; }
}

.flash-highlight {
  animation: flashHighlight 1.2s ease;
}

.prescription-swipe {
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.prescription-swipe.deleting {
  transform: translateX(100%);
  opacity: 0;
}

/* allow vertical page scroll but detect horizontal gestures */
.swipe-draggable {
  touch-action: pan-y;       /* allow vertical scroll, detect horizontal drag */
  will-change: transform;
  transition: transform 0.2s ease;
}

/* final deleting state */
.swipe-draggable.deleting {
  transform: translateX(100%) !important;
  opacity: 0 !important;
  transition: transform 0.3s ease, opacity 0.3s ease;
}


.draggable {
  background-color: #3498db;
  position: absolute;
  user-select: none;
  touch-action: none; /* Prevent scrolling while dragging */
  cursor: grab;
}


.text-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  white-space: normal;
}


.doctor-card {
  background-color: #f8f9fc;
  transition: 
    transform 0.18s ease,
    box-shadow 0.18s ease,
    border-color 0.18s ease;
}

.doctor-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 0px 3px rgba(0, 0, 0, 0.08);
  border-color: #dbe1f1;
}
