/*
 * Checkout Classique - Style Blocks
 * Reproduit le design du checkout WooCommerce Blocks
 * sur le shortcode classique [woocommerce_checkout]
 * Date: 25 mars 2026 — v5
 */

/* ============================
   CONTENEUR GLOBAL — max-width
   ============================ */
.woocommerce-checkout .woocommerce {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 0 20px !important;
}

/* ============================
   LAYOUT 2 COLONNES (CSS Grid)
   ============================ */
.woocommerce-checkout form.woocommerce-checkout {
  display: grid !important;
  grid-template-columns: 1fr 440px !important;
  grid-template-rows: auto 1fr !important;
  gap: 0 48px !important;
}

/* Express checkout : pleine largeur, première ligne */
.woocommerce-checkout form.woocommerce-checkout > #wc-stripe-express-checkout-element,
.woocommerce-checkout form.woocommerce-checkout > #wc-stripe-express-checkout__order-attribution-inputs,
.woocommerce-checkout form.woocommerce-checkout > #wc-stripe-express-checkout-button-separator {
  grid-column: 1 / -1 !important;
}

/* Formulaire : colonne gauche */
.woocommerce-checkout form.woocommerce-checkout > #customer_details {
  grid-column: 1 !important;
  grid-row: 2 !important;
  padding-right: 0 !important;
  box-sizing: border-box !important;
  width: 100% !important;
  max-width: 100% !important;
}

/* Récap commande : colonne droite, sticky */
.woocommerce-checkout form.woocommerce-checkout > .checkout-wrapper {
  grid-column: 2 !important;
  grid-row: 2 !important;
  box-sizing: border-box !important;
  position: sticky !important;
  top: 100px !important;
  align-self: start !important;
  width: 100% !important;
  max-width: 100% !important;
  background: #fafafa !important;
  border-radius: 12px !important;
  padding: 18px !important;
}

/* Billing et shipping empilés dans col2-set */
.woocommerce-checkout #customer_details.col2-set {
  display: block !important;
}

.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
  width: 100% !important;
  max-width: 100% !important;
  flex: 0 0 100% !important;
  float: none !important;
  padding: 0 !important;
}

/* ============================
   TYPOGRAPHIE
   ============================ */
.woocommerce-checkout,
.woocommerce-checkout input,
.woocommerce-checkout select,
.woocommerce-checkout textarea,
.woocommerce-checkout label,
.woocommerce-checkout button {
  font-family: "Plus Jakarta Sans", sans-serif !important;
  font-size: 15px;
  color: rgb(14, 14, 20);
}

/* Titres de sections */
.woocommerce-checkout h3,
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3,
.woocommerce-checkout #order_review_heading {
  font-family: "Plus Jakarta Sans", sans-serif !important;
  font-size: 18px;
  font-weight: 600;
  color: rgb(14, 14, 20);
  margin: 28px 0 16px;
  padding: 0;
  border: none;
  letter-spacing: -0.02em;
}

.woocommerce-checkout .col-1 h3:first-child {
  margin-top: 0;
}

/* ============================
   INPUTS & SELECTS
   ============================ */
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .select2-container--default .select2-selection--single {
  border: 1px solid rgba(0, 0, 0, 0.16) !important;
  border-radius: 8px !important;
  padding: 14px 14px !important;
  height: auto !important;
  min-height: 48px !important;
  font-size: 15px !important;
  background: #fff !important;
  color: rgb(14, 14, 20) !important;
  box-shadow: none !important;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  width: 100%;
  box-sizing: border-box;
}

.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row textarea:focus,
.woocommerce-checkout .form-row select:focus {
  border-color: rgb(14, 14, 20) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(14, 14, 20, 0.08) !important;
}

/* Select2 */
.woocommerce-checkout .select2-container--default .select2-selection--single {
  display: flex;
  align-items: center;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
  padding: 0 !important;
  line-height: normal !important;
  color: rgb(14, 14, 20) !important;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100% !important;
  right: 12px !important;
}

/* Labels */
.woocommerce-checkout .form-row label {
  font-size: 13px;
  font-weight: 500;
  color: rgba(14, 14, 20, 0.7);
  margin-bottom: 6px;
  display: block;
  text-transform: none;
  letter-spacing: 0;
}

.woocommerce-checkout .form-row label .required {
  color: rgba(14, 14, 20, 0.4);
  text-decoration: none;
}

/* Espacement des champs */
.woocommerce-checkout .form-row {
  margin-bottom: 14px !important;
  padding: 0 !important;
}

/* Champs inline */
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last {
  width: 48.5% !important;
}

.woocommerce-checkout .form-row-first {
  margin-right: 3% !important;
  float: left !important;
}

