.cart-container {
  position: relative;
  width: 200px; height: 43px;
  margin: 0 auto -12px auto;
}

.cart-container.hidden {
  height: 0px;
  margin-bottom: -24px;
  overflow: hidden;
}

.cart-icon-container {
  position: absolute;
  top: 0; left: 0;
  width: 40px; height: 36px;
  overflow: visible;
}

.shopping-bag-icon {
  position: absolute;
  top: 6px;
  width: 30px; height: 30px;
  fill: #f21058;
}
.shopping-bag-icon:hover {
  fill: #dc1849;
  cursor: pointer;
}
.cart-icon-container a, 
.cart-icon-container a:visited
{
  color: #f21058;
  fill: #f21058;
}
.cart-icon-container a:hover {
  color: #dc1849;
  fill: #dc1849;
}

.cart-badge {
  position: absolute;
  top: 0; right: 0;
  width: 24px; height: 24px;
  border-radius: 48px;
  border: 2px solid #ffffff;
  background: #f21058;
  box-shadow: 0 0 2px rgba(0, 0, 0, 0.4);
  text-align: center;
  line-height: 21px;
}

a .cart-badge, a:visited .cart-badge, a:hover .cart-badge {
  font-size: 9px;
  font-weight: bold;
  color: #ffffff;
}

.cart-total {
  position: absolute;
  top: 1px; right: 0;
  text-align: right;
  font-weight: bold;
}

.cart-link {
  position: absolute;
  right: 0; bottom: 0;
  text-align: right;
}

.cart-link a, .cart-link a:visited, .cart-link a:hover {
  font-size: 13px;
  color: #f21058;
  text-decoration: none;
}

.cart-link a:hover {
  text-decoration: underline;
}

.shopping-cart {
  margin: 24px;
}

.shopping-cart.loading {
  width: 100%; height: 240px;
  background: no-repeat 50% 50% url('/wp-content/plugins/tqc-stripe/svg/spinner.svg');
  background-size: 48px 48px;
}

.shopping-cart p.empty-cart {
  display: none;
  text-align: center;
  color: #909090;
  margin-top: 48px;
  font-style: italic;
}

.shopping-cart p.fatal-error, 
.shopping-cart p.internal-error, 
.shopping-cart p.order-received
{
  display: none;
  text-align: left;
  color: #000000;
  padding: 0 48px 0 48px;
  margin: 0 0 0 0;
}

.shopping-cart.empty p.empty-cart, 
.shopping-cart.fatal-error p.fatal-error, 
.shopping-cart.internal-error p.internal-error, 
.shopping-cart.order-received p.order-received
{
  display: block;
}

.shopping-cart.loading .products, 
.shopping-cart.loading .totals, 
.shopping-cart.loading .order, 

.shopping-cart.empty .products, 
.shopping-cart.empty .totals, 
.shopping-cart.empty .order, 

.shopping-cart.fatal-error .products, 
.shopping-cart.fatal-error .totals, 
.shopping-cart.fatal-error .order, 

.shopping-cart.internal-error .products, 
.shopping-cart.internal-error .totals, 
.shopping-cart.internal-error .order, 

.shopping-cart.order-received .products, 
.shopping-cart.order-received .totals, 
.shopping-cart.order-received .order
{
  display: none;
}

.shopping-cart.order-received.empty p.empty-cart
{
  display: none !important;
}

.shopping-cart .products {
  
}

.shopping-cart .products .product {
  position: relative;;
  margin-bottom: 24px;
  padding: 0 12px 24px 12px;
  border-bottom: 1px solid #f0f0f0;
}

.shopping-cart .product-image {
  padding: 0 0 0 12px;
}
.shopping-cart .product-image img {
  width: 100%;
}

.shopping-cart .product-infos {
  padding: 0 0 0 18px;
}

.shopping-cart .product-details {
  margin-top: 6px;
}

.shopping-cart .product-details h2 {
  margin-top: 0px;
}

.shopping-cart .product-details p.description {
  margin-top: 3px;
  font-style: italic;
}

.shopping-cart .product-controls {
  margin: 18px 0 0 0;
  padding: 0 0 0 0;
}

.product-controls select.quantity {
  margin: 0 9px 0 0;
  padding: 0 0 0 0;
}

.shopping-cart .product-price {
  margin-top: 18px;
  font-size: 14px;
  font-weight: bold;
}

.shopping-cart .labels ul, 
.shopping-cart .amounts ul
{
  margin-top: 6px;
  text-align: right;
  line-height: 24px;
}

.shopping-cart .amounts ul {
  margin-right: 100px;
}

.shopping-cart .labels ul li, 
.shopping-cart .amounts ul li
{
  font-size: 16px;
}

.shopping-cart ul li.total-products {
  
}
.shopping-cart ul li.total-shipping {
  color: #707070;
}
.shopping-cart ul li.total {
  font-weight: bold;
}

.shopping-cart .order-btn-container {
  text-align: right;
  padding: 24px 100px 0 0;
}

button.big, button.big:hover {
  padding: 12px 24px;
  border-radius: 24px;
  border: none;
  font-weight: bold;
  font-size: 14px;
}

button.medium, button.medium:hover {
  padding: 12px 24px;
  border-radius: 24px;
  border: none;
  font-weight: bold;
  font-size: 14px;
}

