@import url('https://fonts.googleapis.com/css2?family=Ruda:wght@500;700;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fira+Sans+Condensed:wght@200;400;600&display=swap');

/*  Général */

html,
body {
    height: 100%;
    margin: 0px;
    padding: 0px;
    scroll-behavior: smooth;
}

body {
    font-family: 'Fira Sans Condensed', sans-serif;
    font-weight: 400;
}

::selection {
  color: #00AEC7;
  background-color: white;
}

li {
    list-style-type: none;
}

.lead {
    margin-top: 30px;
}

@media screen and (min-width: 992px) {
    .lead {
        font-size: 1.7em;
    }
}

@media screen and (min-width: 576px) and (max-width: 992px) {
    .lead {
        font-size: 1.4em;
    }
}

@media screen and (max-width: 576px) {
    .lead {
        font-size: 1.1em;
    }
}

.card .card-testimony::before {
    content: '\201C';
    height: 80px;
    position: absolute;  
    top: -60px;
    left: 0px;
    font-size: 10em;
    color: #00AEC7;
    font-weight: 500;
    z-index: 1;
    opacity: 0.2;
}

.card .card-testimony::after {
    content: '\201D';
    height: 80px;
    position: absolute;  
    bottom: 0px;
    right: 0px;
    font-size: 10em;
    color: #00AEC7;
    font-weight: 500;
    z-index: 1;
    opacity: 0.2;
}



header::before {  
  content: attr(data-outline);
  position: absolute;  
  color: white;
  text-shadow: 1px 0 0 grey, 0 1px 0 grey, -1px 0 0 grey, 0 -1px 0 grey;
  font-weight: 500;
  z-index: 1;
  opacity: 0.2;
}

@media screen and (min-width: 992px) {
    header::before {
        font-size: 10em;
        top: 0.2em;
        left: 0.3em;
    }
}

@media screen and (min-width: 576px) and (max-width: 992px) {
    header::before {
        font-size: 8em;
        top: 0.2em;
        left: 0.2em;
    }
}

@media screen and (max-width: 576px) {
    header::before {
        font-size: 7em;
        top: 0.3em;
        left: 0em;
    }
}




.figure {
    padding-top: 1.25rem;
    font-weight: 400;
    font-size: 2em;
}

.figures {
    margin-top: 10vh;
}

@media screen and (min-width: 800px) {
    .img-container {
        height: 50vh;
    }
}

@media screen and (max-width: 800px) {
    .img-container {
        height: 40vh;
    }
}

.img-container {
    overflow: hidden;
}

.img-container video,
.img-container img,
.img-container iframe {
    object-fit: cover;
    object-position: center;
    height: 100%;
    width: 100%;
}

.figure img {
    width: 50px;
    height: auto;
}

.icons-list img {
    width: 40px;
    height: auto;
}

.icons-list img:hover {
    filter: invert(1);
}

#navbar .link-text {
    line-height: 0.5;
}

#navbar .link-text .figure {
    font-size: 1em;
}

.anchor {
    position: absolute;
    bottom: 20px;
    width: 100%;
}

#scroll.anchor img {
    width: 75px;
    height: auto;
}

/*  Liens et boutons */

body a {
    color: black;
}

body a:hover {
    text-decoration: none;
    color: #cb063b;
}

.link-button {
    padding: 6px 20px;
    margin: 0px 10px;
    border: none;
    transform: skewX(28deg);    
}

.link-button .text-left, .link-button .text-right {
    transform: skewX(-28deg);
}

.link-button .figure {
    padding: 0;
    line-height: 0.8em;
}

.link-button i {
    font-size: 3em;
}

.link-button:hover {
    background-color: gainsboro;
    color: black;
    cursor: pointer;
}

.link-button:hover i {
    color: #cb063b;
}
.link-button:focus {
  outline: none;
}

@media screen and (min-width: 600px) {
    .link-button {
        font-size: 0.9em;
    }

    .link-button .figure {
        font-size: 1.75em;        
    }

    .link-button .text-right i {
        padding-left: 20px;
    }

    .link-button .text-left i {
        padding-right: 20px;
    }


}

@media screen and (max-width: 600px) {
    .link-button {
        font-size: 0.8em;
    }

    .link-button .figure {
        font-size: 1.4em;
    }

    .link-button .text-right i {
        padding-left: 10px;
    }

    .link-button .text-left i {
        padding-right: 10px;
    }
}

.link-text {
    font-size: 1em;
    position: relative;
    line-height: normal;
}

.link-text .figure {
    font-size: 1.2em;
    padding: 0;
    line-height: 1em;
}