.woocommerce-checkout .form-row-last {
  float: right !important;
}

/* ============================
   SECTION LIVRAISON
   ============================ */
.woocommerce-checkout .woocommerce-shipping-methods {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  overflow: hidden;
}

.woocommerce-checkout .woocommerce-shipping-methods li {
  padding: 0 !important;
  margin: 0 !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  transition: background 0.15s ease;
  position: relative;
}

.woocommerce-checkout .woocommerce-shipping-methods li:hover {
  background: rgba(0, 0, 0, 0.02);
}

.woocommerce-checkout .woocommerce-shipping-methods li:last-child {
  border-bottom: none;
}

/* Cacher le radio natif */
.woocommerce-checkout .woocommerce-shipping-methods li input[type="radio"] {
  position: absolute !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
}

/* Label = toute la ligne cliquable */
.woocommerce-checkout .woocommerce-shipping-methods li label {
  font-size: 13px !important;
  font-weight: 500;
  cursor: pointer;
  display: block !important;
  padding: 11px 14px 11px 40px !important;
  position: relative;
  line-height: 1.4;
}

/* Custom radio circle */
.woocommerce-checkout .woocommerce-shipping-methods li label::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  border: 2px solid rgba(0, 0, 0, 0.25);
  border-radius: 50%;
  background: #fff;
  transition: all 0.15s ease;
  box-sizing: border-box;
}

.woocommerce-checkout .woocommerce-shipping-methods li input[type="radio"]:checked + label::before {
  border-color: rgb(14, 14, 20);
  background: rgb(14, 14, 20);
  box-shadow: inset 0 0 0 3px #fff;
}

/* Prix dans le label — plus discret */
.woocommerce-checkout .woocommerce-shipping-methods li label .woocommerce-Price-amount {
  font-weight: 400;
  color: rgba(14, 14, 20, 0.5);
  font-size: 12px;
}

/* Label "Expédition" dans le tableau recap */
.woocommerce-checkout .woocommerce-checkout-review-order-table .shipping th {
  vertical-align: top;
  padding-top: 14px !important;
}

/* Masquer la CB Stripe (garder Apple Pay / Google Pay) */
.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method.payment_method_stripe {
  display: none !important;
}

/* Masquer Link (wallet Stripe) dans l'express checkout */
#wc-stripe-express-checkout-element-link {
  display: none !important;
}

/* ============================
   SECTION PAIEMENT
   ============================ */
.woocommerce-checkout #payment {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

.woocommerce-checkout #payment ul.payment_methods {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 20px 0 !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  border-radius: 8px !important;
  overflow: hidden;
}

.woocommerce-checkout #payment ul.payment_methods li {
  padding: 0 !important;
  margin: 0 !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  background: transparent !important;
  transition: background 0.15s ease;
}

.woocommerce-checkout #payment ul.payment_methods li:hover {
  background: rgba(0, 0, 0, 0.02) !important;
}

.woocommerce-checkout #payment ul.payment_methods li:last-child {
  border-bottom: none;
}

/* Radio + label sur la même ligne */
.woocommerce-checkout #payment ul.payment_methods li input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.woocommerce-checkout #payment ul.payment_methods li label {
  display: flex !important;
  align-items: center;
  padding: 13px 14px !important;
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  gap: 10px;
  position: relative;
  padding-left: 42px !important;
}

/* Custom radio circle */
.woocommerce-checkout #payment ul.payment_methods li label::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  border: 2px solid rgba(0, 0, 0, 0.25);
  border-radius: 50%;
  background: #fff;
  transition: all 0.15s ease;
  box-sizing: border-box;
}

.woocommerce-checkout #payment ul.payment_methods li input[type="radio"]:checked + label::before {
  border-color: rgb(14, 14, 20);
  background: rgb(14, 14, 20);
  box-shadow: inset 0 0 0 3px #fff;
}

.woocommerce-checkout #payment ul.payment_methods li img {
  max-height: 22px;
  margin-left: auto;
}

.woocommerce-checkout #payment div.payment_box {
  background: rgba(0, 0, 0, 0.03) !important;
  border: none !important;
  padding: 14px 16px !important;
  margin: 0 !important;
  color: rgba(14, 14, 20, 0.7) !important;
  font-size: 13px;
}

.woocommerce-checkout #payment div.payment_box::before {
  display: none !important;
}

/* ============================
   BOUTON COMMANDER
   ============================ */
.woocommerce-checkout #place_order {
  background-color: rgb(14, 14, 20) !important;
  color: rgb(255, 255, 255) !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 16px 30px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  font-family: "Plus Jakarta Sans", sans-serif !important;
  width: 100%;
  cursor: pointer;
  transition: all 0.2s ease;
  min-height: 54px;
  text-transform: none !important;
  letter-spacing: -0.01em !important;
}

