@media screen and (max-width: 1280px) {
	
	/* >>> typos */
	h2.alternative { font-size: 2.75em; }
	
	/* header / espacements */
	#header { height: 120px; }
	.header-content { 
		position: relative;
		max-width: 1700px;
	}
	#menu { height: 80px; }
	#menu .sous-menu {
		top: 119px;
		min-height: calc(100vh - 121px);
	}
	#menu .sous-menu ul li a { 
		padding: 10%;
		font-size: .875em;
	}
	body.fixed_head ._page { padding-top: 120px; }
	body.fixed_head #header { 
		height: 80px;
		position: fixed; z-index:1001;
		width: 100%; left:0; top:0;
	}
	body.fixed_head #logo-header { 
		max-width: 280px;
		margin-left: -15px;
		padding: 10px 15px;
	}
	body.fixed_head #menu { height: 80px; }
	body.fixed_head #menu-top { display: none }
	body.fixed_head #menu .sous-menu {
		top: 79px;
		min-height: calc(100vh - 81px);
	}
	
	/* >>> footer */
	.footer-content_info {
		width: 25%;
		padding: 0;
	}
	.logo-footer { margin: 0 0 2em }
	#nav-footer {
		max-width: 820px;
		padding-bottom: 60px;
		width: 75%;
	}
	
}

@media screen and (max-width: 1024px) {
	
}

@media screen and (max-width: 980px) {
	
	/* >>> typos */
	h2 { font-size: 2em; }
	h3 { font-size: 1.5em; }
	h2.alternative { font-size: 2.5em; }
	
	/* >>> alt navigation */
	#header { padding: 0 20px }
	#logo-header { 
		width: 80%;
		max-width: 280px;
		margin-left: -15px;
		padding: 10px 15px;
	}
	#menu-alt { display:block }
	#menu {
		top:0;
		left: -260px;
		bottom:0;
		width: 260px;
		height: 100%;
		z-index: 1002;
		padding: 50px 0 0;
		position: fixed;
		background-color: #fff;
		-webkit-transition: left .3s;
		-o-transition: left .3s;
		transition: left .3s;
		overflow-y: hidden;	
	}
	#menu-top { width: 100%; }
	#menu-top a.rs-bouton {
		margin: 0 2px 0 0;
		-webkit-box-flex: 0;
		    -ms-flex: 0 0 auto;
		        flex: 0 0 auto;
	}
	#menu-top a:first-child { border-radius: 0 }
	#menu-top a.tel-bouton {
		margin: 0;
		text-align: center;
		-webkit-box-flex: 1;
		    -ms-flex: 1 1 auto;
		        flex: 1 1 auto;
	}
	#menu > ul { 
		display: block; 
		overflow: auto;
		height: 100%; 
	}
	#menu > ul > li { 
		display: block; 
		text-align: left; 
		height: auto; 
	}
	#menu > ul > li > a { 
		display: block; 
		padding: 8px 20px; 
		line-height: normal; 
	}
	#menu li.first-item > a { position:relative; }
	#menu li.first-item > a:after {
		content:"+";
		position: absolute;
		right: 10px; top: 50%;
		margin-top: -15px;
		font-weight: 400;
		font-size: 20px;
		color: #d8b35f
	}
	#menu li.first-item.ss-menu-opened > a:after { content:"-"; color:#d8b35f }
	/* --- */
	#menu .sous-menu {
		padding: 0;
		height: auto;
		position: static;
		background-color: #f4ead7;
		min-height: inherit;
		padding: 10px 0;
	}
	#menu .sous-menu ul { display: block; }
	#menu .sous-menu ul li { 
		padding: 0;
		width: 100%;
	}
	#menu .sous-menu ul li a {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
		-webkit-box-pack: justify;
		    -ms-flex-pack: justify;
		        justify-content: space-between;
		background-color: #f4ead7;
		padding: 0 10px;
	}
	#menu .sous-menu ul li a span {
		display: block;
		text-align: left;
		max-width: 150px;
		padding: 0 0 0 10px;
		line-height: 1.3em;
		-webkit-box-flex: 1;
		    -ms-flex: 1 1 auto;
		        flex: 1 1 auto;
	}
	#menu .sous-menu ul li .menu-thumb {
		width: 60px;
		height: 60px;
		max-width: 60px;
		-webkit-box-flex: 0;
		    -ms-flex: 0 0 auto;
		        flex: 0 0 auto;
	}
	#menu .sous-menu ul li a:hover { 
		color: #d8b35f; 
		-webkit-transform: translateY(0); 
		    -ms-transform: translateY(0); 
		        transform: translateY(0);
	}
	#menu .sous-menu ul li.active a { color: #d8b35f; }
	body.fixed_head #header { height: 60px; }
	body.fixed_head #logo-header { 
		padding: 10px;
		max-width: 200px; 
	}
	body.fixed_head #menu { height: 100%; }
	body.fixed_head #menu-top { 
		display: -webkit-box; 
		display: -ms-flexbox; 
		display: flex;
	}
	body.fixed_head #menu .sous-menu {
		top: 0;
		min-height: inherit;
	}
	body.menu-opened #menu-overlay { display:block; opacity:1; }
	body.menu-opened #menu { left:0; }
	
	/* >>> footer */
	#footer { padding: 30px 10px }
	.footer-content {
		-webkit-box-pack: center;
		    -ms-flex-pack: center;
		        justify-content: center;
	}
	.footer-content_info {
		width: 50%;
		padding: 0 10px;
		text-align: right;
	}
	.logo-footer { 
		margin: 0 0 2em auto;
		max-width: 320px;
	}
	#nav-footer {
		padding: 0 10px;
		display: block;
		width: 50%;
	}
	#footer .nav_footer_col { 
		display: block;
		padding: 5px 20px;
		max-width: 100%;
	}
	.rs-footer {
		position: relative;
		right: 0;
	}
	
	/* >>> contact */
	#content-contact { padding-bottom: 0 }
	#content-contact .wp33 p { padding: 0; }
	
}