.link-text i {
    padding-left: 20px;
    font-size: 2em;
    position: absolute;
    bottom: 0;
}

#navbar .link-text i {
    padding-left: 10px;
    font-size: 1.4em;
    position: relative;
}

.link-text:hover,
.link-text:hover i {
    color: #cb063b;
    cursor: pointer;
}

/*
.dropdown.show {
    background-color: #00aec7;
}

.dropdown.show .link-text,
.dropdown.show .link-text i {
    color: white;
}
*/

.dropdown-menu {
    border: 0;
    border-radius: 0;
    margin: 0;
}

/*  Niveaux de titre */

h1 > * {
    z-index: 100;
    position: relative;
}

@media screen and (min-width: 992px) {
    h1 {
        font-size: 3em
    }
}

@media screen and (min-width: 600px) and (max-width: 992px) {
    h1 {
        margin-top: 5vh;
        font-size: 2.6em;
    }
}

@media screen and (max-width: 600px) {
    h1 {
        margin-top: 10vh;
        font-size: 2em;
    }
}

@media screen and (min-width: 800px) {
    h2 {
        font-size: 2.3em
    }
}

@media screen and (min-width: 600px) and (max-width: 800px) {
    h2 {
        font-size: 2em;
    }
}

@media screen and (max-width: 600px) {
    h2 {
        font-size: 1.5em;
    }
}

@media screen and (min-width: 800px) {
    h3 {
        font-size: 1.5em;
    }
}

@media screen and (min-width: 600px) and (max-width: 800px) {
    h3 {
        font-size: 1.35em;
    }
}

@media screen and (max-width: 600px) {
    h3 {
        font-size: 1.2em;
    }
}

h4,
h5,
h6 {
    font-size: 1.25em;
}

/*  Polices et textes */

.uppercase {
    text-transform: uppercase;
}

.lowercase {
    text-transform: lowercase;
}

.ruda {
    font-family: 'Ruda', sans-serif;
}

.fira {
    font-family: 'Fira Sans Condensed', sans-serif;
}

.light {
    font-weight: 200;
}

.regular {
    font-weight: 400;
}

.bold {
    font-weight: 600;
}

.ruda.light {
    font-weight: 500;
}

.ruda.regular, {
    font-weight: 700;
}

.ruda.bold {
    font-weight: 900;
}

/*  Couleurs */

.white {
    color: #ffffff;
}

.lightgrey {
    color: #eeeeee;
}

.grey {
    color: #c7c7c7;
}

.darkgrey {
    color: #7c7c7c;
}

.black {
    color: #171717;
}

.blue {
    color: #00aec7;
}

.pink {
    color: #cb063b;
}

.white-bg {
    background-color: #ffffff;
    color: black;
}

.lightgrey-bg {
    background-color: #eeeeee;
    color: #171717;
}

.grey-bg {
    background-color: #c7c7c7;
    color: white;
}

.darkgrey-bg {
    background-color: #7c7c7c;
    color: white;
}

.black-bg {
    background-color: #171717;
    color: white;
}

.pink-bg {
    background-color: #cb063b;
    color: white;
}

.blue-bg {
    background-color: #00aec7;
    color: white;
}

.none-bg {
    background-color: transparent;
}

.pink-bottom {
    border-bottom: 1px solid #cb063b !important;
}

.pink-top {
    border-top: 1px solid #cb063b !important;
}

.pink-left {
    border-left: 1px solid #cb063b !important;
}

.pink-right {
    border-right: 1px solid #cb063b !important;
}

.pink-border {
    border: 1px solid #cb063b !important;
}

.blue-bottom {
    border-bottom: 1px solid #00aec7 !important;
}

.blue-top {
    border-top: 1px solid #00aec7 !important;
}

.blue-left {
    border-left: 1px solid #00aec7 !important;
}

.blue-right {
    border-right: 1px solid #00aec7 !important;
}

.blue-border {
    border: 1px solid #00aec7 !important;
}

.black-bottom {
    border-bottom: 1px solid #171717 !important;
}

.black-top {
    border-top: 1px solid #171717 !important;
}

.black-left {
    border-left: 1px solid #171717 !important;
}

.black-right {
    border-right: 1px solid #171717 !important;
}

.black-border {
    border: 1px solid #171717 !important;
}

.white-bottom {
    border-bottom: 1px solid #ffffff !important;
}

.white-top {
    border-top: 1px solid #ffffff !important;
}

.white-left {
    border-left: 1px solid #ffffff !important;
}

.white-right {
    border-right: 1px solid #ffffff !important;
}

.white-border {
    border: 1px solid #ffffff !important;
}

