.elementor-49 .elementor-element.elementor-element-8ede661{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}/* Start custom CSS for shortcode, class: .elementor-element-7bcb401 *//* ═══════════════════════════════════════════════════════
   LA CHATOUNERIE — PANIER WOOCOMMERCE
   CSS additionnel — Apparence > Personnaliser > CSS additionnel
   ═══════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=DM+Sans:wght@400;500;600;700&display=swap');

/* ── VARIABLES ── */
body.woocommerce-cart {
  --c:    #FFF6EC;
  --li:   #F5EBE0;
  --sa:   #E6D5C3;
  --ca:   #C4956A;
  --cdk:  #A67C52;
  --to:   #7A5635;
  --ch:   #2A1B12;
  --go:   #D4A54A;
  --glt:  #FDF3D7;
  --wh:   #FFFFFF;
  --ww:   #FEFBF6;
  --t2:   #6B5546;
  --t3:   #A0907F;
  --t4:   #C4B5A6;
  --bd:   rgba(196,149,106,.15);
  --sh:   0 2px 14px rgba(42,27,18,.06);
  --shm:  0 8px 28px rgba(42,27,18,.1);
  --ez:   cubic-bezier(.25,.46,.45,.94);
}

/* ── RESET BASE ── */
body.woocommerce-cart {
  background: var(--ww) !important;
  font-family: 'DM Sans', sans-serif !important;
}
body.woocommerce-cart * { font-family: 'DM Sans', sans-serif !important; }
body.woocommerce-cart h1,
body.woocommerce-cart h2,
body.woocommerce-cart h3,
body.woocommerce-cart .cart_totals h2,
body.woocommerce-cart td.product-name a { font-family: 'Playfair Display', serif !important; }

body.woocommerce-cart #main,
body.woocommerce-cart .site-main,
body.woocommerce-cart main { padding-top: 0 !important; margin-top: 0 !important; }

/* ── CONTENEUR GLOBAL ── */
body.woocommerce-cart .woocommerce {
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 0 clamp(16px,3vw,48px) clamp(60px,7vw,100px) !important;
  display: block !important; /* reset flex précédent */
}

/* ── TITRE PAGE ── */
body.woocommerce-cart .woocommerce > h1,
body.woocommerce-cart .entry-title,
body.woocommerce-cart h1.entry-title {
  font-family: 'Playfair Display', serif !important;
  font-size: clamp(2rem,4vw,3rem) !important;
  font-weight: 700 !important;
  color: var(--ch) !important;
  text-align: center !important;
  padding: clamp(32px,5vw,56px) 0 clamp(20px,3vw,36px) !important;
  letter-spacing: -.02em !important;
  margin: 0 !important;
}

/* ── LAYOUT 2 COLONNES : form + totaux côte à côte ── */
@media (min-width: 780px) {
  body.woocommerce-cart .woocommerce {
    display: grid !important;
    grid-template-areas:
      "notices  notices"
      "form     totals" !important;
    grid-template-columns: 1fr 380px !important;
    grid-template-rows: auto 1fr !important;
    gap: 0 32px !important;
    align-items: start !important;
  }
  body.woocommerce-cart .woocommerce-notices-wrapper { grid-area: notices !important; }
  body.woocommerce-cart .woocommerce-cart-form      { grid-area: form    !important; }
  body.woocommerce-cart .cart-collaterals           { grid-area: totals  !important; }
}

/* ═══════════════════════════════
   TABLE PANIER
═══════════════════════════════ */
body.woocommerce-cart table.shop_table,
body.woocommerce-cart table.wpr-shop-table {
  border: none !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  width: 100% !important;
  background: transparent !important;
}

/* Masquer header */
body.woocommerce-cart table.shop_table thead,
body.woocommerce-cart table.wpr-shop-table thead { display: none !important; }

/* ── CARTE ARTICLE ── */
body.woocommerce-cart tr.cart_item,
body.woocommerce-cart tr.woocommerce-cart-form__cart-item {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  background: var(--wh) !important;
  border: 1px solid var(--bd) !important;
  border-radius: 20px !important;
  padding: 16px 18px !important;
  margin-bottom: 10px !important;
  box-shadow: var(--sh) !important;
  transition: transform .3s var(--ez), box-shadow .3s var(--ez) !important;
}
body.woocommerce-cart tr.cart_item:hover,
body.woocommerce-cart tr.woocommerce-cart-form__cart-item:hover {
  transform: translateY(-2px) !important;
  box-shadow: var(--shm) !important;
}

/* Toutes les td */
body.woocommerce-cart tr.cart_item td,
body.woocommerce-cart tr.woocommerce-cart-form__cart-item td {
  border: none !important;
  padding: 0 !important;
  background: transparent !important;
  vertical-align: middle !important;
  display: block !important;
}

