/***********
 * FRAME 1 *
 * *********/
.frame-header {
	height: 50vh;
}

.frame-header .mail {
	width: 360px;
	max-width: 100%;
	
	box-shadow: 1px 1px 16px 0 rgba(0, 0, 0, 0.2), -1px -1px 16px 0 rgba(0, 0, 0, 0.2);
	padding: 30px 5px;
	box-sizing: border-box;
}

.frame-header .tel {
	margin: 40px auto 0 auto;
}

.frame-header .infos {
	position: absolute;
	right: 0;
	bottom: 40px;
	
	padding: 40px 120px 40px 40px;
	box-sizing: border-box;
	text-align: left;
}

.frame-header .infos p {
	margin: 0 0 20px 0;
	font-weight: 500;
}

.frame-header .infos i {
	display: block;
	font-size: 18px;
}

.frame-header .rectangle {
	position: absolute;
	left: 0;
	top: 140px;
}

.frame-header .rectangle > div {
	width: 320px;
	height: 100px;
}

.frame-header .rectangle .top {
	margin: 0 0 80px 0;
}








/***********
 * FRAME 2 *
 * *********/
.frame-2 {
	position: relative;
	height: calc(50vh - 159px);
}

.frame-2 .map {
	height: 100%;
}














/* Responsive
–––––––––––––––––––––––––––––––––––––––––––––––––– */

/* Plus petit que 1500
–––––––––––––––––––––––––––––––––––––––––––––––––– */
@media (max-width: 1500px) {
	.frame-header {
		display: block;
		height: auto;
		padding: 40px 0 0 0;
		word-break: break-word;
	}
	
	.frame-header > .container {
		padding: 0 20px 40px 20px;
	}
	
	.frame-header .infos {
		position: static;
		display: block;
		text-align: center;
		padding: 40px 20px;
	}
}



/* Plus petit que 1150
–––––––––––––––––––––––––––––––––––––––––––––––––– */
@media (max-width: 1150px) {
	.frame-header .rectangle {
		display: none;
	}
}






/*-- HAUTEUR --*/

/* Plus petit que 900
–––––––––––––––––––––––––––––––––––––––––––––––––– */
@media (max-height: 900px) {
	.frame-header {
		display: block;
		height: auto;
		padding: 40px 0 0 0;
	}
	
	.frame-2 {
		height: 400px;
	}
}