/*
 * Cart & Checkout — minimal styling pass
 * Scope: pages where is_cart() or is_checkout() is true.
 * Goal: tidy default WC markup; no template changes.
 * Tokens (--text-*, --space-*, --color-*) defined in archive-redesign-v1.css; we redeclare a fallback set here so the file works even when that file isn't loaded on these pages.
 */

.woocommerce-cart .col-full,
.woocommerce-checkout .col-full {
  max-width: 100em;
}

.woocommerce-cart,
.woocommerce-checkout {
  --cc-text:        #1a1a1a;
  --cc-text-soft:   #555;
  --cc-text-muted:  #888;
  --cc-border:      #e5e5e5;
  --cc-border-soft: #f0eeea;
  --cc-surface:     #faf7f2;
  --cc-accent:      #ef0000;
  --cc-success:     #2d7a4f;
  --cc-radius:      8px;
  --cc-radius-sm:   6px;
  --cc-gap:         16px;
  --cc-gap-lg:      24px;
  --cc-gap-xl:      32px;
  font-family: 'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  color: var(--cc-text);
}

/* ── Page title ── */
.woocommerce-cart .entry-title,
.woocommerce-checkout .entry-title,
.woocommerce-cart h1.entry-title,
.woocommerce-checkout h1.entry-title {
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 1.5rem 0 1.5rem;
}

/* ── Notices ── */
.woocommerce-cart .woocommerce-info,
.woocommerce-cart .woocommerce-message,
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message {
  background: var(--cc-surface);
  color: var(--cc-text);
  border: 1px solid var(--cc-border);
  border-left: 3px solid var(--cc-accent);
  border-radius: var(--cc-radius-sm);
  padding: 14px 18px;
  font-size: 0.95rem;
  line-height: 1.55;
  margin: 0 0 1.5rem;
}
.woocommerce-cart .woocommerce-info::before,
.woocommerce-checkout .woocommerce-info::before { display: none; }
.woocommerce-cart .woocommerce-info a,
.woocommerce-checkout .woocommerce-info a {
  color: var(--cc-accent);
  text-decoration: underline;
}

/* ══════════════════════════════════════════════════
   CART
   ══════════════════════════════════════════════════ */

/* Table reset */
.woocommerce-cart .shop_table {
  width: 100%;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius);
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  background: #fff;
}
.woocommerce-cart .shop_table thead th {
  background: var(--cc-surface);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--cc-text-soft);
  padding: 12px 16px;
  border: none;
  border-bottom: 1px solid var(--cc-border);
  text-align: left;
}
.woocommerce-cart .shop_table tbody td {
  padding: 18px 16px;
  border: none;
  border-bottom: 1px solid var(--cc-border-soft);
  vertical-align: middle;
  background: #fff;
}
.woocommerce-cart .shop_table tbody tr:last-child td { border-bottom: none; }

/* Remove button */
.woocommerce-cart .shop_table td.product-remove {
  width: 40px;
  text-align: center;
  padding-left: 16px;
  padding-right: 0;
}
/* Cart remove (×) button — small circular muted token, not the saturated
   red button it picks up from the Storefront customizer's button-bg rule.
   !important on background/border/box-shadow is needed because Storefront's
   inline customizer CSS sets a bright bg + colored border on every <button>
   and <.button>, and WC's a.remove gets pulled into that styling somehow
   (likely a generic `button, .button` selector picking it up). */
