/**
 * PCA Search Component Styles
 * 
 * Styles for the modern search component with Algolia integration
 * 
 * @package PCA
 * @since 1.0.0
 */

/* Main component container - unique prefix */
.pcat-search-component {
    width: 100% !important;
    position: relative !important;
}

/* Screen reader text for accessibility */
.pcat-sr-text {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0,0,0,0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* Search form - unique prefix */
.pcat-search-form {
    width: 100% !important;
}

/* Search wrapper - Tailwind style with gray background */
.pcat-search-wrapper {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    background: #f9fafb !important; /* Light gray background like Tailwind bg-gray-50 */
    border: 1px solid #d1d5db !important;
    border-radius: 12px !important; /* Rounded corners */
    padding: 0 !important;
    transition: all 0.2s ease !important;
    overflow: hidden !important;
    width: 100% !important;
    height: 38px !important; /* Fixed height */
    box-sizing: border-box !important;
}

.pcat-search-wrapper:hover {
    border-color: #9ca3af !important;
}

.pcat-search-wrapper:focus-within {
    border-color: #3b82f6 !important; /* Blue focus like Tailwind */
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1) !important;
}

/* Search icon */
.pcat-search-icon {
    position: absolute !important;
    left: 12px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #6b7280 !important; /* Tailwind gray-500 */
    pointer-events: none !important;
    z-index: 1 !important;
}

.pcat-search-icon svg {
    width: 16px !important;
    height: 16px !important;
}

/* Search input - Tailwind style */
.pcat-search-input {
    flex: 1 !important;
    width: 100% !important;
    height: 100% !important;
    border: none !important;
    outline: none !important;
    background: transparent !important;
    padding: 8px 44px 8px 40px !important; /* Left padding for icon, right for clear button */
    font-size: 14px !important;
    color: #111827 !important; /* Tailwind gray-900 */
    min-width: 0 !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    box-sizing: border-box !important;
}

.pcat-search-input::placeholder {
    color: #9ca3af !important; /* Tailwind gray-400 */
}

/* Remove default search input styling */
input[type="search"].pcat-search-input {
    -webkit-appearance: none !important;
    appearance: none !important;
}

.pcat-search-input::-webkit-search-decoration,
.pcat-search-input::-webkit-search-cancel-button,
.pcat-search-input::-webkit-search-results-button,
.pcat-search-input::-webkit-search-results-decoration {
    -webkit-appearance: none !important;
    display: none !important;
}

/* Clear button */
.pcat-search-clear {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 28px !important;
    height: 28px !important;
    background: transparent !important;
    border: none !important;
    border-radius: 50% !important;
    color: #6b7280 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    flex-shrink: 0 !important;
    position: absolute !important;
    right: 8px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
}

.pcat-search-clear:hover {
    background: #e5e7eb !important;
    color: #111827 !important;
}

.pcat-search-clear svg {
    width: 14px !important;
    height: 14px !important;
}

