/**
 * Global Search CSS Styles
 * Extracted from CRM-Boiler-Plate WebApp
 * Tabler-like design with maximum z-index for sticky override
 */

/* Enhanced Global Search Styling - MAXIMUM Z-INDEX FOR STICKY OVERRIDE */
.search-dropdown {
    position: fixed !important;
    z-index: 999999 !important; /* Maximum z-index to override all sticky elements */
    background: white !important;
    border: 1px solid var(--tblr-border-color, #dadcde) !important;
    border-radius: var(--tblr-border-radius, 0.375rem) !important;
    box-shadow: var(--tblr-box-shadow-dropdown, 0 0.5rem 1rem rgba(0, 0, 0, 0.15)) !important;
    overflow: hidden !important; /* Prevent any scrollbar on container */
    backdrop-filter: blur(4px);
    animation: slideDown 0.15s ease-out;
    /* Force rendering layer */
    isolation: isolate;
    will-change: transform;
    transform: translateZ(0);
    display: none !important; /* Force display when not d-none */
    visibility: visible !important;
    opacity: 1 !important;
    min-width: 300px !important;
    max-width: 500px !important;
    max-height: 400px !important; /* Fixed max height */
    font-family: inherit;
}

/* Ensure dropdown is visible when not hidden */
.search-dropdown:not(.d-none) {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Search content container - ONLY scrollable element */
.search-content {
    overflow-y: auto !important;
    overflow-x: hidden !important;
    scrollbar-width: thin !important;
    scrollbar-color: rgba(0, 0, 0, 0.2) transparent !important;
    background: white !important;
    max-height: 400px !important; /* Fixed max height to match container */
    height: auto !important;
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Remove any other potential scrollbars */
.search-results {
    overflow: visible !important;
    max-height: none !important;
    height: auto !important;
}

/* Custom scrollbar for webkit browsers */
.search-content::-webkit-scrollbar {
    width: 6px !important;
}

.search-content::-webkit-scrollbar-track {
    background: transparent !important;
}

.search-content::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.2) !important;
    border-radius: 3px !important;
}

.search-content::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.3) !important;
}

/* Search item styling */
.search-item {
    cursor: pointer;
    transition: all 0.15s ease-in-out;
    padding: 0.75rem 1rem !important;
    border-bottom: 1px solid var(--tblr-border-color-translucent, rgba(98, 105, 118, 0.16));
    margin: 0;
}

.search-item:last-child {
    border-bottom: none;
}

