/* div {border: solid 1px black} /**/

/* Règles du responsive :
   jusqu'à 600    : mobile
   de 601 à 1000  : tablette et petits écrans
   de 1001 à 1400 : desktop
   sup à 1401     : fixe */

/* CSS général balisse html et body */
body {font-family: Calibri, Helvetica, Arial, sans-serif;
  margin: 0; padding: 0;
  overflow-y: scroll}
table {border-spacing : 0; border-collapse : collapse}

body {
  --vert : green;
  --orange : orange;
  --rouge : red;
}
.onlySAV {display: none}

/* écran principal du dialogue */
#dialogue {margin: auto; position: relative; max-width: 1440px; min-height: 100vh}
.diFooter {height: 5em}
#contenu {min-height: 280px; padding-left: 6px}

.pageZ #dialogue {display:none}
.pageZ #bureauMDI {display: block}

/* iframe embarqué */
#contenu iframe {width: 100%; height: 920px; border: none}

@media only screen and (max-width: 600px) {
/*  #dialogue {padding-left: 4px; padding-right: 4px} /**/
}

/* entête du dialogue
     desktop       texte, logo ht=70px
     tablette      texte 75%, logo ht=40px
     smatphone     logo ht=40px, menu icône on
 */
#entete {padding: .4em .6em 0 .6em; margin-bottom: 1em}
#entete img {max-height: 70px}
.admin .billSirius {font-size: 2.4em; height: 100%; display: flex; align-items: center}
.billSirius img {padding-right: .4em}
.icoMenu {display: none}
#etpAdmin {padding-left: 1em}

@media only screen and (max-width: 1000px) {
  #entete {position: sticky; top: 0; left: 0; width: 100%; background-color: white; z-index: 98}
  .billSirius {font-size: 1.8em}
  #entete img {max-height: 40px}
}
@media only screen and (max-width: 600px) {
  .billSirius {display: none}
  .icoMenu {display: inline}
  .diFooter {height: 12em}
  label.offSM {display: none}
  div.offSM {display: none}
}

/* menu du site, caché en mode smartphone */
#affMenu {display: none}
#affMenu label {padding-top:.6em; width: 8em}
#affMenu span {padding-right: .6em}
#popmenu {display: none; position: absolute; top: 0; right: 20px; z-index: 99;
  text-align: right; padding: 2em; background-color: white}
#popmenu label {display: block; padding-bottom: 1em}

div.traitmenu {border-bottom: 2px silver solid}
#dialmenu {position: relative; height: 1.8em; top: -1.8em; text-transform: uppercase}
#dialmenu label {position: relative; top: -2px;
  display: inline-block; height: 1.8em; margin: 0; padding-left: .5em; padding-right: .5em;
  border-bottom: 2px silver solid;
  font-weight: bold}

@media only screen and (max-width: 1000px) {
  #dialmenu label {font-size: 0.95em}
  #popmenu {display: none}
}
@media only screen and (max-width: 600px) {
  .traitmenu,  #dialmenu {display: none}
  #affMenu {display: flex}
}

/* étapes */

.etapes {position: absolute; bottom: 40px; width: 100%}
.etapes li:not(.clic) {cursor: default}
.etapes div {position:relative;counter-reset:progress;padding-top:1.4em}
.etapes ul {display: flex; justify-content: space-between; margin-right: auto; margin-left: auto}
.etapes li{counter-increment:progress;text-align:center;position:relative;flex:1 0 0;list-style-type: none; height: 45px}
.etapes li:not(:first-of-type):before{content:"";height:1px;background-color:currentColor;position:absolute;width:calc(100% - 12px);left:calc(-50% + 6px);bottom:12px}
.etapes span{text-transform:uppercase;font-weight:700;padding-bottom:5px; font-size:.9em}
.etapes span:before{content:counter(progress) ". "}
.etapes button{background-color:currentColor;color:inherit;width:10px;height:10px;padding:0;position:absolute;left:50%;bottom:8px;border:none;-webkit-transform:translate(-50%);transform:translate(-50%);min-height:10px}
@media screen and (max-width:1000px){.etapes span {font-size: .8em}.etapes ul {padding-left: 0}}
@media screen and (max-width:700px){.etapes span {font-size: .7em}}
@media screen and (max-width:600px){
  .etapes {bottom: 120px}
  .etapes ul {flex-wrap: wrap}
  .etapes span {font-size: .9em}
  .etapes li:before{display: none}
  .etapes li {flex-basis: 100%; height: 22px}
  .etapes button {display: none}
}

