/* Reset
-------------------------------------------------- */
main.checkout {
  padding: calc(60px + 70px) 42.5px 0;
  width: 100%;
  display: flex;
  flex-flow: column wrap;
  align-items: flex-start;
}
main.checkout section {
  padding: 30px 0 0 0;
  width: 100%;
  display: flex;
  flex-flow: column wrap;
  align-items: flex-start;
  display: grid;
  gap: 25px;
  border-top: 1px solid var(--color-light-grey);
  grid-template-columns: repeat(12, 1fr);
}
main.checkout h2 {
  grid-column: 1 / span 2;
  color: var(--color-grey);
}
main.checkout article {
  grid-column: 4 / span 6;
  font-size: 20px;
  line-height: 26px;
}
#original-price{color:#4EBC31;text-decoration: line-through;font-size: 25px;
line-height: normal;margin-left:25px}
div.twocolumns{
   display: flex;
  flex-flow: row wrap;
  align-items: flex-start;justify-content: center;
  gap: 25px;width: 100%;align-content: center;
   
}
div.twocolumns:nth-child(1){margin-bottom:25px}
div.onecolumn{
   display: flex;
  flex-flow: column wrap;
  align-items: flex-start;justify-content: center;
  gap: 25px;width: 100%;align-content: center;
   
}

div.onecolumn input.grey {
  
  width: 100%;
   
}
div.column{
   display: flex;
  flex-flow: column nowrap;
  align-items: stretch;
  width: 100%;
}
body.checkout div.column > div{margin-bottom:12.5px;border-radius: 4px;}




div.column label{
  width: 100%;
display: inline-block;
align-items: center;
padding: 12.5px;font-size:16px;line-height:20px;
background-color: var(--color-lighter-grey);
border-radius: 4px;
cursor: pointer;
transition: background-color 0.3s;
user-select: none;
}




div.threecolumns{
   display: flex;
  flex-flow: row wrap;
  align-items: flex-start;justify-content: center;
  gap: 25px;width: 100%;align-content: center;
   
}
div.threecolumns input.grey {
  flex:1
   
}

main.checkout section .box {
  border-bottom: 1px solid var(--color-light-grey);
  display: flex;
  flex-flow: column wrap;
  align-items: stretch;
  gap: 25px;width: 100%;padding-bottom:42.5px;margin-bottom:12.5px;
}
main.checkout section .box div.small{
  color: var(--color-grey);font-size:16px;line-height:20px;
}
main.checkout section .box:last-child{border:0}
main.checkout section .box div{
  flex:1
}
main.checkout section .box div span.title{

font-size: 18px;display: flex;
line-height: normal;font-family: 'Practical500';
}
main.checkout section .box div span.title span{margin-right:12.5px;width:20px;height:20px;display: block;text-align:center;font-feature-settings: "ss10" 1;
}


a.empty:hover {
  opacity: 0.3;
}
a.empty {
  text-decoration: underline;
    text-decoration-color: currentcolor;
    text-decoration-thickness: auto;
  text-decoration-color: currentcolor;
  text-decoration-thickness: auto;
  text-decoration-thickness: 1px;
  text-underline-offset: .15em;
  text-decoration-color: currentColor;
  transition: opacity .3s ease;
}


body.checkout div.column div.checked label{background:red}


/* Radio buttons avec le même style que les checkboxes */
main.checkout input[type="radio"] {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

main.checkout input[type="radio"] + label {
  position: relative;
  display: block;
  padding-left: 45px;
  cursor: pointer;
  user-select: none;
  font-size: 16px;
  line-height: 20px;
}
main.checkout input[type="radio"] + label:hover {
  background:var(--color-light-grey)
}
main.checkout input[type="radio"] + label:before {
  content: "";
  position: absolute;
  left: 17px;
  top: 17px;
  width: 10px;
  height: 10px;
  border: 1px solid #000;
  background: #fff;
}

main.checkout input[type="radio"]:checked + label::before {
  background: #000;
}

main.checkout div.checked input[type="radio"] + label::before {
  background: #000;
}

.total{position: sticky;bottom:0;left:0;width:100%;
color: white;
background-color: rgba(0, 0, 0, 0.8);
padding: 42.5px 0;
display: flex;
justify-content: space-between;
align-items: center;
z-index: 10;}

.total:after{content:'';position:absolute;top:0;left:-42.5px;width:42.5px;height:100%;background-color: rgba(0, 0, 0, 0.8);}
.total:before{content:'';position:absolute;top:0;right:-42.5px;width:42.5px;height:100%;background-color: rgba(0, 0, 0, 0.8);}



.total strong {
  font-size: 25px;
  line-height: normal;
}
.subtotal{
   display: flex;justify-content: space-between;
   padding: 0 15px 30px 15px;font-size: 14px;
line-height: 20px;cursor: pointer
}
.subtotal button:hover{
  opacity: 0.3;cursor: pointer
}
.subtotal button{text-decoration: underline;
  text-decoration-color: currentcolor;
  text-decoration-thickness: auto;
text-decoration-thickness: 1px;
text-underline-offset: 0.15em;
text-decoration-color: currentColor;
transition: opacity 0.3s cubic-bezier(0.25, 0.1, 0.25, 1);}
.total span {
  flex:1
}

.total span:last-child {
  text-align:right
}
body.payment .total span:nth-child(2) {
  text-align:center
}
.total button, .payementback {text-align: center;
   color: black;
display: inline-block;
padding: 9px 18px;
background: var(--color-bg);
color: var(--color-text);
border: 1px solid var(--color-text);
border-radius: 32px;
font-family: 'Practical400',sans-serif;
line-height: normal;
cursor: pointer;
transition: background-color .125s ease,color .125s ease,border-color .125s ease;
  padding: 14px 28px;
  font-size: 25px;
  line-height: normal;white-space: nowrap;
  
}
.total button:hover, .payementback:hover {
  background-color: red;color:black!important
}


main.checkout input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}
main.checkout label {
  position: relative;
  display: flex;
  padding-left: 45px;
  cursor: pointer;
  user-select: none;
  font-size: 16px;
  line-height: 20px;justify-content: space-between
}
main.checkout label:hover{background:var(--color-light-grey)}