.woocommerce-checkout #place_order:hover {
  background-color: rgb(40, 40, 48) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* ============================
   RECAP COMMANDE (colonne droite)
   ============================ */
.woocommerce-checkout #order_review_heading {
  font-size: 16px !important;
  font-weight: 600 !important;
  margin-top: 0 !important;
  margin-bottom: 16px !important;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table {
  border: none !important;
  border-radius: 0 !important;
  margin-bottom: 16px;
  border-collapse: collapse;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table th,
.woocommerce-checkout .woocommerce-checkout-review-order-table td {
  padding: 10px 0 !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
  font-size: 13px;
  font-weight: 400;
  background: transparent !important;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table thead th {
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase !important;
  letter-spacing: 0.05em;
  color: rgba(14, 14, 20, 0.5) !important;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total th,
.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total td {
  font-size: 16px;
  font-weight: 700;
  border-bottom: none !important;
  padding-top: 14px !important;
}

/* TVA mention plus discrète */
.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total .includes_tax {
  font-size: 11px !important;
  font-weight: 400 !important;
  color: rgba(14, 14, 20, 0.5) !important;
  display: block;
  margin-top: 2px;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table .product-name {
  font-family: "Plus Jakarta Sans", sans-serif !important;
  font-size: 13px !important;
  font-weight: 500;
}

/* ============================
   NOTICES (login, coupon)
   ============================ */
.woocommerce-checkout .woocommerce-form-login-toggle,
.woocommerce-checkout .woocommerce-form-coupon-toggle {
  margin-bottom: 12px;
}

.woocommerce-checkout .woocommerce-info {
  border-top: none !important;
  border-left: 3px solid rgb(14, 14, 20) !important;
  background: #f7f7f8 !important;
  padding: 14px 18px !important;
  font-size: 14px;
  color: rgb(14, 14, 20) !important;
  margin-bottom: 8px !important;
  border-radius: 0 8px 8px 0 !important;
}

.woocommerce-checkout .woocommerce-info::before {
  display: none !important;
}

/* ============================
   COUPON FORM
   ============================ */
.woocommerce-checkout .checkout_coupon {
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  border-radius: 8px !important;
  padding: 16px !important;
  margin-bottom: 20px !important;
}

.woocommerce-checkout .checkout_coupon .form-row-first {
  width: 68% !important;
}

.woocommerce-checkout .checkout_coupon .form-row-last {
  width: 28% !important;
}

.woocommerce-checkout .checkout_coupon button {
  background: rgb(14, 14, 20) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 14px 18px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer;
  min-height: 48px;
}

/* ============================
   CHECKBOX & LIENS
   ============================ */
.woocommerce-checkout input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: rgb(14, 14, 20);
  margin-right: 8px;
  border-radius: 4px;
}

.woocommerce-checkout a {
  color: rgb(14, 14, 20);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ============================
   TITRE DE PAGE
   ============================ */
.woocommerce-checkout .entry-title {
  font-family: "Plus Jakarta Sans", sans-serif !important;
  font-size: 28px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 28px;
  letter-spacing: -0.03em;
}

/* ============================
   TERMES & CONDITIONS
   ============================ */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
  margin: 14px 0;
  font-size: 13px;
  color: rgba(14, 14, 20, 0.6);
}

/* ============================
   SÉPARATEUR EXPRESS CHECKOUT
   ============================ */
#wc-stripe-express-checkout-button-separator {
  text-align: center;
  margin: 12px 0;
  font-size: 13px;
  color: rgba(14, 14, 20, 0.4);
}

/* ============================
   ALMA / PAYPAL 4X
   ============================ */
.woocommerce-checkout .checkout-wrapper .alma-widget-container {
  font-size: 13px;
  margin-bottom: 16px;
}

/* ============================
   RESPONSIVE
   ============================ */
@media (max-width: 768px) {
  .woocommerce-checkout form.woocommerce-checkout {
    display: block !important;
  }

  .woocommerce-checkout form.woocommerce-checkout > #customer_details {
    width: 100% !important;
    padding-right: 0 !important;
  }

  .woocommerce-checkout form.woocommerce-checkout > .checkout-wrapper {
    width: 100% !important;
    position: static !important;
    margin-top: 24px !important;
    border-radius: 12px !important;
  }

  .woocommerce-checkout .form-row-first,
  .woocommerce-checkout .form-row-last {
    width: 100% !important;
    float: none !important;
    margin-right: 0 !important;
  }
}
