/* AQ Theme -- CSS complementaire (ce qui ne s'exprime pas dans theme.json) */

@font-face {
	font-family: "Roboto";
	font-style: normal;
	font-weight: 400 700;
	font-display: swap;
	src: url("../fonts/roboto-latin.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
	font-family: "Playfair Display";
	font-style: normal;
	font-weight: 400 700;
	font-display: swap;
	src: url("../fonts/playfair-display-latin.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Lien d'evitement : cache jusqu'au focus clavier, puis visible en haut a gauche */
.aq-skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 100;
}
.aq-skip-link:focus {
	left: 0;
	padding: 0.75rem 1.5rem;
	background: var(--wp--preset--color--base);
	color: var(--wp--preset--color--primary);
	font-weight: 600;
	text-decoration: underline;
}

/* Coller le contenu au header et au footer : on annule le block-gap vertical
   (~24px) que WordPress applique entre les blocs de premier niveau de .wp-site-blocks. */
#aq-contenu,
footer.wp-block-template-part {
	margin-block-start: 0;
}

/* En-tete : navigation un peu aeree */
.wp-block-navigation {
	--wp--style--block-gap: 1.25rem;
}

/* Liens de navigation sans soulignement par defaut (lisibilite de la barre) */
header .wp-block-navigation a:where(:not(:hover)) {
	text-decoration: none;
}

:where(a, button, input, select, textarea, summary, [tabindex]):focus-visible,
.wp-element-button:focus-visible,
.wp-block-navigation-item__content:focus-visible {
	outline: 3px solid var(--wp--preset--color--primary);
	outline-offset: 3px;
}
header :where(a, button, input, select, textarea, summary, [tabindex]):focus-visible,
header .wp-element-button:focus-visible,
header .wp-block-navigation-item__content:focus-visible,
footer :where(a, button, input, select, textarea, summary, [tabindex]):focus-visible,
footer .wp-element-button:focus-visible,
footer .wp-block-navigation-item__content:focus-visible {
	outline-color: var(--wp--preset--color--base);
	box-shadow: 0 0 0 5px rgba(255, 255, 255, 0.24);
}

/* En-tete a bande noire : logo et lien de deconnexion */
header .aq-logo {
	margin: 0;
}
header .aq-logo img {
	display: block;
	height: auto;
}
/* Lien "Se deconnecter" presente comme un bouton contour clair */
header .wp-block-loginout a {
	display: inline-block;
	padding: 0.5rem 1.1rem;
	border: 1px solid rgba(255, 255, 255, 0.5);
	border-radius: 9px;
	color: var(--wp--preset--color--base);
	text-decoration: none;
	font-weight: 700;
	font-size: var(--wp--preset--font-size--small);
}
header .wp-block-loginout a:hover {
	background: rgba(255, 255, 255, 0.12);
}

/* Menu deroulant "Profil" : panneau clair lisible sous la bande noire */
header .wp-block-navigation .wp-block-navigation__submenu-container {
	background-color: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--bordure);
	border-radius: 10px;
	padding: 0.4rem 0;
	box-shadow: 0 10px 30px rgba(17, 17, 20, 0.18);
	min-width: 14rem;
}
header .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
	color: var(--wp--preset--color--contrast);
	padding: 0.5rem 1.1rem;
}
header .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover {
	background: var(--wp--preset--color--surface);
}

/* Cartes : legere ombre au survol */
.wp-block-group.has-border-color {
	transition: box-shadow 0.15s ease;
}
.wp-block-group.has-border-color:hover {
	box-shadow: 0 6px 20px rgba(17, 17, 20, 0.08);
}

.wp-block-cover .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3rem;
	min-width: min(100%, 11rem);
}

/* Carte "Mon adhesion" (aq-membership, shortcode [aq_mon_adhesion]) */
.aq-adhesion-carte {
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--bordure);
	border-radius: 8px;
	padding: var(--wp--preset--spacing--50);
}
.aq-adhesion-carte hr {
	border: 0;
	border-top: 1px solid var(--wp--preset--color--bordure);
	margin: var(--wp--preset--spacing--30) 0;
}
.aq-adhesion-cle {
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
	margin: 0 0 0.15rem;
}
.aq-adhesion-valeur {
	font-weight: 600;
	margin: 0;
}
.aq-adhesion-avis {
	margin: var(--wp--preset--spacing--30) 0 0;
	padding: 0.75rem 1rem;
	border-radius: 6px;
	background: var(--wp--preset--color--primary-light);
	color: var(--wp--preset--color--primary-strong);
	font-size: var(--wp--preset--font-size--small);
}