main.checkout label:before {
  content: "";
  position: absolute;
  left: 17px;
  top: 17px;
  width: 10px;
  height: 10px;
  border: 1px solid #000;
  background: #fff;
}
main.checkout input[type="checkbox"]:checked + label::before {
  background: #000;
}

main.checkout div.checked input[type="checkbox"] + label::before {
  background: #000;
}
main.checkout label span{float:right;font-size:14px;line-height: 20px;display: flex;}
main.checkout label span.name{font-size:16px;line-height: 20px;flex:1}

main.checkout label span.aa-preview {
    font-size: 23px;
    margin-right: 1rem;
    vertical-align: middle;
   float:left;
}
div.column.select label:before {
  display: none
}
main.checkout div.column.select label{
  padding:0
}

main.checkout div.column.select{
  border-radius: 4px;
}
main.checkout div.column.select label{
  background:red
}


/* Le label devient le conteneur de référence pour l'arrow */
main.checkout div.column.select label {
  position: relative;
  display: block;  
}

/* Supprime la flèche native du navigateur */
main.checkout div.column.select select {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  padding: 12.5px 17px;outline:none
}

/* Flèche positionnée à droite, centrée verticalement */
main.checkout div.column.select label .ot-arrow {
  position: absolute;
  right: 17px;     
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none; 
}



main.checkout .product-item label{padding:25px 12.5px;}
main.checkout .product-item label::before{content:none}
main.checkout label span.family-name{font-size: 30px;
padding-right: 1rem;float:left}

main.checkout label span.style-count{float:left;flex:1}


.payment input[type="text"],
.payment input[type="email"],
.payment input[type="tel"] {
  width: 100%;
padding: 10px 15px; 
background-color: var(--color-lighter-grey);
border-radius: 6px;
border: none;
font-size: 1rem;
font-family:inherit;
color: var(--color-text);
outline: none;
-webkit-appearance: none;
appearance: none;
}
.payment div.column {
  flex: 1;
  margin-bottom: 12.5px;
}
.payment div.column > div {
  border:0
}
.payment input[disabled] {
    background: #f5f5f5;
    color: #666;
}

.payment .column > div {
    margin-bottom: 0;
}


div.column ol {
    counter-reset: foo;
    display: table;font-size: 16px;
line-height: 20px;
}

div.column ol > li {
    counter-increment: foo;
    display: table-row;
}

div.column ol > li::before {
    content: counter(foo) ".";
    display: table-cell;width:25px;
    text-align: left;
}



@media only screen and (max-width:1440px){
  
main.checkout article {
  grid-column: 3 / span 8;
  
}
}


@media only screen and (max-width:680px){
   main.checkout {
  padding: 65px 15px 0;
  width: 100%;
  display: flex;
  flex-flow: column wrap;
  align-items: flex-start;
}
   main.checkout section {
  padding: 15px 0 60px;
  gap: 26px;
}
main.checkout section {
  padding: 30px 0 130px 0;
  width: 100%;
  display: flex;
  flex-flow: column wrap;
  align-items: flex-start;
  display: grid;
  gap: 25px;
  border-top: 1px solid var(--color-light-grey);
  grid-template-columns: repeat(12, 1fr);
}
   main.checkout h2 {
  grid-column: 1 / -1;
}
   main.checkout article {
  grid-column: 1 / span 12;
}
   
   div.twocolumns {
  display: flex;
      flex-flow: column wrap;}
   
   main.checkout label span.family-name {
  font-size: 14px;
  padding-right: 1rem;
  float: left;
}
   .total {
 
  flex-flow: column wrap;
  gap: 20px;
}
   .total div{
 
  flex-flow: column wrap;
  gap: 20px;
}
   div.twocolumns {
      gap: 15px;}
   
   .order-confirmation nav.submenu{display:none}
   
   
   
}