/* Suppression — à droite */
body.woocommerce-cart td.product-remove {
  order: 99 !important;
  margin-left: auto !important;
  flex-shrink: 0 !important;
  width: auto !important;
}
body.woocommerce-cart td.product-remove a.remove {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 30px !important;
  height: 30px !important;
  border-radius: 50% !important;
  background: var(--li) !important;
  color: var(--t4) !important;
  font-size: .8rem !important;
  text-decoration: none !important;
  transition: background .2s, color .2s, transform .25s !important;
  line-height: 1 !important;
}
body.woocommerce-cart td.product-remove a.remove:hover {
  background: var(--li) !important;
  color: var(--ca) !important;
  transform: rotate(90deg) !important;
}

/* Image */
body.woocommerce-cart td.product-thumbnail {
  flex-shrink: 0 !important;
  width: 76px !important;
}
body.woocommerce-cart td.product-thumbnail img {
  width: 76px !important;
  height: 76px !important;
  object-fit: cover !important;
  border-radius: 14px !important;
  display: block !important;
  border: 1px solid var(--bd) !important;
}

/* Nom produit */
body.woocommerce-cart td.product-name {
  flex: 1 !important;
  min-width: 0 !important;
}
body.woocommerce-cart td.product-name a {
  font-family: 'Playfair Display', serif !important;
  font-size: .95rem !important;
  font-weight: 700 !important;
  color: var(--ch) !important;
  text-decoration: none !important;
  display: block !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  margin-bottom: 4px !important;
  transition: color .2s !important;
}
body.woocommerce-cart td.product-name a:hover { color: var(--ca) !important; }
body.woocommerce-cart td.product-name .variation {
  font-size: .72rem !important;
  color: var(--t3) !important;
}

/* Prix unitaire */
body.woocommerce-cart td.product-price {
  font-size: .8rem !important;
  color: var(--t3) !important;
  font-weight: 500 !important;
  white-space: nowrap !important;
  padding: 0 6px !important;
  flex-shrink: 0 !important;
}

/* Quantité */
body.woocommerce-cart td.product-quantity {
  flex-shrink: 0 !important;
  padding: 0 4px !important;
}
body.woocommerce-cart td.product-quantity .quantity {
  display: flex !important;
  align-items: center !important;
  background: var(--li) !important;
  border-radius: 100px !important;
  padding: 3px !important;
  gap: 0 !important;
  width: fit-content !important;
}
body.woocommerce-cart td.product-quantity input.qty,
body.woocommerce-cart td.product-quantity input[type="number"] {
  width: 34px !important;
  text-align: center !important;
  border: none !important;
  background: transparent !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: .86rem !important;
  font-weight: 700 !important;
  color: var(--ch) !important;
  outline: none !important;
  box-shadow: none !important;
  -moz-appearance: textfield !important;
  padding: 4px 0 !important;
}
body.woocommerce-cart td.product-quantity input[type="number"]::-webkit-inner-spin-button,
body.woocommerce-cart td.product-quantity input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none !important;
}

/* Boutons +/- injectés par JS */
body.woocommerce-cart .tch-btn {
  all: unset !important;
  box-sizing: border-box !important;
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  color: var(--ca) !important;
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background .2s, transform .15s !important;
  flex-shrink: 0 !important;
  font-family: 'DM Sans', sans-serif !important;
  line-height: 1 !important;
}
body.woocommerce-cart .tch-btn:hover {
  background: var(--sa) !important;
  transform: scale(1.1) !important;
}
body.woocommerce-cart .tch-btn:focus { outline: none !important; }

/* Sous-total ligne */
body.woocommerce-cart td.product-subtotal {
  font-family: 'Playfair Display', serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--ch) !important;
  white-space: nowrap !important;
  padding: 0 6px !important;
  flex-shrink: 0 !important;
  text-align: right !important;
}

/* ── LIGNE ACTIONS (coupon + update) ── */
body.woocommerce-cart tr.actions > td,
body.woocommerce-cart .actions {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  border: none !important;
  background: transparent !important;
  padding: 14px 0 28px !important;
  width: 100% !important;
}
body.woocommerce-cart .coupon {
  display: flex !important;
  gap: 8px !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}
