@charset "utf-8";

@keyframes t21 {
	0% {transform:scale(1);opacity:1;}
	100% {transform:scale(0);opacity:0;}
}

@keyframes t21s {
	0% {transform:scale(0);opacity:0;}
	100% {transform:scale(1);opacity:1;}
}

@keyframes t22 {
	0% {transform:translateY(0);}
	100% {transform:translateY(300px);opacity:0;}
}

@keyframes t22s {
	0% {transform:translateY(-200%);opacity:0;}
	100% {transform:translateY(0);opacity:1;}
}

#BM111 nav {
	transition: all .6s;
	opacity: 0;
}

html:not(.scrollEnHaut) #BM111 nav {opacity:1;}

h1, h2, h3 {margin:0;}
h2 {font-size:1.8em;line-height:1.1;color:#292929;font-weight:normal;}
footer {margin-top:0;}

#accueil {
	height: auto;
	max-height: none;
	height: calc(100vw - var(--scrollbar-width));
}

#accueil .texte #accTxt {
	width: 100%;
	height: 100%;
	font-size: 1.1em;
}

#accueil .texte #accTxt > * {
	margin: auto;
	padding: 25px 0;
}

#accTxt_2 > div {
	position: sticky;
	top: 150px;
	top: 9.5vw;
}

#accTxt_2.avantRech > div {z-index:100;}
#repDesti {margin:2px 0;}
.avantRech #repDesti, .avantRech #repDestiFerme {display:block;}
.blocRech {display:flex;}

#accTxt_1 {
	display: flex;
	flex-direction: column;
}

#accTxt_1_1 {flex:1;}

#accTxt_1_1 > div {
	position: sticky;
	top: 7vw;
	text-align: center;
}

#accueil .titre {
	font-size: 7.5vw;
	white-space: nowrap;
	text-align: center;
	line-height: 1.1;
	animation-duration: 1s;
	animation-fill-mode: forwards;
}

#accueil .titre2 {
	display: none;
}

input[type="text"], button {
	outline: none;
	margin: auto;
	border: 0;
	border-radius: 20px;
	vertical-align: bottom;
}

.blocRech input {
	width: 100%;
	box-shadow: 0 0 5px 0 #00000047;
}

#accueil button, #accueil .btn {
	color: #fff;
	background-color: var(--color2od);
	background-image: linear-gradient(135deg, #ffffff33 0%, transparent 30%, transparent 70%, #00000022 100%);
}

#btnCommentQuand {
	top: 0;
	transition: left 1s, top .5s cubic-bezier(.4, 0, 1, 1), background-color .3s, font-size 1.5s;
}

#accueil .btn {
	border-radius: 20px;
	display: inline-block;
}

#accueil button:hover, #accueil .btn:hover {
	background-color: #d72929;
	box-shadow: 0 0 0 1px #fff6, 0 0 0 9px #ce26227e;
}

#accueil button, #accueil .btn, .blocRech input {
	padding: 5px 20px;
	height: 38px;
}

#accTxt_1 button img {
	width: 17px;
	height: 12px;
	opacity: .7;
	margin: -2px 4px 0 0;
}

#accueil #reqPropo {
	white-space: nowrap;
	margin-top: 9px;
	width: 100%;
	text-align: center;
	position: relative;
	transition: 1s opacity;
}
#accueil #reqPropo::before {
	content: 'ou';
	color: #fff;
	text-shadow: 0 0 4px #000;
	display: block;
}
#accTxt_2.avantRech #reqPropo {visibility:hidden;}
#accueil #reqPropo a.btn {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
}


/* Boîte à outils (pour mobile) */
#outils {text-align:center;}

#outils .og, #outils .od, #outils .oc {
	display: inline-block;
	text-transform: uppercase;
	color: #fff;
	cursor: pointer;
	height: 91px;
	font-size: 1.1em;
	padding: 20px 0;
}

