/* ================================================================
   FABULOUS — WooCommerce Checkout / Cart / Confirmation  v5.0
   Single-Column, Peso-inspired
   ================================================================ */

/* ── Tokens ──────────────────────────────────────────────────── */
:root {
  --f-bg:      #f5f3f0;
  --f-white:   #ffffff;
  --f-panel:   #f8f7f5;
  --f-text:    #1a1917;
  --f-mid:     #6b6560;
  --f-dim:     #9e9890;
  --f-sand:    #c8b89a;
  --f-border:  rgba(0,0,0,0.10);
  --f-border2: rgba(0,0,0,0.055);
  --f-r:       5px;
  --f-rl:      10px;
  --f-head:    'Playfair Display', Georgia, serif;
  --f-body:    'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --f-max:     680px;
  --f-pad:     clamp(16px, 5vw, 40px);
}

/* ── Screen-reader ────────────────────────────────────────────── */
.screen-reader-text {
  position:absolute!important;width:1px!important;height:1px!important;
  padding:0!important;margin:-1px!important;overflow:hidden!important;
  clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important;
}

/* ================================================================
   BODY
   ================================================================ */
body.woocommerce-cart,
body.woocommerce-checkout,
body.woocommerce-order-received {
  background: var(--f-bg) !important;
  color: var(--f-text) !important;
  font-family: var(--f-body) !important;
  font-size: 15px !important;
  line-height: 1.6 !important;
  -webkit-font-smoothing: antialiased !important;
}
body.woocommerce-checkout header,
body.woocommerce-cart header,
body.woocommerce-order-received header {
  background: var(--f-white) !important;
  border-bottom: 1px solid var(--f-border) !important;
  box-shadow: none !important;
}
body.woocommerce-checkout footer,
body.woocommerce-cart footer,
body.woocommerce-order-received footer {
  background: var(--f-white) !important;
  border-top: 1px solid var(--f-border) !important;
}
body.woocommerce-checkout footer *,
body.woocommerce-cart footer * { color: var(--f-dim) !important; }

/* ── Farben ───────────────────────────────────────────────────── */
body.woocommerce-checkout p,
body.woocommerce-checkout span,
body.woocommerce-checkout td,
body.woocommerce-checkout th,
body.woocommerce-cart p,
body.woocommerce-cart td,
body.woocommerce-cart th { color: var(--f-text) !important; }

body.woocommerce-checkout h1,
body.woocommerce-checkout h2,
body.woocommerce-checkout h3,
body.woocommerce-cart h1,
body.woocommerce-cart h2,
body.woocommerce-cart h3 {
  color: var(--f-text) !important;
  font-family: var(--f-head) !important;
}
body.woocommerce-checkout a,
body.woocommerce-cart a { color: var(--f-text) !important; text-decoration: underline !important; }
body.woocommerce-checkout a:hover,
body.woocommerce-cart a:hover { color: var(--f-sand) !important; }

/* Block-Wrapper transparent */
body.woocommerce-checkout main,
body.woocommerce-checkout .wp-block-group,
body.woocommerce-checkout .wp-block-post-content,
body.woocommerce-checkout .entry-content,
body.woocommerce-checkout article,
body.woocommerce-cart main,
body.woocommerce-cart .entry-content {
  background: transparent !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* ── Notices ──────────────────────────────────────────────────── */
body.woocommerce-checkout .woocommerce-message { display: none !important; }
.woocommerce-message a.button,
.woocommerce-message .wc-forward { display: none !important; }

.woocommerce-error {
  background: rgba(180,60,60,0.06) !important;
  border-top: 3px solid #b43c3c !important;
  border-radius: 0 !important;
  padding: 12px 18px !important;
  color: var(--f-text) !important;
  font-size: 0.875rem !important;
  box-shadow: none !important;
  margin-bottom: 16px !important;
}
.woocommerce-info {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--f-border) !important;
  border-radius: 0 !important;
  padding: 0 0 10px !important;
  margin-bottom: 16px !important;
  color: var(--f-mid) !important;
  font-size: 0.8125rem !important;
  box-shadow: none !important;
}
.woocommerce-info::before { color: var(--f-sand) !important; }
.woocommerce-info a { color: var(--f-text) !important; }