.search-item:hover,
.search-item.active {
    background-color: var(--tblr-bg-surface-secondary, #f8fafc) !important;
    border-radius: 0;
}

/* Stronger highlight for selected item */
.search-item.active {
    background-color: var(--tblr-primary-lt, #dbeafe) !important; /* light primary */
    border-left: 3px solid var(--tblr-primary, #206bc4);
}

.search-item.active .fw-medium {
    font-weight: 600;
    color: var(--tblr-primary, #206bc4);
}

.search-item.active svg {
    stroke: var(--tblr-primary, #206bc4);
}

/* Search section headers */
.search-section-header {
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--tblr-muted, #626976);
    background-color: var(--tblr-bg-surface-tertiary, #f1f5f9) !important;
    padding: 0.5rem 1rem !important;
    margin: 0;
    border-bottom: 1px solid var(--tblr-border-color-translucent, rgba(98, 105, 118, 0.16));
}

.search-section:first-child .search-section-header {
    border-top-left-radius: var(--tblr-border-radius, 0.375rem);
    border-top-right-radius: var(--tblr-border-radius, 0.375rem);
}

/* Avatar styling */
.avatar {
    width: 2rem;
    height: 2rem;
    border-radius: var(--tblr-border-radius-pill, 50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-size: cover;
    background-position: center;
    font-size: 0.75rem;
    font-weight: 500;
    color: white;
    flex-shrink: 0;
}

/* Flex layout */
.search-item .d-flex {
    align-items: center;
    gap: 0.75rem;
}

.search-item .fw-medium {
    font-weight: 500;
    color: var(--tblr-body-color, #1e293b);
    margin-bottom: 0.125rem;
}

.search-item .text-muted {
    color: var(--tblr-muted, #626976) !important;
    font-size: 0.8125rem;
}

/* Badge styling */
.search-item .badge {
    font-size: 0.6875rem;
    font-weight: 500;
    padding: 0.25rem 0.5rem;
    border-radius: var(--tblr-border-radius-sm, 0.25rem);
}

.badge.bg-success {
    background-color: var(--tblr-success, #3a8f6f) !important;
}

.badge.bg-primary {
    background-color: var(--tblr-primary, #206bc4) !important;
}

.badge.bg-info {
    background-color: var(--tblr-info, #4299e1) !important;
}

.badge.bg-success-lt {
    background-color: rgba(58, 143, 111, 0.1) !important;
    color: var(--tblr-success, #3a8f6f) !important;
}

.badge.bg-primary-lt {
    background-color: rgba(32, 107, 196, 0.1) !important;
    color: var(--tblr-primary, #206bc4) !important;
}

/* Icon styling */
.search-item i {
    width: 1.25rem;
    height: 1.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
}

/* Icon colors */
.text-primary {
    color: var(--tblr-primary, #206bc4) !important;
}

.text-success {
    color: var(--tblr-success, #3a8f6f) !important;
}

.text-info {
    color: var(--tblr-info, #4299e1) !important;
}

.text-muted {
    color: var(--tblr-muted, #626976) !important;
}

/* Loading state */
.search-loading {
    padding: 1.5rem 1rem !important;
}

.search-loading .spinner-border-sm {
    width: 1rem;
    height: 1rem;
    border-width: 0.125rem;
}

/* Empty state */
.search-content > div:empty + .search-results:empty::before {
    content: "Start typing to search...";
    display: block;
    text-align: center;
    padding: 2rem 1rem;
    color: var(--tblr-muted, #626976);
    font-style: italic;
}

/* No results message styling */
.search-results > div:only-child.p-3 {
    padding: 2rem 1rem !important;
    color: var(--tblr-muted, #626976);
    font-style: italic;
}

/* Improve spacing for flex items */
.search-item .flex-fill {
    min-width: 0;
    flex: 1;
}

.search-item .ms-2 {
    margin-left: auto !important;
    flex-shrink: 0;
}

/* Clear button styling */
.search-clear-btn {
    position: absolute;
    right: 45px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    border: none;
    background: transparent;
    padding: 4px 8px;
    display: none;
    color: #6c757d;
    font-size: 14px;
    line-height: 1;
    border-radius: 4px;
    cursor: pointer;
}

.search-clear-btn:hover {
    background-color: #f8f9fa;
    color: #495057;
}

/* Wider search input on desktop */
@media (min-width: 768px) {
    #globalSearchInput {
        min-width: 360px !important;
    }
}

/* Animation for dropdown */
@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Ensure search works even with sticky elements */
.sticky-top {
    z-index: 1020 !important;
}

/* Global search container specific fixes */
.header .container-fluid {
    position: relative;
    z-index: 9994;
}

.header .navbar-nav {
    z-index: 9993;
}

/* Force search dropdown to be absolutely on top */
body:has(.search-dropdown:not(.d-none)) {
    overflow-anchor: none;
}

.search-dropdown:not(.d-none) {
    position: fixed !important;
    right: auto !important;
    transform: translateZ(0) !important;
    z-index: 999999 !important;
    /* Force above absolutely everything */
    isolation: isolate !important;
    contain: layout style paint !important;
}

/* Nuclear option - force all page elements to lower z-index */
body > *:not(.search-dropdown):not(script):not(style) {
    position: relative;
    z-index: 1000 !important;
}

/* Ensure search input group stays accessible */
.header .input-group {
    z-index: 999997 !important;
    position: relative !important;
}

/* Dark theme support */
[data-bs-theme="dark"] .search-dropdown {
    background: var(--tblr-bg-surface-dark, #1a1a1a) !important;
    border-color: var(--tblr-border-color-dark, #333) !important;
}

[data-bs-theme="dark"] .search-item:hover,
[data-bs-theme="dark"] .search-item.active {
    background-color: var(--tblr-bg-surface-secondary-dark, #2a2a2a) !important;
}

[data-bs-theme="dark"] .search-section-header {
    background-color: var(--tblr-bg-surface-tertiary-dark, #333) !important;
    color: var(--tblr-muted-dark, #999) !important;
}

[data-bs-theme="dark"] .search-item .text-muted {
    color: var(--tblr-muted-dark, #999) !important;
}

[data-bs-theme="dark"] .search-item .fw-medium {
    color: var(--tblr-body-color-dark, #fff) !important;
}

/* Responsive adjustments */
@media (max-width: 767px) {
    .search-dropdown {
        min-width: 280px !important;
        max-width: calc(100vw - 2rem) !important;
        left: 1rem !important;
        right: 1rem !important;
    }
    
    #globalSearchInput {
        min-width: 200px !important;
    }
}

/* Focus states */
#globalSearchInput:focus {
    border-color: var(--tblr-primary, #206bc4);
    box-shadow: 0 0 0 0.2rem rgba(32, 107, 196, 0.25);
}

/* Accessibility improvements */
.search-item:focus {
    outline: 2px solid var(--tblr-primary, #206bc4);
    outline-offset: 2px;
}

.search-clear-btn:focus {
    outline: 2px solid var(--tblr-primary, #206bc4);
    outline-offset: 2px;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .search-dropdown {
        border-width: 2px !important;
    }
    
    .search-item {
        border-bottom-width: 2px !important;
    }
    
    .search-item:hover,
    .search-item.active {
        background-color: #000 !important;
        color: #fff !important;
    }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    .search-dropdown {
        animation: none !important;
    }
    
    .search-item {
        transition: none !important;
    }
}