#outils .og, #outils .od {
	background-color: #e84446;
	background: linear-gradient(135deg, #e55656 0%, #ce3232 100%);
	width: 50%;
	border-bottom: 1px solid #fff;
}

#outils .og {border-right:1px solid #fff;}

#outils .oc {
	background-color: var(--bar-menu-color);
	width: 100%;
	padding: 25px 0;
}

#outils div:hover, #outils div.b:hover {background-color:#187489;}

#outils div:active, #outils div.b:active {background-color:yellowgreen;}

#outils a:hover {text-decoration:none;}

#outils img {
	height: 30px;
	width: 45px;
	margin-bottom: 6px;
}

#outils a {
	color: #fff;
	display: block;
}

#outils .sp1 img {
	transform: scale(1.2);
}
/* *** */


section {
	margin: 40px 0;
	padding: 20px 0;
}

#envie {
	text-align: center;
	padding-top: 10px;
}

.sti {
	margin-top: 8px;
	margin-bottom: 15px;
	opacity: .8;
	line-height: 1.2;
}

#envie .sti {margin-bottom:5px;}

#envie a {color:#000;}

#envie .bloc1 {
	display: flex;
	margin-top: 30px;
}

#envie .bloc1 > div:nth-child(2) {width:100%;}

#envie .bloc1 img {width:150px;}

#envie ul {
	padding: 0;
	list-style: none;
	justify-content: center;
	font-size: 1.1em;
	display: grid;
	grid-auto-flow: column;
	grid-template-rows: repeat(6, 1fr);
	grid-template-columns: repeat(auto-fit, minmax(50%, 1fr));
}

#envie ul li {
	margin: 5px;
	line-height: 1.4;
	white-space: nowrap;
	max-width: 100%;
}

#envie ul li a {
	display: block;
	border: 2px solid #d6d6d6;
	border-radius: 15px;
	padding: 5px 12px;
	width: 100%;
	height: 100%;
	transition: all .3s;
	text-decoration: none;
}

#envie ul li a:hover {
	border-color: var(--btn-hover-color);
	transform: scale(1.09);
}

#envie h3 {
	font-size: 1.1em;
}

#decorg {
	clear: both;
	padding-top: 0;
}

#oqc {
	display: flex;
	padding-top: 0;
	padding-bottom: 0;
	gap: 5px;
}

#qui {
	background-color: #f2f2f2;
	background-image: url(/images/accueil/index/mappemonde.png);
	width: 100%;
	background-repeat: no-repeat;
	background-position: center 20%;
	background-size: 95%;
	text-align: center;
	padding: 15px;
}

#qui img.nous {
	max-width: 200px;
	border-radius: 50%;
	margin: 30px;
}

#qui h2 {
	font-size: 1.8em;
	margin-bottom: 30px;
}

#qui #texteDecouverte {
	font-size: .9em;
	opacity: .9;
	text-align: justify;
	max-width: 600px;
	margin: 0 auto;
	padding-bottom: 30px;
}

#qui #texteDecouverte p {
	margin-top: 0;
	margin-bottom: 1em;
	line-height: 1.2;
}

#qui img.plus {
	float: right;
	opacity: .4;
	margin-top: -16px;
}

#qui img.plus:hover {opacity:.8;}

#qui #texteDecouverte {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 10;
	overflow: hidden;
	max-height: calc(10 * 1.2em);
	transition: all 1s;
}

#qui #texteDecouverte.clampOuv {
	display: block;
	max-height: 500px;
}

#qui .clampPlus::before {content:'\2771';display:inline-block;transform:rotate(90deg);opacity:.4;}

.bonplan {
	text-align: center;
	background-color: #f2f2f2;
}

#ouquandBlocs {
	display: flex;
	margin: 0 -15px;
}

#ouquandBlocs article {
	flex: 1;
	margin: 15px;
	font-size: .9em;
}

#ouquandBlocs h2 {
	margin-bottom: 15px;
}

#idee {
	margin-top: 40px;
	text-align: center;
}

#idee .carou {
	margin-top: 30px;
}