/* Submit button */
.pca-search-submit {
    margin: 4px;
    padding: 8px 20px;
    background: #ff9900;
    color: white;
    border: none;
    border-radius: 9999px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.pca-search-submit:hover {
    background: #f59e0b;
}

/* AJAX Suggestions Dropdown */
.pca-search-suggestions {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    background: white;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
    max-height: 400px;
    overflow-y: auto;
    z-index: 1000;
}

.pca-search-suggestion {
    padding: 12px 16px;
    cursor: pointer;
    transition: background 0.2s ease;
    border-bottom: 1px solid #f3f4f6;
}

.pca-search-suggestion:last-child {
    border-bottom: none;
}

.pca-search-suggestion:hover,
.pca-search-suggestion[aria-selected="true"] {
    background: #f9fafb;
}

.pca-search-suggestion-title {
    font-weight: 500;
    color: #111827;
    margin-bottom: 4px;
}

.pca-search-suggestion-meta {
    font-size: 13px;
    color: #6b7280;
}

/* Algolia dropdown category styling */
.algolia-autocomplete .aa-dataset-1 {
    border-top: 1px solid #e5e7eb;
    padding-top: 8px;
    margin-top: 8px;
}

.algolia-autocomplete .aa-dataset-1:first-child {
    border-top: none;
    padding-top: 0;
    margin-top: 0;
}

/* Style the suggestion type label */
.algolia-suggestion .suggestion-type-label {
    display: inline-block;
    padding: 2px 8px;
    background: #3b82f6;
    color: white;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 3px;
    margin-left: 8px;
}

/* Different colors for different post types */
.algolia-suggestion[data-post-type="hotels"] .suggestion-title {
    color: #059669;
}

.algolia-suggestion[data-post-type="st_tours"] .suggestion-title {
    color: #1f2937;
}


/* Loading state */
.pca-search-loading {
    padding: 20px;
    text-align: center;
    color: #6b7280;
}

.pca-search-loading::after {
    content: '';
    display: inline-block;
    width: 16px;
    height: 16px;
    margin-left: 8px;
    border: 2px solid #e5e7eb;
    border-top-color: #ff9900;
    border-radius: 50%;
    animation: pca-spin 0.6s linear infinite;
}

@keyframes pca-spin {
    to { transform: rotate(360deg); }
}

/* No results */
.pca-search-no-results {
    padding: 20px;
    text-align: center;
    color: #6b7280;
}

/* Responsive adjustments */
@media (max-width: 640px) {
    .pca-search-wrapper {
        border-radius: 12px; /* Less rounded on mobile */
    }
    
    .pca-search-input {
        font-size: 16px; /* Prevent zoom on iOS */
    }
}

/* Dark mode support (optional) */
@media (prefers-color-scheme: dark) {
    .pca-search-wrapper {
        background: #1f2937;
        border-color: #374151;
    }
    
    .pca-search-input {
        color: #f3f4f6;
    }
    
    .pca-search-icon {
        color: #9ca3af;
    }
}

/* Integration with filter panel */
.pca-filter-body .pca-search-component {
    margin-bottom: 20px;
}

.pca-filter-body .pca-search-wrapper {
    background: #f9fafb;
}

/* Sidebar integration */
.sidebar-item .pca-search-component {
    margin-bottom: 20px;
}

/* Algolia Autocomplete Dropdown Styles */
.algolia-autocomplete {
    width: 100% !important;
    max-width: 400px !important; /* Limit dropdown width */
}

.algolia-autocomplete .aa-dropdown-menu {
    width: 100%;
    max-width: 400px; /* Match parent max-width */
    background: white;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
    margin-top: 8px;
    max-height: 400px;
    overflow-y: auto;
}

.algolia-autocomplete .aa-suggestion {
    padding: 12px 16px;
    cursor: pointer;
    border-bottom: 1px solid #f3f4f6;
    transition: background 0.2s ease;
}

.algolia-autocomplete .aa-suggestion:last-child {
    border-bottom: none;
}

.algolia-autocomplete .aa-suggestion.aa-cursor,
.algolia-autocomplete .aa-suggestion:hover {
    background: #f9fafb;
}

.algolia-suggestion {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.algolia-suggestion .suggestion-title {
    font-weight: 500;
    color: #111827;
    font-size: 14px;
    line-height: 1.4;
}

.algolia-suggestion .suggestion-title mark {
    background: #fef3c7;
    color: #92400e;
    font-weight: 600;
    padding: 0 2px;
}

.algolia-suggestion .suggestion-snippet {
    font-size: 13px;
    color: #6b7280;
    line-height: 1.4;
}

.algolia-suggestion .suggestion-snippet mark {
    background: #fef3c7;
    color: #92400e;
    font-weight: 500;
}

.algolia-suggestion .suggestion-type-label {
    font-size: 11px;
    color: #6b7280;
    background: #f3f4f6;
    padding: 2px 6px;
    border-radius: 4px;
    display: inline-block;
    margin-top: 4px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

/* Different styling for hotel suggestions */
.algolia-suggestion[data-post-type="hotels"] .suggestion-title {
    color: #059669;
}

.algolia-suggestion[data-post-type="hotels"] .suggestion-type-label {
    background: #d1fae5;
    color: #065f46;
}

/* Empty state */
.algolia-autocomplete .aa-empty {
    padding: 20px;
    text-align: center;
    color: #6b7280;
    font-size: 14px;
}

/* Enhanced search integration - unique prefix */
.pcat-search-component .pcat-ac-container {
    position: relative !important;
}

.pcat-search-component .aa-input-container {
    display: contents !important;
}

.pcat-search-component .aa-input-search {
    /* Override vendor styles to match Tailwind input */
    flex: 1 !important;
    width: 100% !important;
    height: 100% !important;
    border: none !important;
    outline: none !important;
    background: transparent !important;
    padding: 8px 44px 8px 40px !important; /* Match main input padding */
    font-size: 14px !important;
    color: #111827 !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    box-sizing: border-box !important;
}

/* Hide vendor's default icons */
.pcat-search-component .aa-input-icon {
    display: none !important;
}

/* Toolbar context specific styles */
.pca-toolbar-search .algolia-autocomplete {
    position: absolute !important;
    left: 0;
    right: auto;
    width: auto !important;
    min-width: 300px;
    max-width: 400px !important;
}

.pca-toolbar-search .algolia-autocomplete .aa-dropdown-menu {
    left: 0 !important;
    right: auto !important;
}

/* Mobile responsive for Algolia */
@media (max-width: 640px) {
    .algolia-autocomplete .aa-dropdown-menu {
        border-radius: 8px;
    }
    
    .algolia-suggestion .suggestion-title {
        font-size: 15px;
    }
    
    .algolia-suggestion .suggestion-snippet {
        font-size: 13px;
    }
    
    /* Full width on mobile */
    .pca-toolbar-search .algolia-autocomplete {
        max-width: 100% !important;
        min-width: 100%;
    }
}