/* Extra animations & utility classes */
.view-container {
  display: none;
}
.view-container.active {
  display: block;
  animation: fadeIn 0.35s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
.scrollbar-hide::-webkit-scrollbar {
  display: none;
}
.scrollbar-hide {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

/* Custom form and active state styling */
.form-input-standard {
  height: 2.5rem; /* 40px */
}
.active-tab-line {
  position: relative;
}
.active-tab-line::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background-color: #172D4F;
  border-radius: 9999px;
}
.mobile-card-shadow {
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.02), 0 4px 12px rgba(23, 45, 79, 0.04);
}

/* Hide HTML5 number input spinners globally */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
input[type="number"] {
  -moz-appearance: textfield;
}

/* Premium custom style for the collector assignment dropdown */
.assign-collector-select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 0.6rem center;
  background-size: 0.75rem;
  padding-right: 1.85rem !important;
}

/* Custom premium date input styling */
.date-input-premium {
  position: relative;
}

/* Hide native webkit date inputs spin/clear buttons */
.date-input-premium::-webkit-inner-spin-button,
.date-input-premium::-webkit-clear-button {
  display: none !important;
  -webkit-appearance: none;
}

/* Hide native calendar icon when value is selected to make room for clear button */
.date-input-premium.has-value::-webkit-calendar-picker-indicator {
  display: none !important;
}

/* Position and style native calendar picker icon */
.date-input-premium::-webkit-calendar-picker-indicator {
  cursor: pointer;
  opacity: 0.5;
  transition: opacity 0.15s ease-in-out;
}

.date-input-premium::-webkit-calendar-picker-indicator:hover {
  opacity: 0.8;
}

/* Make the main scroll container a flexbox column to push footer to the bottom */
main > div.flex-1.overflow-y-auto {
  display: flex;
  flex-direction: column;
}

main > div.flex-1.overflow-y-auto > footer {
  margin-top: auto !important;
}

/* Print Only Styling */
@media print {
  @page {
    size: A4 landscape;
    margin: 8mm 12mm 12mm 12mm;
  }
  #sidebar, #sidebarOverlay, main, .no-print {
    display: none !important;
  }
  #report-print-template {
    display: block !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
  thead {
    display: table-header-group;
  }
  tr {
    page-break-inside: avoid;
    break-inside: avoid;
  }
}

/* Flatpickr Premium Customizations */
.flatpickr-calendar {
  border: 1px border-brand-border !important;
  box-shadow: 0 10px 25px -5px rgba(23, 45, 79, 0.1), 0 8px 10px -6px rgba(23, 45, 79, 0.1) !important;
  border-radius: 12px !important;
  font-family: 'Inter', sans-serif !important;
  overflow: hidden;
}
.flatpickr-day.selected, 
.flatpickr-day.startRange, 
.flatpickr-day.endRange, 
.flatpickr-day.selected.inRange, 
.flatpickr-day.startRange.inRange, 
.flatpickr-day.endRange.inRange, 
.flatpickr-day.selected:focus, 
.flatpickr-day.startRange:focus, 
.flatpickr-day.endRange:focus, 
.flatpickr-day.selected:hover, 
.flatpickr-day.startRange:hover, 
.flatpickr-day.endRange:hover, 
.flatpickr-day.prevMonthDay.selected, 
.flatpickr-day.nextMonthDay.selected {
  background: #172D4F !important; /* brand-teal */
  border-color: #172D4F !important;
  color: #fff !important;
}
.flatpickr-day.today {
  border-color: #C5A880 !important; /* brand-gold */
}
.flatpickr-day.today:hover {
  background: #C5A880 !important;
  color: #172D4F !important;
  border-color: #C5A880 !important;
}
.flatpickr-months .flatpickr-month {
  background: #172D4F !important;
  color: #fff !important;
}
.flatpickr-current-month .flatpickr-monthDropdown-months {
  font-weight: 700 !important;
}
.flatpickr-weekdays {
  background: #172D4F !important;
}
span.flatpickr-weekday {
  color: rgba(255, 255, 255, 0.8) !important;
  font-weight: 600 !important;
}
.flatpickr-months .flatpickr-prev-month, 
.flatpickr-months .flatpickr-next-month {
  color: #fff !important;
  fill: #fff !important;
}
.flatpickr-months .flatpickr-prev-month:hover, 
.flatpickr-months .flatpickr-next-month:hover {
  color: #C5A880 !important;
}
.flatpickr-months .flatpickr-prev-month svg, 
.flatpickr-months .flatpickr-next-month svg {
  fill: currentColor !important;
}

/* Prevent KYC card content overlap when card is locked/verified */
.kyc-card-locked > *:not(.kyc-status-overlay) {
  opacity: 0 !important;
  pointer-events: none !important;
  user-select: none !important;
}

/* Disable pointer cursor and hover styles on locked/verified KYC cards */
.kyc-card-locked,
.kyc-card-locked:hover {
  cursor: default !important;
}

/* Ensure verified card border and background stay solid emerald on hover */
.kyc-card-locked.border-emerald-400:hover {
  border-color: #34d399 !important; /* tailwind emerald-400 */
  background-color: rgba(236, 253, 245, 0.5) !important; /* tailwind emerald-50/50 */
}

/* Ensure awaiting verification card border and background stay solid amber on hover */
.kyc-card-locked.border-amber-400:hover {
  border-color: #fbbf24 !important; /* tailwind amber-400 */
  background-color: rgba(254, 243, 199, 0.5) !important; /* tailwind amber-50/50 */
}

/* Make all gray shaded texts bolder and darker (navy blue) for high contrast and legibility */
.text-brand-muted,
.text-slate-300,
.text-slate-400,
.text-slate-500,
.text-slate-600,
.text-gray-300,
.text-gray-400,
.text-gray-500,
.text-gray-600 {
  color: #172D4F !important;
  font-weight: 700 !important;
}