.MiniaGuide .ouv .t {
	height: auto;
	max-height: 47px;
	overflow: hidden;
	transition: max-height .8s;
	-webkit-mask-image: none;
	line-height: 1.1;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	padding-bottom: 0;
	border-bottom: 0 solid transparent;
}

.MiniaGuide .ouv:hover .t {
	position: relative;
	z-index: 1;
	height: auto;
	max-height: 250px;
	-webkit-mask-image: linear-gradient(to top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 1) 5px, rgba(0, 0, 0, 1) 100%);
	-webkit-line-clamp: initial;
	display: block; /* pour Firefox, à cause du line-clamp */
	padding-bottom: 10px;
}

.MiniaGuide article h3 {padding-top:0;}

#oqc article {
	font-size: .9em;
	line-height: 1.3em;
}

#oqc article > a {
	color: initial !important;
	text-decoration: none;
	border-radius: 25px;
	display: block;
	padding: 15px 20px;
	width: 100%;
	height: 100%;
	transition: all .2s;
}

#oqc article a:hover {
	box-shadow: 0 0 0 2px #89b2e3bf inset;
}

#oqc article .be h2 {
	margin-bottom: 5px;
}

#oqc article .be > div {
	padding: 5px 0;
	overflow: hidden;
}

#partenaire {
	text-align: center;
	padding-bottom: 0;
}

#partenaire h2 {
	max-width: 600px;
	border-bottom: 2px solid #888;
	margin: auto;
	padding-bottom: 25px;
}

#oqc img {
	width: 56px;
	height: 56px;
	max-height: 49px;
	float: left;
	padding: 6px 19px 0 0;
	opacity: .8;
}

#partenaire > div {
	margin: 15px auto;
}

#partenaire > div img {
	margin: calc(5px + .5vw);
}

#nl {
	display: flex;
	text-align: center;
	align-items: center;
	background-color: #b2bcbf;
	padding: 0;
	margin: 0;
}

#nl p {
	margin-bottom: 10px;
}

#nl > div {
	flex: 1 1 100%;
}

#nl > div:nth-child(1) {
	display: none;
}

#nl > div:nth-child(2) div {
	margin: 20px;
}

#nl h2 {
	margin-bottom: 15px;
	font-weight: bold;
}

#nl input, #nl .bout {
	height: 38px;
}

#nl input {
	margin: 0;
	width: 85%;
	max-width: 350px;
	padding-right: 35px;
}

#nl .bout {
	display: inline-block;
	margin: 0 0 0 -32px;
	width: 50px;
	background-color: #bbb;
	border: 1px solid #fff;
	border-radius: 20px;
	vertical-align: bottom;
	cursor: pointer;
	display: inline-flex;
	justify-content: center;
}

#nl .bout img {
	width: 16px;
	height: 11.1px;
	align-self: center;
}

#nl .bout:hover {
	background-color: var(--btn-hover-color);
}

#nl .bout:hover img {
	filter: invert(1);
}

.v990seul {
	flex-wrap: wrap;
}

/* redefinition */
.MiniaGuide article.MiniaSpan2 {
	display: flex;
	flex-direction: column;
	justify-content: space-evenly;
	text-align:center;
	flex: 0 0 480px !important;
	max-width: calc(100% - 40px);
}
.MiniaGuide article.MiniaSpan2 img {
	width: 95%;
	width: 80%;
}
.carou .MiniaGuide article {flex:0 0 260px;}
.carou .tuiles .tu.mappemonde {
	text-align: center;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}




/* AFTER MOBILE */

@media screen and (min-width: 480px) {
	.blocRech input {width:15em;}
	.avantRech .blocRech {
		width: fit-content;
		margin: auto;
		margin-bottom: 0;
	}
	#outils .og, #outils .od, #outils .oc {font-size:1em;}
	#outils .o1, #outils .o3 {width:33%;}
	#outils .o2 {width:34%;}
	#outils .o1, #outils .o2 {border-right:1px solid #fff;}
	#outils .o3 {border-right:0 solid #fff;}
	#qui #texteDecouverte {
		font-size: .85em;
		columns: 2;
		column-gap: calc(15px + 1vw);
		display: block;
		max-height: none;
	}
	#qui .clampPlus {display:none;}
}