.darkgrey-bottom {
    border-bottom: 1px solid #7c7c7c !important;
}

.darkgrey-top {
    border-top: 1px solid #7c7c7c !important;
}

.darkgrey-left {
    border-left: 1px solid #7c7c7c !important;
}

.darkgrey-right {
    border-right: 1px solid #7c7c7c !important;
}

.darkgrey-border {
    border: 1px solid #7c7c7c !important;
}

.grey-bottom {
    border-bottom: 1px solid #c7c7c7 !important;
}

.grey-top {
    border-top: 1px solid #c7c7c7 !important;
}

.grey-left {
    border-left: 1px solid #c7c7c7 !important;
}

.grey-right {
    border-right: 1px solid #c7c7c7 !important;
}

.grey-border {
    border: 1px solid #c7c7c7 !important;
}

.lightgrey-bottom {
    border-bottom: 1px solid #eeeeee !important;
}

.lightgrey-top {
    border-top: 1px solid #eeeeee !important;
}

.lightgrey-left {
    border-left: 1px solid #eeeeee !important;
}

.lightgrey-right {
    border-right: 1px solid #eeeeee !important;
}

.lightgrey-border {
    border: 1px solid #eeeeee !important;
}

.dotted-bottom {
    border-style: none none dotted none !important;
    border-width: 3px !important;
}

.dotted-top {
    border-style: dotted none none none !important;
    border-width: 3px !important;
}

.dotted-left {
    border-style: none none none dotted !important;
    border-width: 3px !important;
}

.dotted-right {
    border-style: none dotted none none !important;
    border-width: 3px !important;
}

.dotted-border {
    border-style: dotted !important;
    border-width: 3px !important;
}

/* Masks */

.black-mask {
    background: rgba(0, 0, 0, 0.8);
}

.white-mask {
    background: rgba(255, 255, 255, 0.8);
}

.blue-mask {
    background: rgba(0, 174, 199, 0.8);
}

.pink-mask {
    background: rgba(203, 6, 59, 0.8);
}

/* Gradiants */

.black-gradiant {
    background: repeating-linear-gradient(90deg, rgba(0, 0, 0, 1), rgba(0, 0, 0, 0.5) 50%, rgba(0, 0, 0, 1));
}

.white-gradiant {
    background: repeating-linear-gradient(90deg, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 1));
}

.pink-gradiant {
    background: repeating-linear-gradient(90deg, rgba(203, 6, 59, 1), rgba(203, 6, 59, 0.5) 50%, rgba(203, 6, 59, 1));
}

.blue-gradiant {
    background: repeating-linear-gradient(90deg, rgba(0, 174, 199, 1), rgba(0, 174, 199, 0.5) 50%, rgba(0, 174, 199, 1));
}

.blue-black-gradiant {
    background: repeating-linear-gradient(90deg, rgba(0, 174, 199, 1), rgba(38, 38, 38, 1));
}

.black-blue-gradiant {
    background: repeating-linear-gradient(90deg, rgba(38, 38, 38, 1), rgba(0, 174, 199, 1));
}

/* Partial Mask */

.white-mask-left {
    background: rgba(255, 255, 255, 0.8);
}

.white-mask-left {
    background: linear-gradient(to right, rgba(255, 255, 255, 0.8) 58%, rgba(0, 0, 0, 0.8) 58%);
}

.blue-mask-left {
    background: rgba(0, 174, 199, 0.8);
}

@media (min-width: 768px) {
    .blue-mask-left {
        background: linear-gradient(to right, rgba(0, 174, 199, 0.8) 58%, rgba(0, 0, 0, 0.8) 58%);
    }
}

.pink-mask-left {
    background: rgba(0, 0, 0, 0.8);
}

@media (min-width: 768px) {
    .pink-mask-left {
        background: linear-gradient(to right, rgba(203, 6, 59, 0.8) 58%, rgba(0, 0, 0, 0.8) 58%);
    }
}

.white-mask-right {
    background: rgba(255, 255, 255, 0.8);
}

@media (min-width: 768px) {
    .white-mask-right {
        background: linear-gradient(to left, rgba(255, 255, 255, 0.8) 53%, rgba(0, 0, 0, 0.8) 53%);
    }
}

.blue-mask-right {
    background: rgba(0, 174, 199, 0.8);
}

@media (min-width: 768px) {
    .blue-mask-right {
        background: linear-gradient(to left, rgba(0, 174, 199, 0.8) 53%, rgba(0, 0, 0, 0.8) 53%);
    }
}

.pink-mask-right {
    background: rgba(0, 0, 0, 0.8);
}

