/***** bloc grid *****/
.bloc_grid	                        { display: grid; grid-template-columns: 1fr 1fr; align-items: center; position: relative; margin: 95px 0; gap: 80px;}
.bloc_grid.align_top                { align-items: start;}
.bloc_grid .photo					{ position: relative; line-height: 0;}
.bloc_grid .photo:before            { content: ""; display: block; position: absolute; width: 50vw; height: 100%; top: 0; height: 100%; background: url(../images/shape.webp) center / cover no-repeat; right: calc(100% + 20px);}
.bloc_grid .photo img 				{ width: 100%; height: auto; object-fit: cover; display: block; position: relative; z-index: 10;}
.bloc_grid .texte					{ position: relative;}
.bloc_grid .texte :last-child 		{ margin-bottom: 0;}
.bloc_grid p               			{ margin-bottom: 15px;}
.bloc_grid .link					{ margin-top: 10px;}
.bloc_grid.reverse .texte			{ grid-area: 1 / 1; }
.bloc_grid.reverse .photo        	{ grid-area: 1 / 2;}
.bloc_grid.reverse .photo:before    { right: auto; left: calc(100% + 20px);}

@media (max-width:1200px) { 
.bloc_grid	                        { margin: 80px 0;}
}
@media (max-width:1000px) { 
.bloc_grid	                        { grid-template-columns: 1fr; margin: 80px 0; gap: 60px;}
.bloc_grid.reverse .texte,
.bloc_grid .texte					{ padding: 0;}
.bloc_grid.reverse .texte			{ grid-area: 2;}
.bloc_grid.reverse .photo        	{ grid-area: 1;}
.bloc_grid .photo:before            { display: none;}
}
@media (max-width:600px) { 
.bloc_grid	                        { margin: 40px 0; grid-gap: 30px;}
.bloc_grid p               			{ margin-bottom: 10px;}
.bloc_grid .photo:before            { right: calc(100% + 20px);}
.bloc_grid.reverse .photo:before    { left: calc(100% + 20px); right: auto;}
}