/* ── Gutschein-Toggle (alter WC-Toggle) komplett ausblenden ───── */
.woocommerce-form-coupon-toggle,
.checkout_coupon.woocommerce-form-coupon { display: none !important; }

/* ================================================================
   CHECKOUT-HEADER  (Peso: Logo links, Cart rechts)
   ================================================================ */
.fab-checkout-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 0 18px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--f-border);
  width: 100%;
}
.fab-logo-link {
  text-decoration: none !important;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.fab-logo-text {
  font-family: var(--f-head);
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--f-text) !important;
  line-height: 1;
  text-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.07);
  text-decoration: none !important;
}
.fab-logo-claim {
  font-size: 0.58rem;
  letter-spacing: 0.22em;
  color: var(--f-dim) !important;
  text-transform: uppercase;
  line-height: 1;
  text-decoration: none !important;
}
.fab-cart-link {
  position: relative;
  display: flex;
  align-items: center;
  color: var(--f-text) !important;
  text-decoration: none !important;
  padding: 6px;
}
.fab-cart-count {
  position: absolute;
  top: -3px; right: -3px;
  background: var(--f-text);
  color: #fff;
  font-size: 0.58rem;
  font-weight: 700;
  width: 15px; height: 15px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ================================================================
   CHECKOUT — CONTAINER (Single-Column, zentriert)
   ================================================================ */
body.woocommerce-checkout .woocommerce,
body.woocommerce-checkout .woocommerce-page {
  max-width: var(--f-max) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 0 var(--f-pad) 80px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  background: transparent !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* ── CHECKOUT FORM: Single-Column (alle Cards untereinander) ──── */
form.checkout.woocommerce-checkout {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
  width: 100% !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Bestellübersicht (#order_review) ganz oben */
#order_review {
  order: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  flex: none !important;
  position: static !important;
  background: var(--f-white) !important;
  border: 1px solid var(--f-border) !important;
  border-radius: var(--f-rl) !important;
  overflow: hidden !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Kundendaten (#customer_details) darunter */
#customer_details {
  order: 2 !important;
  width: 100% !important;
  flex: none !important;
  background: var(--f-white) !important;
  border-radius: var(--f-rl) !important;
  padding: 28px 28px !important;
  border: 1px solid var(--f-border) !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* col2-set: Billing + Shipping gestapelt */
.col2-set { display: block !important; }
.col2-set .col-1,
.col2-set .col-2 {
  float: none !important;
  width: 100% !important;
  display: block !important;
  padding: 0 !important;
}
#customer_details > div + div { margin-top: 24px !important; }

/* ── Sektion-Titel ────────────────────────────────────────────── */
.woocommerce-billing-fields > h3,
.woocommerce-shipping-fields > h3 {
  font-family: var(--f-body) !important;
  font-size: 0.9375rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: var(--f-text) !important;
  margin: 0 0 16px !important;
  padding-bottom: 0 !important;
  border-bottom: none !important;
}

/* ── Input-Felder ─────────────────────────────────────────────── */
body.woocommerce-checkout input[type="text"],
body.woocommerce-checkout input[type="email"],
body.woocommerce-checkout input[type="tel"],
body.woocommerce-checkout input[type="number"],
body.woocommerce-checkout input[type="password"],
body.woocommerce-checkout select,
body.woocommerce-checkout textarea,
body.woocommerce-cart input[type="text"],
body.woocommerce-cart input[type="number"],
body.woocommerce-cart select {
  background: var(--f-white) !important;
  background-color: var(--f-white) !important;
  border: 1px solid rgba(0,0,0,0.18) !important;
  border-radius: var(--f-r) !important;
  color: var(--f-text) !important;
  font-family: var(--f-body) !important;
  font-size: 0.9375rem !important;
  font-weight: 400 !important;
  padding: 13px 16px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  outline: none !important;
  transition: border-color 0.15s ease, box-shadow 0.15s ease !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  box-shadow: none !important;
  visibility: visible !important;
  opacity: 1 !important;
}
body.woocommerce-checkout input:focus,
body.woocommerce-checkout select:focus,
body.woocommerce-checkout textarea:focus {
  border-color: var(--f-text) !important;
  box-shadow: 0 0 0 3px rgba(26,25,23,0.07) !important;
}
body.woocommerce-checkout input::placeholder,
body.woocommerce-checkout textarea::placeholder {
  color: var(--f-dim) !important;
  opacity: 1 !important;
}
body.woocommerce-checkout select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b6560' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 14px center !important;
  padding-right: 40px !important;
  cursor: pointer !important;
}

/* ── Formular-Grid: SINGLE COLUMN (außer PLZ+Stadt) ─────────── */
.woocommerce-billing-fields__field-wrapper {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 0 !important;
}
.woocommerce-billing-fields__field-wrapper .form-row {
  grid-column: 1 !important;
  float: none !important;
  width: 100% !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
  clear: none !important;
}
/* PLZ und Stadt nebeneinander */
#billing_postcode_field,
#billing_city_field {
  display: inline-block !important;
  width: calc(50% - 6px) !important;
  margin-right: 12px !important;
  vertical-align: top !important;
}
#billing_city_field { margin-right: 0 !important; }

/* Versteckte Felder */
#billing_state_field,
#shipping_state_field,
#billing_phone_field { display: none !important; }
.woocommerce-additional-fields { display: none !important; }

/* Label-Stil */
.form-row { margin-bottom: 14px !important; }
.form-row label {
  display: block !important;
  font-family: var(--f-body) !important;
  font-size: 0.75rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;
  text-transform: none !important;
  color: var(--f-mid) !important;
  margin-bottom: 6px !important;
}
.form-row label .required { color: var(--f-sand) !important; text-decoration: none !important; }
.woocommerce-input-wrapper { width: 100% !important; }

/* Checkbox */
.woocommerce-checkout input[type="checkbox"] {
  width: 16px !important; height: 16px !important;
  accent-color: var(--f-text) !important;
  margin-right: 8px !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
}

/* Lieferadresse-Toggle */
#ship-to-different-address {
  margin: 18px 0 !important;
  padding-top: 14px !important;
  border-top: 1px solid var(--f-border) !important;
}
#ship-to-different-address label {
  display: flex !important;
  align-items: center !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  color: var(--f-text) !important;
  cursor: pointer !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* ================================================================
   BESTELLÜBERSICHT (obere Card)
   ================================================================ */
h3#order_review_heading {
  font-family: var(--f-body) !important;
  font-size: 0.68rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--f-mid) !important;
  padding: 18px 22px 14px !important;
  margin: 0 !important;
  border-bottom: 1px solid var(--f-border) !important;
}

