/* ------------------------------------------------------------------
   Bloc d'inscription Brevo  (fragment custom/fragment/brevo-newsletter.twig)
   Chargé via base.twig, hors build SCSS pour rester facile à éditer.

   Markup réel du formulaire (shortcode [sibwp_form id=1]) :
     form.sib_signup_form
       div.sib_signup_box_inside_1
         div.sib_msg_disp
         p.sib-email-area      > input[type=email]
         p.sib-FIRSTNAME-area  > input[type=text]
         p.sib-LASTNAME-area   > input[type=text]
         p                     > input[type=submit].sib-default-btn
   Le texte de label (ex. "Votre e-mail*") est un simple noeud texte ;
   le JS brevo-newsletter.js le convertit en <label class="bn-label">.
   ------------------------------------------------------------------ */

.brevo-newsletter-block {
	text-align: center;
}

.brevo-newsletter-block .container {
	max-width: 1040px;
}

.brevo-newsletter-block h2 {
	margin-bottom: 12px;
}

.brevo-newsletter-block > .container > p {
	margin: 0 auto 32px;
	max-width: 640px;
	line-height: 1.5;
	opacity: .9;
}

/* --- Conteneur du formulaire --- */
.brevo-newsletter-block .sib_signup_form {
	margin: 0 auto;
	max-width: 980px;
}

.brevo-newsletter-block .sib_loader {
	display: none !important;
}

/* --- Tous les champs + le bouton sur UNE seule ligne ---
   flex-wrap: wrap est indispensable : après envoi, Brevo injecte le
   message dans .sib_msg_disp ; ce div doit pouvoir passer SEUL à la
   ligne au lieu d'écraser les champs (qui sinon s'empilent à gauche). */
.brevo-newsletter-block .sib_signup_box_inside_1 {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	justify-content: center;
	gap: 12px;
}

/* Zone de message : occupe toujours sa propre ligne, jamais en concurrence
   avec les champs. Placée en dernier via order. */
.brevo-newsletter-block .sib_msg_disp {
	order: 99;
	flex: 1 1 100%;
	width: 100%;
	margin: 0;
}

/* Vide -> totalement retirée du flux (pas de ligne fantôme) */
.brevo-newsletter-block .sib_msg_disp:empty {
	display: none;
}

/* Inscription réussie : on masque les champs et le bouton,
   il ne reste que le message de confirmation. */
.brevo-newsletter-block .sib_signup_box_inside_1:has(.sib-alert-message-success) p[class*="-area"],
.brevo-newsletter-block .sib_signup_box_inside_1:has(.sib-alert-message-success) p:not([class]) {
	display: none;
}

/* Paragraphe = un champ : occupe l'espace disponible à parts égales.
   Base 160px : les 3 champs + le bouton tiennent sur une ligne jusqu'à
   ~760px, en dessous le media query les empile. */
.brevo-newsletter-block .sib_signup_form p[class*="-area"] {
	position: relative;
	flex: 1 1 160px;
	min-width: 0;
	margin: 0;
	padding: 0;
	text-align: left;
}

/* Paragraphe du bouton (pas de classe) : largeur auto */
.brevo-newsletter-block .sib_signup_form p:not([class]) {
	flex: 0 0 auto;
	margin: 0;
	padding: 0;
	display: flex;
}

/* --- Champs de saisie --- */
.brevo-newsletter-block .sib_signup_form input[type="email"],
.brevo-newsletter-block .sib_signup_form input[type="text"] {
	width: 100%;
	height: 56px;
	box-sizing: border-box;
	padding: 0 18px;
	border: 1px solid #d6d6d6;
	border-radius: 10px;
	background: #ffffff;
	color: #000000;
	font-size: 16px;
	line-height: 1.2;
}

.brevo-newsletter-block .sib_signup_form input[type="email"]:focus,
.brevo-newsletter-block .sib_signup_form input[type="text"]:focus {
	outline: none;
	border-color: #00c2bf;
	box-shadow: 0 0 0 3px rgba(0, 194, 191, .18);
}

/* --- Label flottant "material design" (élément créé par le JS) --- */
.brevo-newsletter-block .bn-label {
	position: absolute;
	left: 13px;
	top: 50%;
	transform: translateY(-50%);
	transform-origin: left center;
	padding: 0 5px;
	background: #ffffff;
	color: #8a8a8a;
	font-size: 16px;
	line-height: 1;
	white-space: nowrap;
	pointer-events: none;
	transition: transform .16s ease, color .16s ease, top .16s ease;
}

/* Champ actif (focus) OU déjà rempli -> le label monte sur la bordure */
.brevo-newsletter-block p[class*="-area"]:focus-within .bn-label,
.brevo-newsletter-block p[class*="-area"]:has(input:not(:placeholder-shown)) .bn-label {
	top: 0;
	transform: translateY(-50%) scale(.78);
	color: #00807e;
}

/* --- Bouton d'envoi --- */
.brevo-newsletter-block .sib-default-btn,
.brevo-newsletter-block .sib_signup_form input[type="submit"] {
	height: 56px;
	padding: 0 32px;
	border: 0;
	border-radius: 10px;
	background: #00c2bf;
	color: #ffffff;
	font-size: 16px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .04em;
	white-space: nowrap;
	cursor: pointer;
	transition: background .25s ease-in-out, transform .25s ease-in-out;
}

.brevo-newsletter-block .sib-default-btn:hover,
.brevo-newsletter-block .sib_signup_form input[type="submit"]:hover {
	background: #00bebe;
	transform: translateY(-2px);
}

/* --- Messages de retour Brevo (succès / erreur) --- */
.brevo-newsletter-block .sib-alert-message {
	margin: 16px auto 0;
	max-width: 600px;
	text-align: center;
}

/* --- Mobile : champs et bouton empilés (une ligne = trop étroit) --- */
@media (max-width: 760px) {
	.brevo-newsletter-block .sib_signup_box_inside_1 {
		flex-wrap: wrap;
	}

	.brevo-newsletter-block .sib_signup_form p[class*="-area"],
	.brevo-newsletter-block .sib_signup_form p:not([class]) {
		flex: 1 1 100%;
	}

	.brevo-newsletter-block .sib-default-btn,
	.brevo-newsletter-block .sib_signup_form input[type="submit"] {
		width: 100%;
	}
}