@media screen and (min-width: 530px) {
	#envie ul {
		display: flex;
		flex-wrap: wrap;
	}
	#envie ul li {flex:0 0 160px;}
}

@media screen and (min-width: 640px) {
	#BM111 nav {opacity:1;}
	#accueil {
		margin-bottom: 30px;
		height: 50vh;
		max-height: 24vw; /* ratio calculé par l'image d'origine 480x100/1920=25 ; -1 par securité */
		/* max-height: 23.4vw; */ /* ratio calculé par l'image d'origine 450x100/1920=23.4 */
	}
	#accueil .fond {border-bottom:1px solid #999;}
	#accueil .texte #accTxt {
		display: flex;
		justify-content: space-evenly;
		align-items: center;
		flex-direction: row-reverse;
	}
	#accueil .titre {
		font-size: 3vw;
		margin-bottom: 5px;
	}
	#accueil .titre2 {display:block;}
	.blocRech input, #accueil button, #accueil .btn {
		font-size: .9em;
	}
	#accueil .texte #accTxt > * {
		padding: 0;
		height: 100%;
	}
	#accLegende {display:block;}
	#BlocOutils {display:none;}
	#oqc article .be h2 {margin-top:0;}
	#nl > div:nth-child(1) {
		display: block;
		background-repeat: no-repeat;
		background-size: cover;
		height: 240px;
		background-position: bottom;
	}
	.MiniaGuide article.MiniaSpan2 {max-width:none;}
	#repDesti {margin-left:-10px;}
}

@media screen and (min-width: 640px) and (max-width: 1199.5px) {
	#nl > div:nth-child(1) {background-image:url(/images/accueil/index/nl-medium.jpg);}
	#accueil button, #accueil .btn, .blocRech input {
		padding: 0 20px;
		height: 25px;
		font-size: .9em;
	}
}

@media screen and (min-width: 990px) {
	#accTxt_2 > div {
		top: calc(6.5vw + 70px);
		margin-bottom: 0;
	}
	#envie .bloc1 > div:nth-child(odd) {
		flex: 0 0 20%;
		align-self: center;
	}
	#envie .bloc1 > div:nth-child(1) {
		background-image: url(/images/accueil/index/valise.jpg);
		background-repeat: no-repeat;
		background-position: center;
		background-size: contain;
		height: 240px;
	}
	#oqc article:nth-child(2) {
		border-left: 1px solid #7b9398;
		border-right: 1px solid #7b9398;
		padding: 0 5px;
	}
	#oqc.v990seul article {flex:1;}
}

@media screen and (min-width: 1200px) {
	#nl > div:nth-child(1) {
		background-position-y: inherit;
		background-image: url(/images/accueil/index/nl-large.jpg);
	}
}




/*********************/
/*** Modifs Tuiles ***/
.carou.larg .tuiles {
	width: 100%;
	margin: 0; /* évite un -5px qui pose pb sur mobile (dépassement de la largeur) */
}
#decorg .tuiles {
	margin: 0; /* évite un -5px qui pose pb sur mobile (dépassement de la largeur) */
}
#envie .tuiles .tu {
	max-width: 28vw;
	padding-top: 10px;
	overflow: initial;
	border-radius: 50%;
}
#envie .tuiles .tu .d2 {
	overflow: hidden;
	/* border-radius: 20px; */
	border-radius: 50%;
	transition: all .3s;
}
#envie .tuiles .tu:hover .d2 {
	transform: scale(1.08);
	z-index: 1;
}
#envie .carou .btn {top:41%;}
#envie .tuiles .tu .txBas {padding-bottom:0;}
#decorg .tuiles {justify-content:space-between;}
#decorg .tuiles h2 {
	margin-bottom: 20px;
	font-size: 5vw;
	line-height: 1.1;
	color: #2d2d2d;
	font-weight: normal;
}
#decorg .tuiles .tu a {color:inherit;}
#decorg .tuiles .tuA .d2 > img {transition:all .3s;}
#decorg .tuiles .tuA:hover .d2 > img {transform:scale(1.05);}
#idee .tuiles .tu {border-radius:22px;}
#idee .MiniaGuide .ouv > div + a img {border-radius:22px;}