.woocommerce-checkout-review-order {
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}

.woocommerce-checkout-review-order-table {
  width: 100% !important;
  border-collapse: collapse !important;
  background: transparent !important;
}
.woocommerce-checkout-review-order-table thead { display: none !important; }

/* Produkt-Zeile */
.woocommerce-checkout-review-order-table .cart_item td {
  padding: 14px 22px !important;
  border-bottom: 1px solid var(--f-border2) !important;
  font-size: 0.875rem !important;
  color: var(--f-text) !important;
  background: transparent !important;
  vertical-align: middle !important;
}
.woocommerce-checkout-review-order-table .product-total {
  text-align: right !important;
  font-weight: 500 !important;
  white-space: nowrap !important;
  width: 80px !important;
}

/* Produktbild-Wrapper */
.fab-item { display: flex !important; align-items: center !important; gap: 14px !important; }
.fab-thumb-wrap { position: relative !important; flex-shrink: 0 !important; width: 54px !important; height: 66px !important; }
.fab-thumb-wrap img,
.fab-item .fab-thumb {
  width: 54px !important; height: 66px !important;
  object-fit: cover !important;
  border-radius: 4px !important;
  border: 1px solid var(--f-border) !important;
  display: block !important;
}
.fab-qty-badge {
  position: absolute !important;
  top: -6px !important; right: -6px !important;
  background: #706a63 !important;
  color: #fff !important;
  font-size: 0.58rem !important;
  font-weight: 700 !important;
  width: 18px !important; height: 18px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  border: 1.5px solid var(--f-white) !important;
}
.fab-item-info {
  line-height: 1.4 !important;
  flex: 1 !important;
  min-width: 0 !important;
}
.fab-item-info strong {
  font-weight: 500 !important;
  font-size: 0.875rem !important;
  display: block !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Mengenzeile */
.woocommerce-checkout-review-order-table .product-quantity {
  font-size: 0.78rem !important;
  color: var(--f-mid) !important;
}

/* Summenzeilen */
.woocommerce-checkout-review-order-table tfoot tr th,
.woocommerce-checkout-review-order-table tfoot tr td {
  padding: 9px 22px !important;
  font-size: 0.875rem !important;
  color: var(--f-mid) !important;
  border-bottom: 1px solid var(--f-border2) !important;
  background: transparent !important;
}
.woocommerce-checkout-review-order-table tfoot .order-total th,
.woocommerce-checkout-review-order-table tfoot .order-total td {
  border-bottom: none !important;
  padding-top: 14px !important;
  padding-bottom: 14px !important;
  color: var(--f-text) !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
}
.woocommerce-checkout-review-order-table tfoot .order-total td strong {
  font-family: var(--f-head) !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
}
.woocommerce-checkout-review-order-table tfoot .tax-rate td,
.woocommerce-checkout-review-order-table tfoot .tax-rate th {
  font-size: 0.78rem !important;
  color: var(--f-dim) !important;
}

/* Versand */
.shipping_method { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.shipping_method li {
  padding: 8px 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-size: 0.875rem !important;
  color: var(--f-text) !important;
}
.shipping_method input[type="radio"] { accent-color: var(--f-text) !important; }

/* ================================================================
   ZAHLUNGSBEREICH  (untere Card, kein eigener Rahmen — Teil von #order_review)
   ================================================================ */
#payment {
  background: transparent !important;
  padding: 0 22px !important;
  margin: 0 !important;
  border-top: 1px solid var(--f-border) !important;
  visibility: visible !important;
  opacity: 1 !important;
}
#payment .payment_methods {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
#payment .payment_methods li {
  padding: 0 !important;
  border-bottom: 1px solid var(--f-border2) !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px !important;
  background: transparent !important;
  list-style: none !important;
  color: var(--f-text) !important;
}
#payment .payment_methods li > label:first-of-type {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  width: 100% !important;
  padding: 13px 0 !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  color: var(--f-text) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  cursor: pointer !important;
  text-decoration: none !important;
}
#payment .payment_methods li input[type="radio"] {
  accent-color: var(--f-text) !important;
  width: 16px !important; height: 16px !important;
  flex-shrink: 0 !important; margin: 0 !important;
}
#payment .payment_methods li img {
  height: 22px !important; max-width: 48px !important;
  object-fit: contain !important; opacity: 0.85 !important;
  margin-left: auto !important;
}
#payment .payment_box {
  background: var(--f-panel) !important;
  border: 1px solid var(--f-border) !important;
  border-radius: var(--f-r) !important;
  padding: 14px 16px !important;
  width: 100% !important;
  margin: 4px 0 12px !important;
}
#payment .payment_box p {
  font-size: 0.8125rem !important;
  color: var(--f-mid) !important;
  margin: 0 !important;
}

