@charset "UTF-8";

.map {
  width: 100%;
  height: 200px;
}

#cesiumContainer {
  width: 100%;
  height: 100%;
  /* margin-left: -10px;
    margin-right: -10px;  */
  padding: 0px;
  left: 0px;
  right: 0px;
  top: 0px;
  bottom: 0px;
  position: fixed;
  overflow: hidden;
}

/* Masque l'identifiant dans le titre de l'infoBox */
.cesium-infoBox-title {
  display: none;
}

/* Assure que le bouton de fermeture soit visible */
.cesium-infoBox-close {
  z-index: 1000;
  display: block;
  position: absolute;
  top: 5px;
  right: 5px;
  height: 20px;
  background: transparent;
  border: none;
  border-radius: 2px;
  font-weight: bold;
  font-size: 16px;
  padding: 0 5px;
  margin: 0;
  color: #edffff;
  width: 50px;
  height: 50px;
}

.cesium-infoBox-description {
  width: 200px;
  margin-top: 50px;
  padding-left: 50px;
}

button.cesium-infoBox-camera {
  display: block;
  position: absolute;
  top: 4px;
  left: 4px;
  width: 22px;
  height: 22px;
  background: transparent;
  border-color: transparent;
  border-radius: 3px;
  padding: 0 5px;
  margin: 0;
  margin-right: 150px !important;
}

.custom-control-button {
  background-color: #d0d0d0;
  color: white;
  border: none;
  padding: 5px 10px;
  margin-top: 5px;
  margin-left: 10px;
}

.custom-control-button-2 {
  background-color: #f46060;
  color: white;
  border: none;
  padding: 5px 10px;
  margin-top: -200px;
  margin-left: 10px;
}

.custom-control-button-3 {
  background-color: #1bc48a;
  color: white;
  border: none;
  padding: 5px 10px;
  margin-top: -200px;
  margin-left: 10px;
}

#toolbar {
  position: absolute;
  top: 120px;
  right: 10px;
  z-index: 100;
  background: rgba(42, 42, 42, 0.8);
  padding: 10px;
  padding-top: 12px;
  border-radius: 5px;
}

#barre_laterale {
  position: absolute;
  top: 200px;
  margin-left: -20px;
  z-index: 100;
  background: transparent;
  padding: 10px;
  border-radius: 5px;
  font-size: 80%;
  width: 350px;
}

button {
  color: #506faa;
  background-color: transparent;
  padding-top: 4px;
  padding-bottom: 4px;
  width: 240px;
  height: 30px;
  padding-left: 10px;
  padding-right: 10px;
  text-align: center;
  font-size: 120%;
  transition: 0.1s;
  border-width: 2px 2px 2px 2px;
  border-style: none;
  border-radius: 0px;
  border-color: #2e99b9 #2e99b9 #2660b9 #2660b9;
  border-collapse: separate;
  margin-top: 10px;
}

button:hover {
  transition-duration: 0.1s;
  color: #ffffff;
  background-color: #d0d0d0;
  /*color: #FFFFFF;*/
}

.btn_devis {
  font-size: 130%;
  background-color: var(--vert_transparent);
  color: #ffffff;
  width: 200px;
  height: 30px;
  margin-top: -5px;
}

btn_devis:hover {
  transition-duration: 0.1s;
  color: #f46060;
  background-color: #ffffff;
}

.btn_menu {
  font-size: 120%;
  background-color: #ffffff;
  color: black;
  width: 200px;
  height: 30px;
  margin-top: -5px;
}

.btn_menu p {
  margin: 0px;
  font-family: RoundedElegance, Roboto, Arial;
  font-weight: 400;
  font-size: 0.875rem;
  line-height: 1.43;
  color: white;
  padding-left: 8px;
}

btn_menu:hover {
  transition-duration: 0.1s;
  color: #f46060;
  background-color: #ffffff;
}

.div_item {
  width: 100%;
  cursor: pointer;
  background-color: var(--items);
  margin-top: 10px;
  margin-bottom: 10px;
}

.p_item {
  margin: 0px;
  font-family: RoundedElegance, Roboto, Arial;
  font-weight: 400;
  font-size: 0.875rem;
  line-height: 1.43;
  color: white;
  padding-left: 8px;
  text-align: left;
}

.p_item_devis {
  padding-top: 6px;
  padding-bottom: 6px;
}

.table_items {
}

.table_items tr {
  line-height: 1.43;
  height: 20px;
}

.table_items td {
  /* width: 250px; */
  margin: 0px;
  font-family: RoundedElegance, Roboto, Arial;
  font-weight: 400;
  font-size: 0.875rem;
  line-height: 1.43;
  color: white;
  padding-left: 4px;
  padding-right: 4px;
  text-align: left;
  background-color: white;
  color: rgb(117, 117, 117);
  margin-top: 10px;
  margin-bottom: 10px;
}

