/*
/*
 Theme Name: Divi Child-La-Florida
 Theme URI: 
 Description: Divi Child Theme
 Author: Olivier Rochefort
 Author URI: 
 Template: Divi
 Version: 1.0.0
*/

/* =Theme customization starts here
------------------------------------------------------- */

@font-face {
	font-family: "VolvoBroad Regular";
	font-style: normal;
	font-weight: normal;
	src: url("w-fonts/VolvoBroad.woff") format("woff");
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: "VolvoBroad Regular", sans-serif !important; /* Ajoutez toujours une police de secours */
}
.et_pb_module_heading .et_pb_text_inner {
	/* Remplacez .et_pb_text_0 par la classe de votre module */
	font-family: "VolvoBroad Regular", sans-serif !important;
}
.et_pb_module.et_pb_text.h3-distribution-florida .et_pb_text_inner h3 {
	/*
    1. min: 1.5rem (Taille minimale pour les petits écrans/mobiles)
    2. preferred: 5vw (Taille dynamique qui s'adapte à la largeur de la fenêtre)
    3. max: 2rem (Taille maximale souhaitée sur desktop)
  */
	/* fontSize minimum 1.5rem, idéal 5vw, maximum 2rem */
	font-size: clamp(1.5rem, 5vw, 2rem) !important;
	line-height: 1.2 !important; /* Mieux pour la réactivité */
}

/* menu perso */
/* ======================================= */
/* I. STYLES DESKTOP PAR DÉFAUT (> 980px) */
/* ======================================= */

.et-l.et-l--header .row-menu-florida {
	padding: 20px !important;
	justify-content: center;
}
/* Retrait de la bordure du logo + RÉDUCTION DE LA TAILLE DU LOGO DANS LE MODULE MENU */
.menu-bouton .et_pb_menu__logo {
	border-width: 0px !important;
	padding: 0px !important;
	max-width: 250px !important;
	width: 250px !important;
}

/* ALIGNEMENT VERTICAL ET HORIZONTAL DES LIENS DU MENU */
.menu-bouton .et_pb_menu__menu > nav > ul {
	display: flex !important;
	align-items: center !important;
	justify-content: flex-start !important; /* Aligner à droite */
	height: 100% !important;
}
.menu-bouton .et_pb_menu__menu > nav > ul > li {
	height: auto !important;
	white-space: nowrap !important; /* Empêche tout passage à la ligne */
}

/* Styles des liens de menu (boutons) - COMPACTION ET LUSTRÉ */
.menu-bouton .et_pb_menu__menu > nav > ul > li > a {
	padding: 6px 10px; /* Compaction */
	/* border: 2px solid #2e5b9d;*/
	border-radius: 5px;
	margin-right: 6px;
	display: flex;
	text-decoration: none !important;
	text-transform: uppercase;
	font-weight: bold;
	/* background-color: #ffffff !important; */
	color: #ffffff !important;
	/* EFFET LUSTRÉ 
	background: linear-gradient(
		to bottom,
		rgba(255, 255, 255, 0.399) 0%,
		rgba(255, 255, 255, 0) 50%,
		rgba(248, 243, 243, 0.733) 100%
	) !important;

	transition: all 0.3s ease;*/
}

/* Taille de police réactive avec CLAMP() pour le menu (Max. 15px) */
.menu-bouton .et_pb_menu__menu > nav > ul > li > a {
	font-size: clamp(12px, 1.8vw, 18px) !important;
}

/* Effet au survol (Hover) des liens du menu */
.menu-bouton .et_pb_menu__menu > nav > ul > li > a:hover {
	background-color: #2e5b9d !important;
	color: #ffffff !important;
	border-color: #2e5b9d !important;
	cursor: pointer;
	background: none !important; /* Retire l'effet lustré au survol */
}

/* Style du bouton BILLETTERIE (Desktop) */
.bouton-billetterie .et_pb_button {
	background-color: #2e5b9d !important;
	color: #ffffff !important;
	border-radius: 5px !important;
	border: none !important;
	padding: 10px 20px !important;
	text-transform: uppercase !important;
	font-weight: bold !important;
	font-size: clamp(16px, 3vw, 20px) !important;
	transition: all 0.3s ease;
}

/* Effet au survol du bouton BILLETTERIE (Desktop) */
.bouton-billetterie .et_pb_button:hover {
	background-color: transparent !important;
	color: #2e5b9d !important;
	border: 2px solid #2e5b9d !important;
}

/* ======================================= */
/* II. STYLE ÉCRANS MOYENS (981px à 1315px) */
/* Gère la compaction maximale des boutons pour les tablettes/petits PC */
/* ======================================= */
@media only screen and (min-width: 981px) and (max-width: 1315px) {
	/* Compaction maximale des liens de menu */
	.menu-bouton .et_pb_menu__menu > nav > ul > li > a {
		padding: 4px 8px !important;
		margin-right: 4px !important;
	}

	/* Réduction de la taille de police Max. (Max. 13px) */
	.menu-bouton .et_pb_menu__menu > nav > ul > li > a {
		font-size: clamp(11px, 1.3vw, 13px) !important;
	}

	/* Compacter le bouton BILLETTERIE */
	.bouton-billetterie .et_pb_button {
		padding: 6px 12px !important;
		font-size: 13px !important;
	}
}