button.small, button.small:hover {
  margin-top: 9px;
  padding: 5px 12px 6px 12px;
  border-radius: 24px;
  border: none;
  font-weight: bold;
  font-size: 14px;
  line-height: 18px;
}

button.pink, button.pink:hover {
  color: white;
  background: no-repeat 50% 50% url('/wp-content/plugins/tqc-stripe/svg/spinner-02.svg') #f61b52;
  background-size: 24px 24px;
}
button.small.pink {
  background: #f61b52;
}
button.pink:hover, 
button.pink:hover span
{
  background: #dc1849;
  cursor: pointer;
}
button.pink span {
  padding: 12px 0 12px 0;
  color: white;
  font-weight: bold;
  font-size: 14px;
  background: #f61b52;
  pointer-events: none;
}
button.pink.loading span {
  opacity: 0.0;
}

button.outlined-pink, button.outlined-pink:hover {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  color: #f61b52;
  background: #ffffff;
  border: 2px solid #f61b52;
}
button.outlined-pink:hover, 
button.outlined-pink:hover span
{
  color: #ffffff;
  background: #dc1849;
  border-color: #dc1849;
  cursor: pointer;
}
button.outlined-pink span {
  padding: 12px 0 12px 0;
  color: #f61b52;
  font-weight: bold;
  font-size: 14px;
  background: #ffffff;
  pointer-events: none;
}
button.outlined-pink.loading span {
  opacity: 0.0;
}

button.small.pink span {
  padding: 6px 0 6px 0;
  color: white;
  font-weight: bold;
  font-size: 10px;
  background: none;
  pointer-events: none;
}
button.small.pink span:hover {
  background: none;
}

svg.trash-can-icon {
  width: 14px; height: 14px;
  margin-bottom: -3px;
  fill: #909090;
}

svg.trash-can-icon:hover {
  fill: #505050;
  cursor: pointer;
}

#shopping-overlay .overlay-content {
  height: 371px;
}

#shopping-overlay .overlay-content .product-col {
  border-right: 1px solid #e0e0e0;
}

#shopping-overlay .overlay-content .product-col h1 {
  margin: 0 0 0 0;
  padding: 14px 0 9px 0;
  font-size: 16px;
  line-height: 20px;
  text-align: center;
}

#shopping-overlay .overlay-content .product-col img {
  margin: 0 0 0 0;
  padding: 0 0 0 0;
}

#shopping-overlay .overlay-content .product-col p {
  margin: 0 0 0 0;
  padding: 0 0 7px 0;
  text-align: center;
}

#shopping-overlay .overlay-content .btn-col {
  text-align: center;
}

#shopping-overlay .overlay-content .btn-col p {
  margin: 130px 0 36px 0;
  font-size: 18px;
  text-align: center;
}

.shopping-cart .product-mobile-img {
  display: none;
}

.shopping-cart .order-btn-container {
  text-align: right;
  padding: 24px 100px 0 0;
  margin-top: 0;
}

.shopping-cart table.totals .faint {
  color: #707070;
}

.shopping-cart table.totals .strong {
  font-weight: bold;
}

.shopping-cart table.totals .label {
  text-align: right;
}

.shopping-cart table.totals .amount {
  padding-left: 24px;
  text-align: right;
}

.shopping-cart table.totals {
  float: right;
  margin-right: 96px;
}

@media only screen and (max-width: 767px) {
  .shopping-cart {
    padding-bottom: 12px;
  }
  
  .shopping-cart .product-image {
    display: none;
  }
  
  .shopping-cart .product-mobile-img {
    display: block;
    float: left;
    width: 120px;
    padding: 0 12px 24px 0;
  }
  
  .shopping-cart .product-details {
    margin-top: 0px;
  }

  .shopping-cart .product-details h2 {
    margin-top: 0px;
    font-size: 18px;
    line-height: 22px;
  }

  .shopping-cart .product-details p.description {
    margin-top: 3px;
    line-height: 18px;
    font-style: italic;
  }

  .shopping-cart .product-controls {
    margin: 9px 0 0 0;
    padding: 0 0 0 0;
  }
  
  .shopping-cart .product-price {
    margin: 9px 0 0 0;
    padding: 0 0 0 0;
  }
  
  .shopping-cart .order-btn-container {
    text-align: center;
    padding: 0 0 0 0;
    margin-top: 24px;
  }
  
  .shopping-cart table.totals {
    margin-right: 36px;
  }
  
  #tqc-stripe-shopping-cart {
    display: none;
  }
}

label {
  -webkit-user-drag: none;
  -moz-user-drag: none;
  user-drag: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  cursor: pointer;
  font-weight: normal !important;
}

label input[type="checkbox"] {
  margin-right: 3px !important;
  vertical-align: 1px !important;
}

#recap h3 {
  margin: 24px 0 0 24px;
}

#recap .person-data {
  margin: 0 0 0 0;
  padding-left: 24px;
}

#recap .person-data p {
  margin: 0;
  padding: 0;
}

#recap .number-line {
  margin: 0 0 0 24px;
}

#recap h3 + .number-line {
  margin-top: 16px;
}

#recap .number-line + .number-line {
  margin-top: 22px;
}

#recap .total {
  font-weight: bold;
}