.woocommerce-cart .shop_table td.product-remove a.remove,
.woocommerce-cart .shop_table td.product-remove a.remove:visited {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 28px !important;
  height: 28px !important;
  min-width: 0 !important;
  padding: 0 !important;
  border-radius: 50% !important;
  background: var(--cc-surface) !important;
  background-color: var(--cc-surface) !important;
  border: 1px solid var(--cc-border) !important;
  color: var(--cc-text-muted) !important;
  font-size: 18px !important;
  line-height: 1 !important;
  font-weight: 400 !important;
  text-decoration: none !important;
  box-shadow: none !important;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.woocommerce-cart .shop_table td.product-remove a.remove:hover,
.woocommerce-cart .shop_table td.product-remove a.remove:focus {
  background: var(--cc-accent) !important;
  background-color: var(--cc-accent) !important;
  border-color: var(--cc-accent) !important;
  color: #fff !important;
}

/* Product image cell */
.woocommerce-cart .shop_table td.product-thumbnail { width: 96px; }
.woocommerce-cart .shop_table td.product-thumbnail a { display: block; }
.woocommerce-cart .shop_table td.product-thumbnail img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: var(--cc-radius-sm);
  border: 1px solid var(--cc-border-soft);
  display: block;
}

/* Product name */
.woocommerce-cart .shop_table td.product-name a {
  color: var(--cc-text);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.95rem;
}
.woocommerce-cart .shop_table td.product-name a:hover { color: var(--cc-accent); }
.woocommerce-cart .shop_table td.product-name .variation,
.woocommerce-cart .shop_table td.product-name dl {
  margin: 4px 0 0;
  font-size: 0.8rem;
  color: var(--cc-text-muted);
}

/* Price / subtotal cells */
.woocommerce-cart .shop_table td.product-price,
.woocommerce-cart .shop_table td.product-subtotal {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--cc-text);
  white-space: nowrap;
}
/* Reset legacy parent-theme leak: style.css:1086 paints every .woocommerce-Price-amount
   #060 + display:block + font-size:1.6em. That breaks every total, subtotal and line
   item on cart/checkout. Force inherit so cells size their own type. */
.woocommerce-cart .woocommerce-Price-amount,
.woocommerce-cart .amount,
.woocommerce-checkout .woocommerce-Price-amount,
.woocommerce-checkout .amount {
  display: inline !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  color: inherit !important;
}

/* Quantity input */
.woocommerce-cart .quantity .qty,
.woocommerce-checkout .quantity .qty {
  width: 64px;
  height: 38px;
  padding: 0 10px;
  text-align: center;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius-sm);
  background: #fff;
  font-size: 0.95rem;
  font-weight: 500;
}

/* Coupon row + actions row */
.woocommerce-cart .shop_table td.actions {
  padding: 18px 16px;
  background: var(--cc-surface);
  border-top: 1px solid var(--cc-border);
}
.woocommerce-cart .coupon { display: flex; gap: 8px; align-items: center; }
.woocommerce-cart .coupon label { display: none; }
.woocommerce-cart .coupon input[type="text"] {
  height: 40px;
  padding: 0 12px;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius-sm);
  font-size: 0.9rem;
  min-width: 200px;
}