.colonne_boutons {
  display: flex;
  flex-flow: column wrap;
}

.barre-h {
  height: 50px;
  background-color: var(--gris_barre);
  position: fixed;
  top: 50px;
  z-index: 10;
  left: 0px;
  right: 0px;
}

.barre-v {
  /* width: 100%; */
  height: 50px;
  background-color: var(--gris_barre);
  position: absolute;
  top: 50px;
  bottom: 0px;
  position: fixed;
  z-index: 5;
  overflow: hidden;
}

.cadre-sous-menu {
  /* height: 100%; */
  width: 0;
  background-color: rgba(255, 255, 255, 0.945);
  position: absolute;
  left: 260px;
  top: 100px;
  bottom: 30px;
  z-index: 10;
  transition: width 0.5s;
}

#accueil {
  margin-top: -50px;
  height: 105%;
  width: 180px;
  padding-left: 2px;
  padding-right: 2px;
  background-color: var(--barre-verticale);
  position: absolute;
  left: 70px;
  z-index: 10;
  transition: left 1s;
  transition: width 0.5s;
  transition: left 0.7s;
  border-right: 2px solid rgba(255, 255, 255, 0.411);
  /* Couleur plus foncée */
  border-right: 2px solid rgba(255, 255, 255, 0.411);
  /* Couleur plus foncée */
}

#barre_dtech {
  height: 100%;
  width: 0;
  background-color: rgba(0, 155, 207, 0.3);
  position: absolute;
  left: 260px;
  /* top: 100px; */
  z-index: 10;
  transition: width 0.5s;
}

.titre-2 {
  font-family: RoundedElegance, Roboto, Arial;
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 1.6;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin: 0px 16px;
}

.cesium-geocoder-searchButton,
.cesium-home-button,
.cesium-toolbar-button {
  border-radius: 5px;
  background-color: #009bce;
  border-color: #009bce;
  color: #fff;
}

.t_000 {
  text-align: left;
  height: 50px;
  width: 240px;
  margin-top: 0px;
  margin-left: 0px;
  /* Toujours à gauche */
  display: inline-flex;
  flex-direction: row;
  justify-content: left;
  /* Centrer les items horizontalement */
  align-items: center;
  /* Centrer les items verticalement */
  background-color: var(--gris-barre);
  color: white;

  /* Positionnement indépendant */
  position: absolute;
  /* Ou fixed si on veut qu'il reste fixe à l'écran */
  top: 0px;
  /* Position verticale */
  left: 0px;
  /* Collé à gauche */
  z-index: 1;
  /* Pas masqué */
}

.t_001 {
  text-align: left;
  height: 50px;
  /* width: 100%; */
  position: fixed;
  right: 0px;
  margin-top: 0px;
  left: 240px;
  display: inline-flex;
  flex-direction: row;
  justify-content: left;
  /* Centrer les items horizontalement */
  align-items: center;
  /* Centrer les items verticalement */
  background-color: var(--gris-barre);
  color: white;
}

.t_002 {
  text-align: center;
  height: 50px;
  width: 100%;
  right: 0;
  margin-top: 0px;
  display: inline-flex;
  flex-direction: row;
  justify-content: center;
  /* Centrer les items horizontalement */
  align-items: center;
  /* Centrer les items verticalement */
  background-color: var(--items);
  color: white;
}

.t_003 {
  text-align: right;
  height: 50px;
  width: 350px;
  margin-top: 0px;
  margin-left: 0px;
  background-color: var(--gris-barre);
  color: white;
  position: absolute;
  top: 0px;
  /* Position verticale */
  right: 120px;
  /* Collé à droite */
  z-index: 2;
}

.t_outil_et {
  padding: 6px;
  text-align: left;
  height: 25px;
  width: 750px;
  position: fixed;
  bottom: 250px;
  left: 270px;
  display: inline-flex;
  background-color: var(--gris-barre);
  color: white;
  align-items: center;
  flex-direction: row;
  justify-content: left;
}

.t_outil {
  padding: 6px;
  text-align: left;
  height: 180px;
  width: 750px;
  position: fixed;
  bottom: 50px;
  left: 270px;
  display: inline-flex;
  /* flex-direction: row;
    justify-content: left;
    /* Centrer les items horizontalement */
  /* align-items: center; */
  /* Centrer les items verticalement */
  background-color: var(--gris-barre);
  color: white;
}

.t_outil_menuh {
  top: 110px;
  left: 40px;
}

.t_outil_boxmenuh {
  top: 150px;
  left: 40px;
  height: 20px;
}

.t_outil_dialog {
  padding: 6px;
  text-align: left;
  position: fixed;
  bottom: 350px;
  top: 190px;
  left: 40px;
  display: inline-flex;
  background-color: var(--gris-barre);
  color: white;
  align-items: center;
  flex-direction: row;
  justify-content: left;
}