/* ======================================= */
/* III. STYLES MOBILE FINAL (<= 980px) */
/* Gère l'affichage empilé pour téléphones */
/* ======================================= */
@media only screen and (max-width: 980px) {
	/* CORRECTION Z-INDEX POUR FORCER LE MENU OUVERT À ÊTRE AU-DESSUS */
	.menu-bouton .et_mobile_menu {
		z-index: 99999 !important;
		background-color: #2e5b9d !important;
	}
	.menu-bouton .et_mobile_menu ul {
		background-color: #2e5b9d !important;
	}
	/* 1. FLEXBOX SUR LA RANGÉE (Pour gérer l'ordre Logo/Menu/Bouton) */
	.row-menu-florida {
		display: flex !important;
		flex-wrap: wrap !important;
		align-items: center;
		margin-left: 0 !important;
		margin-right: 0 !important;
		padding: 10px 10px !important;
	}

	/* Module Menu (Logo + Hamburger) - Pleine largeur */
	.menu-bouton {
		width: 100% !important;
		order: 1 !important;
		margin: 0 !important;
		padding: 5px 15px 5px 15px !important;
	}

	/* Réglage du Logo à l'intérieur du Module Menu (Utilisation de float) */
	.menu-bouton .et_pb_menu__logo {
		max-width: 150px !important;
		order: 1 !important;
		float: left !important;
	}

	/* Hamburger à l'intérieur du Module Menu (Utilisation de float) */
	.menu-bouton .et_pb_menu__menu-button {
		color: #ffffff !important;
		font-size: 35px !important;
		float: right !important;
		line-height: 1.2 !important;
		margin-top: 5px !important;
	}
	/* Nettoyage du flottant */
	.menu-bouton::after {
		content: "";
		display: table;
		clear: both;
	}

	/* Module Bouton BILLETTERIE (Pleine largeur sur la deuxième ligne) */
	.bouton-billetterie {
		width: 95% !important;
		order: 2 !important;
		margin: 10px auto !important;
		padding-top: 0 !important;
	}

	/* Ajustement du bouton BILLETTERIE */
	.bouton-billetterie .et_pb_button {
		padding: 12px 0px !important;
		font-size: 16px !important;
		text-align: center !important;
		display: block !important;
	}
	.mobile_menu_bar {
		margin-bottom: 10px !important;
	}
	/* STYLE DU MENU OUVERT (Liste propre) */
	.menu-bouton #mobile_menu {
		background-color: #2e5b9d !important;
	}
	.menu-bouton #mobile_menu li a {
		border: none !important;
		border-radius: 0 !important;
		margin: 0 !important;
		background-color: transparent !important;
		color: #ffffff !important;
		padding: 15px 20px !important;
		border-bottom: 1px solid rgba(255, 255, 255, 0.1);
		text-transform: uppercase !important;
	}
	.menu-bouton #mobile_menu li a:hover,
	.menu-bouton #mobile_menu li.current-menu-item a {
		background-color: rgba(0, 0, 0, 0.1) !important;
		color: #f8e3a2 !important;
	}
	.menu-bouton .et_mobile_menu_close {
		padding-bottom: 10px !important;
	}
}
/* end menu perso */

/* taxonimi filter dans lafloridaloop*/
.tx-ville.dmach-postmeta-value span {
	text-align: center !important;
}
.divi-engine-grid-list-view-switcher {
	display: none !important;
}
/* == Styles pour les modules de statut == */

.et_pb_de_mach_acf_item.statut-select-activator .en_vente {
	display: none !important;
	/* border: 2px solid #2082c4 !important;
	border-radius: 25px !important;
	padding: 1rem 0.6rem !important;
	background: none !important; */
}

.et_pb_de_mach_acf_item.statut-select-activator .prevente {
	display: none !important;
	/* border: 2px solid #2082c4 !important;
	border-radius: 25px !important;
	padding: 1rem 0.6rem !important;
	background: none !important;*/
}

.et_pb_de_mach_acf_item.statut-select-activator .a_venir {
	display: none !important;
	/* border: 2px solid #ffffff !important;
	border-radius: 25px !important;
	color: #ffffff !important;
	padding: 1rem 0.6rem !important;
	background: none !important;*/
}

.et_pb_de_mach_acf_item.statut-select-activator .annule {
	border: 2px solid #ff0000 !important;
	border-radius: 25px !important;
	padding: 1rem 0.6rem !important;
	color: #ff0000 !important;
	background: none !important;
}

/* Formulaire */