@media (min-width: 768px) {
    .pink-mask-right {
        background: linear-gradient(to left, rgba(203, 6, 59, 0.8) 53%, rgba(0, 0, 0, 0.8) 53%);
    }
}

/* Background images */

.full-center-bg {
    background-repeat: no-repeat;
    background-position: center;
    background-attachment: fixed;
    background-size: cover;
}

.full-top-bg {
    background-repeat: no-repeat;
    background-position: center top;
    background-attachment: fixed;
    background-size: cover;
}

.full-bottom-bg {
    background-repeat: no-repeat;
    background-position: center bottom;
    background-attachment: fixed;
    background-size: cover;
}

/* BACKGROUNDS */

.index-bg {
    background-image: url("../images/backgrounds/maquette-grande-surface.jpg");
}

/* Section societe */

.bureau-de-dessin-bg {
    background-image: url("../images/backgrounds/local-numeriplan-mamers.jpg");
}

.pole-releve-3d-bg {
    background-image: url("../images/backgrounds/releve-3d-scanner-laser.jpg");
}

.pole-dessin-3d-bg {
    background-image: url("../images/backgrounds/dessin-plan-2d-3d.jpg");
}

.pole-imagerie-3d-bg {
    background-image: url("../images/backgrounds/imagerie-3d-visite-virtuelle.jpg");
}

/* Section services */

.modelisation-du-batiment-bg {
    background-image: url("../images/backgrounds/maquette-batiment.jpg");
}

.nuage-de-points-bg {
    background-image: url("../images/backgrounds/nuage-de-points-industrie.jpg");
}

.maquette-numerique-bg {
    background-image: url("../images/backgrounds/maquette-numerique-bâtiment.jpg");
}

.plan-2d-3d-bg {
    background-image: url("../images/backgrounds/plan-2d-3d-architecture.jpg");
}

.avant-projet-bg {
    background-image: url("../images/backgrounds/plan-avant-projet.jpg");
}

.permis-de-construire-bg {
    background-image: url("../images/backgrounds/plan-permis-de-construire.jpg");
}

.rendu-3d-realiste-bg {
    background-image: url("../images/backgrounds/rendu-3d-architecture.jpg");
}

.visite-virtuelle-bg {
    background-image: url("../images/backgrounds/visite-virtuelle-maison.jpg");
}

/* Section secteurs */

.dessin-en-architecture-bg {
    background-image: url("../images/backgrounds/dessin-architecture.jpg");
}

.maison-individuelle-bg {
    background-image: url("../images/backgrounds/maquette-maison-individuelle.jpg");
}

.immobilier-collectif-bg {
    background-image: url("../images/backgrounds/maquette-immobilier-collectif.jpg");
}

.patrimoine-historique-bg {
    background-image: url("../images/backgrounds/maquette-patrimoine-historique.jpg");
}

.local-tertiaire-bg {
    background-image: url("../images/backgrounds/maquette-local-tertiaire.jpg");
}

.industrie-du-futur-bg {
    background-image: url("../images/backgrounds/maquette-industrie-du-futur.jpg");
}

.collectivite-locale-bg {
    background-image: url("../images/backgrounds/maquette-collectivite-locale.jpg");
}

/* Section autres */

.contact-bg {
    background-image: url("../images/backgrounds/dessin-batiment.jpg");
}

.emploi-bg {
    background-image: url("../images/backgrounds/dessin-maison-individuelle.jpg");
}

/* ANIMATIONS */

.pop-right {
    -webkit-animation-duration: 2s;
    -webkit-animation-name: slide-right, fade-in;
}

.pop-left {
    -webkit-animation-duration: 2s;
    -webkit-animation-name: slide-left, fade-in;
}

.pop-bottom {
    -webkit-animation-duration: 2s;
    -webkit-animation-name: slide-bottom, fade-in;
}

.pop-top {
    -webkit-animation-duration: 2s;
    -webkit-animation-name: slide-top, fade-in;
}

.rotate-right {
    -webkit-animation-duration: 1s;
    animation-timing-function: ease-in;
    -webkit-animation-name: rotate-right, fade-in;
}

.rotate-left {
    -webkit-animation-duration: 1s;
    animation-timing-function: ease-in;
    -webkit-animation-name: rotate-left, fade-in;
}

.fade-in {
    -webkit-animation-duration: 2s;
    -webkit-animation-name: fade-in;
}

.shaking {
    -webkit-animation-delay: 2s;
    -webkit-animation-duration: 10s;
    -webkit-animation-name: shaking;
    -webkit-animation-iteration-count: infinite;
}

