/* ============================================================
   Lumeastore Cart & Checkout — Beautyplaza-style layout
   Loaded conditionally on cart and checkout pages.
   ============================================================ */

/* Layout shell */
.lumea-cart-page,
.lumea-checkout-page { background: var(--background); padding: 32px 0 80px; min-height: 60vh; font-family: var(--font-inter, 'Inter', sans-serif); color: var(--foreground); }
.lumea-cart-shell,
.lumea-checkout-shell { max-width: 1280px; margin: 0 auto; padding: 0 20px; }

/* Neutralize legacy lumea cart/checkout layout (theme used to apply a parent
 * grid on .woocommerce-cart .woocommerce that squeezes our new shell into 50%).
 * We render the 2-col layout ourselves inside .lumea-cart-grid; the parent
 * wrapper must be a plain block. */
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce {
  display: block !important;
  grid-template-columns: none !important;
  gap: 0 !important;
  max-width: none !important;
  width: 100% !important;
}
.woocommerce-cart .wc-page-content,
.woocommerce-checkout .wc-page-content,
.woocommerce-cart .entry-content,
.woocommerce-checkout .entry-content {
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* Section-container that wraps the page should not double-pad our shell */
.woocommerce-cart .section-container.page-wrapper,
.woocommerce-checkout .section-container.page-wrapper {
  max-width: none !important;
  padding: 0 !important;
}

/* Topbar (cart) */
.lumea-cart-topbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.lumea-cart-back { display: inline-flex; align-items: center; gap: 8px; color: var(--brand-600); text-decoration: none; font-weight: 600; font-size: 14px; }
.lumea-cart-back:hover { color: var(--brand-700); text-decoration: underline; }
.lumea-cart-trust { display: inline-flex; align-items: center; gap: 8px; color: var(--muted-foreground); font-size: 13px; }
.lumea-cart-trust svg { color: var(--brand-500); }

/* Header */
.lumea-cart-header { margin-bottom: 18px; }
.lumea-cart-title { font-family: var(--font-playfair, 'Playfair Display', serif); font-size: clamp(28px, 4vw, 38px); font-weight: 700; color: var(--foreground); margin: 0 0 4px; letter-spacing: -0.02em; }
.lumea-cart-sub { color: var(--muted-foreground); font-size: 14px; margin: 0; }
.lumea-cart-sub strong { color: var(--foreground); font-weight: 700; }

/* Two-column grid */
.lumea-cart-grid,
.lumea-checkout-grid { display: grid; grid-template-columns: minmax(0, 1fr) 380px; gap: 32px; align-items: start; }
@media (max-width: 1024px) { .lumea-cart-grid, .lumea-checkout-grid { grid-template-columns: 1fr; gap: 24px; } }

/* ============================================================
   Cart items table
   ============================================================ */
.lumea-cart-items { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.lumea-cart-row { display: grid; grid-template-columns: minmax(0, 1fr) 110px 130px 110px 36px; align-items: center; gap: 16px; padding: 18px 18px; border-bottom: 1px solid var(--border); }
.lumea-cart-row:last-child { border-bottom: none; }
.lumea-cart-row--head { background: transparent; padding: 12px 18px; border-bottom: 1px solid var(--border); font-size: 13px; color: var(--muted-foreground); font-weight: 600; text-transform: none; }
.lumea-cart-row--head .lumea-col { text-align: left; }
.lumea-cart-row--head .lumea-col--price,
.lumea-cart-row--head .lumea-col--qty,
.lumea-cart-row--head .lumea-col--sub { text-align: center; }
.lumea-cart-row--free { background: var(--muted); }
.lumea-col { min-width: 0; }
.lumea-col--price, .lumea-col--qty, .lumea-col--sub { text-align: center; font-weight: 600; color: var(--foreground); }
.lumea-col--sub { font-weight: 700; }

/* Product cell */
.lumea-prod { display: flex; gap: 16px; align-items: flex-start; }
.lumea-prod-thumb { flex: 0 0 80px; width: 80px; height: 80px; border-radius: 8px; overflow: hidden; background: var(--muted); display: flex; align-items: center; justify-content: center; }
.lumea-prod-thumb img { width: 100%; height: 100%; object-fit: contain; display: block; }
.lumea-prod-info { min-width: 0; flex: 1; }
.lumea-prod-brand { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; color: var(--brand-600); margin-bottom: 4px; }
.lumea-prod-name { font-size: 15px; font-weight: 600; line-height: 1.35; margin-bottom: 6px; }
.lumea-prod-name a { color: var(--foreground); text-decoration: none; }
.lumea-prod-name a:hover { color: var(--brand-600); }
.lumea-prod-eta { color: #16a34a; font-size: 13px; font-weight: 600; margin-top: 4px; }
.lumea-prod-discount { color: #dc2626; font-size: 13px; font-weight: 600; margin-top: 2px; }
.lumea-cart-row--free .lumea-prod-brand { color: var(--plum-500); }

/* Strikethrough on sale (WC outputs <del>...<ins>) */
.lumea-col--price del, .lumea-col--sub del { color: var(--muted-foreground); font-weight: 400; margin-right: 4px; }
.lumea-col--price ins, .lumea-col--sub ins { background: transparent; text-decoration: none; color: var(--foreground); }

.lumea-price-free { color: #16a34a; font-weight: 700; }

/* Qty stepper */
.lumea-qty .quantity { display: inline-flex; align-items: stretch; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; background: var(--card); }
.lumea-qty .quantity .minus,
.lumea-qty .quantity .plus,
.lumea-qty .quantity button { background: transparent; border: 0; width: 34px; height: 38px; font-size: 18px; line-height: 1; cursor: pointer; color: var(--foreground); }
.lumea-qty .quantity .minus:hover, .lumea-qty .quantity .plus:hover { background: var(--muted); }
.lumea-qty .quantity input.qty { width: 44px; height: 38px; border: 0; border-left: 1px solid var(--border); border-right: 1px solid var(--border); text-align: center; font-size: 15px; font-weight: 600; background: transparent; -moz-appearance: textfield; }
.lumea-qty .quantity input.qty::-webkit-outer-spin-button,
.lumea-qty .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.lumea-qty-locked { display: inline-block; padding: 8px 14px; background: var(--muted); border-radius: 8px; font-weight: 600; }

/* Auto-add +/- buttons via :before/:after if WC theme didn't render them */
.lumea-qty .quantity:not(:has(.minus)) { position: relative; }

/* Remove */
.lumea-remove { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 50%; color: var(--muted-foreground); text-decoration: none; font-size: 22px; line-height: 1; transition: all .15s; }
.lumea-remove:hover { background: var(--secondary); color: var(--rose-dark); }

/* Cart actions footer */
.lumea-cart-actions { display: flex; gap: 12px; justify-content: flex-end; margin-top: 16px; }

/* Buttons */
.lumea-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 22px; font-size: 14px; font-weight: 600; border-radius: 10px; border: 1px solid transparent; cursor: pointer; text-decoration: none; transition: all .2s ease; line-height: 1; font-family: inherit; }
.lumea-btn--ghost { background: var(--card); color: var(--foreground); border-color: var(--border); }
.lumea-btn--ghost:hover { border-color: var(--brand-500); color: var(--brand-700); }
.lumea-btn--cta { background: #111; color: #fff; padding: 16px 22px; font-size: 15px; width: 100%; border-radius: 10px; }
.lumea-btn--cta:hover { background: #000; transform: translateY(-1px); box-shadow: 0 6px 18px rgba(0,0,0,.18); color: #fff; }
.lumea-btn--cta svg { transition: transform .2s; }
.lumea-btn--cta:hover svg { transform: translateX(3px); }

/* ============================================================
   Order summary card (cart + checkout)
   ============================================================ */
.lumea-cart-summary, .lumea-checkout-summary { position: sticky; top: 96px; }
.lumea-summary-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 22px; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.lumea-summary-title { font-family: var(--font-playfair, 'Playfair Display', serif); font-size: 22px; font-weight: 700; margin: 0 0 16px; color: var(--foreground); letter-spacing: -0.01em; }

.lumea-summary-rows { display: flex; flex-direction: column; gap: 8px; padding: 8px 0 14px; border-bottom: 1px solid var(--border); margin-bottom: 14px; }
.lumea-summary-row { display: flex; justify-content: space-between; align-items: baseline; font-size: 14px; color: var(--foreground); }
.lumea-summary-row--coupon { color: #16a34a; font-weight: 600; }
.lumea-summary-row--total { font-size: 18px; font-weight: 700; padding-top: 8px; border-top: 1px solid var(--border); margin-top: 4px; }
.lumea-summary-row--total span:last-child { font-family: var(--font-playfair, 'Playfair Display', serif); }
.lumea-summary-vat { display: flex; justify-content: space-between; font-size: 12px; color: var(--muted-foreground); margin-top: -2px; }

/* Coupon accordion */
.lumea-coupon-accordion { margin: 0 0 16px; border-top: 1px solid var(--border); padding-top: 14px; }
.lumea-coupon-accordion summary { display: flex; align-items: center; justify-content: space-between; font-size: 14px; font-weight: 600; cursor: pointer; padding: 6px 0; list-style: none; color: var(--foreground); }
.lumea-coupon-accordion summary::-webkit-details-marker { display: none; }
.lumea-coupon-accordion[open] summary svg { transform: rotate(180deg); }
.lumea-coupon-accordion summary svg { transition: transform .2s; color: var(--muted-foreground); }
.lumea-coupon-form { display: flex; gap: 8px; margin-top: 10px; }
.lumea-coupon-form input[type="text"] { flex: 1; height: 42px; padding: 0 12px; border: 1px solid var(--border); border-radius: 8px; background: var(--card); color: var(--foreground); font-size: 14px; }
.lumea-coupon-form input[type="text"]:focus { outline: none; border-color: var(--brand-500); box-shadow: 0 0 0 3px rgba(201,152,106,.15); }
.lumea-coupon-form .lumea-btn { white-space: nowrap; }

/* Free-shipping bar */
.lumea-fship { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--border); }
.lumea-fship-text { font-size: 13px; color: var(--foreground); margin-bottom: 8px; }
.lumea-fship-text strong { color: var(--brand-700); font-weight: 700; }
.lumea-fship-bar { width: 100%; height: 8px; background: var(--secondary); border-radius: 999px; overflow: hidden; }
.lumea-fship-bar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--brand-400), var(--brand-600)); transition: width .35s ease; }

/* Payment icons */
.lumea-pay-icons { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--border); }
.lumea-pay-icons .psi { display: inline-flex; line-height: 0; border-radius: 4px; overflow: hidden; box-shadow: 0 0 0 1px rgba(0,0,0,0.10); transition: transform .15s ease, box-shadow .15s ease; }
.lumea-pay-icons .psi svg { display: block; width: 40px; height: 26px; }
.lumea-pay-icons .psi:hover { transform: translateY(-1px); box-shadow: 0 3px 10px rgba(0,0,0,0.12); }

/* ============================================================
   Cart cross-sells
   ============================================================ */
.lumea-cart-collaterals { max-width: 1280px; margin: 56px auto 0; padding: 0 20px; }
.lumea-cart-collaterals .cross-sells > h2 { font-family: var(--font-playfair, 'Playfair Display', serif); font-size: 24px; font-weight: 700; text-align: center; margin: 0 0 24px; color: var(--foreground); }
.lumea-cart-collaterals ul.products { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; list-style: none; padding: 0; margin: 0; }

/* ============================================================
   Checkout: stepper
   ============================================================ */
.lumea-stepper { list-style: none; padding: 0; margin: 0 0 32px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; position: relative; }
.lumea-step { display: flex; flex-direction: column; align-items: center; gap: 8px; position: relative; padding-top: 4px; }
.lumea-step::before { content: ''; position: absolute; top: 18px; left: -50%; width: 100%; height: 2px; background: var(--border); z-index: 0; }
.lumea-step:first-child::before { display: none; }
.lumea-step--done::before, .lumea-step--active::before { background: var(--brand-500); }
.lumea-step-num { position: relative; z-index: 1; width: 36px; height: 36px; border-radius: 50%; background: var(--card); border: 2px solid var(--border); color: var(--muted-foreground); font-weight: 700; font-size: 14px; display: inline-flex; align-items: center; justify-content: center; }
.lumea-step--done .lumea-step-num { background: var(--brand-500); border-color: var(--brand-500); color: #fff; }
.lumea-step--active .lumea-step-num { background: var(--brand-500); border-color: var(--brand-500); color: #fff; }
.lumea-step-label { font-size: 13px; font-weight: 600; color: var(--muted-foreground); text-align: center; }
.lumea-step--done .lumea-step-label, .lumea-step--active .lumea-step-label { color: var(--brand-700); }
@media (max-width: 640px) { .lumea-step-label { font-size: 11px; } .lumea-step-num { width: 30px; height: 30px; font-size: 12px; } .lumea-step::before { top: 15px; } }

/* Section heads inside the form */
.lumea-section-head { margin-bottom: 18px; }
.lumea-section-head--review { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border); }
.lumea-section-title { font-family: var(--font-playfair, 'Playfair Display', serif); font-size: 26px; font-weight: 700; margin: 0 0 4px; color: var(--foreground); }
.lumea-section-sub { color: var(--muted-foreground); font-size: 14px; margin: 0; }
.lumea-section-trust { margin-top: 10px; display: inline-flex; align-items: center; gap: 8px; color: var(--brand-600); font-size: 14px; font-weight: 600; }

/* Checkout form fields restyle */
.lumea-checkout-main .form-row { margin: 0 0 14px; padding: 0; }
.lumea-checkout-main .form-row label { display: block; font-size: 14px; font-weight: 600; margin-bottom: 6px; color: var(--foreground); }
.lumea-checkout-main .form-row .optional { color: var(--muted-foreground); font-weight: 400; font-size: 13px; }
.lumea-checkout-main .input-text,
.lumea-checkout-main .form-row input[type="text"],
.lumea-checkout-main .form-row input[type="email"],
.lumea-checkout-main .form-row input[type="tel"],
.lumea-checkout-main .form-row input[type="password"],
.lumea-checkout-main .form-row input[type="number"],
.lumea-checkout-main .form-row select,
.lumea-checkout-main .form-row textarea,
.lumea-checkout-main .select2-selection {
	width: 100%; min-height: 44px; padding: 10px 14px; border: 1px solid var(--border); border-radius: 8px; background: var(--card); color: var(--foreground); font-size: 15px; font-family: inherit; box-sizing: border-box;
}
.lumea-checkout-main .form-row input:focus, .lumea-checkout-main .form-row select:focus, .lumea-checkout-main .form-row textarea:focus { outline: none; border-color: var(--brand-500); box-shadow: 0 0 0 3px rgba(201,152,106,.15); }
.lumea-checkout-main .select2-container--default .select2-selection--single { border: 1px solid var(--border); height: 44px; }
.lumea-checkout-main .select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 42px; padding-left: 14px; color: var(--foreground); }
.lumea-checkout-main .select2-container--default .select2-selection--single .select2-selection__arrow { height: 42px; }

/* Customer details columns */
.lumea-customer-details { display: grid; grid-template-columns: 1fr; gap: 28px; }
.lumea-customer-details > .col-1, .lumea-customer-details > .col-2 { float: none; width: auto; padding: 0; }
.lumea-customer-details h3 { font-family: var(--font-playfair, 'Playfair Display', serif); font-size: 20px; font-weight: 700; margin: 0 0 14px; color: var(--foreground); }

/* Order review (payment + place order) */
.lumea-order-review .shop_table { width: 100%; border: 1px solid var(--border); border-radius: var(--radius); border-collapse: separate; border-spacing: 0; overflow: hidden; margin-bottom: 16px; }
.lumea-order-review .shop_table th, .lumea-order-review .shop_table td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--border); }
.lumea-order-review .shop_table tr:last-child th, .lumea-order-review .shop_table tr:last-child td { border-bottom: none; }
.lumea-order-review .order-total { font-size: 18px; font-weight: 700; }
.lumea-order-review #payment { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px; }
.lumea-order-review #payment ul.payment_methods { list-style: none; padding: 0; margin: 0 0 16px; display: flex; flex-direction: column; gap: 8px; }
.lumea-order-review #payment ul.payment_methods li { padding: 12px 14px; border: 1px solid var(--border); border-radius: 10px; background: var(--background); }
.lumea-order-review #payment ul.payment_methods li:has(input:checked) { border-color: var(--brand-500); background: var(--secondary); }
.lumea-order-review #payment .payment_box { font-size: 13px; color: var(--muted-foreground); margin-top: 10px; padding: 10px 12px; background: var(--muted); border-radius: 8px; }
.lumea-order-review #place_order { background: #111; color: #fff; border: 0; padding: 16px 22px; font-size: 15px; font-weight: 700; border-radius: 10px; width: 100%; cursor: pointer; transition: all .2s; margin-top: 8px; }
.lumea-order-review #place_order:hover { background: #000; transform: translateY(-1px); box-shadow: 0 6px 18px rgba(0,0,0,.18); }

