/* ── EPP Advanced Search Widget ─────────────────────────────────────── */

.epp-search-wrap {
    position: relative;
    width: 100%;
    box-sizing: border-box;
}

/* Input row */
.epp-search-input-wrap {
    position: relative;
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
}

.epp-search-field {
    flex: 1;
    padding: 11px 44px 11px 42px;
    border: 1.5px solid var(--epp-input-border,#e5e7eb);
    border-radius: var(--epp-radius,8px);
    font-size: var(--epp-text-sm,13px);
    line-height: var(--epp-leading-normal,1.5);
    color: var(--epp-input-color,#1f2937);
    background: var(--epp-input-bg,#ffffff);
    outline: none;
    transition: border-color var(--epp-transition,.22s ease), box-shadow var(--epp-transition,.22s ease);
    box-sizing: border-box;
    -webkit-appearance: none;
    appearance: none;
}
.epp-search-field:focus {
    border-color: var(--epp-primary,#7c3aed);
    box-shadow: var(--epp-focus-ring,0 0 0 3px rgba(124,58,237,.2));
}
.epp-search-field::placeholder { color: var(--epp-input-placeholder,#9ca3af); }
.epp-search-field::-webkit-search-cancel-button { display: none; }
.epp-search-input-wrap .epp-search-field { padding-left: 42px !important; }

/* Icons */
.epp-search-icon,
.epp-search-spinner {
    position: absolute;
    left: 13px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--epp-gray-400,#9ca3af);
    line-height: 0;
    pointer-events: none;
    transition: opacity var(--epp-transition-fast,.15s ease);
}
.epp-search-spinner {
    left: auto;
    right: 13px;
    animation: eppSearchSpin .7s linear infinite;
}
@keyframes eppSearchSpin { to { transform: translateY(-50%) rotate(360deg); } }

/* Clear button */
.epp-search-clear {
    position: absolute;
    right: 13px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    padding: 4px;
    cursor: pointer;
    color: var(--epp-gray-400,#9ca3af);
    border-radius: var(--epp-radius-sm,4px);
    transition: color var(--epp-transition-fast,.15s ease), background var(--epp-transition-fast,.15s ease);
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
}
.epp-search-clear:hover {
    color: var(--epp-gray-600,#4b5563);
    background: var(--epp-gray-100,#f3f4f6);
}
.epp-search-clear:focus-visible {
    outline: 2px solid var(--epp-primary,#7c3aed);
    outline-offset: 2px;
}

/* Search button */
.epp-search-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 11px 20px;
    background: var(--epp-primary,#7c3aed);
    color: #fff;
    border: none;
    border-radius: var(--epp-radius,8px);
    font-size: var(--epp-text-sm,13px);
    font-weight: var(--epp-font-semibold,600);
    cursor: pointer;
    transition: background var(--epp-transition,.22s ease), transform var(--epp-transition-fast,.15s ease);
    white-space: nowrap;
}
.epp-search-btn:hover {
    background: var(--epp-primary-dark,#6d28d9);
    transform: translateY(-1px);
}
.epp-search-btn:active {
    transform: translateY(0);
}
.epp-search-btn:focus-visible {
    outline: none;
    box-shadow: var(--epp-focus-ring,0 0 0 3px rgba(124,58,237,.25));
}

/* Category filter */
.epp-search-category-filter {
    padding: 10px 32px 10px 12px;
    border: 1.5px solid var(--epp-input-border,#e5e7eb);
    border-radius: var(--epp-radius,8px);
    font-size: var(--epp-text-sm,13px);
    color: var(--epp-input-color,#1f2937);
    background: var(--epp-input-bg,#ffffff) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 24 24" fill="none" stroke="%239ca3af" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="6 9 12 15 18 9"/></svg>') no-repeat right 10px center;
    cursor: pointer;
    outline: none;
    transition: border-color var(--epp-transition,.22s ease);
    -webkit-appearance: none;
    appearance: none;
    min-width: 160px;
}
.epp-search-category-filter:focus {
    border-color: var(--epp-primary,#7c3aed);
    box-shadow: var(--epp-focus-ring,0 0 0 3px rgba(124,58,237,.2));
}

/* Results dropdown */
.epp-search-results {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    width: 100%;
    background: var(--epp-card-bg,#fff);
    border: 1.5px solid var(--epp-card-border,#e5e7eb);
    border-radius: var(--epp-radius-md,10px);
    box-shadow: var(--epp-shadow-md,0 8px 24px rgba(0,0,0,.10));
    z-index: 9999;
    max-height: 380px;
    overflow-y: auto;
    box-sizing: border-box;
    animation: eppResultsIn .15s ease;
}
@keyframes eppResultsIn {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Result item */
.epp-result-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    text-decoration: none;
    color: inherit;
    border-bottom: 1px solid var(--epp-gray-100,#f3f4f6);
    transition: background var(--epp-transition-fast,.15s ease);
    cursor: pointer;
}
.epp-result-item:last-child { border-bottom: none; }
.epp-result-item:hover,
.epp-result-item:focus { background: var(--epp-gray-50,#f9fafb); outline: none; }
.epp-result-item:focus-visible { box-shadow: inset 0 0 0 2px var(--epp-primary,#7c3aed); }

/* Thumbnail */
.epp-result-thumb {
    width: 44px;
    height: 44px;
    border-radius: var(--epp-radius-sm,6px);
    object-fit: cover;
    flex-shrink: 0;
    background: var(--epp-gray-100,#f3f4f6);
}
.epp-result-thumb-placeholder {
    width: 44px;
    height: 44px;
    border-radius: var(--epp-radius-sm,6px);
    background: var(--epp-gray-100,#f3f4f6);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--epp-gray-300,#d1d5db);
}

/* Text */
.epp-result-body { flex: 1; min-width: 0; }
.epp-result-title {
    font-size: var(--epp-text-sm,13px);
    font-weight: var(--epp-font-semibold,600);
    color: var(--epp-gray-900,#111827);
    margin: 0 0 3px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.3;
}
.epp-result-meta {
    display: flex;
    align-items: center;
    gap: 8px;
}
.epp-result-type {
    font-size: var(--epp-text-xs,11px);
    font-weight: var(--epp-font-semibold,600);
    color: var(--epp-primary,#7c3aed);
    background: var(--epp-primary-light,#ede9fe);
    padding: 2px 7px;
    border-radius: var(--epp-radius-full,9999px);
    white-space: nowrap;
}
.epp-result-excerpt {
    font-size: var(--epp-text-xs,11px);
    color: var(--epp-gray-500,#6b7280);
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Keyword highlight */
.epp-result-highlight {
    background: var(--epp-accent-light,#fef3c7);
    color: inherit;
    border-radius: 2px;
    padding: 0 1px;
}

/* No results / states */
.epp-search-no-results,
.epp-search-status {
    padding: 18px 16px;
    text-align: center;
    font-size: var(--epp-text-sm,13px);
    color: var(--epp-gray-400,#9ca3af);
}
.epp-search-status { color: var(--epp-primary,#7c3aed); }

/* View All Results link */
.epp-search-view-all {
    display: block;
    padding: 12px 16px;
    text-align: center;
    font-size: var(--epp-text-sm,13px);
    font-weight: var(--epp-font-semibold,600);
    color: var(--epp-primary,#7c3aed);
    text-decoration: none;
    border-top: 1px solid var(--epp-gray-100,#f3f4f6);
    background: var(--epp-gray-50,#f9fafb);
    transition: background var(--epp-transition-fast,.15s ease), color var(--epp-transition-fast,.15s ease);
}
.epp-search-view-all:hover {
    background: var(--epp-primary-light,#ede9fe);
    color: var(--epp-primary-dark,#6d28d9);
}
.epp-search-view-all:focus-visible {
    outline: none;
    box-shadow: inset 0 0 0 2px var(--epp-primary,#7c3aed);
}