/* Encadre condense (tableau de bord, shortcode [aq_adhesion_encadre]) */
.aq-adhesion-encadre {
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--bordure);
	border-radius: 10px;
	padding: var(--wp--preset--spacing--40);
}
.aq-adhesion-encadre__annonce {
	margin: 0 0 var(--wp--preset--spacing--30);
	padding: 0.6rem 0.9rem;
	border-radius: 8px;
	background: var(--wp--preset--color--primary-light);
	color: var(--wp--preset--color--primary-strong);
	font-weight: 600;
}
.aq-adhesion-encadre__corps {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--wp--preset--spacing--30);
}
.aq-adhesion-encadre__infos {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}
.aq-adhesion-encadre__niveau {
	font-weight: 700;
	font-size: 1.1rem;
}
.aq-adhesion-encadre__echeance {
	color: var(--wp--preset--color--muted);
}
.aq-adhesion-encadre__rappel {
	margin: var(--wp--preset--spacing--30) 0 0;
	color: var(--wp--preset--color--accent);
	font-weight: 600;
}

/* Parcours d'accueil (aq-membership, shortcode [aq_premiers_pas]) */
.aq-premiers-pas {
	background: var(--wp--preset--color--surface);
	border: 1px solid var(--wp--preset--color--bordure);
	border-radius: 10px;
	padding: var(--wp--preset--spacing--40);
}
.aq-premiers-pas__titre {
	margin: 0;
	font-size: 1.15rem;
}
.aq-premiers-pas__intro {
	margin: 0.25rem 0 var(--wp--preset--spacing--30);
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
}
.aq-premiers-pas__liste {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.aq-premiers-pas__item {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.5rem 0;
	border-top: 1px solid var(--wp--preset--color--bordure);
}
.aq-premiers-pas__item:first-child {
	border-top: 0;
}
.aq-premiers-pas__coche {
	font-weight: 700;
	width: 1.2rem;
	text-align: center;
}
.aq-premiers-pas__item.is-faite .aq-premiers-pas__coche {
	color: var(--wp--preset--color--accent);
}
.aq-premiers-pas__item.is-todo .aq-premiers-pas__coche {
	color: var(--wp--preset--color--muted);
}
.aq-premiers-pas__label {
	flex: 1 1 auto;
}
.aq-premiers-pas__item.is-faite .aq-premiers-pas__label {
	color: var(--wp--preset--color--muted);
}
.aq-premiers-pas__statut {
	color: var(--wp--preset--color--accent);
	font-size: var(--wp--preset--font-size--small);
	font-weight: 600;
}
.aq-premiers-pas__cta {
	flex: 0 0 auto;
	font-size: var(--wp--preset--font-size--small);
}

/* Profil d'un membre (aq-directory, shortcode [aq_profil]) */
.aq-profil-entete {
	text-align: center;
	margin-bottom: var(--wp--preset--spacing--50);
}
.aq-profil-avatar img {
	border-radius: 50%;
	width: 120px;
	height: 120px;
}
.aq-profil-nom {
	margin: var(--wp--preset--spacing--30) 0 0.25rem;
}
.aq-profil-depuis {
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
	margin: 0;
}
.aq-profil-modifier {
	display: inline-block;
	margin-top: var(--wp--preset--spacing--30);
	font-weight: 600;
}
.aq-profil-champs {
	display: grid;
	grid-template-columns: minmax(0, max-content) minmax(0, 1fr);
	gap: 0.5rem var(--wp--preset--spacing--40);
	max-width: 30rem;
	margin: 0 auto;
}
.aq-profil-champs dt {
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
}
.aq-profil-champs dd {
	margin: 0;
	font-weight: 600;
	overflow-wrap: anywhere;
}
.aq-profil-bio {
	max-width: 38rem;
	margin: var(--wp--preset--spacing--50) auto 0;
	overflow-wrap: anywhere;
}

/* Bottin des membres (aq-directory) */
.aq-bottin-count {
	color: var(--wp--preset--color--muted);
	margin-bottom: var(--wp--preset--spacing--40);
}
.aq-bottin-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 14rem), 1fr));
	gap: var(--wp--preset--spacing--40);
}
.aq-bottin-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.5rem;
	padding: var(--wp--preset--spacing--40);
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--bordure);
	border-radius: 8px;
	transition: box-shadow 0.15s ease;
}
.aq-bottin-card:hover {
	box-shadow: 0 6px 20px rgba(17, 17, 20, 0.08);
}
.aq-bottin-card img {
	border-radius: 50%;
	width: 96px;
	height: 96px;
}
.aq-bottin-name {
	font-weight: 600;
	text-decoration: none;
	overflow-wrap: anywhere;
}
.aq-bottin-date {
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
}
.aq-bottin-locked {
	text-align: center;
	color: var(--wp--preset--color--muted);
}