/* Update cart + apply coupon buttons (lower contrast secondary) */
.woocommerce-cart .button[name="update_cart"],
.woocommerce-cart .button[name="apply_coupon"] {
  height: 40px;
  padding: 0 18px;
  border-radius: var(--cc-radius-sm);
  border: 1px solid var(--cc-border);
  background: #fff;
  color: var(--cc-text);
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.woocommerce-cart .button[name="update_cart"]:hover,
.woocommerce-cart .button[name="apply_coupon"]:hover {
  border-color: var(--cc-text);
  background: var(--cc-surface);
}
.woocommerce-cart .button[name="update_cart"][disabled] {
  opacity: 0.4; cursor: not-allowed;
}

/* Two-column cart layout: items left, totals/checkout right.
   .woocommerce on the cart page contains <form.cart> and <div.cart-collaterals>
   as direct siblings — flip into a grid so the totals card sits alongside. */
@media (min-width: 900px) {
  .woocommerce-cart .woocommerce {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: var(--cc-gap-xl);
    align-items: start;
  }
  .woocommerce-cart .woocommerce > .woocommerce-notices-wrapper { grid-column: 1 / -1; }
  .woocommerce-cart .cart-collaterals {
    margin-top: 0;
    position: sticky;
    top: 1rem;
  }
}
.woocommerce-cart .cart-collaterals {
  margin-top: var(--cc-gap-lg);
  display: block;
}
.woocommerce-cart .cart_totals {
  background: #fff;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius);
  padding: 22px 24px;
}
.woocommerce-cart .cart_totals h2 {
  font-size: 1.15rem;
  font-weight: 700;
  margin: 0 0 14px;
  letter-spacing: -0.01em;
}
.woocommerce-cart .cart_totals table { width: 100%; border: none; }
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td {
  padding: 10px 0;
  border: none;
  border-bottom: 1px solid var(--cc-border-soft);
  background: transparent;
  font-size: 0.95rem;
}
.woocommerce-cart .cart_totals table tr:last-child th,
.woocommerce-cart .cart_totals table tr:last-child td { border-bottom: none; }
.woocommerce-cart .cart_totals table th { color: var(--cc-text-soft); font-weight: 500; text-align: left; }
.woocommerce-cart .cart_totals table td { text-align: right; font-weight: 600; }
.woocommerce-cart .cart_totals .order-total th,
.woocommerce-cart .cart_totals .order-total td {
  font-size: 1.1rem; font-weight: 700; padding-top: 14px;
}

.woocommerce-cart .wc-proceed-to-checkout { padding: 16px 0 0; margin: 0; }
/* Storefront's customizer generates inline `.button.alt { background-color: ... }`
   with high specificity; need !important to win on cart/checkout. */
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button.button.alt {
  display: block !important;
  width: 100% !important;
  height: 48px !important;
  line-height: 48px !important;
  padding: 0 !important;
  text-align: center !important;
  background: var(--cc-text) !important;
  background-color: var(--cc-text) !important;
  color: #fff !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  border: none !important;
  border-radius: var(--cc-radius) !important;
  text-decoration: none !important;
  transition: background 0.15s ease !important;
}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button.button.alt:hover {
  background: #333 !important;
  background-color: #333 !important;
  color: #fff !important;
}

/* ══════════════════════════════════════════════════
   CHECKOUT
   ══════════════════════════════════════════════════ */

.woocommerce-checkout form.checkout { margin-top: 1rem; }

/* Custom intro banner (style.css paints #my_custom_checkout_field with bright lightgreen). */
.woocommerce-checkout #my_custom_checkout_field {
  background: var(--cc-surface) !important;
  color: var(--cc-text) !important;
  border: 1px solid var(--cc-border);
  border-left: 3px solid var(--cc-accent);
  border-radius: var(--cc-radius-sm);
  padding: 14px 18px !important;
  font-size: 0.92rem;
  line-height: 1.6;
  margin: 0 0 1.5rem !important;
}

/* ── 2-column checkout layout (≥900px) ──
   Float-based: customer_details left (fills), order review heading + table right
   (stacked, sticky). Floats let the two right-column siblings sit flush together
   regardless of how tall the left column grows. */
@media (min-width: 900px) {
  .woocommerce-checkout form.checkout {
    display: block;
  }
  .woocommerce-checkout form.checkout::after {
    content: '';
    display: table;
    clear: both;
  }
  .woocommerce-checkout form.checkout > #my_custom_checkout_field {
    width: 100%;
    margin: 0 0 1.5rem !important;
    clear: both;
  }
  .woocommerce-checkout form.checkout > #customer_details {
    float: left;
    width: calc(100% - 380px - 32px);
    min-width: 0;
  }
  .woocommerce-checkout form.checkout > #order_review_heading,
  .woocommerce-checkout form.checkout > #order_review {
    float: right;
    clear: right;
    width: 380px;
  }
  .woocommerce-checkout form.checkout > #order_review_heading {
    margin-top: 0;
  }
  .woocommerce-checkout form.checkout > #order_review {
    position: sticky;
    top: 1rem;
  }
  /* Inside customer_details: Storefront's .col-1/.col-2 split billing & shipping
     side by side. In the narrower left column we want them stacked. */
  .woocommerce-checkout #customer_details .col2-set,
  .woocommerce-checkout #customer_details > .col2-set {
    display: block;
  }
  .woocommerce-checkout #customer_details .col-1,
  .woocommerce-checkout #customer_details .col-2 {
    width: 100% !important;
    float: none !important;
    margin: 0 0 1rem;
  }
}