/* pied de page */
div.traitnoir {padding-top: .5em; border-bottom: 1px solid black}
footer {position: absolute; width: 100%; height: 50px; right: 0; bottom: 0; background-color: #ECECEC;
}
footer label {display: inline-block; height: 20px; padding: .4em; vertical-align: top}
/*span.footRZ {display: inline-block; padding: 4px 10px 0 4px}*/
#annonce span {display: inline-block; padding: 8px 0 0 12px}
/* .footMT img {padding-top: 4px}*/
#version {text-align: right}

@media only screen and (max-width: 1000px) {
  footer label {padding: .2em .2em 0 .2em}
  #annonce label {padding-top: .8em; padding-left: 6px; font-size: .8em}
  #version label {font-size: .9em; max-width: 90px; padding-top: .6em}
}
@media only screen and (max-width: 600px) {
  footer {height: 120px}
  #annonce label {padding-top: .2em; padding-left: 6px; display: block}
  #version {padding-top: 1.8em}
  #version label {display: block; padding-top: .3em}
}

/* écran du SAV */
.contenuSAV .qstFAQ {padding-bottom: .5em}
@media only screen and (max-width: 1000px) {
  .sav label {display: block}
  .sav label.qst {padding-top: 1em}
}
#contenu {max-width: 90%}
@media only screen and (max-width: 1000px) {
  #contenu {max-width: 100%}
}

/* gestion du petit panier */
#diPP {position: absolute; top: 124px; right: 0; height: 100%; box-shadow: 0 40px 90px white}
#diPP button {cursor: pointer; border:2px solid currentColor; background-color: white}
#diPP button.valid:hover,#diPP button.valid.agSL {border: 2px solid var(--vert); background-color: var(--vert); color: white}
#diPP button.agNo:hover,#diPP button.agNo.agSL {border: 2px solid silver; background-color: silver; color: white}
#diPP button.alert:hover,#diPP button.agSL.alert {border: 2px solid var(--rouge); background-color: var(--rouge); color: white}
#diPP button.beware:hover,#diPP button.agSL.beware {border: 2px solid var(--orange); background-color: var(--orange); color: white}

#petitPanier {position: sticky; top: 10px; width: 390px; z-index: 21; background-color: #f8f8f8}
.titrePP {position: relative; border-bottom: 1px solid silver; padding: 8px}
.infosPP {position: relative; padding: 8px 8px 16px 8px}
@media only screen and (max-width: 1000px) {
  #petitPanier {top: 60px}
  #diPP {top: 94px; width: 100%; background-color: #fcfcfc; z-index:20}
}
.infosPani {font-size: .8em}
.spPani {border: 1px solid silver; border-radius: 6px; margin-top: 12px; padding: 8px 0 8px 0}
.tiPani {margin-left: 8px; font-size: 1.2em; font-weight: bold}
.scPani>div,.plPani>div,.rbPani>div {display: inline-block}
.scPani {padding-top: 8px}
.plPani {padding-top: 4px}
.plLast {border-bottom: 1px solid silver; padding-bottom: 6px; margin-bottom: 6px}
.dtPani {margin-left: 8px; width: 320px}
.csPani {margin-left: 8px; padding-left: 30px; width: 320px; font-weight: bold}
.nbPani {margin-left: 8px; width: 30px; text-align: right; padding-right: 10px}
.taPani {width: 210px}
.icPani {width: 34px; text-align: right}
.goPani {padding-top: 12px; text-align: right}
.toPani {margin-top: 12px; border-top: 1px solid silver; padding-top: 8px}
.rbPani {margin-top: 12px}
.rbPani .icPani {width: 36px}
.rbPani label {display: inline-block; width: 258px}
.rbPani span {font-size: 1.2em}
.ppNmTA {display: inline-block; width: 11.8em}
.ppNbTA {display: inline-block; width: 1.2em; text-align: center}
.ppPuTA {display: inline-block; width: 4em; padding-right: 12px; text-align: right}
.ppPM {display: inline-block; background-color: white; font-size: 1.4em; font-weight: bold}
.ppInput {text-align: right; display: inline-block; width: 1.6em; height: 1.6em}
.noInput {display: inline-block; width: 1.6em}
#bcOkPP {width: 180px}

/*    .tp2 span {position: relative; top: 2px}
    .tm2 span {position: relative; top: -2px} /**/
.pxPani {width: 70px; text-align: right}
.slPani {padding-bottom: 16px}
@media only screen and (max-width: 600px) {
  #diPP {top: 60px}
  #petitPanier {width: 350px; top: 60px}
  .dtPani,.csPani {width:280px}
  .taPani {width:170px}
  .rbPani label {width: 218px}
  .infosPani  {font-size: .7em}
}