/* ------------------------------------------------------------------ *
 * Formulaires Forminator -- habillage commun a TOUS les formulaires.
 * Les formulaires sont en design "Basic Styles" (ils heritent du theme) ;
 * on les stylise ici une seule fois avec les jetons AQ.
 * ------------------------------------------------------------------ */

/* Libelles */
.forminator-ui.forminator-custom-form .forminator-label {
	display: block;
	margin-bottom: 0.4rem;
	font-family: var(--wp--preset--font-family--body);
	font-weight: 600;
	/* !important : Forminator injecte des regles de couleur ciblees par ID
	   (heritees de l'ancien design) qui battraient nos classes sinon. */
	color: var(--wp--preset--color--contrast) !important;
}
.forminator-ui .forminator-required {
	color: var(--wp--preset--color--accent);
}

/* Espacement entre les champs */
.forminator-ui.forminator-custom-form .forminator-row {
	margin-bottom: var(--wp--preset--spacing--40);
}

/* Champs de saisie : encadres */
.forminator-ui .forminator-input,
.forminator-ui textarea.forminator-textarea,
.forminator-ui select.forminator-select,
.forminator-ui .forminator-field input[type="text"],
.forminator-ui .forminator-field input[type="email"],
.forminator-ui .forminator-field input[type="tel"],
.forminator-ui .forminator-field input[type="url"],
.forminator-ui .forminator-field input[type="number"],
.forminator-ui .forminator-field input[type="password"] {
	width: 100%;
	padding: 0.7rem 0.9rem;
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--bordure);
	border-radius: 8px;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1rem;
	line-height: 1.4;
}
.forminator-ui .forminator-input::placeholder,
.forminator-ui textarea::placeholder {
	color: var(--wp--preset--color--muted);
	opacity: 1;
}
.forminator-ui .forminator-input:focus,
.forminator-ui textarea.forminator-textarea:focus,
.forminator-ui select.forminator-select:focus {
	outline: none;
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px var(--wp--preset--color--primary-light);
}

/* Menu deroulant des listes (select2) : Forminator l'ajoute au <body>, hors du
   conteneur du thème -> sans fond il devient transparent et illisible. On force
   un panneau blanc opaque, lisible. (Selecteurs select2 globaux, pas .forminator-ui.) */