.t_outil_flex {
  flex-direction: row;
  justify-content: left;
  /* Centrer les items horizontalement */
  align-items: center;
  /* Centrer les items verticalement */
}

/* Conteneur ligne des sliders */
.sliders {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 10px;
}

/* Groupe individuel de chaque slider + input */
.slider-group {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

/* Uniformisation des inputs texte */
.slider-group input[type='text'] {
  margin-top: 3px;
  text-align: center;
  width: 50px;
  height: 20px;
}

.lod-group {
  display: flex;
  gap: 10px;
  margin: 20px;
}

.lod-button {
  width: 32px;
  height: 32px;
  background-color: #2c2c2c;
  border: 1px solid #666;
  border-radius: 6px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.2s;
  margin-bottom: 6px;
}

.lod-button:hover {
  background-color: #444;
}

.lod-button svg {
  width: 100%;
  height: 100%;
}

.lod-button circle {
  fill: white;
}

/* .css-j8z28h {
            z-index: 25;
            position: absolute;
            bottom: 230px;
            right: 30px;
            width: 125px;
            height: 125px;
        } */

.cesium-viewer-toolbar {
  /* display: block;
            position: absolute; */
  top: 55px;
  right: 10px;
  z-index: 15;
}

/* .cesium-viewer-animationContainer {
            position: absolute;
            bottom: 100;
            left: 0;
            padding: 0;
            width: 169px;
            height: 112px;
        } */

.multi-box {
  overflow: hidden;
  height: 100%;
  width: 600px;
  background-color: rgb(255, 255, 255);
  position: absolute;
  right: 0px;
  z-index: 150;
  transition: right 1s;
}

.css-2evgrs.Mui-selected {
  color: white;
  background-color: rgb(0, 156, 210);
}

.css-1u5mult {
  margin-left: 16px;
  bottom: 50px;
  height: 50px;
  width: 24px;
  border-bottom-right-radius: 30px;
  box-shadow: rgb(0, 155, 206) 0px 25px 0px 0px;
}

.css-ll1fto {
  display: inline-flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center;
  position: relative;
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
  cursor: pointer;
  user-select: none;
  vertical-align: middle;
  appearance: none;
  text-align: center;
  font-size: 1.5rem;
  background-color: rgb(0, 155, 206);
  width: 40px;
  height: 40px;
  color: white;
  outline: 0px;
  border-width: 0px;
  border-style: initial;
  border-color: initial;
  border-image: initial;
  margin: 0px;
  text-decoration: none;
  flex: 0 0 auto;
  padding: 8px;
  overflow: visible;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1);
  border-radius: 15px 0px 0px 15px;
}

.css-w0pj6f {
  overflow: hidden;
  pointer-events: none;
  position: absolute;
  z-index: 0;
  inset: 0px;
  border-radius: inherit;
}

.css-1wfl5ae {
  margin-left: 16px;
  bottom: -50px;
  height: 50px;
  width: 24px;
  border-top-right-radius: 30px;
  box-shadow: rgb(0, 155, 206) 0px -25px 0px 0px;
}

.css-vubbuv {
  user-select: none;
  width: 1em;
  height: 1em;
  display: inline-block;
  fill: currentcolor;
  flex-shrink: 0;
  font-size: 1.5rem;
  transition: fill 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

.css-j8gl39 {
  width: 40px;
  height: 40px;
  position: absolute;
  z-index: 20;
  right: 600px;
  transition: right 1s;
  top: 45%;
}

.hr-a {
  margin: 0px;
  margin-left: 6px;
  margin-right: 6px;
  flex-shrink: 0;
  border-width: 0px thin 0px 0px;
  border-style: solid;
  border-color: rgba(0, 0, 0, 0.12);
  height: 100%;
  background-color: rgb(226, 226, 226);
  width: 2px;
  /* position: absolute; */
}

.css-11ybaep {
  overflow: hidden;
  min-height: 48px;
  display: flex;
  background-color: rgb(117, 117, 117);
  font-family: sans-serif;
  font-size: 0.875rem;
  height: 50px;
}

.css-1anid1y {
  position: relative;
  display: inline-block;
  flex: 1 1 auto;
  white-space: nowrap;
  overflow-x: hidden;
  width: 100%;
}

.css-k008qs {
  display: flex;
}

.css-1obctz6 {
  position: absolute;
  height: 2px;
  bottom: 0px;
  width: 100%;
  background-color: rgb(92, 127, 113);
  transition: 300ms cubic-bezier(0.4, 0, 0.2, 1);
}

.checkbox-switch {
  display: inline-flex;
  width: 58px;
  height: 38px;
  overflow: hidden;
  padding: 12px;
  box-sizing: border-box;
  position: relative;
  flex-shrink: 0;
  z-index: 0;
  vertical-align: middle;
}
