/* =========================================================================
 * SJ Buscador de Servicios — estilos
 * Identidad visual de santosjorna.es (negro + rojo de marca).
 * Todas las variables con prefijo --sj- para que sean fáciles de ajustar.
 * ===================================================================== */

:root {
	--sj-rojo: #E2241B;            /* acento principal (se sobreescribe desde ajustes) */
	--sj-card: #1A1A1A;            /* fondo de la tarjeta modal */
	--sj-overlay: rgba(13, 13, 13, .85); /* fondo del overlay */
	--sj-texto: #FFFFFF;           /* texto principal */
	--sj-texto-sec: #B3B3B3;       /* texto secundario / descripciones */
	--sj-input-bg: #0D0D0D;        /* fondo del input */
	--sj-borde: #333333;           /* bordes finos */
	--sj-radio-card: 16px;         /* radio de la tarjeta */
	--sj-radio-item: 10px;         /* radio de cada resultado */
}

/* -------------------------------------------------------------------------
 * Icono de lupa (botón disparador)
 * ---------------------------------------------------------------------- */
.sj-buscador-lupa {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	margin: 0;
	border: 0;
	background: transparent;
	color: currentColor; /* hereda el blanco del header */
	cursor: pointer;
	line-height: 0;
	transition: color .2s ease, transform .2s ease;
	-webkit-appearance: none;
	appearance: none;
}

.sj-buscador-lupa:hover,
.sj-buscador-lupa:focus-visible {
	color: var(--sj-rojo);
	outline: none;
}

.sj-buscador-lupa-svg {
	width: 22px;
	height: 22px;
	display: block;
}

/* Contenedor de la lupa inyectada automáticamente. */
.sj-buscador-auto {
	display: inline-flex;
	align-items: center;
}

/* Fallback: si el JS no encuentra el header, lupa fija arriba a la derecha. */
.sj-buscador-auto.sj-buscador-auto--fixed {
	position: fixed;
	top: 18px;
	right: 18px;
	z-index: 99998;
	color: #fff;
}

/* -------------------------------------------------------------------------
 * Overlay y tarjeta modal
 * ---------------------------------------------------------------------- */
.sj-buscador-overlay {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding: 10vh 16px 16px;
	background: var(--sj-overlay);
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
	opacity: 0;
	transition: opacity .18s ease;
}

/* El atributo [hidden] lo controla el JS; cuando se abre, se añade .is-open. */
.sj-buscador-overlay[hidden] {
	display: none;
}

.sj-buscador-overlay.is-open {
	opacity: 1;
}

.sj-buscador-card {
	position: relative;
	width: 100%;
	max-width: 560px;
	background: var(--sj-card);
	border-radius: var(--sj-radio-card);
	box-shadow: 0 20px 60px rgba(0, 0, 0, .5);
	padding: 22px 22px 16px;
	color: var(--sj-texto);
	font-family: inherit; /* hereda la tipografía del sitio (Poppins/Montserrat) */
	transform: translateY(-8px);
	transition: transform .18s ease;
}

.sj-buscador-overlay.is-open .sj-buscador-card {
	transform: translateY(0);
}

/* Botón cerrar (✕) */
.sj-buscador-cerrar {
	position: absolute;
	top: 12px;
	right: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: transparent;
	color: var(--sj-texto-sec);
	cursor: pointer;
	line-height: 0;
	transition: color .2s ease, background .2s ease;
}

.sj-buscador-cerrar:hover,
.sj-buscador-cerrar:focus-visible {
	color: var(--sj-texto);
	background: rgba(255, 255, 255, .06);
	outline: none;
}

/* -------------------------------------------------------------------------
 * Campo de búsqueda
 * ---------------------------------------------------------------------- */
