/* ==========================================================================
   AAP Filters
   ========================================================================== */

.aap-filters {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	margin-bottom: 28px;
	padding: 12px;
	background: var(--color-grisclair, #F5F6F8);
	border: 1px solid #b3b8c2;
	border-radius: 14px;
	box-shadow: 0 1px 2px var(--overlay-light, rgba(18, 18, 23, 0.04));
}

/* Ligne 1 : recherche + thématique */
.aap-filters__row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	flex: 1 1 100%;
}

.aap-filters__row .aap-filters__search {
	flex: 2 1 320px;
}

.aap-filters__row .aap-filters__select {
	flex: 1 1 220px;
	min-width: 200px;
}

/* Search input */
.aap-filters__search {
	position: relative;
	flex: 1 1 240px;
	min-width: 220px;
}

.aap-filters__search svg {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	color: #9CA3AF;
	pointer-events: none;
	z-index: 1;
}

.aap-filters input.aap-filters__input[type="text"] {
	width: 100%;
	height: 42px;
	padding: 0 14px 0 40px;
	border: 1px solid #b3b8c2;
	border-radius: 10px;
	font-family: var(--font-primary);
	font-size: 14px;
	color: var(--color-contrast);
	background: var(--color-base);
	outline: none;
	transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.aap-filters input.aap-filters__input[type="text"]::placeholder {
	color: #9CA3AF;
}

.aap-filters input.aap-filters__input[type="text"]:hover {
	border-color: #969ba6;
}

.aap-filters input.aap-filters__input[type="text"]:focus {
	background: var(--color-base);
	border-color: var(--color-secondary);
	box-shadow: 0 0 0 3px rgba(145, 183, 143, 0.18);
}

/* Selects (fallback natif si Tom Select n'est pas chargé) */
.aap-filters__selects {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	flex: 1 1 100%;
}

/* Ligne actions : Mots-clés + toggle + reset */
.aap-filters__row--actions {
	flex: 1 1 100%;
}

.aap-filters__row--actions .w-aap-filters__select {
	flex: 1 1 auto;
	min-width: 220px;
}

.aap-filters__select {
	flex: 1 1 200px;
	min-width: 180px;
}

select.aap-filters__select {
	height: 42px;
	padding: 0 36px 0 14px;
	border: 1px solid #b3b8c2;
	border-radius: 10px;
	font-family: var(--font-primary);
	font-size: 14px;
	font-weight: var(--font-weight-medium);
	color: var(--color-contrast);
	background-color: var(--color-base);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235A5B55' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	appearance: none;
	cursor: pointer;
	outline: none;
	transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

select.aap-filters__select:hover {
	border-color: #969ba6;
}

select.aap-filters__select:focus {
	background-color: var(--color-base);
	border-color: var(--color-secondary);
	box-shadow: 0 0 0 3px rgba(145, 183, 143, 0.18);
}

select.aap-filters__select.aap-filters__select--active {
	background-color: var(--color-cream);
	color: var(--color-contrast);
	border-color: var(--color-secondary);
	font-weight: var(--font-weight-semi-bold);
}

/* Wrapper de chaque select Tom Select : porte le flex/min-width pour aligner les champs */
.aap-filters .w-aap-filters__select {
	flex: 1 1 200px;
	min-width: 180px;
	display: flex;
}

.aap-filters__row .w-aap-filters__select {
	flex: 0 0 60%;
	min-width: 200px;
}

.aap-filters__row .aap-filters__search {
	flex: 1 1 auto;
}

.aap-filters .w-aap-filters__select > .ts-wrapper,
.aap-filters .w-aap-filters__select > select {
	flex: 1 1 auto;
	width: 100%;
	min-width: 0;
}

/* Fallback : si un .ts-wrapper est rendu sans wrapper parent (edge case),
   il garde le comportement flex précédent. */
.aap-filters > .ts-wrapper,
.aap-filters__selects > .ts-wrapper,
.aap-filters__row > .ts-wrapper {
	flex: 1 1 200px;
	min-width: 180px;
}

.aap-filters .ts-wrapper.single .ts-control,
.aap-filters .ts-wrapper.multi .ts-control {
	min-height: 42px;
	padding: 0 36px 0 14px;
	border: 1px solid #b3b8c2;
	border-radius: 10px;
	font-size: 14px;
	color: var(--color-contrast);
	display: flex;
	align-items: center;
}

.aap-filters .ts-wrapper.multi .ts-control {
	padding: 4px 36px 4px 8px;
	flex-wrap: wrap;
}

.aap-filters .ts-wrapper.focus .ts-control,
.aap-filters .ts-wrapper.input-active .ts-control {
	border-color: var(--color-secondary);
	box-shadow: 0 0 0 3px rgba(145, 183, 143, 0.18);
}

.aap-filters .ts-wrapper.aap-filters__ts--active .ts-control {
	background-color: var(--color-cream);
	border-color: var(--color-secondary);
}

/* Toggle "Masquer les AAP passés" */
.aap-filters__toggle {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	height: 42px;
	padding: 0 14px;
	border: 1px solid #b3b8c2;
	border-radius: 10px;
	font-family: var(--font-primary);
	font-size: 13px;
	font-weight: var(--font-weight-medium);
	color: var(--color-contrast);
	background: var(--color-base);
	cursor: pointer;
	user-select: none;
	transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.aap-filters__toggle:hover {
	border-color: #969ba6;
}

.aap-filters__toggle input[type="checkbox"] {
	appearance: none;
	-webkit-appearance: none;
	width: 16px;
	height: 16px;
	margin: 0;
	border: 1.5px solid #B5B7B0;
	border-radius: 4px;
	background: var(--color-base);
	cursor: pointer;
	position: relative;
	flex-shrink: 0;
	transition: background-color 0.15s ease, border-color 0.15s ease;
}

.aap-filters__toggle input[type="checkbox"]:checked {
	background: var(--color-secondary);
	border-color: var(--color-secondary);
}

.aap-filters__toggle input[type="checkbox"]:checked::after {
	content: '';
	position: absolute;
	left: 4px;
	top: 1px;
	width: 5px;
	height: 9px;
	border: solid var(--color-base);
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

.aap-filters__toggle:has(input:checked) {
	background: var(--color-cream);
	border-color: var(--color-secondary);
	color: var(--color-contrast);
	font-weight: var(--font-weight-semi-bold);
}

/* Reset button */
.aap-filters__reset {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	height: 42px;
	padding: 0 14px;
	border: none;
	border-radius: 10px;
	font-family: var(--font-primary);
	font-size: 13px;
	font-weight: var(--font-weight-semi-bold);
	color: var(--color-gris);
	background: transparent;
	cursor: pointer;
	transition: background-color 0.2s ease, color 0.2s ease, opacity 0.2s ease;
}

.aap-filters__reset[aria-disabled="true"] {
	opacity: 0.4;
	cursor: default;
	pointer-events: none;
}

.aap-filters__reset:not([aria-disabled="true"]):hover {
	background: #FEE2E2;
	color: var(--color-danger);
}

.aap-filters__reset svg {
	flex-shrink: 0;
}

/* Results container */
.aap-results {
	transition: opacity 0.2s ease;
	margin-block-start: 0 !important;
}

.aap-results--loading {
	opacity: 0.4;
	pointer-events: none;
}

/* Responsive */
@media (max-width: 782px) {
	.aap-filters {
		padding: 10px;
		gap: 8px;
	}

	.aap-filters__row {
		flex-direction: column;
		align-items: stretch;
	}

	.aap-filters__row .aap-filters__search,
	.aap-filters__row .aap-filters__select,
	.aap-filters__row .w-aap-filters__select,
	.aap-filters__row .ts-wrapper {
		flex: 1 1 100%;
		min-width: 0;
	}

	.aap-filters__selects {
		flex: 1 1 100%;
	}

	.aap-filters__select,
	.aap-filters .ts-wrapper {
		flex: 1 1 100%;
		min-width: 0;
	}

	.aap-filters__reset {
		flex: 1 1 100%;
		justify-content: center;
	}
}

/* ==========================================================================
   CTA Pro (liste tronquée pour les users Free)
   ========================================================================== */

.aap-pro-cta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	margin-top: 32px;
	padding: 24px 28px;
	background: var(--wp--preset--color--grisclair);
	border: 1px solid var(--wp--preset--color--grismoyen);
	border-radius: 16px;
}

.aap-pro-cta__text {
	flex: 1 1 320px;
}

.aap-pro-cta__text strong {
	display: block;
	font-family: var(--font-headings, inherit);
	font-size: 18px;
	color: var(--color-contrast);
	margin-bottom: 6px;
}

.aap-pro-cta__text p {
	margin: 0;
	font-size: 14px;
	line-height: 1.5;
	color: var(--color-contrast);
	opacity: 0.8;
}

.aap-pro-cta__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 22px;
	background: var(--color-primary);
	color: var(--color-contrast);
	border-radius: 10px;
	font-weight: 600;
	font-size: 14px;
	text-decoration: none;
	transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.aap-pro-cta__btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 20px var(--overlay-strong);
	text-decoration: none;
}