/* Express-Checkout */
.woocommerce-PaymentMethods--express,
#express-checkout-section {
  padding: 18px 22px !important;
  border-bottom: 1px solid var(--f-border) !important;
}

/* ── Gutschein-Bereich (direkt über "Jetzt kaufen") ─────────── */
.fab-coupon-wrap {
  padding: 0 22px 16px !important;
}
.fab-coupon-row {
  display: flex !important;
  gap: 8px !important;
}
.fab-coupon-row input {
  flex: 1 !important;
  font-size: 0.875rem !important;
  padding: 11px 14px !important;
  border: 1px solid rgba(0,0,0,0.18) !important;
  border-radius: var(--f-r) !important;
  background: var(--f-white) !important;
  color: var(--f-text) !important;
  font-family: var(--f-body) !important;
  width: auto !important;
  outline: none !important;
}
.fab-coupon-row input:focus {
  border-color: var(--f-text) !important;
  box-shadow: 0 0 0 3px rgba(26,25,23,0.07) !important;
}
.fab-coupon-row input::placeholder { color: var(--f-dim) !important; }
.fab-coupon-apply {
  background: transparent !important;
  border: 1px solid rgba(0,0,0,0.18) !important;
  border-radius: var(--f-r) !important;
  padding: 11px 18px !important;
  font-size: 0.8125rem !important;
  font-weight: 500 !important;
  color: var(--f-text) !important;
  font-family: var(--f-body) !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  transition: background 0.15s !important;
}
.fab-coupon-apply:hover { background: var(--f-panel) !important; }
.fab-coupon-msg {
  font-size: 0.78rem !important;
  margin-top: 6px !important;
  min-height: 1em !important;
}