/* ============================================================
   Checkout summary aside
   ============================================================ */
.lumea-summary-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 14px; }
.lumea-summary-edit { color: var(--brand-600); font-size: 13px; font-weight: 600; text-decoration: none; }
.lumea-summary-edit:hover { color: var(--brand-700); text-decoration: underline; }
.lumea-summary-items { list-style: none; padding: 0; margin: 0 0 16px; max-height: 360px; overflow-y: auto; display: flex; flex-direction: column; gap: 12px; }
.lumea-summary-item { display: flex; gap: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border); }
.lumea-summary-item:last-child { border-bottom: none; padding-bottom: 0; }
.lumea-summary-thumb { flex: 0 0 56px; width: 56px; height: 56px; border-radius: 6px; overflow: hidden; background: var(--muted); }
.lumea-summary-thumb img { width: 100%; height: 100%; object-fit: contain; }
.lumea-summary-itembody { min-width: 0; flex: 1; }
.lumea-summary-brand { font-size: 11px; font-weight: 700; text-transform: uppercase; color: var(--brand-600); letter-spacing: .04em; }
.lumea-summary-name { font-size: 13px; font-weight: 600; color: var(--foreground); line-height: 1.35; margin: 2px 0 6px; }
.lumea-summary-meta { display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: var(--muted-foreground); }
.lumea-summary-line { font-weight: 700; color: var(--foreground); }
.lumea-summary-change { display: inline-block; margin-top: 8px; color: var(--brand-600); font-size: 13px; font-weight: 600; text-decoration: none; }
.lumea-summary-change:hover { color: var(--brand-700); text-decoration: underline; }

/* ============================================================
   Mobile responsive – cart items collapse to stacked cards
   ============================================================ */
@media (max-width: 760px) {
	.lumea-cart-row--head { display: none; }
	.lumea-cart-row { grid-template-columns: 1fr; gap: 10px; padding: 16px; position: relative; }
	.lumea-col--price, .lumea-col--qty, .lumea-col--sub { display: flex; justify-content: space-between; text-align: left; padding: 6px 0; border-top: 1px dashed var(--border); }
	.lumea-col--price::before { content: attr(data-title); color: var(--muted-foreground); font-weight: 600; font-size: 13px; }
	.lumea-col--qty::before  { content: attr(data-title); color: var(--muted-foreground); font-weight: 600; font-size: 13px; }
	.lumea-col--sub::before  { content: attr(data-title); color: var(--muted-foreground); font-weight: 600; font-size: 13px; }
	.lumea-col--rm { position: absolute; top: 12px; right: 12px; }
}