@keyframes slide-top {
    0% {
        transform: translateY(300px);
    }

    100% {
        transform: translateY(0px);
    }
}

@keyframes slide-bottom {
    0% {
        transform: translateY(-300px);
    }

    100% {
        transform: translateY(-0px);
    }
}

@keyframes slide-right {
    0% {
        transform: translateX(-300px);
    }

    100% {
        transform: translateX(-0px);
    }
}

@keyframes slide-left {
    0% {
        transform: translateX(300px);
    }

    100% {
        transform: translateX(-0px);
    }
}

@keyframes fade-in {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes rotate-right {
    from {
        transform: rotateY(-180deg);
    }

    to {
        transform: rotateY(0deg);
    }
}

@keyframes rotate-left {
    from {
        transform: rotateY(180deg);
    }

    to {
        transform: rotateY(0deg);
    }
}

@keyframes shaking {
    0% {
        transform: rotateZ(0deg);
    }

    2% {
        transform: rotateZ(5deg);
    }

    4% {
        transform: rotateZ(-8deg);
    }

    6% {
        transform: rotateZ(6deg);
    }

    9% {
        transform: rotateZ(0deg);
    }

    100% {
        transform: rotateZ(0deg);
    }
}

/* SPECIFICS */

/* Circular menu */

.circular-menu {
    width: 100%;
    margin: 0 auto;
    position: relative;
}

.circle {
    margin: auto;
    opacity: 0;
    -webkit-transform: scale(0);
    -moz-transform: scale(0);
    transform: scale(0);
    -webkit-transition: all 0.4s ease-out;
    -moz-transition: all 0.4s ease-out;
    transition: all 0.4s ease-out;
}

.open.circle {
    opacity: 1;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    transform: scale(1);
}

.circle a {
    text-decoration: none;
    display: block;
    background-color: #00aec7;
    line-height: 40px;
    position: absolute;
    text-align: center;
    border-radius: 50%;
}

.circle a:hover, .circle a[aria-expanded="true"] {
    background-color: #cb063b;
}

.circle a .circular-label {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color : white;
}

.menu-button {
    position: absolute;
    text-align: center;
    color: #444;
    display: block;
    font-weight: bold;
}

@media screen and (min-width: 800px) {
    .menu-button {
        font-size: 3em;
        height: 40px;
        width: 80px;
        top: calc(50% - 35px);
        left: calc(50% - 40px);
    }
    .circle {
        width: 600px;
        height: 600px;
    }
    .circle a {        
        height: 130px;
        width: 130px;
        margin-left: -65px;
        margin-top: -65px;
        font-size: 1em;
    }
}

@media screen and (max-width: 800px) {
    .menu-button {
        font-size: 2em;
        height: 40px;
        width: 60px;
        top: calc(50% - 25px);
        left: calc(50% - 30px);
    }
    .circle {
        width: 480px;
        height: 480px;
    }
    .circle a {        
        height: 110px;
        width: 110px;
        margin-left: -55px;
        margin-top: -55px;
        font-size: 0.9em;
    }
}

/* Slider */

.slider {
    margin: 0px auto;
    width: 90%;
}

.slick-slide {
    margin: 0px 20px;
}

.slick-slide img {
    width: 100%;
}

.slick-prev:before,
.slick-next:before {
    color: black;
}

.slick-slide {
    transition: all ease-in-out .3s;
    opacity: .2;
}

.slick-active {
    opacity: .5;
}

.slick-current {
    opacity: 1;
}

.slick-arrow.slick-prev,
.slick-arrow.slick-next {
    width: 50px;
    height: 50px;
}

.slick-arrow:before {
    color: #00aec7 !important;
}

.slick-arrow.slick-prev {
    left: -60px;
}

.slick-arrow.slick-next {
    right: -60px;
}

.slick-arrow.slick-prev:before,
.slick-arrow.slick-next:before {
    font-size: 40px;
}

/*
Divers
*/

nav .breadcrumb {
    border-radius: 0;
    padding: 1rem 0rem;
    background-color: transparent;
}

nav .breadcrumb ol {
    padding: 0;
}

.landing {
    padding-top: 10vh;
    min-height: 100vh;
    position: relative;
}

@media screen and (max-width: 576px) {
    .landing {
        padding-top: 5vh;
    }
}

.list-group-item {
    background-color: transparent;
    border: none;
    font-size: 1.25em;
    padding-left: 0;
}

.img-thumbnail {
    background-color: transparent;
    border: none;
    padding: 0;
    border-radius: 0;
}

.cc-window {
    border: 3px solid #00aec7;
}

.link-text.dropdown-toggle::after {
    display: none;
}

#navbar .nav-link:hover,
#navbar .dropdown-item:hover {
    color: #00aec7;
}

