/***** top page *****/
.top_page 							{ position: relative; background: #e6f7fd;  padding: 50px 0 70px; animation: color 3s;}
.top_page::after                    { content: ""; background-color: #fff; width: 100%; height: 1000%; left: 0; top: 100%; position: absolute;}
.top_page .sous_titre               { font-size: 25px; line-height: 30px;}
.top_page .titre_main               { color: #000;}
.top_page .chapo                    { color: #000;}

@keyframes color {
  from {background-color: #ffffff;}
  to {background-color: #e6f7fd;}
}


@media (min-width:1201px) { 
.top_page .devis:hover              { color: #fff;}
.top_page .devis:hover::after       { filter: brightness(0) invert(1);}
}

@media (max-width:1600px) {
.top_page                           { margin:0 -12.5vw; padding: 50px 12.5vw 70px;}
}

@media (max-width:1200px) { 
.top_page 							{ margin-top: 0; padding: 50px 0;}
}
@media (max-width:600px) { 
.breadcrumb 						{ display: none}
.top_page .titre_main               { font-size: 25px; line-height: 30px;}
.top_page							{ padding: 40px 0;}
.top_page .chapo 					{ font-size:13px;}
}

/***** breadcrumb *****/
.breadcrumb							{ line-height: 0; position: relative; margin-bottom: 60px; text-align: left;}
.breadcrumb a                       { color: #182c83;}
.breadcrumb a.active                { color: #0db0ed;}
.breadcrumb li 						{ display: inline-block; font-size: 14px; line-height: 20px; margin-right: 50px; position: relative;}
.breadcrumb li:after				{ content: ""; width: 6px; height: 6px; background-color: #0db0ed; right: -30px; position: absolute; transform: rotate(45deg); top: 8px;}
.breadcrumb li:last-child:after 	{ display: none;}

@media (min-width:1201px) {
.breadcrumb li a:hover				{ color:#0db0ed;}
}
@media (max-width:1200px) { 
.breadcrumb							{ display: none;}
}


/***** page content *****/
.page 								{ position: relative; padding-bottom: 100px; padding-top: 140px;}
.page p								{ margin-bottom: 15px;}
.page .ul_list a, 
.page p a							{ border-bottom: 1px solid transparent; padding-bottom: 2px; color: #0db0ed;}

@media (min-width:1201px) {
.page .ul_list a:hover,
.page p a:hover						{ border-color: #0db0ed; }
}
@media (max-width:1200px) {
.page 								{ padding: 100px 0 80px;}
}
@media (max-width:700px) {
.page 								{ padding-top: 100px;}
}
@media (max-width:600px) {
.page 								{ padding-bottom: 50px;}
.page p								{ margin-bottom: 10px;}
.page .ul_list						{ margin-bottom: 10px;}
}


/***** atouts *****/
.atouts                             { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 30px; margin: 100px 0;}
.atouts .item                       { padding: 40px 40px 35px; background-color:#000000; color: #fff;}
.atouts .icone                      { width: 100px; height: 100px; display: grid; align-items: center; justify-content: center; background-color:#fff; border-radius: 50%; margin-bottom: 20px;}
.atouts .sous_titre                 { font-size: 20px; line-height: 35px; margin-bottom: 10px;}

@media (max-width:1200px) {
.atouts                             { gap: 20px;}
.atouts .item                       { padding: 30px;}
}
@media (max-width:1000px) {
.atouts                             { grid-template-columns: 1fr 1fr; gap: 10px; margin: 40px 0;}
.atouts .item                       { padding: 30px;}
.atouts .item:first-child           { grid-area: 1/3/2/1;}
}
@media (max-width:600px) {
.atouts                             { grid-template-columns: 1fr; gap: 10px;}
.atouts .item                       { padding: 20px;}
.atouts .item:first-child           { grid-area:auto;}
.atouts .icone                      { width: 70px; height: 70px; margin-bottom: 5px;}
.atouts .icone img                  { transform: scale(0.8);}
}



/***** bloc texte *****/
.bloc_texte							{ margin: 80px auto; position: relative;}
.bloc_texte :last-child				{ margin-bottom: 0;}
.bloc_texte img,
.bloc_texte video					{ width: 100%; height: auto; display: block;}

@media (max-width:1200px) { 
.bloc_texte							{ margin: 60px auto;}
}
@media (max-width:1000px) { 
.bloc_texte							{ margin: 50px auto;}
}
@media (max-width:600px) { 
.bloc_texte							{ margin: 30px 0;}
}

.page_contact                       { padding-bottom: 0;}










