:root {
  --bg-color: #eee;
  --theme-color: #fff;
  --main-color: #0047FF; }

/* --------------- Menu --------------- */
.btn-retour {
  display: inline-flex;
  align-items: center;
  background-color: #1a1a1a; /* fond sombre */
  color: white;
  padding: 5px 15px;
  border-radius: 8px;
  text-decoration: none;
  font-family: sans-serif;
  font-size: 16px;
  transition: background 0.2s ease;
}

.btn-retour:hover {
  color: white;
}

.fleche-retour {
  width: 45px;
  height: 45px;
  margin-right: 5px;
}

/* --------------- navbar --------------- */
.navbar {
  position: fixed;
  left: 0;
  top: 0px;
  padding: 0;
  margin: 0;
  width: 100%;
  height: 85px;
  background-color: rgba(0, 0, 0, 0.7);
  z-index: 1000; 
  }

  .navbar.nav-scroll {
    padding: 0;
    position: fixed;
    top: -80px;
    padding: 15px 0;
    -webkit-transition: -webkit-transform .8s;
    transition: -webkit-transform .8s;
    -o-transition: transform .8s;
    transition: transform .8s;
    transition: transform .8s, -webkit-transform .8s;
    -webkit-transform: translateY(80px);
    -ms-transform: translateY(80px);
    transform: translateY(80px);
  }
  .logo {
    width: 200px;
    border: none !important;
  }
  .navbar .logo {
    padding: 7px 15px;
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 30px; }
  .navbar .navbar-nav {
    padding: 2px 5px;
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 30px;
    margin-left: 15px; }
    .navbar .navbar-nav .nav-link {
      padding: 5px 20px;
      border-radius: 30px;
      font-size: 14px;
      color: #fff; }
      .navbar .navbar-nav .nav-link.active {
        background: rgba(255, 255, 255, 0.1); }
  .navbar .topnav .menu-icon {
    color: #fff; }
  .navbar .topnav .butn {
    padding: 7px 20px;
    background: #fff;
    color: #1d1d1d;
    margin-right: 15px; }

/* --------------- header --------------- */

.text-header {
  text-align: left !important;
  margin: 0 auto;
}

.header-mda {
  min-height: 100vh;
  padding: 140px 0 180px;
  position: relative;
  overflow: hidden !important; }
  .header-mda .caption h1 {
    font-size: 4rem;
    line-height: 1.2;
    padding-bottom: 30px;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-color: white;
    background-size: cover;
    -webkit-font-smoothing: antialiased; }
  .header-mda .caption h1::first-line {
  font-size: 6rem; }
  
.image-container {
  position: relative;
}
.image-header-texte {
  position: absolute;
}
.image-header-fond {
  position: absolute;
  opacity: 0.7;
}

/* --------------- Services --------------- */

.item {
  margin-bottom: 45px;
}
.services-mda .sec-head h2 {
  font-size: 65px;
  line-height: 1.2; }

.services-mda .sec-head span {
  letter-spacing: 4px; }

.services-mda .sec-head .img1 {
  width: 180px;
  height: 55px;
  overflow: visible; }
  .services-mda .sec-head .img1 img {
    border-radius: 30px; }

.services-mda .sec-head .img2 {
  width: 55px;
  height: 55px;
  overflow: visible; }
  .services-mda .sec-head .img2 img {
    border-radius: 50px; }

.services-mda .item {
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 15px;
  border-radius: 20px; }
  .services-mda .item .cont {
    padding: 15px; }
    .services-mda .item .cont .icon {
      width: 52px;
      height: 52px;
      line-height: 50px;
      text-align: center;
      border: 1px solid rgba(255, 255, 255, 0.1);
      border-radius: 50%; }
      .services-mda .item .cont .icon img {
        width: 25px; }
    .services-mda .item .cont .text {
      margin-top: 100px;
      margin-bottom: 20px; }
      .services-mda .item .cont .text p {
        font-size: 14px;
        font-weight: 300;
        line-height: 22px; }

.marq-sa {
  overflow: hidden !important; }
  .marq-sa .item {
    padding: 0 80px !important;
    position: relative; }
    .marq-sa .item:after {
      content: '';
      width: 12px;
      height: 12px;
      background: #fff;
      border-radius: 50%;
      position: absolute;
      top: 50%;
      left: 0;
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      transform: translateY(-50%); }
    .marq-sa .item h2 {
      white-space: nowrap;
      font-size: 96px;
      line-height: 120px;
      letter-spacing: -4px;
      background: -webkit-gradient(linear, left top, right top, from(#fff), to(transparent));
      background: -webkit-linear-gradient(left, #fff, transparent);
      background: -o-linear-gradient(left, #fff, transparent);
      background: linear-gradient(to right, #fff, transparent);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent; }

/* Pricing
-----------------------------------------------------------------*/

.card-body {
  background-color: rgb(140, 29, 29);
  border-radius: 10px;
  margin: 0 auto;
  width: 450px;
}

.card-text {
  color: white;
  margin: 0 auto;
  text-align: center;
}

/* --------------- footer --------------- */
.footer-logo {
  padding-bottom: 85px;
}
.footer-mp .info-item h6 {
  font-size: 18px;
  line-height: 1.5; }

.footer-mp .footer-logo {
  position: relative;
  margin-top: 100px; }
  .footer-mp .footer-logo h1 {
    font-size: 290px;
    line-height: 1.2; }
    .footer-mp .footer-logo h1 span {
      font-family: "Playfair Display", serif;
      font-style: italic; }
  .footer-mp .footer-logo .union {
    position: absolute;
    top: 0;
    right: 0;
    width: 180px;
    background: #fff;
    padding: 10px;
    border-radius: 50%; }
    .footer-mp .footer-logo .union .icon {
      width: 64px;
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translateX(-50%) translateY(-50%);
      -ms-transform: translateX(-50%) translateY(-50%);
      transform: translateX(-50%) translateY(-50%); }

.footer-mp .social-icon {
  padding-top: 30px; }
  .footer-mp .social-icon a {
    width: 45px;
    height: 45px;
    line-height: 45px;
    text-align: center;
    border: 1px solid rgba(0, 0, 0, 0.2);
    border-radius: 50%;
    font-size: 14px;
    margin: 0 5px; }
    .footer-mp .social-icon a:hover {
      color: #fff;
      background: var(--main-color);
      border-color: var(--main-color);
      -webkit-transition: all .4s;
      -o-transition: all .4s;
      transition: all .4s; }

.footer-mp .sub-footer .copy p {
  font-size: 14px; }

.footer-mp .sub-footer .links {
  width: 100%; }
  .footer-mp .sub-footer .links a {
    font-size: 14px; }
  .footer-mp .sub-footer .links .active {
    color: var(--main-color); }

body {
  font-family: "Inter", sans-serif;
  font-size: 18px;
  line-height: 28px;
  font-weight: 400;
  color: #1d1d1d;
  background-color: var(--theme-color); }

main {
  position: relative; }
  main:after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url(../imgs/stars.svg);
    background-repeat: repeat;
    opacity: .3;
    z-index: -1; }

h1, h2, h3, h4, h5, h6 {
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -.02rem;
  margin: 0; }

h1 {
  font-size: 64px; }

h2 {
  font-size: 48px; }

h3 {
  font-size: 40px; }

h4 {
  font-size: 36px; }

h5 {
  font-size: 32px; }

h6 {
  font-size: 24px; }

.sub-color {
  color: #666; }

.sub-head {
  font-size: 20px;
  line-height: 28px; }

.sec-head-lg h2 {
  font-size: 90px;
  line-height: 1.1; }

p {
  color: #666;
  font-size: 16px;
  font-weight: 400;
  margin: 0; }

.italic {
  font-style: italic; }

.sec-head .sub-head {
  position: relative;
  padding-left: 25px; }
  .sec-head .sub-head:after {
    content: '';
    width: 7px;
    height: 7px;
    background: #000;
    border-radius: 50%;
    position: absolute;
    top: 10px;
    left: 0; }

.loader-wrap svg {
  fill: #1d1d1d; }

.butn.butn-bord {
  border: 1px solid rgba(255, 255, 255, 0.3); }
  .butn.butn-bord:hover {
    background: #fff;
    color: #212121; }

.butn .icon img {
  width: 18px; }

.butn.butn-bord {
  border-color: #333; }

.butn-circle {
  width: 180px;
  height: 180px;
  border: 1px solid #141414;
  border-radius: 50%;
  -webkit-transition: all .4s;
  -o-transition: all .4s;
  transition: all .4s; }
  .butn-circle.butn-dark {
    color: #fff;
    background: #141414; }
  .butn-circle.butn-light {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.2); }
    .butn-circle.butn-light:hover {
      background: #fff;
      color: #141414; }
      .butn-circle.butn-light:hover .text {
        color: #141414; }
      .butn-circle.butn-light:hover svg path {
        stroke: #141414; }
  .butn-circle svg path {
    -webkit-transition: all .4s;
    -o-transition: all .4s;
    transition: all .4s; }
  .butn-circle:hover {
    background: #141414;
    color: #fff; }
    .butn-circle:hover svg path {
      stroke: #fff; }
    .butn-circle:hover .text-dark {
      color: #fff !important; }

.box-dark {
  background: #000;
  color: #fff;
  border-radius: 70px;
  position: relative;
  z-index: 4; }
  .box-dark.goup {
    margin-top: -80px; }
  .box-dark p {
    color: #b6b6b6; }

/* ====================== [ Start Responsive ] ====================== */
@media screen and (max-width: 992px) {
  .header-mda .caption h1 {
    font-size: 120px;
    line-height: 1; }
  .services-mda .sec-head h2 {
    font-size: 50px; }
  .sec-head-lg h2 {
    font-size: 70px; }
  .faqs .main-marq h4 {
    font-size: 180px; }
  .footer-mp .footer-logo h1 {
    font-size: 170px; } }

@media screen and (max-width: 768px) {
  .navbar .logo img {
    max-width: 110px; }
  .sec-head-lg h2 {
    font-size: 36px;
    letter-spacing: -1px; }
    .sec-head-lg h2 br {
      display: none; }
  .sec-head-lg .d-flex {
    display: block !important;
    margin-top: 15px; }
  .box-dark {
    border-radius: 40px; }
  .header-mda {
    min-height: auto; }
  .header-mda .caption h1 {
    font-size: 64px; }
  .services-mda .sec-head h2 {
    font-size: 40px; }
    .services-mda .sec-head h2 span {
      position: relative;
      top: -10px; }
    .services-mda .sec-head h2 .fit-img {
      display: none; }
  .testimonials-ds .qoute-icon .text {
    width: 180px; }
  .testimonials-ds .qoute-icon .icon {
    width: 80px; }
  .testimonials-ds .item h4 {
    font-size: 25px;
    letter-spacing: normal; }
  .faqs .main-marq h4 {
    font-size: 90px; }
  .footer-mp .footer-logo .union {
    display: none; }
  .footer-mp .footer-logo h1 {
    font-size: 90px; } }

/* ======================================================
   Section “Cercle rouge + texte” – Home10 (circle-container)
   ====================================================== */
.circle-container {
  width: 100%;				/* prend toute la largeur du col-xxl-4 */
  max-width: 600px;         /* adapte selon ta maquette */
  aspect-ratio: 1/1;        /* carré qui devient rond */
  background-color: rgba(178,34,34,0.8);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin: auto;              /* centrer dans la colonne */
}

.circle-title {
  color: #fff;
  font-size: 2rem;         /* ajuste la taille du texte */
  line-height: 1.3;
  margin: 0;
}
/* ======================================================
   Override voile sombre du header
   ====================================================== */
header.header-mda.bg-img[val­id]::before,
header.header-mda.bg-img.valign::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background-color: rgba(0, 0, 0, 0.9) !important; /* 90% d’opacité */
  pointer-events: none;
  z-index: 1 !important;
}

/* ====== Fond image + overlay blanc 90% pour l’adresse ====== */
.footer-address-bg {
  position: relative;
  background: url("../imgs/manwork.png") no-repeat center center;
  background-size: cover;
  padding: 4rem 1rem;       /* ajustez l’espacement haut/bas si besoin */
}

/* Surcouche blanche 90% opaque */
.footer-address-bg::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background-color: rgba(255,255,255,0.9);
  z-index: 1;
}

/* Contenu texte audessus de l’overlay */
.footer-address-bg .container,
.footer-address-bg .row,
.footer-address-bg .col-lg-4 {
  position: relative;
  z-index: 2;
}

/* Pour le texte */
.footer-address-bg h6 {
  color: #000;             /* texte sombre sur fond clair */
  margin: 0;
  line-height: 1.5;
}