.sj-buscador-campo {
	position: relative;
	display: flex;
	align-items: center;
	/* Margen superior amplio para que el botón de cierre (✕) quede por encima
	   del campo y no se pise con el buscador. */
	margin: 30px 0 14px;
	background: var(--sj-input-bg);
	border: 1px solid var(--sj-borde);
	border-radius: 12px;
	padding: 0 14px;
	transition: border-color .2s ease, box-shadow .2s ease;
}

.sj-buscador-campo:focus-within {
	border-color: var(--sj-rojo);
	box-shadow: 0 0 0 1px var(--sj-rojo);
}

.sj-buscador-campo-icono {
	flex: 0 0 auto;
	color: var(--sj-texto-sec);
	width: 20px;
	height: 20px;
}

.sj-buscador-campo:focus-within .sj-buscador-campo-icono {
	color: var(--sj-rojo);
}

.sj-buscador-input {
	flex: 1 1 auto;
	width: 100%;
	min-height: 52px;
	padding: 0 10px;
	border: 0;
	background: transparent;
	color: var(--sj-texto);
	font-family: inherit;
	font-size: 18px;
	line-height: 1.3;
	caret-color: var(--sj-rojo);
	outline: none;
	-webkit-appearance: none;
	appearance: none;
}

.sj-buscador-input::placeholder {
	color: var(--sj-texto-sec);
	opacity: .8;
}

/* Oculta la "x" nativa del input search para mantener el diseño limpio. */
.sj-buscador-input::-webkit-search-decoration,
.sj-buscador-input::-webkit-search-cancel-button {
	-webkit-appearance: none;
}

/* -------------------------------------------------------------------------
 * Resultados
 * ---------------------------------------------------------------------- */
.sj-buscador-resultados {
	list-style: none;
	margin: 0;
	padding: 0;
	max-height: 60vh;
	overflow-y: auto;
}

.sj-buscador-resultados:empty {
	display: none;
}

.sj-buscador-item {
	display: block;
	padding: 12px 14px;
	border-radius: var(--sj-radio-item);
	cursor: pointer;
	transition: background .15s ease;
}

.sj-buscador-item:hover,
.sj-buscador-item.is-active {
	background: rgba(255, 255, 255, .05);
}

/* Resultado seleccionado por teclado: acento rojo. */
.sj-buscador-item.is-active {
	box-shadow: inset 0 0 0 1px var(--sj-rojo);
}

.sj-buscador-item-titulo {
	display: block;
	color: var(--sj-texto);
	font-weight: 600;
	font-size: 16px;
	line-height: 1.35;
}

.sj-buscador-item-desc {
	display: block;
	margin-top: 3px;
	color: var(--sj-texto-sec);
	font-size: 13.5px;
	line-height: 1.45;
}

/* Palabra coincidente resaltada dentro del fragmento de contexto. */
.sj-buscador-hl {
	background: transparent;
	color: var(--sj-rojo);
	font-weight: 700;
}

/* -------------------------------------------------------------------------
 * Estados (vacío / sin resultados)
 * ---------------------------------------------------------------------- */
.sj-buscador-estado {
	margin: 8px 4px 6px;
	color: var(--sj-texto-sec);
	font-size: 14px;
	opacity: .75;
}

.sj-buscador-estado[hidden] {
	display: none;
}

/* -------------------------------------------------------------------------
 * Responsive (móvil < 600px)
 * ---------------------------------------------------------------------- */
@media (max-width: 600px) {
	.sj-buscador-overlay {
		padding: 16px;
		align-items: flex-start;
	}

	.sj-buscador-card {
		max-width: 100%;
		padding: 18px 16px 12px;
	}

	.sj-buscador-input {
		min-height: 48px;
		font-size: 16px; /* evita el zoom automático de iOS */
	}

	.sj-buscador-resultados {
		max-height: 70vh;
		overflow-y: auto;
	}
}

/* Respeta usuarios que prefieren menos movimiento. */
@media (prefers-reduced-motion: reduce) {
	.sj-buscador-overlay,
	.sj-buscador-card,
	.sj-buscador-lupa,
	.sj-buscador-cerrar {
		transition: none;
	}
}