body.woocommerce-cart .coupon label { display: none !important; }
body.woocommerce-cart .coupon #coupon_code {
  padding: 10px 18px !important;
  border: 1.5px solid var(--bd) !important;
  border-radius: 100px !important;
  font-size: .82rem !important;
  color: var(--ch) !important;
  background: var(--wh) !important;
  outline: none !important;
  transition: border-color .25s !important;
  font-family: 'DM Sans', sans-serif !important;
  width: 200px !important;
}
body.woocommerce-cart .coupon #coupon_code::placeholder { color: var(--t4) !important; }
body.woocommerce-cart .coupon #coupon_code:focus { border-color: var(--ca) !important; }
body.woocommerce-cart .coupon .button {
  padding: 10px 20px !important;
  border-radius: 100px !important;
  background: var(--ch) !important;
  color: #fff !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: .8rem !important;
  font-weight: 700 !important;
  border: none !important;
  cursor: pointer !important;
  transition: background .25s !important;
  white-space: nowrap !important;
}
body.woocommerce-cart .coupon .button:hover { background: var(--ca) !important; }
body.woocommerce-cart button[name="update_cart"] {
  padding: 10px 20px !important;
  border-radius: 100px !important;
  background: transparent !important;
  color: var(--t3) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: .8rem !important;
  font-weight: 600 !important;
  border: 1.5px solid var(--bd) !important;
  cursor: pointer !important;
  transition: all .25s !important;
  white-space: nowrap !important;
}
body.woocommerce-cart button[name="update_cart"]:not(:disabled):hover {
  border-color: var(--ca) !important;
  color: var(--ca) !important;
}
body.woocommerce-cart button[name="update_cart"]:disabled {
  opacity: .3 !important;
  cursor: not-allowed !important;
}

/* ═══════════════════════════════
   BLOC TOTAUX
═══════════════════════════════ */
body.woocommerce-cart .cart-collaterals {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}
body.woocommerce-cart .cart_totals {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  background: var(--wh) !important;
  border: 1px solid var(--bd) !important;
  border-radius: 22px !important;
  overflow: hidden !important;
  box-shadow: var(--shm) !important;
  position: sticky !important;
  top: 24px !important;
}
/* Barre top dégradé */
body.woocommerce-cart .cart_totals::before {
  content: '' !important;
  display: block !important;
  height: 3px !important;
  background: linear-gradient(90deg, var(--ca), var(--go)) !important;
  flex-shrink: 0 !important;
}
body.woocommerce-cart .cart_totals h2 {
  font-family: 'Playfair Display', serif !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--ch) !important;
  padding: 22px 24px 14px !important;
  margin: 0 !important;
  border-bottom: 1px solid var(--li) !important;
}

/* Table des totaux */
body.woocommerce-cart .cart_totals table.shop_table {
  width: 100% !important;
  border-collapse: collapse !important;
  border: none !important;
  display: table !important;
}
body.woocommerce-cart .cart_totals table.shop_table thead { display: none !important; }
body.woocommerce-cart .cart_totals table.shop_table tbody { display: table-row-group !important; }
body.woocommerce-cart .cart_totals table.shop_table tr {
  display: table-row !important;
  border-bottom: 1px solid var(--li) !important;
  background: transparent !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  transform: none !important;
}
body.woocommerce-cart .cart_totals table.shop_table tr:hover {
  transform: none !important;
  box-shadow: none !important;
}
body.woocommerce-cart .cart_totals table.shop_table tr:last-child { border-bottom: none !important; }
body.woocommerce-cart .cart_totals table.shop_table th {
  font-size: .83rem !important;
  font-weight: 600 !important;
  color: var(--t2) !important;
  text-align: left !important;
  padding: 13px 24px !important;
  border: none !important;
  background: transparent !important;
  display: table-cell !important;
  width: 45% !important;
}
body.woocommerce-cart .cart_totals table.shop_table td {
  font-size: .9rem !important;
  font-weight: 700 !important;
  color: var(--ch) !important;
  text-align: right !important;
  padding: 13px 24px !important;
  border: none !important;
  background: transparent !important;
  display: table-cell !important;
}

/* Ligne livraison */
body.woocommerce-cart .cart_totals tr.shipping,
body.woocommerce-cart .cart_totals tr.woocommerce-shipping-totals {
  background: var(--glt) !important;
}
body.woocommerce-cart .cart_totals tr.shipping th,
body.woocommerce-cart .cart_totals tr.shipping td,
body.woocommerce-cart .cart_totals tr.woocommerce-shipping-totals th,
body.woocommerce-cart .cart_totals tr.woocommerce-shipping-totals td {
  color: var(--to) !important;
  font-weight: 700 !important;
}

/* Ligne total */
body.woocommerce-cart .cart_totals tr.order-total {
  border-top: 2px solid var(--li) !important;
  border-bottom: none !important;
}
body.woocommerce-cart .cart_totals tr.order-total th {
  font-family: 'Playfair Display', serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--ch) !important;
}
body.woocommerce-cart .cart_totals tr.order-total td {
  font-family: 'Playfair Display', serif !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--cdk) !important;
}