/* Datenschutz */
.woocommerce-privacy-policy-text {
  font-size: 0.72rem !important;
  color: var(--f-dim) !important;
  line-height: 1.6 !important;
  padding: 0 22px 14px !important;
  text-align: center !important;
}
.woocommerce-privacy-policy-text a {
  color: var(--f-mid) !important;
  text-decoration: underline !important;
}

/* ── CTA: Jetzt kaufen ───────────────────────────────────────── */
#place_order {
  display: block !important;
  width: calc(100% - 44px) !important;
  margin: 4px 22px 22px !important;
  background: var(--f-text) !important;
  color: var(--f-white) !important;
  font-family: var(--f-body) !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  padding: 17px 32px !important;
  border: none !important;
  border-radius: var(--f-r) !important;
  cursor: pointer !important;
  pointer-events: all !important;
  transition: background 0.2s ease !important;
  box-shadow: none !important;
  visibility: visible !important;
  opacity: 1 !important;
}
#place_order:hover { background: #333028 !important; }
#place_order:disabled { opacity: 0.45 !important; cursor: not-allowed !important; }

/* SSL-Badge */
#order_review::after {
  content: '🔒  Sichere & verschlüsselte Zahlung';
  display: block;
  font-family: var(--f-body);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--f-dim);
  text-align: center;
  padding: 0 22px 18px;
}

/* ================================================================
   SELECT2
   ================================================================ */
.woocommerce-checkout .select2-container--default .select2-selection--single {
  background: var(--f-white) !important;
  border: 1px solid rgba(0,0,0,0.18) !important;
  border-radius: var(--f-r) !important;
  height: auto !important;
  padding: 13px 40px 13px 16px !important;
  box-shadow: none !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--f-text) !important;
  font-family: var(--f-body) !important;
  font-size: 0.9375rem !important;
  line-height: 1 !important;
  padding: 0 !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 50% !important; right: 14px !important; transform: translateY(-50%) !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow b {
  border-top-color: var(--f-mid) !important;
}
.select2-dropdown {
  background: var(--f-white) !important;
  border: 1px solid var(--f-border) !important;
  border-radius: var(--f-r) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12) !important;
}
.select2-results__option {
  font-family: var(--f-body) !important;
  font-size: 0.875rem !important;
  color: var(--f-mid) !important;
  padding: 10px 16px !important;
}
.select2-results__option--highlighted[aria-selected],
.select2-results__option--highlighted[data-selected] {
  background: var(--f-bg) !important;
  color: var(--f-text) !important;
}
.select2-container--default.select2-container--focus .select2-selection--single {
  border-color: var(--f-text) !important;
  box-shadow: 0 0 0 3px rgba(26,25,23,0.07) !important;
}

/* ================================================================
   WARENKORB
   ================================================================ */