@media screen and (min-width: 480px) {
	#envie .tuiles .tu {max-width:22vw;}
	#decorg .tuiles h2 {font-size:1.8em;}
}

@media screen and (min-width: 640px) {
	#envie .tuiles .tu {max-width:130px;}
	#qui {
		background-position: center;
		background-size: 95%;
	}
}

@media screen and (max-width: 780px) {
	#decorg .tuiles {justify-content:center;}
	#decorg .tuiles .tu {max-width:500px;}
	#decorg .tuiles.max2 .tu {flex:0 0 calc(100% - 10px) !important;}
}

@media screen and (min-width: 990px) {
	#decorg .tuiles {margin:-15px;}
	.carou.larg .tuiles {
		scroll-padding-left: 515px;
		-webkit-mask-image: linear-gradient(to right, rgba(0, 0, 0, .2) 0%, rgba(0, 0, 0, 1) calc(50vw - 495px), rgba(0, 0, 0, 1) calc(100vw - (50vw - 495px)), rgba(0, 0, 0, .2) 100%);
	}
	#envie .carou.larg .tuiles article {
		scroll-margin: calc(calc(100vw - 1355px) / 2);
		flex: 0 0 calc(940px / 6);
		max-width: none;
	}
	#envie h3 {font-size:1.2em;}
	#idee .carou.larg .tuiles article {
		scroll-margin: calc(calc(100vw - 1520px) / 2);
		flex: 0 0 240px;
		max-width: none;
	}
	#qui {background-size:900px;}
	#qui #texteDecouverte p {line-height:inherit;}
	.carou.larg .tuiles article:first-child {margin-left:calc(calc(100% - 1005px) / 2);}
	.carou.larg .tuiles article:last-child {margin-right:calc(calc(100% - 1005px) / 2);}
	.carou.larg .btn.prev {left:0;}
	.carou.larg .btn.next {right:0;}
	.carou .MiniaGuide {gap:5px;}
}

@media screen and (min-width: 1400px) {
	#accueil #reqPropo {
		position: absolute;
		top: 0;
		left: 255px;
		margin: 0;
	}
	#accueil #reqPropo::before {
		display: inline-block;
		margin: 0 15px;
		position: absolute;
		top: 5px;
		left: 5px;
	}
	#accTxt_2.avantRech #reqPropo {visibility:hidden;}
}

@media screen and (min-width: 1600px) {
	.carou.larg .tuiles {
		scroll-padding-left: 515px;
		-webkit-mask-image: linear-gradient(to right, rgba(0, 0, 0, .2) 0%, rgba(0, 0, 0, .2) calc(50vw - 915px), rgba(0, 0, 0, 1) calc(50vw - 615px), rgba(0, 0, 0, 1) calc(100vw - (50vw - 615px)), rgba(0, 0, 0, .2) calc(100vw - (50vw - 915px)), rgba(0, 0, 0, .2) 100%);
	}
	.carou .MiniaGuide {gap:10px;}
	#envie .carou.larg .tuiles article {
		flex: 0 0 180px;
		scroll-margin: calc(calc(100vw - 1415px) / 2);
	}
	#idee .carou.larg .tuiles article {
		flex: 0 0 300px;
		scroll-margin: calc(calc(100vw - 1635px) / 2);
	}
	.carou.larg .tuiles article:first-child {margin-left:calc(calc(100% - 1230px) / 2);}
	.carou.larg .tuiles article:last-child {margin-right:calc(calc(100% - 1230px) / 2);}
}
/* *** *** */