/* ── BOUTON COMMANDER ── */
body.woocommerce-cart .wc-proceed-to-checkout {
  padding: 18px 24px 8px !important;
}
body.woocommerce-cart a.checkout-button,
body.woocommerce-cart .checkout-button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: 100% !important;
  padding: 16px 20px !important;
  border-radius: 100px !important;
  background: linear-gradient(135deg, #C4956A 0%, #D4A54A 100%) !important;
  color: #ffffff !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: .92rem !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  border: none !important;
  cursor: pointer !important;
  letter-spacing: .015em !important;
  box-shadow: 0 6px 22px rgba(196,149,106,.3) !important;
  transition: transform .3s var(--ez), box-shadow .3s var(--ez) !important;
}
body.woocommerce-cart a.checkout-button:hover,
body.woocommerce-cart .checkout-button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 30px rgba(196,149,106,.44) !important;
  color: #ffffff !important;
}

/* Réassurance */
body.woocommerce-cart .wc-proceed-to-checkout::after {
  content: '🔒 Paiement sécurisé  ·  🚚 Livraison offerte  ·  ↩️ 30j retours gratuits' !important;
  display: block !important;
  text-align: center !important;
  font-size: .67rem !important;
  color: var(--t3) !important;
  padding: 12px 24px 20px !important;
  font-family: 'DM Sans', sans-serif !important;
  line-height: 1.8 !important;
}

/* ── MESSAGES WC ── */
body.woocommerce-cart .woocommerce-message,
body.woocommerce-cart .woocommerce-info {
  background: var(--c) !important;
  border-top-color: var(--ca) !important;
  border-radius: 0 12px 12px 0 !important;
  color: var(--t2) !important;
  font-size: .86rem !important;
  font-family: 'DM Sans', sans-serif !important;
  margin-bottom: 20px !important;
}
body.woocommerce-cart .woocommerce-message a.button,
body.woocommerce-cart .woocommerce-info a.button {
  background: var(--ch) !important;
  color: #fff !important;
  border-radius: 100px !important;
  font-size: .78rem !important;
  font-weight: 700 !important;
  padding: 7px 16px !important;
  text-decoration: none !important;
  transition: background .25s !important;
  font-family: 'DM Sans', sans-serif !important;
}
body.woocommerce-cart .woocommerce-message a.button:hover,
body.woocommerce-cart .woocommerce-info a.button:hover { background: var(--ca) !important; }
body.woocommerce-cart .woocommerce-error {
  background: var(--li) !important;
  border-top-color: #CEBB9E !important;
  border-radius: 0 12px 12px 0 !important;
  color: var(--t2) !important;
  font-family: 'DM Sans', sans-serif !important;
}
body.woocommerce-cart .woocommerce-error,
body.woocommerce-cart .woocommerce-error li { color: var(--t2) !important; }

/* Panier vide */
body.woocommerce-cart p.cart-empty {
  font-family: 'Playfair Display', serif !important;
  font-size: 1.2rem !important;
  color: var(--t3) !important;
  text-align: center !important;
  padding: 48px 0 20px !important;
}
body.woocommerce-cart .return-to-shop { text-align: center !important; }
body.woocommerce-cart .return-to-shop a.button {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 13px 28px !important;
  border-radius: 100px !important;
  background: var(--ch) !important;
  color: #fff !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: .86rem !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: background .25s, transform .25s !important;
}
body.woocommerce-cart .return-to-shop a.button:hover {
  background: var(--ca) !important;
  transform: translateY(-2px) !important;
}

/* ── RESPONSIVE ── */
@media (max-width: 779px) {
  body.woocommerce-cart .woocommerce { display: block !important; }
  body.woocommerce-cart .cart_totals { position: static !important; margin-top: 20px !important; }
  body.woocommerce-cart td.product-price { display: none !important; }
}
@media (max-width: 520px) {
  body.woocommerce-cart tr.cart_item,
  body.woocommerce-cart tr.woocommerce-cart-form__cart-item {
    flex-wrap: wrap !important;
    gap: 10px !important;
  }
  body.woocommerce-cart td.product-thumbnail { width: 60px !important; }
  body.woocommerce-cart td.product-thumbnail img { width: 60px !important; height: 60px !important; }
  body.woocommerce-cart .coupon #coupon_code { width: 130px !important; }
  body.woocommerce-cart .wc-proceed-to-checkout { padding: 16px 18px 8px !important; }
  body.woocommerce-cart .wc-proceed-to-checkout::after { padding: 10px 18px 18px !important; }
}/* End custom CSS */