.select2-container--open .select2-dropdown,
.select2-dropdown {
	background-color: var(--wp--preset--color--base, #fff) !important;
	border: 1px solid var(--wp--preset--color--bordure, #d8d8d8) !important;
	box-shadow: 0 10px 30px rgba(17, 17, 20, 0.18);
}
.select2-container .select2-results__option {
	background-color: var(--wp--preset--color--base, #fff);
	color: var(--wp--preset--color--contrast, #1a1a1a);
}
.select2-container .select2-results__option--highlighted[aria-selected],
.select2-container .select2-results__option--highlighted {
	background-color: var(--wp--preset--color--primary) !important;
	color: var(--wp--preset--color--base, #fff) !important;
}
.select2-container--default .select2-search--dropdown .select2-search__field {
	border: 1px solid var(--wp--preset--color--bordure, #d8d8d8);
}

/* Cases a cocher / boutons radio */
.forminator-ui .forminator-radio,
.forminator-ui .forminator-checkbox {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.4rem;
}
.forminator-ui input[type="radio"],
.forminator-ui input[type="checkbox"] {
	accent-color: var(--wp--preset--color--primary);
}
/* Libelles d'option (texte a cote de chaque case / radio).
   Forminator genere dans style-<id>.css une regle a 4 classes + !important
   (`...forminator-design--basic .forminator-checkbox-label{color:white!important}`,
   heritee de l'ancien design fond sombre). On la bat avec une regle a 5 classes. */
.forminator-ui.forminator-custom-form.forminator-design--basic .forminator-field .forminator-checkbox-label,
.forminator-ui.forminator-custom-form.forminator-design--basic .forminator-field .forminator-radio-label {
	color: var(--wp--preset--color--contrast) !important;
}

/* Texte d'aide sous les champs */
.forminator-ui .forminator-description {
	margin-top: 0.35rem;
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
}

/* Messages d'erreur */
.forminator-ui .forminator-error-message,
.forminator-ui .forminator-label--error {
	color: #b3261e;
	font-size: var(--wp--preset--font-size--small);
}
.forminator-ui .forminator-has_error .forminator-input,
.forminator-ui .forminator-has_error textarea.forminator-textarea {
	border-color: #b3261e;
}

/* Bouton d'envoi : bouton principal AQ */
.forminator-ui button.forminator-button,
.forminator-ui button.forminator-button-submit {
	display: inline-block;
	padding: 0.75rem 1.8rem;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	border: 0;
	border-radius: 9px;
	font-family: var(--wp--preset--font-family--body);
	font-weight: 700;
	font-size: 1rem;
	cursor: pointer;
	transition: background 0.15s ease;
}
.forminator-ui button.forminator-button:hover,
.forminator-ui button.forminator-button-submit:hover {
	background: var(--wp--preset--color--primary-strong);
}

/* Page "Mot de passe oublie" (aq-membership, shortcode [aq_mot_de_passe_oublie]) */
.aq-mdp-form {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.aq-mdp-label {
	font-weight: 600;
	color: var(--wp--preset--color--contrast);
}
.aq-mdp-input {
	width: 100%;
	padding: 0.7rem 0.9rem;
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--bordure);
	border-radius: 8px;
	color: var(--wp--preset--color--contrast);
	font-size: 1rem;
}
.aq-mdp-input:focus {
	outline: none;
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px var(--wp--preset--color--primary-light);
}
.aq-mdp-bouton {
	margin-top: 0.5rem;
	align-self: flex-start;
	padding: 0.75rem 1.8rem;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	border: 0;
	border-radius: 9px;
	font-weight: 700;
	font-size: 1rem;
	cursor: pointer;
	transition: background 0.15s ease;
}
.aq-mdp-bouton:hover {
	background: var(--wp--preset--color--primary-strong);
}
.aq-mdp-message {
	padding: 0.75rem 1rem;
	border-radius: 6px;
	font-size: var(--wp--preset--font-size--small);
}
.aq-mdp-message--succes {
	background: var(--wp--preset--color--primary-light);
	color: var(--wp--preset--color--primary-strong);
}
.aq-mdp-message--erreur {
	background: #f9e4e8;
	color: #b3261e;
}
.aq-mdp-retour {
	margin-top: var(--wp--preset--spacing--40);
	font-size: var(--wp--preset--font-size--small);
}

/* Reglages de visibilite du profil */
.aq-visibilite {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}
.aq-visibilite-intro {
	margin: 0;
	color: var(--wp--preset--color--muted);
}
.aq-visibilite-confirme {
	margin: 0;
	padding: 0.75rem 1rem;
	border-radius: 6px;
	font-size: var(--wp--preset--font-size--small);
	background: var(--wp--preset--color--primary-light);
	color: var(--wp--preset--color--primary-strong);
}
.aq-visibilite-liste {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}
.aq-visibilite-champ {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
	margin: 0;
	padding: 0.85rem 1.1rem;
	border: 1px solid var(--wp--preset--color--bordure);
	border-radius: 10px;
	background: var(--wp--preset--color--base);
}
.aq-visibilite-nom {
	font-weight: 700;
	color: var(--wp--preset--color--contrast);
}
.aq-visibilite-prive {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--wp--preset--color--muted);
	cursor: pointer;
}
.aq-visibilite-prive input {
	accent-color: var(--wp--preset--color--primary);
}
.aq-visibilite-submit {
	align-self: flex-start;
	padding: 0.75rem 1.8rem;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	border: 0;
	border-radius: 9px;
	font-weight: 700;
	font-size: 1rem;
	cursor: pointer;
	transition: background 0.15s ease;
}
.aq-visibilite-submit:hover {
	background: var(--wp--preset--color--primary-strong);
}

/* ------------------------------------------------------------------ *
 * Page Commercants
 * ------------------------------------------------------------------ */

/* Filtre par categorie : le <select> natif du bloc Categories est habille
   comme les champs de formulaire Forminator (meme rendu sur tout le site). */
.wp-block-categories select,
.wp-block-categories__dropdown {
	padding: 0.7rem 0.9rem;
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--bordure);
	border-radius: 8px;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1rem;
	line-height: 1.4;
	min-width: 0;
	width: min(100%, 22rem);
	cursor: pointer;
}
.wp-block-categories select:focus,
.wp-block-categories__dropdown:focus {
	outline: none;
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px var(--wp--preset--color--primary-light);
}

/* Pastille "rabais membre" sur les cartes de commerce */
.aq-rabais {
	align-self: flex-start;
	margin: 0;
	padding: 0.2rem 0.7rem;
	border-radius: 999px;
	background: var(--wp--preset--color--primary-light);
	color: var(--wp--preset--color--primary-strong);
	font-size: var(--wp--preset--font-size--small);
	font-weight: 700;
}

/* Visuel de remplacement quand un commerce n'a pas de logo */
.aq-logo-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	aspect-ratio: 4 / 3;
	border-radius: 6px;
	background: var(--wp--preset--color--surface);
	border: 1px dashed var(--wp--preset--color--bordure);
}
.aq-logo-placeholder span {
	color: var(--wp--preset--color--muted);
	font-family: var(--wp--preset--font-family--heading, serif);
	font-size: var(--wp--preset--font-size--small);
	letter-spacing: 0.04em;
}
/* Sur la fiche, le logo (image mise en avant) est un carre a gauche du bandeau */
.aq-fiche-commerce__logo.aq-logo-placeholder {
	width: 100%;
	height: 100%;
	aspect-ratio: 1 / 1;
}

/* ------------------------------------------------------------------ *
 * Evenements (shortcodes [aq_evenements] et [aq_evenement_fiche])
 * ------------------------------------------------------------------ */

.aq-events-section {
	margin-bottom: var(--wp--preset--spacing--60);
}
.aq-events-section:last-child {
	margin-bottom: 0;
}
.aq-events-section__titre {
	margin: 0 0 var(--wp--preset--spacing--40);
	color: var(--wp--preset--color--primary);
}
.aq-events-section--passes .aq-events-section__titre {
	color: var(--wp--preset--color--muted);
}

.aq-events-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 20rem), 1fr));
	gap: var(--wp--preset--spacing--40);
}