#navbar .collapse .nav-link:hover,
#navbar .collapse .dropdown-item:hover {
    color: #00aec7;
}

.dropdown-item:focus,
.dropdown-item:hover {

    background-color: transparent;
}

@media (min-width: 992px) {
    .nav-drop .collapse {
        display: none;
        position: fixed;
        left: 0px;
        right: 0px;
        top: 70px;
        background-color: transparent;
        border: 0;
    }

    .nav-drop.active .collapse {
        display: block;
    }

    .nav-drop .collapse ul {
        display: inline-block;
    }

    .nav-drop .collapse li {
        float: left;
    }
}

#navbar .nav-link:hover,
#navbar .dropdown-item:hover,
#sub-navbar .nav-link:hover,
#sub-navbar .dropdown-item:hover {
    color: #00aec7;
}

a i {
    color: #00aec7;
}

.radius {
    border-radius: .25rem;
}

.price {
    font-size: 1.25rem;
    border-radius: .25rem;
}

.badge-price {
    background-color: #00aec7;
    color: white;
    padding-top: .4rem;
}

@media (min-width: 992px) {
    header {
        padding: 50px 0 30px;
    }
}

#hub {
    padding: 45px 0px;
}

#hub .card:hover .card-text,
#hub .card:hover .card-title {
    color: black;
}

section,
aside {
    padding: 30px 0px;
}

section header,
aside header {
    /*margin-bottom: 20px 0px;*/
    margin-bottom: 20px;
    padding: 15px 0px;
}

#team #employes .card {
    text-align: center;
}

#team #employes .card-img-top {
    max-width: 200px;
    max-height: 200px;
    height: auto;
}

#team #employes .card-title,
#services .card-title {
    margin-bottom: 0px;
    font-size: 1rem;
    color: #00aec7;
}

#team #employes .card-header,
#services .card-header {
    padding: 0;
    background: transparent;
}

#team #employes .card-body {
    padding: 0rem;
    background: transparent;
}

#team #employes .card-footer {
    padding: 0rem;
    font-size: 0.75rem;
    background: transparent;
}

#brands .slider .img-container {
    height : 360px !important; 
    width : auto;
    margin: auto;
}

.card.accordion:hover .card-header {    
    cursor: pointer;
}

header .card,
section .card,
header .card-header,
section .card-header,
section .card-footer,
header .card-footer {
    border: none;
}

#blueprint-video {
    height: 500px;
    position: relative;
    overflow: hidden;
    color: white;
}

#blueprint-video video {
    position: absolute;
    min-height: 100%;
    min-width: 100%;
    top: -300px;
    left: 0;
    bottom: 0;
    right: 0;
    z-index: -100;
}

.cut-bottom-right:before {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    border-bottom: 3rem solid white;
    border-left: 5rem solid #00aec7;
    width: 0;
}

.cut-top-left:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    border-left: 5rem solid white;
    border-bottom: 2rem solid #00aec7;
    width: 0;
}

abbr[title] {
    text-decoration-line: none;
}

dfn {
    font-weight: bold;
    font-style: normal;
}

#footer-contact .row {
    height: 2.5rem;
}

#footer-contact i {
    color: #00aec7;
    font-size: 1.5rem;
}

#footer ul {
    padding: 0px;
}


#footer {
    font-size: 0.75rem;
}

#footer p {
    margin-bottom: 0px;
}

#footer .news-item {
    border: none;
    padding: .25rem 1rem;
}

#footer .news-item:hover {
    background-color: white;
}

.modal-button,
.modal-title {
    font-family: Ubuntu, Helvetica;
}

.modal-header {
    background-color: rgb(0, 174, 199);
    border-bottom: 0;
}

.modal-title {
    color: white;
    font-weight: bolder;
    text-align: center;
}

.modal-body {
    color: rgb(100, 100, 100) !important;
    font-size: 1rem;
}

.modal-footer {
    justify-content: center;
}

#map {
    width: 100%;
    height: 400px;
}

#bloc_rs {
    z-index: 1000;
}

#bloc_rs li {
    list-style: none;
}

#bloc_rs li a {
    display: block;
    margin: auto;
}

#bloc_rs i {
    color: white;
    text-shadow: 2px 2px #00aec7;
}

#bloc_rs img,
#partners .partner-logo {
    -webkit-filter: invert(1) grayscale(1) brightness(2);
    filter: invert(1) grayscale(1) brightness(2);
}

#partners .partner-logo {
    -webkit-filter: grayscale(1);
    filter: grayscale(1);
}