@media screen and (max-width: 860px) {
	
	/* >>> typo */
	.edit_content blockquote,
	.edit_content .citation {
		margin: 0 auto;
		width: 100%;
	}
	
	/* >>> contact */
	.submit-group {
		-webkit-box-pack: end;
		    -ms-flex-pack: end;
		        justify-content: flex-end;
	}
	.submit-group .privacy_checkbox {
		width: 100%;
		padding-right: 0;
		-webkit-box-flex: 1;
		    -ms-flex: 1 1 auto;
		        flex: 1 1 auto;
	}
	.submit-group input[type='submit'] {
		margin: 10px 0 0;
	}
}

@media screen and (max-width: 740px) {
	
	/* >>> typos */
	h2 { font-size: 1.75em; }
	h3 { font-size: 1.25em; }
	h2.alternative { font-size: 2em; }
	.edit_content blockquote,
	.edit_content .citation {
		padding: 0 50px;
		font-size: 1.125em;
	}
	.edit_content blockquote::before,
	.edit_content p.citation::before,
	.edit_content blockquote::after,
	.edit_content p.citation::after {
		width: 33px;
		height: 30px;
	}
	
	/* >>> contact */
	#content-contact .wp33 {
		-webkit-box-ordinal-group: 2;
		    -ms-flex-order: 1;
		        order: 1;
		text-align: center;
	}
	#content-contact .contact-logo { 
		max-width: 320px;
		margin: 0 auto 20px;
		width: 100%;
	}
	#content-contact .wp66 {
		-webkit-box-ordinal-group: 3;
		    -ms-flex-order: 2;
		        order: 2;
	}
}

@media screen and (max-width: 540px) {
	
	/* >>> typo */
	body { font-size: 14px; }
	
	/* >>> espacements */
	#content { padding: 40px 0; }
	
	.footer-content_info {
		width: 100%;
		text-align: center;
	}
	.logo-footer { 
		margin: 0 auto 1em;
		max-width: 280px;
	}
	#nav-footer {
		padding: 20px 0;
		display: block;
		text-align: center;
		width: 100%;
	}
	
	/* >>> 404 */
	#page_404 { padding: 10vh 20px; }
	#content-404 {
		padding: 30px;
		border-radius: 0 40px 0 40px;
	}
	#content-404 h1 { font-size: 2em; }
}

@media screen and (max-width: 480px) {
	
	h1 { font-size:24px; }
	.content_flex label.wp50.right,
	.content_flex label.wp50.left  { padding: 5px 0 }
	
	.bloc-contact .col-tt_right,
	body.bloc-contact.col-tt_right {
		background-image: none;
		padding-left: 10px;
	}
	
	#menu-alt { right: 0 }
	
}

@media screen and (max-width: 360px) {
	
}