body.woocommerce-cart .woocommerce,
body.woocommerce-cart .woocommerce-page {
  max-width: var(--f-max) !important;
  margin: 0 auto !important;
  padding: 0 var(--f-pad) 80px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  background: transparent !important;
}
body.woocommerce-cart h1.entry-title,
body.woocommerce-cart .woocommerce > h1 {
  font-family: var(--f-head) !important;
  font-size: clamp(1.5rem, 4vw, 2.2rem) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  color: var(--f-text) !important;
  margin-bottom: 24px !important;
}
.woocommerce-cart-form {
  background: var(--f-white) !important;
  border: 1px solid var(--f-border) !important;
  border-radius: var(--f-rl) !important;
  overflow: hidden !important;
  width: 100% !important;
}
table.shop_table {
  border-collapse: collapse !important;
  width: 100% !important;
  background: transparent !important;
  border: none !important;
  font-family: var(--f-body) !important;
  color: var(--f-text) !important;
}
table.shop_table thead th {
  font-size: 0.65rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: var(--f-mid) !important;
  padding: 14px 20px !important;
  border-bottom: 1px solid var(--f-border) !important;
  background: var(--f-panel) !important;
}
.woocommerce-cart-form__cart-item td {
  padding: 20px 20px !important;
  border-bottom: 1px solid var(--f-border2) !important;
  vertical-align: middle !important;
  background: transparent !important;
  color: var(--f-text) !important;
}
.product-thumbnail img {
  width: 68px !important; height: 82px !important;
  object-fit: cover !important;
  border-radius: 4px !important;
  display: block !important;
  border: 1px solid var(--f-border) !important;
}
.product-name a {
  font-size: 0.9375rem !important;
  font-weight: 500 !important;
  color: var(--f-text) !important;
  text-decoration: none !important;
}
.product-name a:hover { color: var(--f-sand) !important; }
.product-name .variation {
  margin-top: 4px !important;
  font-size: 0.78rem !important;
  color: var(--f-mid) !important;
}
.product-name .variation dt,
.product-name .variation dd { display: inline !important; margin: 0 !important; }
.product-name .variation dt::after { content: ': '; }
.product-price, .product-subtotal { color: var(--f-text) !important; font-size: 0.9375rem !important; }
.product-subtotal { font-weight: 600 !important; }
.product-quantity input[type="number"] {
  width: 60px !important; text-align: center !important;
  padding: 9px 6px !important;
  -moz-appearance: textfield !important;
}
.product-quantity input::-webkit-inner-spin-button,
.product-quantity input::-webkit-outer-spin-button { -webkit-appearance: none; }
.product-remove a.remove {
  display: flex !important; align-items: center !important; justify-content: center !important;
  width: 28px !important; height: 28px !important;
  background: transparent !important; border: 1px solid var(--f-border) !important;
  border-radius: 50% !important; color: var(--f-dim) !important;
  font-size: 1rem !important; text-decoration: none !important;
  transition: border-color 0.2s, color 0.2s !important;
}
.product-remove a.remove:hover {
  border-color: rgba(180,60,60,0.4) !important;
  color: #b43c3c !important;
}