/* Section headers */
.woocommerce-checkout h3,
.woocommerce-checkout #order_review_heading {
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 2rem 0 1rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid var(--cc-border);
}
.woocommerce-checkout h3:first-of-type { margin-top: 0; }

/* Form rows */
.woocommerce-checkout .form-row {
  margin: 0 0 14px;
  padding: 0;
  display: block;
}
.woocommerce-checkout .form-row label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--cc-text);
  margin: 0 0 6px;
  letter-spacing: 0.01em;
}
.woocommerce-checkout .form-row .required {
  color: var(--cc-accent);
  text-decoration: none;
  margin-left: 2px;
}

/* All text-style inputs + selects */
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .select2-container .select2-selection--single,
.woocommerce-checkout #order_comments {
  width: 100% !important;
  height: 44px;
  min-height: 44px;
  padding: 0 14px;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius-sm);
  background: #fff;
  font-size: 0.95rem;
  font-family: inherit;
  color: var(--cc-text);
  box-shadow: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout #order_comments {
  min-height: 96px;
  height: auto;
  padding: 12px 14px;
  resize: vertical;
}
.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row textarea:focus,
.woocommerce-checkout .form-row select:focus {
  outline: none;
  border-color: var(--cc-text);
  box-shadow: 0 0 0 3px rgba(0,0,0,0.05);
}
.woocommerce-checkout .select2-container .select2-selection--single {
  display: flex;
  align-items: center;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
  padding-left: 0;
  line-height: normal;
  color: var(--cc-text);
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow { height: 42px; }

/* Two-column field grid for billing/shipping where it makes sense */
@media (min-width: 768px) {
  .woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
  .woocommerce-checkout .woocommerce-shipping-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px var(--cc-gap);
  }
  .woocommerce-checkout .woocommerce-billing-fields__field-wrapper > .form-row,
  .woocommerce-checkout .woocommerce-shipping-fields__field-wrapper > .form-row {
    margin-bottom: 0;
  }
  .woocommerce-checkout .form-row-wide,
  .woocommerce-checkout #billing_company_field,
  .woocommerce-checkout #billing_address_1_field,
  .woocommerce-checkout #billing_address_2_field,
  .woocommerce-checkout #billing_country_field,
  .woocommerce-checkout #billing_email_field,
  .woocommerce-checkout #billing_phone_field,
  .woocommerce-checkout #shipping_address_1_field,
  .woocommerce-checkout #shipping_address_2_field,
  .woocommerce-checkout #shipping_company_field,
  .woocommerce-checkout #shipping_country_field,
  .woocommerce-checkout #order_comments_field {
    grid-column: 1 / -1;
  }
}

/* Radio + checkbox rows (e.g. customer type, shipping picker, terms) */
.woocommerce-checkout .form-row.radio,
.woocommerce-checkout .form-row.checkbox,
.woocommerce-checkout #ship-to-different-address,
.woocommerce-checkout .woocommerce-form__label-for-checkbox {
  display: block;
}
.woocommerce-checkout input[type="radio"],
.woocommerce-checkout input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0 8px 0 0;
  vertical-align: middle;
  accent-color: var(--cc-accent);
}
.woocommerce-checkout #ship-to-different-address {
  margin: 1.5rem 0 0.5rem;
  font-size: 0.95rem;
  font-weight: 600;
}
.woocommerce-checkout #ship-to-different-address label {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
}

/* Shipping method (your custom radio group) */
.woocommerce-checkout #shipping_method_field,
.woocommerce-checkout .form-row.shipping_options {
  background: var(--cc-surface);
  padding: 14px 18px;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius);
}
.woocommerce-checkout #shipping_method_field label,
.woocommerce-checkout .form-row.shipping_options label {
  font-weight: 500;
  font-size: 0.92rem;
  color: var(--cc-text-soft);
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
  margin: 6px 0;
}