#bloc_rs a:hover img,
#partners .partner-logo:hover {
    -webkit-filter: none;
    filter: none;
}

#bloc_rs a:hover i {
    color: #cb063b;
}

@media (max-width: 900px) {
    #bloc_rs {
        position: relative;
        top: 0px;
    }

    .links-reseaux {
        column-count: 3;
        column-width: 45px;
    }

    #bloc_rs li a {
        width: 4rem;
        height: 4rem;
    }

    #bloc_rs ul {
        padding: 0;
    }
}

@media (min-width: 900px) {
    #bloc_rs {
        position: fixed;
        top: 140px;
    }

    #bloc_rs li {
        margin: 1rem 0;
    }

    #bloc_rs li a {
        width: 3rem;
        height: 3rem;
    }
}

.list-group-item input,
.list-group-item textarea {
    border: none;
}

.form-control {
    height: 50px;
}

.custom-file-label {
    border: 1px solid #00aec7;
    height: 50px;
    padding-top: 0.75rem !important;
    padding-bottom: 0.75rem !important;
}

.custom-file-label::after {
    height: 100%;
    color: white;
    background-color: #00aec7;
    padding-top: 0.75rem !important;
    padding-bottom: 0.75rem !important;
    content: "Choisir";
}

/* The switch - the box around the slider */
.switch {
    position: relative;
    display: inline-block;
    width: 40px;
    height: 20px;
    margin: 0px;
}

/* Hide default HTML checkbox */
.switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

/* The slider */
.switch .slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #ccc;
    -webkit-transition: .4s;
    transition: .4s;
}

.switch .slider:before {
    position: absolute;
    content: "";
    height: 16px;
    width: 16px;
    left: 2px;
    bottom: 2px;
    background-color: white;
    -webkit-transition: .4s;
    transition: .4s;
}

.switch input:checked + .slider-pink {
    background-color: #cb063b;
}

.switch input:focus + .slider-pink {
    box-shadow: 0 0 1px #cb063b;
}

.switch input:checked + .slider-blue {
    background-color: #00aec7;
}

.switch input:focus + .slider-blue {
    box-shadow: 0 0 1px #00aec7;
}

.switch input:checked + .slider-black {
    background-color: #171717;
}

.switch input:focus + .slider-black {
    box-shadow: 0 0 1px #171717;
}

.switch input:checked + .slider:before {
    -webkit-transform: translateX(16px);
    -ms-transform: translateX(16px);
    transform: translateX(16px);
}

/* Rounded sliders */
.switch .slider.round {
    border-radius: 16px;
}

.switch .slider.round:before {
    border-radius: 50%;
}