.aq-event-card {
	display: flex;
	flex-direction: column;
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--bordure);
	border-radius: 8px;
	overflow: hidden;
	transition: box-shadow 0.15s ease;
}
.aq-event-card:hover {
	box-shadow: 0 6px 20px rgba(17, 17, 20, 0.08);
}
.aq-events-section--passes .aq-event-card {
	background: var(--wp--preset--color--surface);
}
.aq-event-card__media {
	display: block;
}
.aq-event-card__img {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
}
.aq-event-card__noimg {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--wp--preset--color--surface);
}
.aq-event-card__noimg span {
	color: var(--wp--preset--color--muted);
	font-family: var(--wp--preset--font-family--heading, serif);
	font-size: var(--wp--preset--font-size--small);
	letter-spacing: 0.04em;
}
.aq-event-card__body {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--20);
	padding: var(--wp--preset--spacing--40);
}
.aq-event-card__titre {
	margin: 0;
	font-size: var(--wp--preset--font-size--large);
	overflow-wrap: anywhere;
}
.aq-event-card__titre a {
	text-decoration: none;
	color: inherit;
}
.aq-event-card__titre a:hover {
	color: var(--wp--preset--color--primary);
}
.aq-event-card__extrait {
	margin: 0;
	color: var(--wp--preset--color--muted);
}
.aq-event-card__lien {
	align-self: flex-start;
	margin-top: auto;
}

/* Lignes d'information (lieu, date, heures) */
.aq-event-meta {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}
.aq-event-meta__item {
	color: var(--wp--preset--color--contrast);
	font-size: var(--wp--preset--font-size--small);
}
.aq-event-meta--fiche {
	gap: 0.4rem;
	margin: var(--wp--preset--spacing--30) 0 var(--wp--preset--spacing--40);
}
.aq-event-meta--fiche .aq-event-meta__item {
	font-size: 1rem;
	font-weight: 600;
}

/* Fiche d'un evenement */
.aq-fiche-evenement__media img {
	width: 100%;
	max-height: 420px;
	object-fit: cover;
	border-radius: 8px;
}
.aq-fiche-evenement__titre {
	margin: var(--wp--preset--spacing--40) 0 0;
}
.aq-fiche-evenement__contenu {
	margin-top: var(--wp--preset--spacing--40);
}
.aq-fiche-evenement__connexion {
	margin-top: var(--wp--preset--spacing--40);
	padding: var(--wp--preset--spacing--40);
	border-radius: 8px;
	background: var(--wp--preset--color--surface);
}
.aq-fiche-evenement__retour {
	margin-top: var(--wp--preset--spacing--50);
}