/* Custom radio groups (leveransalternativ + customer_type) — override style.css
   `display: flex; wrap; width: 90%` rules that scatter inputs and labels. */
.woocommerce-checkout #leveransalternativ_field .woocommerce-input-wrapper,
.woocommerce-checkout #customer_type_field .woocommerce-input-wrapper {
  display: block !important;
  flex: none !important;
  width: 100% !important;
}
.woocommerce-checkout #leveransalternativ_field .woocommerce-input-wrapper input[type='radio'],
.woocommerce-checkout #customer_type_field .woocommerce-input-wrapper input[type='radio'] {
  width: 16px !important;
  height: 16px !important;
  margin: 0 10px 0 0 !important;
  vertical-align: middle;
  flex: none !important;
}
.woocommerce-checkout #leveransalternativ_field .woocommerce-input-wrapper input[type='radio'] + label,
.woocommerce-checkout #customer_type_field .woocommerce-input-wrapper input[type='radio'] + label {
  display: inline !important;
  width: auto !important;
  margin: 0 1.25em 0 0 !important;
  font-weight: 500;
  font-size: 0.95rem;
  color: var(--cc-text);
  cursor: pointer;
  vertical-align: middle;
}
/* Stack each radio + label pair on its own line for the leveransalternativ list. */
.woocommerce-checkout #leveransalternativ_field .woocommerce-input-wrapper input[type='radio'] {
  display: inline-block;
}
.woocommerce-checkout #leveransalternativ_field .woocommerce-input-wrapper input[type='radio'] + label {
  display: inline-block !important;
  margin: 6px 0 !important;
  width: calc(100% - 30px) !important;
  vertical-align: top;
}
.woocommerce-checkout #leveransalternativ_field .woocommerce-input-wrapper br { display: none; }

/* Order review table (matches cart styling) */
.woocommerce-checkout #order_review { margin-top: 1rem; }
.woocommerce-checkout #order_review .shop_table {
  width: 100%;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius);
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  background: #fff;
}
.woocommerce-checkout #order_review .shop_table thead th,
.woocommerce-checkout #order_review .shop_table tfoot th,
.woocommerce-checkout #order_review .shop_table tfoot td {
  background: var(--cc-surface);
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--cc-text-soft);
  padding: 12px 16px;
  border: none;
}
.woocommerce-checkout #order_review .shop_table thead th { border-bottom: 1px solid var(--cc-border); }
.woocommerce-checkout #order_review .shop_table tbody td,
.woocommerce-checkout #order_review .shop_table tbody th {
  padding: 12px 16px;
  border: none;
  border-bottom: 1px solid var(--cc-border-soft);
  font-size: 0.95rem;
  background: #fff;
}
.woocommerce-checkout #order_review .shop_table tbody tr:last-child td,
.woocommerce-checkout #order_review .shop_table tbody tr:last-child th { border-bottom: none; }
.woocommerce-checkout #order_review .shop_table tfoot tr:not(:last-child) th,
.woocommerce-checkout #order_review .shop_table tfoot tr:not(:last-child) td {
  border-bottom: 1px solid var(--cc-border-soft);
}
.woocommerce-checkout #order_review .shop_table .order-total th,
.woocommerce-checkout #order_review .shop_table .order-total td {
  font-size: 1.05rem;
  color: var(--cc-text);
  text-transform: none;
  letter-spacing: 0;
  font-weight: 700;
}

/* Payment methods box */
.woocommerce-checkout #payment {
  background: var(--cc-surface);
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius);
  padding: 18px 20px;
  margin-top: 1.5rem;
}
.woocommerce-checkout #payment ul.payment_methods {
  list-style: none;
  margin: 0 0 1rem;
  padding: 0;
  border: none;
}
.woocommerce-checkout #payment ul.payment_methods li {
  background: #fff;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius-sm);
  padding: 12px 14px;
  margin: 0 0 10px;
}
.woocommerce-checkout #payment ul.payment_methods li label {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--cc-text);
  margin: 0;
  display: inline;
}
.woocommerce-checkout #payment .payment_box {
  background: var(--cc-surface);
  margin: 10px 0 0;
  padding: 12px 14px;
  border-radius: var(--cc-radius-sm);
  font-size: 0.88rem;
  color: var(--cc-text-soft);
  line-height: 1.5;
  position: relative;
  word-wrap: break-word;
  overflow-wrap: anywhere;
}
.woocommerce-checkout #payment .payment_box::before { display: none !important; }