.card-columns {
    @include media-breakpoint-only(lg) {
        column-count: 4;
    }

    @include media-breakpoint-only(md) {
        column-count: 3;
    }

    @include media-breakpoint-only(xs) {
        column-count: 2;
    }
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {

    background-color: #cb063b;
}

.cd-image-container {
    position: relative;
    width: 100%;
    margin: 0em;
}

.cd-image-container img {
    display: block;
    max-width: 100%;
}

.cd-image-label {
    position: absolute;
    bottom: 0;
    right: 0;
    color: #ffffff;
    padding: 1em;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    opacity: 0;
    -webkit-transform: translateY(20px);
    -moz-transform: translateY(20px);
    -ms-transform: translateY(20px);
    -o-transform: translateY(20px);
    transform: translateY(20px);
    -webkit-transition: -webkit-transform 0.3s 0.7s, opacity 0.3s 0.7s;
    -moz-transition: -moz-transform 0.3s 0.7s, opacity 0.3s 0.7s;
    transition: transform 0.3s 0.7s, opacity 0.3s 0.7s;
}

.cd-image-label.is-hidden {
    visibility: hidden;
}

.is-visible .cd-image-label {
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    -o-transform: translateY(0);
    transform: translateY(0);
}

.cd-resize-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    overflow: hidden;
    /* Force Hardware Acceleration in WebKit */
    -webkit-transform: translateZ(0);
    -moz-transform: translateZ(0);
    -ms-transform: translateZ(0);
    -o-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.cd-resize-img img {
    position: absolute;
    left: 0;
    top: 0;
    display: block;
    height: 100%;
    width: auto;
    max-width: none;
}

.cd-resize-img .cd-image-label {
    right: auto;
    left: 0;
}

.is-visible .cd-resize-img {
    width: 50%;
    /* bounce in animation of the modified image */
    -webkit-animation: cd-bounce-in 0.7s;
    -moz-animation: cd-bounce-in 0.7s;
    animation: cd-bounce-in 0.7s;
}

@-webkit-keyframes cd-bounce-in {
    0% {
        width: 0;
    }

    60% {
        width: 55%;
    }

    100% {
        width: 50%;
    }
}

@-moz-keyframes cd-bounce-in {
    0% {
        width: 0;
    }

    60% {
        width: 55%;
    }

    100% {
        width: 50%;
    }
}

@keyframes cd-bounce-in {
    0% {
        width: 0;
    }

    60% {
        width: 55%;
    }

    100% {
        width: 50%;
    }
}

.cd-handle {
    position: absolute;
    height: 44px;
    width: 44px;
    /* center the element */
    left: 50%;
    top: 50%;
    margin-left: -22px;
    margin-top: -22px;
    border-radius: 50%;
    background: #00aec7 url("../images/icons/cd-arrows.svg") no-repeat center center;
    cursor: move;
    box-shadow: 0 0 0 6px rgba(0, 0, 0, 0.2), 0 0 10px rgba(0, 0, 0, 0.6), inset 0 1px 0 rgba(255, 255, 255, 0.3);
    opacity: 0;
    -webkit-transform: translate3d(0, 0, 0) scale(0);
    -moz-transform: translate3d(0, 0, 0) scale(0);
    -ms-transform: translate3d(0, 0, 0) scale(0);
    -o-transform: translate3d(0, 0, 0) scale(0);
    transform: translate3d(0, 0, 0) scale(0);
}

.cd-handle.draggable {
    background-color: #cb063b;
}

.is-visible .cd-handle {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0) scale(1);
    -moz-transform: translate3d(0, 0, 0) scale(1);
    -ms-transform: translate3d(0, 0, 0) scale(1);
    -o-transform: translate3d(0, 0, 0) scale(1);
    transform: translate3d(0, 0, 0) scale(1);
    -webkit-transition: -webkit-transform 0.3s 0.7s, opacity 0s 0.7s;
    -moz-transition: -moz-transform 0.3s 0.7s, opacity 0s 0.7s;
    transition: transform 0.3s 0.7s, opacity 0s 0.7s;
}

/* CARTE DES REGIONS */

#regionsMap img {
    width: 32vmax;
    height: auto;
}

/* FLUX RSS */
footer .feed-lists {
    padding-left: 0 !important;
}

footer .feed-item {
    margin-bottom: 0.5em;
}

footer .feed-item img {
    width: 5em;
    float: left;
    border-radius: 10%;
    margin: 0.25em 1em 1em 0;
}

footer .feed-item .feed-title a {
    color: #00aec7 !important;
}

footer .feed-item .feed-description a {
    color: #cb063b !important;
}

.video-container {
    position: relative;
    overflow: hidden;
    color: white;
    height: 650px;
}

.video-container video {
    position: absolute;
    top: -200px;
    left: 0;
    bottom: 0;
    right: 0;
    z-index: -100;
}

article,
aside,
figcaption,
figure,
footer,
header,
hgroup,
main,
section {
    overflow: hidden;
}

button.tooltip-btn {
    -moz-appearance: none;
    -webkit-appearance: none;
    background-color: transparent;
    border: none;
}

button.tooltip-btn:active,
button.tooltip-btn:focus {
    outline: none;
    border: none;
}

.modal-dialog {
    max-width: 800px;
}

canvas {
    outline: none;
    -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
    /* mobile webkit */
}

#contact-form .tab {
    display: none;
}

.hidden-toggle {
    position: absolute;
    clip: rect(0, 0, 0, 0);
    pointer-events: none;
}

.btn:not(:disabled):not(.disabled).active,
.btn:not(:disabled):not(.disabled):active,
.show > .btn.dropdown-toggle {
    color: white;
    background-color: #00aec7;
}

#contact-form .feedback,
#support-form .feedback,
#job-form .feedback {
    display: block;
    font-size: 0.75em;
    color: #cb063b;
}

header.white-mask .breadcrumb-item a {
    color: black;
}

header.black-mask .breadcrumb-item a, header.black-bg .breadcrumb-item a {
    color: white;
}

.breadcrumb-item.active a {
    color: #00aec7 !important;
}

img.black-filter {
    filter: brightness(0);
}

img.white-filter {
    filter: brightness(0) invert(1);
}

img.flip-filter {
  -moz-transform:    scaleX(-1); /* Gecko */
  -o-transform:      scaleX(-1); /* Opera */
  -webkit-transform: scaleX(-1); /* Webkit */
  transform:         scaleX(-1); /* Standard */
  filter: FlipH;                 /* IE 6/7/8 */
}