/* Actions (Gutschein + Update) */
.actions {
  padding: 16px 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  background: var(--f-panel) !important;
  border-top: 1px solid var(--f-border) !important;
}
.coupon { display: flex !important; gap: 10px !important; align-items: center !important; }
.coupon input#coupon_code { width: 180px !important; }
.coupon button[name="apply_coupon"],
.actions button[name="update_cart"] {
  background: var(--f-text) !important;
  color: var(--f-white) !important;
  font-family: var(--f-body) !important;
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  padding: 12px 18px !important;
  border: none !important;
  border-radius: var(--f-r) !important;
  cursor: pointer !important;
  pointer-events: all !important;
  transition: background 0.2s !important;
  white-space: nowrap !important;
}
.coupon button[name="apply_coupon"]:hover,
.actions button[name="update_cart"]:hover { background: #333028 !important; }

/* Cart Totals */
.cart-collaterals { margin-top: 28px !important; }
.cart_totals { width: 100% !important; }
.cart_totals h2 {
  font-family: var(--f-head) !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  color: var(--f-text) !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 14px !important;
}
.cart_totals table {
  width: 100% !important;
  border-collapse: collapse !important;
  background: var(--f-white) !important;
  border: 1px solid var(--f-border) !important;
  border-radius: var(--f-rl) !important;
  overflow: hidden !important;
}
.cart_totals table tr th,
.cart_totals table tr td {
  padding: 13px 20px !important;
  border-bottom: 1px solid var(--f-border2) !important;
  font-family: var(--f-body) !important;
  color: var(--f-text) !important;
  background: transparent !important;
}
.cart_totals table tr th {
  font-size: 0.72rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  color: var(--f-mid) !important;
  width: 40% !important;
}
.cart_totals .order-total th,
.cart_totals .order-total td {
  border-bottom: none !important;
  padding-top: 16px !important;
  padding-bottom: 16px !important;
}
.cart_totals .order-total th { font-weight: 600 !important; color: var(--f-text) !important; }
.cart_totals .order-total td {
  font-family: var(--f-head) !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
}
.wc-proceed-to-checkout { margin-top: 12px !important; padding: 0 !important; }
.wc-proceed-to-checkout .checkout-button,
.wc-proceed-to-checkout a.checkout-button {
  display: block !important; width: 100% !important;
  background: var(--f-text) !important;
  color: var(--f-white) !important;
  font-family: var(--f-body) !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  text-decoration: none !important;
  padding: 17px 32px !important;
  border-radius: var(--f-r) !important;
  border: none !important;
  cursor: pointer !important;
  pointer-events: all !important;
  transition: background 0.2s !important;
  box-shadow: none !important;
}
.wc-proceed-to-checkout .checkout-button:hover { background: #333028 !important; }
.blockUI.blockOverlay { background: rgba(245,243,240,0.7) !important; }

/* ================================================================
   BESTELLBESTÄTIGUNG
   ================================================================ */
body.woocommerce-order-received .woocommerce {
  max-width: 680px !important;
  margin: 0 auto !important;
  padding: 60px var(--f-pad) 80px !important;
  background: transparent !important;
}
.woocommerce-thankyou-order-received {
  font-family: var(--f-head) !important;
  font-size: clamp(1.6rem, 4vw, 2.5rem) !important;
  color: var(--f-text) !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  margin-bottom: 8px !important;
}
.woocommerce-order p { color: var(--f-mid) !important; line-height: 1.75 !important; }
.woocommerce-order h2 {
  font-family: var(--f-head) !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  color: var(--f-text) !important;
  letter-spacing: -0.02em !important;
  margin: 28px 0 14px !important;
  border-bottom: 1px solid var(--f-border) !important;
  padding-bottom: 10px !important;
}
.woocommerce-order-overview {
  display: flex !important;
  flex-wrap: wrap !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 28px 0 36px !important;
  background: var(--f-white) !important;
  border: 1px solid var(--f-border) !important;
  border-radius: var(--f-rl) !important;
  overflow: hidden !important;
}
.woocommerce-order-overview li {
  flex: 1 !important;
  min-width: 120px !important;
  padding: 18px 22px !important;
  border-right: 1px solid var(--f-border) !important;
  font-size: 0.68rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--f-mid) !important;
}
.woocommerce-order-overview li:last-child { border-right: none !important; }
.woocommerce-order-overview li strong {
  display: block !important;
  font-size: 0.9375rem !important;
  font-weight: 600 !important;
  color: var(--f-text) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  margin-top: 5px !important;
}
.woocommerce-table--order-details {
  width: 100% !important;
  border-collapse: collapse !important;
  background: var(--f-white) !important;
  border: 1px solid var(--f-border) !important;
  border-radius: var(--f-rl) !important;
  overflow: hidden !important;
  margin-bottom: 28px !important;
}
.woocommerce-table--order-details thead th {
  background: var(--f-panel) !important;
  color: var(--f-mid) !important;
  font-size: 0.65rem !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  padding: 13px 20px !important;
  border-bottom: 1px solid var(--f-border) !important;
}
.woocommerce-table--order-details tbody td {
  padding: 15px 20px !important;
  border-bottom: 1px solid var(--f-border2) !important;
  color: var(--f-text) !important;
  background: transparent !important;
}
.woocommerce-table--order-details tfoot th,
.woocommerce-table--order-details tfoot td {
  padding: 12px 20px !important;
  color: var(--f-mid) !important;
  background: transparent !important;
}
.woocommerce-table--order-details tfoot .order-total th,
.woocommerce-table--order-details tfoot .order-total td {
  color: var(--f-text) !important;
  font-family: var(--f-head) !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  border-top: 1px solid var(--f-border) !important;
  letter-spacing: -0.02em !important;
}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 480px) {
  #customer_details { padding: 20px 16px !important; }
  .woocommerce-checkout-review-order-table .cart_item td { padding: 12px 16px !important; }
  h3#order_review_heading { padding: 14px 16px 12px !important; }
  #payment { padding: 0 16px !important; }
  .fab-coupon-wrap { padding: 0 16px 14px !important; }
  .woocommerce-privacy-policy-text { padding: 0 16px 14px !important; }
  #place_order { width: calc(100% - 32px) !important; margin: 0 16px 18px !important; }
  .fab-checkout-header { padding: 14px 0 14px !important; }
  #billing_postcode_field,
  #billing_city_field { width: 100% !important; display: block !important; }
  .actions { flex-direction: column !important; align-items: flex-start !important; }
  .coupon { flex-direction: column !important; width: 100% !important; }
  .coupon input#coupon_code { width: 100% !important; }
  .woocommerce-order-overview { flex-direction: column !important; }
  .woocommerce-order-overview li { border-right: none !important; border-bottom: 1px solid var(--f-border) !important; }
}