/* Standalone payment <select> (legacy custom field) — narrow column needs
   smaller font + tight padding so the long Swedish payment-method names fit. */
.woocommerce-checkout #payment select,
.woocommerce-checkout #my_custom_checkout_field select,
.woocommerce-checkout select[name="payment_method"] {
  width: 100% !important;
  max-width: 100%;
  height: 40px !important;
  padding: 0 36px 0 12px !important;
  font-size: 0.85rem !important;
  background-color: #fff;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius-sm);
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%23888' d='M0 0l5 6 5-6z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
  text-overflow: ellipsis;
}

/* Terms acceptance */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper { margin: 1rem 0; }
.woocommerce-checkout .woocommerce-form__label-for-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.9rem;
  color: var(--cc-text-soft);
}
.woocommerce-checkout .woocommerce-form__label-for-checkbox input[type="checkbox"] {
  margin-top: 3px;
  flex-shrink: 0;
}

/* Place order button */
.woocommerce-checkout #place_order,
.woocommerce-checkout button[name="woocommerce_checkout_place_order"] {
  display: block;
  width: 100%;
  height: 52px;
  line-height: 52px;
  padding: 0;
  background: var(--cc-text);
  color: #fff;
  border: none;
  border-radius: var(--cc-radius);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: none;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.15s ease;
  margin-top: 1rem;
}
.woocommerce-checkout #place_order:hover,
.woocommerce-checkout button[name="woocommerce_checkout_place_order"]:hover {
  background: #333;
}

/* Edit link below button */
.woocommerce-checkout .checkout_coupon ~ p,
.woocommerce-checkout a.edit_address,
.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .checkout-cart-edit { margin-top: 1rem; }

/* Disclosure (<details>) — VAD GÅR ATT RETURNERA etc. */
.woocommerce-checkout details {
  background: #fff;
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius-sm);
  padding: 10px 14px;
  margin: 0 0 8px;
  font-size: 0.9rem;
}
.woocommerce-checkout details > summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--cc-text);
  list-style: none;
  position: relative;
  padding-right: 24px;
}
.woocommerce-checkout details > summary::-webkit-details-marker,
.woocommerce-checkout details > summary::marker { display: none; content: ''; }
.woocommerce-checkout details > summary::after {
  content: '';
  position: absolute;
  right: 4px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--cc-text-muted);
  border-bottom: 2px solid var(--cc-text-muted);
  transform: translateY(-65%) rotate(45deg);
  transition: transform 0.15s ease;
}
.woocommerce-checkout details[open] > summary::after {
  transform: translateY(-30%) rotate(-135deg);
}
.woocommerce-checkout details[open] { padding-bottom: 14px; }

/* Mobile */
@media (max-width: 767px) {
  .woocommerce-cart .shop_table thead { display: none; }
  .woocommerce-cart .shop_table,
  .woocommerce-cart .shop_table tbody,
  .woocommerce-cart .shop_table tr,
  .woocommerce-cart .shop_table td {
    display: block;
    width: 100%;
  }
  .woocommerce-cart .shop_table tbody tr {
    border-bottom: 1px solid var(--cc-border-soft);
    padding: 14px 0;
  }
  .woocommerce-cart .shop_table tbody td {
    border: none;
    padding: 6px 16px;
    text-align: left;
  }
  .woocommerce-cart .shop_table tbody td.product-thumbnail {
    padding-top: 14px;
  }
  .woocommerce-cart .shop_table td.actions {
    border-top: 1px solid var(--cc-border);
  }
  .woocommerce-cart .cart_totals { max-width: none; }
}
