/*
 * Theme Name: Quartier Harmonie
 * Theme URI: https://quartierharmonie.com/
 * Author: Quartier Harmonie
 * Author URI: https://quartierharmonie.com/
 * Description: Thème minimal
 * Version: 1.0.0
 * Requires at least: 6.0
 * Tested up to: 6.7
 * Requires PHP: 7.4
 * License: GNU General Public License v2 or later
 * License URI: https://www.gnu.org/licenses/gpl-2.0.html
 */

/**
 * Styles de base de WordPress
 * ================================================== */
.alignleft{float:left;margin-right:1.5em}.alignright{float:right;margin-left:1.5em}.aligncenter{display:block;margin-left:auto;margin-right:auto}.wp-caption{max-width:100%;text-align:center}.wp-caption img{max-width:100%;height:auto}.wp-caption-text{font-size:0.9em;color:#666}.gallery{margin:1.5em auto}.gallery-item{display:inline-block;vertical-align:top;margin:0 0 1.5em}.gallery-columns-2 .gallery-item{width:50%}.gallery-columns-3 .gallery-item{width:33.333%}.gallery-columns-4 .gallery-item{width:25%}.screen-reader-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);border:0}.screen-reader-text:focus{position:static;width:auto;height:auto;margin:0;padding:1em;clip:auto;overflow:visible}.sticky{display:block}.entry-content{word-wrap:break-word}.gallery-caption{font-style:italic;text-align:center}.bypostauthor{border-left:3px solid currentColor;padding-left:0.5rem}

/*
body.admin-bar:before {
	content: "";
    background-position: center top;
    background-repeat: no-repeat;
    background-image: url('https://quartierharmonie.com/wp-content/uploads/2025/12/accueil.jpg');
    position: absolute;
    top: 0;
    left: 50%;
	transform: translateX(-50%);
    height: 10682px;
	width: min(100vw, 1920px);
    background-size: cover;
	z-index: -10;
	opacity: 0.4;
}
*/
body.admin-bar.logged-in:before {
    top: 32px;
}



/**
 * Styles généraux
 * ================================================== */
html, body {
	overflow-x: hidden;
}
body {
	padding: 0;
	overflow-x: hidden;
	font-family: "greycliff-cf", sans-serif;
}
.elementor-widget-text-editor li + li {
	margin-top: 20px;
}
.has-submenu .sub-arrow {
	transition: all .3s ease-in-out;
	transform-origin: center;
}
.has-submenu .sub-arrow svg {
	margin-top: 5px;
}
.has-submenu:hover .sub-arrow {
	transform: rotate(90deg);
}
.elementor-nav-menu .sub-arrow .e-font-icon-svg {
	max-height: 15px;
	max-width:  15px;
}



/**
 * Menu sticky
 * ================================================== */
.sticky-nav {
	transition: all 0.3s ease-in-out;
}
.sticky-nav.visible {
	opacity: 1;
	visibility: visible;
}
.sticky-nav.hidden {
	opacity: 0;
	visibility: hidden;
}
body.admin-bar.logged-in .sticky-nav {
	top: 46px;
}
@media (min-width: 782px) {
	body.admin-bar.logged-in .sticky-nav {
		top: 32px;
	}
}



/**
 * Ajustements typos
 * ================================================== */
.elementor-widget-heading .elementor-heading-title[class*=elementor-size-]>a {
	font-family: "the-seasons", Sans-serif;
}
@media (max-width: 767px) {
	.elementor-widget-heading + .elementor-widget-text-editor > p:first-child {
		margin-top: 0;
	}
}



/**
 * Carousels Elementor d'images de modèles
 * ================================================== */
.elementor-image-carousel .swiper-slide figure {
	height: 100%;
}
.elementor-image-carousel .swiper-slide figure img {
	object-fit: cover;
	height: 100%;
}
.elementor-image-carousel-wrapper .elementor-swiper-button-prev,
.elementor-image-carousel-wrapper .elementor-swiper-button-next {
	background-color: var( --e-global-color-secondary );
	border-radius: 50%;
	width: 88px;
	height: 88px;
	display: flex;
	justify-content: center;
	align-items: center;
}



/**
 * Widget : Légende
 * ================================================== */
.elementor-widget-legende_widget {
	max-width: 550px;
}
.elementor-widget-legende_widget ul {
	padding: 0;
}
.elementor-widget-legende_widget li {
	position: relative;
	list-style-type: none;
	padding-left: 35px;
}
.elementor-widget-legende_widget li {
	position: relative;
	list-style-type: none;
	padding-left: 35px;
}
@media (min-width: 992px) {
	.elementor-widget-legende_widget ul {
		display: flex;
		flex-wrap: wrap;
		gap: 15px;
	}
	.elementor-widget-legende_widget li {
		flex: 1 0 45%;
	}	
}
.elementor-widget-legende_widget .legende-color {
	position: absolute;
	width: 18px;
	height: 18px;
	border-radius: 18px;
	top: 0;
	left: 0;
	display: flex;
}
.elementor-widget-legende_widget .legende-color[style*="background:#FFFFFF"]:before {
	content: "";
	flex: 1 0 99%;
	border-radius: inherit;
	box-shadow: 0px 0px 1px 1px rgba(0,0,0,1) inset;
	-webkit-box-shadow: 0px 0px 1px 1px rgba(0,0,0,1) inset;
	-moz-box-shadow: 0px 0px 1px 1px rgba(0,0,0,1) inset;
}
@media (min-width: 992px) and (max-width: 1499px) {
	body:not(.page-id-985) .elementor-form .elementor-field-type-checkbox,
	body:not(.page-id-985) .elementor-form .elementor-field-type-radio {
		flex-direction: column;
	}
}




/**
 * Pied de page : Gérer si on est sur Contact
 * ================================================== */
@media (min-width: 1500px) {
	.maybe-hidden-button:not(:has(.elementor-button-content-wrapper)) {
		padding-bottom: 250px;
	}
}



/**
 * Google Maps
 * ================================================== */
.elementor-widget-google_maps > .elementor-custom-embed {
	flex: 1 0 99%;
	display: flex;
	flex-direction: column;
	min-height: 100%;
}
.elementor-widget-google_maps > .elementor-custom-embed > iframe {
	flex: 1 0 99%;
	min-height: 100%;
}



/**
 * Lightbox
 * ================================================== */
.swiper-zoom-container img {
	background: white;
	padding: 20px;
	display: block;
}



/**
 * Formulaires Elementor
 * ================================================== */
.elementor-form input[type="email"],
.elementor-form input[type="number"],
.elementor-form input[type="date"],
.elementor-form input[type="tel"],
.elementor-form input[type="url"],
.elementor-form input[type="password"],
.elementor-form input[type="text"],
.elementor-form textarea {
    padding: 24px 32px;
}
.elementor-form select {
    padding: 20px 32px;
}
.elementor-form .elementor-select-wrapper {
	flex-direction: column;
}
.elementor-form .elementor-select-wrapper .select-caret-down-wrapper {
	top: 32px;
	right: 20px;
}
.elementor-form .elementor-select-wrapper:after {
	content: "Sélectionnez votre type d'unité";
	flex: 0 0 100%;
	font-size: 15px;
	line-height: 18px;
	color: white;
	margin: 20px 0 0 30px;
}
.elementor-form .elementor-field-type-checkbox,
.elementor-form .elementor-field-type-radio {
	display: flex;
	gap: 30px;
	flex-direction: column;
	align-items: flex-start;
}
.elementor-form .elementor-field-type-checkbox .elementor-field-label,
.elementor-form .elementor-field-type-radio .elementor-field-label {
	height: auto;
	margin: 0;
	position: relative !important;
	top: initial;
	width: auto;
}
.elementor-form .elementor-field-type-checkbox .elementor-field-label:after,
.elementor-form .elementor-field-type-radio .elementor-field-label:after {
	display: block;
	content: "Cochez";
	font-size: 15px;
	line-height: 18px;
	color: white;
	margin: 20px 0 0;
}
.elementor-form .elementor-field-type-checkbox .elementor-field-option,
.elementor-form .elementor-field-type-radio .elementor-field-option {
	display: flex;
	flex-direction: row-reverse;
	font-size: 20px;
	line-height: 24px;
	margin-bottom: 10px;
}
.elementor-form .elementor-field-type-checkbox .elementor-field-option label,
.elementor-form .elementor-field-type-radio .elementor-field-option label {
	flex: 1 1 auto;
}
.elementor-form .elementor-field-type-checkbox input[type="radio"],
.elementor-form .elementor-field-type-radio input[type="radio"],
.elementor-form .elementor-field-type-checkbox input[type="checkbox"],
.elementor-form .elementor-field-type-radio input[type="checkbox"] {
	width: 22px;
	height: 22px;
	border-radius: 22px;
}
@media (min-width: 992px) {
	.elementor-form .elementor-field-type-checkbox,
	.elementor-form .elementor-field-type-radio {
		flex-direction: row;
		flex-wrap: nowrap;
	}
}
.elementor-form .elementor-field-type-checkbox {
	z-index: 3;
}
.elementor-form .elementor-field-type-checkbox .elementor-field-option {
	position: relative;
	padding-right: 40px;
}
.elementor-form .elementor-field-type-checkbox .elementor-field-option input[type="checkbox"] {
	position: absolute;
	top: 0;
	left: -9999rem;
}
.elementor-form .elementor-field-type-checkbox .elementor-field-option:before {
	content: "";
	position: absolute;
	z-index: -2;
	top: 0;
	right: 0;
	height: 22px;
	width: 22px;
	border-radius: 100%;
	background: var(--e-global-color-bdf961f);
}
.elementor-form .elementor-field-type-checkbox .elementor-field-option:has(input:checked):after {
	content: "";
	position: absolute;
	z-index: -1;
	top: 4px;
	right: 4px;
	height: 14px;
	width: 14px;
	border-radius: 100%;
	background-color: var(--e-global-color-primary);
}
.elementor-form .elementor-field-type-submit {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: flex-start !important;
	justify-content: space-between;
}
.elementor-form .elementor-field-type-submit .elementor-button {
	flex: 0 0 auto !important;
	padding: 20px 40px;
	cursor: pointer;
}
@media (min-width: 1200px) {
	.elementor-form .elementor-field-type-submit .elementor-button {
		padding: 20px 75px;
	}
}
@media (min-width: 1500px) {
	.elementor-form .elementor-field-type-submit .elementor-button {
		padding: 20px 100px;
	}
}
.elementor-form .elementor-field-type-submit:before {
	color: var(--e-global-color-bdf961f);
	font-size: 20px;
	line-height: 24px;
	content: "On s'assure de vous répondre dans les plus brefs délais ";
	max-width: 275px;
}
.elementor-form select:invalid {
    color: #a1a1a1;
}
@media (max-width: 1199px) {
	.elementor-field-group {
		flex: 1 0 99%;
	}
}
@media (max-width: 991px) {
	.elementor-form .elementor-field-type-checkbox,
	.elementor-form .elementor-field-type-radio {
		gap: 15px;
	}
	.elementor-form .elementor-field-type-checkbox .elementor-field-label:after,
	.elementor-form .elementor-field-type-radio .elementor-field-label:after {
		margin-top: 10px;
		margin-bottom: 25px;
		font-size: 12px;
	}
	.elementor-field-subgroup {
		width: 100%;
	}
	.elementor-field-option {
		flex-direction: row;
		padding-left: 35px;
		padding-right: 0;
	}
	.elementor-form .elementor-field-type-checkbox .elementor-field-option:before {
		top: 5px;
		left: 0;
		right: auto;
	}
	.elementor-form .elementor-field-type-checkbox .elementor-field-option:has(input:checked):after {
		top: 9px;
		left: 4px;
		right: auto;
	}
}
@media (max-width: 767px) {
	.elementor-form .elementor-field-type-submit {
		flex-direction: column;
		gap: 20px;
	}
	.elementor-form .elementor-field-type-submit .elementor-button {
		width: 100%;
	}
}
.elementor-form-fields-wrapper {
	align-items: start;
}

@media (min-width: 1200px) {
	.elementor-form {
		font-size: 18px !important;
	}
	.elementor-form .elementor-field-type-checkbox,
	.elementor-form .elementor-field-type-radio {
		gap: 20px;
	}
	.elementor-form .elementor-field-type-checkbox .elementor-field-label,
	.elementor-form .elementor-field-type-radio .elementor-field-label {
		flex: 1 1 auto;
	}
	.elementor-form .elementor-field-type-checkbox .elementor-field-subgroup,
	.elementor-form .elementor-field-type-radio .elementor-field-subgroup {
		flex: 0;
	}
	.elementor-form .elementor-field-group .elementor-field,
	.elementor-form .elementor-field-subgroup label {
		font-size: 16px !important;
		line-height: 24px !important;
	}
}