/* ------------------------------------------------------------------ *
 * Fiche commercant (shortcode [aq_commerce_fiche]) -- calque du live
 * ------------------------------------------------------------------ */

.aq-fiche-commerce__hero {
	display: flex;
	align-items: stretch;
	gap: var(--wp--preset--spacing--40);
	min-height: 280px;
	margin-bottom: var(--wp--preset--spacing--50);
	padding: var(--wp--preset--spacing--40);
	border-radius: 10px;
	/* Bandeau decoratif par defaut (a remplacer par un visuel si souhaite) */
	background:
		linear-gradient(120deg, rgba(17, 17, 20, 0.78), rgba(17, 17, 20, 0.45)),
		var(--wp--preset--color--primary, #2f6f5e);
	color: var(--wp--preset--color--base, #fff);
}
.aq-fiche-commerce__logo {
	flex: 0 0 clamp(150px, 22vw, 240px);
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--wp--preset--color--noir, #111114);
	border-radius: 8px;
	overflow: hidden;
}
.aq-fiche-commerce__logo-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.aq-fiche-commerce__titre {
	align-self: center;
	margin: 0;
	color: var(--wp--preset--color--base, #fff);
	font-size: var(--wp--preset--font-size--xx-large, 2.6rem);
	overflow-wrap: anywhere;
}

.aq-fiche-commerce__cat {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	margin: 0 0 var(--wp--preset--spacing--40);
	color: var(--wp--preset--color--primary);
	font-weight: 600;
}
.aq-fiche-commerce__h2 {
	margin: var(--wp--preset--spacing--50) 0 var(--wp--preset--spacing--20);
	color: var(--wp--preset--color--primary);
	font-size: var(--wp--preset--font-size--x-large, 1.8rem);
}
.aq-fiche-commerce__desc {
	color: var(--wp--preset--color--contrast);
}
.aq-fiche-commerce__siteweb {
	margin: var(--wp--preset--spacing--40) 0 0;
}
.aq-fiche-commerce__siteweb a {
	font-weight: 700;
	color: var(--wp--preset--color--primary);
}

/* Carte du membre qui a inscrit le commerce */
.aq-fiche-commerce__auteur {
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--40);
	max-width: 30rem;
	margin: var(--wp--preset--spacing--60) auto var(--wp--preset--spacing--50);
	padding: var(--wp--preset--spacing--40);
	background: var(--wp--preset--color--surface);
	border-radius: 8px;
}
.aq-fiche-commerce__auteur-avatar img {
	width: 84px;
	height: 84px;
	border-radius: 50%;
	display: block;
}
.aq-fiche-commerce__auteur-nom {
	font-weight: 700;
	font-size: var(--wp--preset--font-size--large, 1.25rem);
	color: var(--wp--preset--color--primary);
	text-decoration: none;
}
.aq-fiche-commerce__auteur-bio {
	margin: 0.2rem 0 0;
	color: var(--wp--preset--color--muted);
}
.aq-fiche-commerce__retour {
	text-align: center;
	margin-top: var(--wp--preset--spacing--50);
}

@media (max-width: 600px) {
	.aq-profil-champs {
		grid-template-columns: 1fr;
		gap: 0.15rem;
	}
	.aq-profil-champs dd {
		margin-bottom: var(--wp--preset--spacing--20);
	}
	.aq-visibilite-champ {
		align-items: flex-start;
		flex-direction: column;
	}
	.aq-visibilite-submit,
	.aq-mdp-bouton {
		width: 100%;
	}
	.aq-fiche-commerce__hero {
		flex-direction: column;
		text-align: center;
	}
	.aq-fiche-commerce__logo {
		flex-basis: 200px;
	}
	.aq-fiche-commerce__auteur {
		flex-direction: column;
		text-align: center;
	}
}

/* Respect du choix "moins d'animations" */
@media (prefers-reduced-motion: reduce) {
	.wp-block-group.has-border-color,
	.aq-bottin-card,
	.aq-event-card,
	.forminator-ui button.forminator-button,
	.forminator-ui button.forminator-button-submit,
	.aq-mdp-bouton,
	.aq-visibilite-submit {
		transition: none;
	}
}
