/* ──────────────────────────────────────────
   WooCommerce overrides — Smart Cafe theme
   ──────────────────────────────────────── */

/* === SHOP / ARCHIVE PAGE === */
.woocommerce.archive .smartcafe-page-inner,
.woocommerce-page.archive .smartcafe-page-inner{max-width:1200px;}

.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering{margin-bottom:20px;font-size:13px;color:var(--text3);}
.woocommerce .woocommerce-ordering select{padding:8px 12px;border:1.5px solid var(--border);border-radius:8px;background:#fff;font-family:var(--fb);font-size:13px;color:var(--coffee);}

/* Hide default WC product grid styles — we use our own .prod-grid */
.woocommerce ul.products,
.woocommerce-page ul.products{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:20px;list-style:none;margin:0 0 40px;padding:0;}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product{width:auto !important;margin:0 !important;float:none !important;clear:none !important;padding:0;text-align:left;}

/* === SINGLE PRODUCT PAGE === */
.woocommerce div.product{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;}
@media(max-width:900px){.woocommerce div.product{grid-template-columns:1fr;gap:32px;}}

.woocommerce div.product .images,
.woocommerce div.product div.images{position:sticky;top:90px;float:none !important;width:auto !important;}
@media(max-width:900px){.woocommerce div.product .images{position:static;}}

.woocommerce div.product .images img{width:100%;border-radius:16px;border:1.5px solid var(--border);background:var(--bg2);}
.woocommerce div.product div.summary{float:none !important;width:auto !important;}

.woocommerce div.product .product_title{font-family:var(--fd);font-size:clamp(28px,3.5vw,40px);font-weight:700;color:var(--coffee);line-height:1.2;margin-bottom:12px;}

.woocommerce div.product p.price,
.woocommerce div.product span.price{background:var(--bg2);border:1.5px solid var(--border);border-radius:12px;padding:20px 22px;margin:0 0 24px;display:block;}
.woocommerce div.product p.price ins,
.woocommerce div.product p.price > .amount,
.woocommerce div.product span.price > .amount,
.woocommerce div.product p.price ins .amount{font-family:var(--fd);font-size:42px;font-weight:700;color:var(--coffee);text-decoration:none;line-height:1;}
.woocommerce div.product p.price del{font-size:16px;color:var(--text3);}

.woocommerce div.product .stock,
.woocommerce div.product .in-stock{display:inline-flex;align-items:center;gap:6px;background:var(--green-bg);border:1px solid rgba(37,107,40,.2);border-radius:20px;padding:5px 14px;font-size:12px;font-weight:800;color:var(--green);margin-bottom:20px;}
.woocommerce div.product .stock::before,
.woocommerce div.product .in-stock::before{content:'';width:7px;height:7px;background:var(--green);border-radius:50%;}

.woocommerce div.product .woocommerce-product-details__short-description{font-size:15px;color:var(--text2);line-height:1.75;margin-bottom:20px;}

/* Quantity input */
.woocommerce .quantity{display:flex;align-items:center;gap:0;border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden;margin-right:12px;}
.woocommerce .quantity .qty{width:60px !important;height:44px;border:none;border-left:1.5px solid var(--border);border-right:1.5px solid var(--border);background:#fff;text-align:center;font-size:16px;font-weight:800;font-family:var(--fb);color:var(--coffee);}

/* Add to cart button */
.woocommerce div.product form.cart .button,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt{background:var(--orange) !important;color:#fff !important;border:none !important;border-radius:var(--r) !important;padding:14px 28px !important;font-family:var(--fb) !important;font-size:15px !important;font-weight:900 !important;cursor:pointer;transition:.2s;box-shadow:0 4px 16px rgba(232,146,26,.4);text-shadow:none;}
.woocommerce div.product form.cart .button:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover{background:var(--orange-h) !important;transform:translateY(-1px);}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button{background:#fff;color:var(--coffee);border:1.5px solid var(--border);border-radius:var(--r);padding:10px 18px;font-family:var(--fb);font-weight:700;text-shadow:none;}
.woocommerce a.button:hover,
.woocommerce button.button:hover{background:var(--bg2);}

/* Product meta */
.woocommerce div.product .product_meta{margin-top:20px;padding-top:20px;border-top:1.5px solid var(--border);font-size:13px;color:var(--text3);}
.woocommerce div.product .product_meta > span{display:block;padding:6px 0;}
.woocommerce div.product .product_meta > span > .sku_wrapper,
.woocommerce div.product .product_meta > span > .posted_in,
.woocommerce div.product .product_meta > span > .tagged_as{color:var(--text2);font-weight:700;}

/* Tabs */
.woocommerce div.product .woocommerce-tabs{grid-column:1 / -1;margin-top:40px;}
.woocommerce div.product .woocommerce-tabs ul.tabs{padding:0;margin:0 0 24px;list-style:none;border-bottom:2px solid var(--border);display:flex;gap:4px;}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{display:none;}
.woocommerce div.product .woocommerce-tabs ul.tabs li{background:transparent !important;border:none !important;border-radius:0 !important;margin:0 !important;padding:0 !important;}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after{display:none !important;}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{padding:12px 20px;font-family:var(--fb);font-size:14px;font-weight:800;color:var(--text2);text-decoration:none;border-bottom:3px solid transparent;display:block;margin-bottom:-2px;}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{color:var(--coffee);border-bottom-color:var(--caramel);}
.woocommerce div.product .woocommerce-tabs .panel h2{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--coffee);margin-bottom:14px;}
.woocommerce div.product .woocommerce-tabs .panel{font-size:15px;color:var(--text2);line-height:1.75;}

/* Related products */
.woocommerce .related,
.woocommerce .upsells{grid-column:1 / -1;margin-top:60px;}
.woocommerce .related h2,
.woocommerce .upsells h2{font-family:var(--fd);font-size:clamp(24px,3vw,32px);font-weight:700;color:var(--coffee);margin-bottom:24px;}

/* === CART PAGE === */
.woocommerce-cart .woocommerce{max-width:1100px;margin:0 auto;}
.woocommerce table.shop_table{background:var(--card);border:1.5px solid var(--border);border-radius:14px;border-collapse:separate;border-spacing:0;overflow:hidden;}
.woocommerce table.shop_table th{background:var(--bg2);color:var(--coffee);font-family:var(--fb);font-weight:800;font-size:13px;padding:14px 16px;border-bottom:1.5px solid var(--border);text-transform:uppercase;letter-spacing:.05em;}
.woocommerce table.shop_table td{padding:14px 16px;border-bottom:1px solid var(--border);font-size:14px;color:var(--text);vertical-align:middle;}
.woocommerce table.shop_table tr:last-child td{border-bottom:none;}
.woocommerce table.shop_table img{max-width:80px;border-radius:10px;}
.woocommerce-cart .product-name a{color:var(--coffee);font-family:var(--fd);font-size:17px;font-weight:700;text-decoration:none;}
.woocommerce-cart .product-name a:hover{color:var(--caramel);}
.woocommerce-cart .product-price,
.woocommerce-cart .product-subtotal{font-family:var(--fd);font-weight:700;color:var(--coffee);}
.woocommerce-cart .product-remove a.remove{color:var(--red) !important;font-size:20px;font-weight:700;}
.woocommerce-cart .product-remove a.remove:hover{background:var(--red) !important;color:#fff !important;}

.woocommerce-cart .cart-collaterals,
.woocommerce-cart .wc-block-cart{margin-top:30px;}
.woocommerce-cart .cart_totals{background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:24px;}
.woocommerce-cart .cart_totals h2{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--coffee);margin-bottom:16px;padding-bottom:12px;border-bottom:1.5px solid var(--border);}
.woocommerce-cart .cart_totals table.shop_table{border:none;background:transparent;}
.woocommerce-cart .cart_totals table.shop_table th,
.woocommerce-cart .cart_totals table.shop_table td{background:transparent;border:none;padding:8px 0;border-bottom:1px solid var(--border);}
.woocommerce-cart .cart_totals .order-total td{font-family:var(--fd);font-size:22px;color:var(--caramel);font-weight:700;}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button{display:flex !important;align-items:center;justify-content:center;width:100%;padding:17px !important;background:var(--orange) !important;color:#fff !important;border-radius:var(--r) !important;font-family:var(--fb) !important;font-size:16px !important;font-weight:900 !important;box-shadow:0 4px 16px rgba(232,146,26,.4);}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover{background:var(--orange-h) !important;transform:translateY(-2px);}

/* Coupon */
.woocommerce-cart .cart .coupon{display:flex;gap:8px;align-items:center;}
.woocommerce-cart .cart .coupon input[type="text"]{padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--r);font-family:var(--fb);font-size:14px;}

/* === CHECKOUT PAGE === */
.woocommerce-checkout #customer_details{background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:24px;margin-bottom:20px;}
.woocommerce-checkout h3{font-family:var(--fd);font-size:18px;font-weight:700;color:var(--coffee);margin-bottom:20px;padding-bottom:12px;border-bottom:1.5px solid var(--border);}
.woocommerce form .form-row label{display:block;font-size:12px;font-weight:800;color:var(--text2);margin-bottom:6px;letter-spacing:.04em;text-transform:uppercase;}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:12px 14px;font-family:var(--fb);font-size:15px;color:var(--coffee);transition:.2s;outline:none;}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus{border-color:var(--caramel);box-shadow:0 0 0 3px rgba(200,120,32,.1);}
.woocommerce form .form-row.woocommerce-invalid input.input-text{border-color:var(--red);}

.woocommerce-checkout #order_review_heading{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--coffee);margin-top:24px;}
.woocommerce-checkout #order_review{background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:24px;}
.woocommerce-checkout #order_review table.shop_table th,
.woocommerce-checkout #order_review table.shop_table td{padding:10px 0;border-bottom:1px solid var(--border);background:transparent;}
.woocommerce-checkout #order_review .order-total td{font-family:var(--fd);font-size:22px;color:var(--caramel);font-weight:700;}

.woocommerce-checkout #payment{background:transparent;border:none;padding:0;margin-top:20px;}
.woocommerce-checkout #payment ul.payment_methods{background:var(--bg2);border:1.5px solid var(--border);border-radius:10px;padding:14px 18px;list-style:none;margin:0 0 16px;}
.woocommerce-checkout #payment ul.payment_methods li{list-style:none;padding:8px 0;}
.woocommerce-checkout #payment ul.payment_methods li input[type=radio]{accent-color:var(--caramel);}
.woocommerce-checkout #payment ul.payment_methods li label{font-weight:800;color:var(--coffee);font-size:14px;cursor:pointer;}
.woocommerce-checkout #payment .payment_box{background:#fff;border:1px solid var(--border);border-radius:8px;padding:14px;font-size:13px;color:var(--text2);line-height:1.6;margin-top:10px;}
.woocommerce-checkout #payment #place_order{width:100%;padding:17px !important;background:var(--orange) !important;color:#fff !important;border:none !important;border-radius:var(--r) !important;font-family:var(--fb) !important;font-size:16px !important;font-weight:900 !important;cursor:pointer;box-shadow:0 4px 16px rgba(232,146,26,.4);margin-top:16px;}
.woocommerce-checkout #payment #place_order:hover{background:var(--orange-h) !important;transform:translateY(-1px);}

/* === MESSAGES & NOTICES === */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-notices-wrapper > *{border-radius:10px !important;border-left:4px solid var(--caramel) !important;background:var(--bg2) !important;color:var(--coffee) !important;padding:16px 18px !important;font-size:14px;margin-bottom:16px !important;list-style:none;}
.woocommerce-error{border-left-color:var(--red) !important;background:#fbeae9 !important;color:var(--red) !important;}
.woocommerce-message{border-left-color:var(--green) !important;background:var(--green-bg) !important;color:var(--green) !important;}
.woocommerce-message a.button,
.woocommerce-info a.button{background:var(--orange) !important;color:#fff !important;border:none;padding:8px 16px !important;border-radius:6px !important;font-size:13px !important;text-shadow:none;}

/* === MY ACCOUNT === */
.woocommerce-account .woocommerce-MyAccount-navigation ul{list-style:none;margin:0;padding:0;}
.woocommerce-account .woocommerce-MyAccount-navigation ul li{margin:0;padding:0;border-bottom:1px solid var(--border);}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a{display:block;padding:12px 16px;color:var(--text2);text-decoration:none;font-weight:700;font-size:14px;}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover{background:var(--bg2);color:var(--coffee);}

/* === PRICE FORMATTING === */
.woocommerce-Price-amount{font-weight:700;}
.woocommerce-Price-currencySymbol{font-weight:700;}


/* ══════════════════════════════════════════
   SINGLE PRODUCT — custom layout (sc-*)
   ══════════════════════════════════════════ */

/* Page wrapper */
.sc-single-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
  max-width: 1160px;
  padding: 32px 28px 60px;
}
@media (max-width: 900px) {
  .sc-single-wrap { grid-template-columns: 1fr; gap: 32px; padding: 20px 16px 40px; }
}

/* ── Mobile: limit gallery image height ── */
@media (max-width: 600px) {
  .sc-gallery-main {
    max-height: 80vw;
    overflow: hidden;
  }
  .sc-main-photo {
    max-height: 80vw;
    object-fit: contain;
  }
  .sc-thumbs {
    gap: 8px;
    margin-top: 8px;
  }
  .sc-thumb {
    width: 64px;
    height: 64px;
  }
}

/* ── Gallery ── */
.sc-gallery { position: sticky; top: 90px; }
@media (max-width: 900px) { .sc-gallery { position: static; } }

.sc-gallery-main {
  border: 1.5px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  background: var(--bg2);
}
.sc-main-photo { width: 100%; height: auto; display: block; object-fit: contain; }

.sc-thumbs {
  display: flex;
  gap: 10px;
  margin-top: 12px;
  flex-wrap: wrap;
}
.sc-thumb {
  width: 80px;
  height: 80px;
  border: 1.5px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  padding: 0;
  background: var(--bg2);
  transition: border-color .18s;
}
.sc-thumb:hover, .sc-thumb.active { border-color: var(--caramel); }
.sc-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ── Summary ── */
.sc-cat-label {
  font-family: var(--fb);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .1em;
  color: var(--caramel);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.sc-product-title {
  font-family: var(--fd);
  font-size: clamp(28px, 3.5vw, 40px);
  font-weight: 700;
  color: var(--coffee);
  line-height: 1.2;
  margin-bottom: 14px;
}

/* Stock badge */
.sc-stock-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border-radius: 20px;
  padding: 5px 14px;
  font-family: var(--fb);
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 22px;
}
.sc-stock-badge.in-stock {
  background: var(--green-bg);
  border: 1px solid rgba(37,107,40,.2);
  color: var(--green);
}
.sc-stock-badge.out-stock {
  background: #fbeae9;
  border: 1px solid rgba(192,40,26,.2);
  color: var(--red);
}
.sc-stock-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
}
.in-stock .sc-stock-dot { background: var(--green); }
.out-stock .sc-stock-dot { background: var(--red); }

/* Price box */
.sc-price-box {
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 20px 22px;
  margin-bottom: 24px;
}
.sc-price-main { margin-bottom: 10px; }
.sc-price-sale .woocommerce-Price-amount,
.sc-price-sale {
  font-family: var(--fd);
  font-size: 42px;
  font-weight: 700;
  color: var(--coffee);
  line-height: 1;
}
.sc-wholesale-hint {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  color: var(--green);
  font-weight: 700;
  margin-top: 4px;
}
.sc-wholesale-hint svg { flex-shrink: 0; stroke: var(--green); }

/* Tier cards */
.sc-tier-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1.5px dashed var(--border2);
}
.sc-tier {
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
  text-align: center;
  background: #fff;
  cursor: pointer;
  transition: border-color .18s;
}
.sc-tier.active {
  background: var(--cream);
  border-color: var(--caramel);
}
.sc-tier-label {
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  color: var(--text3);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.sc-tier-price {
  font-family: var(--fd);
  font-size: 22px;
  font-weight: 700;
  color: var(--coffee);
  line-height: 1.1;
}
.sc-tier-price .woocommerce-Price-amount { font-size: inherit; font-family: inherit; font-weight: inherit; color: inherit; }
.sc-price-crossed .woocommerce-Price-amount { text-decoration: line-through; color: var(--text3); }
.sc-tier-sub {
  font-size: 11px;
  font-weight: 700;
  color: var(--text3);
  margin-top: 2px;
}
.sc-tier-save { color: var(--green); }

/* Qty row */
.sc-cart-row { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; }
.sc-qty-label { font-size: 14px; font-weight: 700; color: var(--text2); }
.sc-qty {
  display: flex;
  align-items: center;
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
}
.sc-qty-btn {
  width: 38px; height: 44px;
  background: var(--bg2);
  border: none; cursor: pointer;
  font-size: 20px; font-weight: 700;
  color: var(--coffee);
  transition: background .15s;
}
.sc-qty-btn:hover { background: var(--cream); }
.sc-qty-input {
  width: 60px; height: 44px;
  border: none;
  border-left: 1.5px solid var(--border);
  border-right: 1.5px solid var(--border);
  background: #fff;
  text-align: center;
  font-size: 16px; font-weight: 800;
  font-family: var(--fb);
  color: var(--coffee);
  -moz-appearance: textfield;
}
.sc-qty-input::-webkit-inner-spin-button,
.sc-qty-input::-webkit-outer-spin-button { -webkit-appearance: none; }

/* Add to cart button */
.sc-cart-form { margin-bottom: 0; }
.sc-add-to-cart-btn {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 16px 24px !important;
  background: var(--orange) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--r) !important;
  font-family: var(--fb) !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  cursor: pointer;
  transition: background .2s, transform .15s;
  box-shadow: 0 4px 18px rgba(232,146,26,.45);
  text-shadow: none !important;
  margin-bottom: 10px;
}
.sc-add-to-cart-btn:hover {
  background: var(--orange-h) !important;
  transform: translateY(-2px);
}

/* Fast ship notice */
.sc-fast-ship {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text3);
  margin-bottom: 24px;
}
.sc-fast-ship svg { flex-shrink: 0; }

/* Delivery rows */
.sc-delivery-info {
  border-top: 1.5px solid var(--border);
  margin-bottom: 28px;
}
.sc-delivery-row {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 12px;
  padding: 13px 0;
  border-bottom: 1px solid var(--border);
  align-items: start;
  font-size: 14px;
}
.sc-delivery-key {
  font-weight: 800;
  color: var(--coffee);
}
.sc-delivery-val { color: var(--text2); }

/* Short description */
.sc-short-desc h2 {
  font-family: var(--fd);
  font-size: 20px;
  font-weight: 700;
  color: var(--coffee);
  margin-bottom: 10px;
}
.sc-short-desc p { font-size: 15px; color: var(--text2); line-height: 1.75; }

/* Full description below grid */
.sc-full-desc-wrap {
  max-width: 1160px;
  padding: 0 28px 60px;
  font-size: 15px;
  color: var(--text2);
  line-height: 1.8;
}
.sc-full-desc-wrap h2 { font-family: var(--fd); font-size: 22px; color: var(--coffee); margin: 28px 0 12px; }

/* Out of stock */
.sc-out-of-stock-msg {
  padding: 14px 18px;
  background: #fbeae9;
  border-radius: var(--r);
  color: var(--red);
  font-weight: 700;
  font-size: 14px;
  margin-bottom: 20px;
}

/* Related inside single page */
.sc-single-wrap ~ * .related,
.woocommerce .related,
.woocommerce .upsells {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 28px 60px;
}

/* ── Single product: remove top whitespace ── */
.sc-single-wrap { padding-top: 0 !important; }
.woocommerce div.product { padding-top: 0 !important; }
.woocommerce-breadcrumb { margin-bottom: 16px !important; }

/* ── Related products: horizontal scroll ── */
.woocommerce .related.products,
.woocommerce .upsells.products { overflow: hidden; }

.woocommerce .related.products h2,
.woocommerce .upsells.products h2 { margin-bottom: 20px; }

.woocommerce .related ul.products,
.woocommerce .upsells ul.products {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 20px !important;
  overflow-x: auto;
  padding-bottom: 16px !important;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  grid-template-columns: none !important;
  scrollbar-width: thin;
  scrollbar-color: var(--border2) transparent;
}
.woocommerce .related ul.products::-webkit-scrollbar { height: 5px; }
.woocommerce .related ul.products::-webkit-scrollbar-track { background: transparent; }
.woocommerce .related ul.products::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 4px; }

.woocommerce .related ul.products li.prod-card,
.woocommerce .related ul.products li.product,
.woocommerce .upsells ul.products li.prod-card,
.woocommerce .upsells ul.products li.product {
  flex: 0 0 270px !important;
  min-width: 270px !important;
  width: 270px !important;
  margin: 0 !important;
  float: none !important;
  scroll-snap-align: start;
}

/* ── Qty total line ── */
.sc-qty-total {
  display: inline-block;
  background: var(--green-bg);
  border: 1px solid rgba(37,107,40,.2);
  color: var(--green);
  font-size: 14px;
  font-weight: 800;
  border-radius: var(--r);
  padding: 8px 16px;
  margin: 10px 0 16px;
}

/* ══════════════════════════════════════════
   CATALOG FIXES
══════════════════════════════════════════ */

/* Remove ghost ::before/::after grid cell */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after {
  display: none !important;
  content: none !important;
}

/* Products per row stays consistent */
.woocommerce ul.products.prod-grid li:first-child {
  margin-left: 0 !important;
}

/* Product card — full-width buy button */
.prod-buy-row {
  padding: 0 18px 18px;
}
.buy-btn--full {
  display: flex !important;
  width: 100% !important;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 13px 16px !important;
  white-space: normal !important;
  font-size: 14px !important;
  border-radius: var(--r) !important;
  box-shadow: 0 3px 12px rgba(232,146,26,.35) !important;
}
.buy-btn--full:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(232,146,26,.5) !important;
}

/* Remove "Каталог товарів" title area gap */
.catalog-top { margin-bottom: 20px; }

/* Page title "Каталог товарів" */
.woocommerce-products-header { margin-bottom: 16px !important; }

/* ══════════════════════════════════════════
   SINGLE PRODUCT — remove top image gap
══════════════════════════════════════════ */

/* Remove extra top padding from WooCommerce product div */
.woocommerce div.product,
.woocommerce div.product .images,
.woocommerce div.product div.images {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* sc-single-wrap: remove any inherited top space */
.sc-single-wrap {
  padding-top: 0 !important;
  margin-top: 0 !important;
}
.sc-gallery,
.sc-gallery-main {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Align gallery image top with category label */
.woocommerce div.product .images .woocommerce-product-gallery {
  margin-top: 0 !important;
  padding-top: 0 !important;
}
.woocommerce div.product .images .woocommerce-product-gallery__image:first-child {
  margin-top: 0 !important;
}
.woocommerce div.product .images figure {
  margin: 0 !important;
}

/* ══════════════════════════════════════════
   SINGLE PRODUCT — add-to-cart button full width
══════════════════════════════════════════ */

.woocommerce div.product form.cart {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px;
}
.woocommerce div.product form.cart .button,
.sc-add-to-cart-btn,
.single_add_to_cart_button {
  width: 100% !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: 16px 24px !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  box-shadow: 0 4px 18px rgba(232,146,26,.45) !important;
}

/* ══════════════════════════════════════════
   CUSTOM CART — sc-cart-* classes
══════════════════════════════════════════ */

.sc-cart-wrap {
  padding: 36px 28px 60px;
}
.sc-cart-inner {
  max-width: 1100px;
  margin: 0 auto;
}
.sc-cart-title {
  font-family: var(--fd);
  font-size: clamp(26px, 4vw, 36px);
  font-weight: 700;
  color: var(--coffee);
  margin-bottom: 28px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.sc-cart-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 28px;
  align-items: start;
}
@media (max-width: 900px) {
  .sc-cart-layout { grid-template-columns: 1fr; }
}

/* Cart item card */
.sc-ci {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 18px 20px;
  display: grid;
  grid-template-columns: 90px 1fr auto;
  gap: 16px;
  align-items: start;
  margin-bottom: 14px;
  transition: border-color .2s;
}
.sc-ci:hover { border-color: rgba(200,120,32,.3); }

.sc-ci-img {
  width: 90px;
  height: 90px;
  border-radius: 10px;
  overflow: hidden;
  background: var(--bg2);
  flex-shrink: 0;
}
.sc-ci-img img,
.sc-ci-img a img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 0 !important;
  border: none !important;
}
.sc-ci-img a { display: block; width: 100%; height: 100%; }

.sc-ci-name {
  font-family: var(--fd);
  font-size: 17px;
  font-weight: 700;
  color: var(--coffee);
  margin-bottom: 4px;
  line-height: 1.3;
}
.sc-ci-name a { color: inherit; text-decoration: none; }
.sc-ci-name a:hover { color: var(--caramel); }

.sc-ci-cat {
  font-size: 12px;
  font-weight: 700;
  color: var(--text3);
  margin-bottom: 10px;
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* Qty inside cart item — override WC defaults */
.sc-ci-qty {
  display: flex;
  align-items: center;
  gap: 0;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  width: fit-content;
  margin-top: 10px;
}
.sc-ci-qty-btn {
  background: none;
  border: none;
  width: 34px;
  height: 34px;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  color: var(--coffee);
  transition: background .15s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sc-ci-qty-btn:hover { background: var(--bg2); }
.sc-ci-qty-input {
  width: 44px !important;
  height: 34px !important;
  border: none !important;
  border-left: 1.5px solid var(--border) !important;
  border-right: 1.5px solid var(--border) !important;
  text-align: center;
  font-size: 14px !important;
  font-weight: 800;
  background: transparent;
  color: var(--coffee);
  -moz-appearance: textfield;
}
.sc-ci-qty-input::-webkit-outer-spin-button,
.sc-ci-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* Unit price + wholesale hint */
.sc-ci-unit-line {
  font-size: 13px;
  color: var(--text2);
  margin-bottom: 2px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 2px;
}
.sc-ci-unit-price {
  font-weight: 700;
  color: var(--caramel);
}
.sc-ci-wh-hint {
  color: var(--text3);
  font-weight: 600;
}
.sc-ci-wh-hint.active {
  color: var(--green);
  font-weight: 700;
}

.sc-ci-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
  flex-shrink: 0;
}
.sc-ci-price {
  font-family: var(--fd);
  font-size: 20px;
  font-weight: 700;
  color: var(--coffee);
  white-space: nowrap;
}
.sc-ci-del {
  background: none !important;
  border: 1.5px solid var(--border) !important;
  color: var(--text3) !important;
  border-radius: 6px !important;
  padding: 5px 12px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  font-family: var(--fb) !important;
  cursor: pointer;
  transition: .18s;
  text-decoration: none !important;
  display: inline-block !important;
}
.sc-ci-del:hover {
  background: var(--red) !important;
  border-color: var(--red) !important;
  color: #fff !important;
}

/* Cart actions row */
.sc-cart-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 8px;
  padding: 16px 0 0;
  border-top: 1px solid var(--border);
}
.sc-coupon-row {
  display: flex;
  gap: 8px;
  flex: 1;
}
.sc-coupon-input {
  flex: 1;
  padding: 10px 14px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r) !important;
  font-family: var(--fb) !important;
  font-size: 14px !important;
  background: var(--bg) !important;
  color: var(--coffee) !important;
}
.sc-coupon-btn,
.sc-update-btn {
  padding: 10px 18px !important;
  border: 1.5px solid var(--border2) !important;
  border-radius: var(--r) !important;
  background: var(--bg2) !important;
  color: var(--coffee) !important;
  font-family: var(--fb) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer;
  white-space: nowrap;
}
.sc-coupon-btn:hover,
.sc-update-btn:hover {
  background: var(--cream) !important;
}

/* Cart summary column */
.sc-cart-summary-col {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 24px;
  position: sticky;
  top: 90px;
}
@media (max-width: 900px) {
  .sc-cart-summary-col { position: static; }
}
.sc-cart-summary-col h3 {
  font-family: var(--fd);
  font-size: 20px;
  font-weight: 700;
  color: var(--coffee);
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1.5px solid var(--border);
}
.sc-sum-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.sc-sum-row:last-of-type { border-bottom: none; }
.sc-sum-label { color: var(--text2); font-weight: 600; }
.sc-sum-val { font-weight: 800; color: var(--coffee); }
.sc-sum-disc { color: var(--green) !important; }
.sc-delivery-badge {
  display: flex;
  align-items: center;
  gap: 7px;
  background: var(--green-bg);
  border: 1px solid rgba(37,107,40,.2);
  border-radius: 8px;
  padding: 10px 14px;
  margin: 14px 0;
  font-size: 13px;
  font-weight: 700;
  color: var(--green);
}
.sc-delivery-hint {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 14px;
  margin: 14px 0;
  font-size: 13px;
  color: var(--text2);
  font-weight: 600;
}
.sc-sum-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 0 4px !important;
  margin-top: 6px;
  border-top: 2px solid var(--border) !important;
  border-bottom: none !important;
}
.sc-sum-total .sc-sum-label {
  font-family: var(--fd);
  font-size: 18px;
  font-weight: 700;
  color: var(--coffee);
}
.sc-sum-total .sc-sum-val,
.sc-sum-total-price {
  font-family: var(--fd);
  font-size: 24px;
  font-weight: 800;
  color: var(--caramel);
}

/* Checkout button inside cart */
.woocommerce-cart .wc-proceed-to-checkout,
.sc-cart-summary-col .wc-proceed-to-checkout {
  padding: 0 !important;
  margin-top: 16px !important;
}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.sc-cart-summary-col .wc-proceed-to-checkout a.checkout-button {
  display: flex !important;
  width: 100% !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px !important;
  background: var(--orange) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--r) !important;
  font-family: var(--fb) !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  box-shadow: 0 4px 16px rgba(232,146,26,.4) !important;
  text-decoration: none !important;
  transition: .2s !important;
  gap: 8px;
}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover,
.sc-cart-summary-col .wc-proceed-to-checkout a.checkout-button:hover {
  background: var(--orange-h) !important;
  transform: translateY(-2px) !important;
}
/* Custom direct checkout button */
.sc-checkout-btn {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  padding: 16px;
  margin-top: 16px;
  background: var(--orange);
  color: #fff !important;
  border: none;
  border-radius: var(--r);
  font-family: var(--fb);
  font-size: 16px;
  font-weight: 900;
  box-shadow: 0 4px 16px rgba(232,146,26,.4);
  text-decoration: none !important;
  transition: .2s;
  box-sizing: border-box;
}
.sc-checkout-btn:hover {
  background: var(--orange-h);
  transform: translateY(-2px);
}

.sc-checkout-note {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text3);
  text-align: center;
  justify-content: center;
  margin-top: 10px;
}
.sc-continue-link {
  display: block;
  text-align: center;
  margin-top: 10px;
  font-size: 13px;
  font-weight: 700;
  color: var(--caramel);
  text-decoration: none;
}
.sc-continue-link:hover { color: var(--brown); text-decoration: underline; }

/* Mobile cart item */
@media (max-width: 600px) {
  .sc-ci {
    grid-template-columns: 80px 1fr;
    grid-template-rows: auto auto;
    gap: 12px 14px;
  }
  .sc-ci-img {
    grid-row: 1;
    grid-column: 1;
    width: 80px;
    height: 80px;
  }
  .sc-ci-info {
    grid-row: 1;
    grid-column: 2;
  }
  .sc-ci-right {
    grid-row: 2;
    grid-column: 1 / -1;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid var(--border);
    padding-top: 12px;
    margin-top: 4px;
  }
}

/* ══════════════════════════════════════════
   NOTICES — hide zone/geolocation on product page
══════════════════════════════════════════ */
.single-product .woocommerce-notices-wrapper .woocommerce-info {
  display: none !important;
}

/* ══════════════════════════════════════════
   RELATED PRODUCTS — mobile arrow slider
   Arrows sit in the heading row (no overflow issues)
══════════════════════════════════════════ */

/* Header row: h2 + arrow buttons */
.sc-rel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.sc-rel-header h2 {
  margin-bottom: 0 !important;
}
.sc-rel-nav {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}
.sc-rel-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: none;
  background: var(--orange, #E8921A);
  color: #fff;
  cursor: pointer;
  padding: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
  transition: opacity .2s, transform .12s;
  flex-shrink: 0;
}
.sc-rel-arrow:active { transform: scale(.88); }
.sc-rel-arrow[disabled] { opacity: .25; pointer-events: none; }

/* Hide related/upsells on mobile — desktop only */
@media (max-width: 768px) {
  .woocommerce .related.products,
  .woocommerce .upsells.products { display: none !important; }
}

/* Mobile carousel — 1 item at a time, driven by JS transform */
@media (max-width: 768px) {
  /* Clipping wrapper created by JS */
  .sc-carousel-wrap {
    overflow: hidden;
    width: 100%;
  }
  /* ul slides horizontally via transform */
  .sc-carousel-wrap ul.products {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow: visible !important;
    gap: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    transition: transform .35s cubic-bezier(.4,0,.2,1);
    will-change: transform;
  }
  /* Each card = full width of wrapper */
  .sc-carousel-wrap ul.products li.prod-card,
  .sc-carousel-wrap ul.products li.product {
    flex: 0 0 100% !important;
    width: 100% !important;
    min-width: 100% !important;
    margin: 0 !important;
    padding: 0 4px !important;
    box-sizing: border-box;
    scroll-snap-align: none !important;
  }
}

/* On desktop — hide arrows and reset header */
@media (min-width: 769px) {
  .sc-rel-arrow { display: none !important; }
  .sc-rel-nav   { display: none !important; }
  .sc-rel-header {
    display: block;
    margin-bottom: 0;
  }
  .sc-rel-header h2 {
    margin-bottom: 20px !important;
  }
}


/* ══════════════════════════════════════════════════════════
   WC BLOCKS — CART  (wp-block-woocommerce-cart)
   Стилізація блокового кошика під дизайн Smart Cafe
══════════════════════════════════════════════════════════ */

/* Wrapper / page */
.woocommerce-cart .entry-content,
.woocommerce-cart .page-content,
.woocommerce-cart .smartcafe-page-inner {
  padding: 0 !important;
}
.wp-block-woocommerce-cart {
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 32px 28px 60px !important;
  font-family: var(--fb) !important;
}
@media (max-width: 600px) {
  .wp-block-woocommerce-cart { padding: 20px 16px 48px !important; }
}

/* Two-column layout */
.wp-block-woocommerce-filled-cart-block {
  display: grid !important;
  grid-template-columns: 1fr 360px !important;
  gap: 28px !important;
  align-items: start !important;
}
@media (max-width: 900px) {
  .wp-block-woocommerce-filled-cart-block { grid-template-columns: 1fr !important; }
}

/* ── ITEMS COLUMN ── */
.wp-block-woocommerce-cart-items-block {
  min-width: 0;
}

/* Table → card rows */
.wc-block-cart-items {
  border: none !important;
  border-collapse: separate !important;
  border-spacing: 0 14px !important;
  width: 100% !important;
}
.wc-block-cart-items thead { display: none !important; }
.wc-block-cart-items__row {
  background: var(--card) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 14px !important;
  transition: border-color .2s !important;
}
.wc-block-cart-items__row:hover { border-color: rgba(200,120,32,.3) !important; }
.wc-block-cart-items__row td {
  border: none !important;
  vertical-align: middle !important;
  padding: 16px 10px !important;
}
.wc-block-cart-items__row td:first-child { padding-left: 18px !important; border-radius: 14px 0 0 14px !important; }
.wc-block-cart-items__row td:last-child  { padding-right: 18px !important; border-radius: 0 14px 14px 0 !important; }

/* Image cell */
.wc-block-cart-item__image {
  width: 90px !important;
}
.wc-block-cart-item__image img {
  width: 88px !important;
  height: 88px !important;
  object-fit: cover !important;
  border-radius: 10px !important;
  border: 1.5px solid var(--border) !important;
  display: block !important;
}

/* Product name + meta */
.wc-block-cart-item__product {
  padding-left: 6px !important;
}
.wc-block-cart-item__product-name,
.wc-block-cart-item__product a {
  font-family: var(--fd) !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  color: var(--coffee) !important;
  text-decoration: none !important;
  line-height: 1.3 !important;
  display: block !important;
  margin-bottom: 6px !important;
}
.wc-block-cart-item__product-name:hover,
.wc-block-cart-item__product a:hover { color: var(--caramel) !important; }

.wc-block-components-product-metadata {
  font-size: 12px !important;
  color: var(--text3) !important;
  margin-bottom: 4px !important;
}

/* Qty stepper */
.wc-block-components-quantity-stepper {
  display: inline-flex !important;
  align-items: center !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  width: auto !important;
  background: #fff !important;
}
.wc-block-components-quantity-stepper__minus,
.wc-block-components-quantity-stepper__plus {
  width: 34px !important;
  height: 34px !important;
  border: none !important;
  background: var(--bg2) !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--text2) !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background .15s !important;
  padding: 0 !important;
  flex-shrink: 0 !important;
}
.wc-block-components-quantity-stepper__minus:hover,
.wc-block-components-quantity-stepper__plus:hover { background: var(--cream) !important; }
.wc-block-components-quantity-stepper input,
.wc-block-components-quantity-stepper__input {
  width: 44px !important;
  height: 34px !important;
  border: none !important;
  border-left: 1.5px solid var(--border) !important;
  border-right: 1.5px solid var(--border) !important;
  text-align: center !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  font-family: var(--fb) !important;
  color: var(--coffee) !important;
  background: #fff !important;
}

/* Remove link */
.wc-block-cart-item__remove-link {
  display: inline-block !important;
  margin-top: 8px !important;
  padding: 4px 12px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 5px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--text3) !important;
  background: none !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: .18s !important;
  font-family: var(--fb) !important;
}
.wc-block-cart-item__remove-link:hover {
  background: var(--red) !important;
  border-color: var(--red) !important;
  color: #fff !important;
}

/* Price cell */
.wc-block-cart-item__total {
  text-align: right !important;
  white-space: nowrap !important;
}
.wc-block-cart-item__total .wc-block-components-product-price__value,
.wc-block-cart-item__total .woocommerce-Price-amount {
  font-family: var(--fd) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--coffee) !important;
}

/* ── TOTALS COLUMN (Summary sidebar) ── */
.wp-block-woocommerce-cart-totals-block {
  background: var(--card) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 14px !important;
  padding: 24px !important;
  position: sticky !important;
  top: 90px !important;
}
@media (max-width: 900px) {
  .wp-block-woocommerce-cart-totals-block { position: static !important; }
}

/* Summary heading */
.wp-block-woocommerce-cart-order-summary-heading-block .wc-block-cart__totals-title,
.wc-block-components-order-summary__toggle {
  font-family: var(--fd) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--coffee) !important;
  padding-bottom: 12px !important;
  border-bottom: 1.5px solid var(--border) !important;
  margin-bottom: 14px !important;
  display: block !important;
  width: 100% !important;
  background: none !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
  cursor: default !important;
  text-align: left !important;
}

/* Order summary items list inside sidebar */
.wc-block-components-order-summary__content {
  margin-bottom: 12px !important;
}
.wc-block-components-order-summary-item {
  display: flex !important;
  gap: 10px !important;
  padding: 8px 0 !important;
  border-bottom: 1px solid var(--border) !important;
  font-size: 13px !important;
}
.wc-block-components-order-summary-item__image img {
  width: 50px !important;
  height: 50px !important;
  object-fit: cover !important;
  border-radius: 6px !important;
  border: 1px solid var(--border) !important;
}
.wc-block-components-order-summary-item__description {
  flex: 1 !important;
  font-size: 13px !important;
  color: var(--text2) !important;
}
.wc-block-components-order-summary-item__quantity {
  color: var(--text3) !important;
  font-size: 12px !important;
}
.wc-block-components-order-summary-item__total-price {
  font-weight: 800 !important;
  color: var(--coffee) !important;
}

/* Totals rows */
.wc-block-components-totals-wrapper {
  border-top: 1px solid var(--border) !important;
  margin-top: 10px !important;
}
.wc-block-components-totals-item {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 8px 0 !important;
  font-size: 14px !important;
  border-bottom: 1px solid var(--border) !important;
}
.wc-block-components-totals-item:last-child { border-bottom: none !important; }
.wc-block-components-totals-item__label { color: var(--text2) !important; font-weight: 600 !important; }
.wc-block-components-totals-item__value { font-weight: 800 !important; color: var(--coffee) !important; }

/* Total footer (grand total) */
.wc-block-components-totals-footer-item {
  border-top: 2px solid var(--border) !important;
  border-bottom: none !important;
  padding-top: 14px !important;
  margin-top: 8px !important;
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
  font-family: var(--fd) !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--coffee) !important;
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value,
.wc-block-components-totals-footer-item .woocommerce-Price-amount {
  font-family: var(--fd) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--caramel) !important;
}

/* Coupon field */
.wc-block-components-totals-coupon__form {
  display: flex !important;
  gap: 8px !important;
}
.wc-block-components-totals-coupon__input input,
.wc-block-components-totals-coupon input[type="text"] {
  padding: 10px 14px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r) !important;
  font-family: var(--fb) !important;
  font-size: 14px !important;
  background: var(--bg) !important;
  color: var(--coffee) !important;
  flex: 1 !important;
}
.wc-block-components-totals-coupon__button {
  padding: 10px 16px !important;
  background: var(--bg2) !important;
  border: 1.5px solid var(--border2) !important;
  border-radius: var(--r) !important;
  font-family: var(--fb) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--coffee) !important;
  cursor: pointer !important;
  white-space: nowrap !important;
}
.wc-block-components-totals-coupon__button:hover { background: var(--cream) !important; }

/* Proceed to checkout button */
.wc-block-cart__submit-container,
.wp-block-woocommerce-proceed-to-checkout-block {
  margin-top: 16px !important;
}
.wc-block-cart__submit-button,
.wc-block-cart__submit,
.wp-block-woocommerce-proceed-to-checkout-block a,
.wp-block-woocommerce-proceed-to-checkout-block button {
  display: flex !important;
  width: 100% !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px 24px !important;
  background: var(--orange) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--r) !important;
  font-family: var(--fb) !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  cursor: pointer !important;
  text-decoration: none !important;
  text-align: center !important;
  box-shadow: 0 4px 16px rgba(232,146,26,.4) !important;
  transition: background .2s, transform .15s !important;
}
.wc-block-cart__submit-button:hover,
.wc-block-cart__submit:hover,
.wp-block-woocommerce-proceed-to-checkout-block a:hover,
.wp-block-woocommerce-proceed-to-checkout-block button:hover {
  background: var(--orange-h) !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
}

/* Accepted payment icons row */
.wc-block-cart__payment-method-icons { margin-top: 10px !important; }

/* Express payment block */
.wp-block-woocommerce-cart-express-payment-block {
  margin-bottom: 16px !important;
}

/* Continue shopping / cross-sells */
.wc-block-cart__continue-shopping { display: none !important; }


/* ══════════════════════════════════════════════════════════
   WC BLOCKS — CHECKOUT  (wp-block-woocommerce-checkout)
══════════════════════════════════════════════════════════ */

.woocommerce-checkout .entry-content,
.woocommerce-checkout .page-content,
.woocommerce-checkout .smartcafe-page-inner {
  padding: 0 !important;
}
.wp-block-woocommerce-checkout {
  max-width: 980px !important;
  margin: 0 auto !important;
  padding: 32px 28px 60px !important;
  font-family: var(--fb) !important;
}
@media (max-width: 600px) {
  .wp-block-woocommerce-checkout { padding: 20px 16px 48px !important; }
}

/* Page title */
.woocommerce-checkout .page-title,
.woocommerce-checkout h1.entry-title {
  font-family: var(--fd) !important;
  font-size: clamp(24px,4vw,34px) !important;
  font-weight: 700 !important;
  color: var(--coffee) !important;
  margin-bottom: 24px !important;
}

/* Form layout: left main + right sidebar */
.wc-block-checkout__form {
  display: grid !important;
  grid-template-columns: 1fr 340px !important;
  gap: 28px !important;
  align-items: start !important;
}
@media (max-width: 860px) {
  .wc-block-checkout__form { grid-template-columns: 1fr !important; }
}
.wc-block-checkout__main { min-width: 0; }
.wc-block-checkout__sidebar {
  position: sticky !important;
  top: 90px !important;
}
@media (max-width: 860px) {
  .wc-block-checkout__sidebar { position: static !important; order: -1 !important; }
}

/* Each checkout step = card section */
.wc-block-components-checkout-step {
  background: var(--card) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 14px !important;
  padding: 22px 24px !important;
  margin-bottom: 18px !important;
}

.wc-block-components-checkout-step__heading,
.wc-block-components-checkout-step__title {
  font-family: var(--fd) !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  color: var(--coffee) !important;
  padding-bottom: 14px !important;
  border-bottom: 1.5px solid var(--border) !important;
  margin-bottom: 18px !important;
  display: block !important;
}

.wc-block-components-checkout-step__heading-tag { display: none !important; }

/* Form inputs */
.wc-block-components-text-input input,
.wc-block-components-country-input input,
.wc-block-components-select select,
.wc-block-components-address-form input,
.wc-block-components-address-form select,
.wc-block-checkout .wc-block-components-text-input input,
.wp-block-woocommerce-checkout input[type="text"],
.wp-block-woocommerce-checkout input[type="email"],
.wp-block-woocommerce-checkout input[type="tel"],
.wp-block-woocommerce-checkout select,
.wp-block-woocommerce-checkout textarea {
  width: 100% !important;
  background: var(--bg) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 8px !important;
  padding: 11px 14px !important;
  font-family: var(--fb) !important;
  font-size: 15px !important;
  color: var(--coffee) !important;
  outline: none !important;
  transition: border-color .2s, box-shadow .2s !important;
}
.wc-block-components-text-input input:focus,
.wc-block-components-address-form input:focus,
.wc-block-components-address-form select:focus,
.wp-block-woocommerce-checkout input:focus,
.wp-block-woocommerce-checkout select:focus,
.wp-block-woocommerce-checkout textarea:focus {
  border-color: var(--caramel) !important;
  box-shadow: 0 0 0 3px rgba(200,120,32,.1) !important;
}

/* Labels */
.wc-block-components-text-input label,
.wc-block-components-address-form label,
.wc-block-components-checkout-step label {
  font-size: 12px !important;
  font-weight: 800 !important;
  color: var(--text2) !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  margin-bottom: 5px !important;
  display: block !important;
}

/* Shipping options */
.wc-block-components-shipping-rates-control__option,
.wc-block-components-radio-control__option {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 10px !important;
  padding: 13px 16px !important;
  margin-bottom: 10px !important;
  cursor: pointer !important;
  transition: border-color .2s, background .2s !important;
  background: var(--card) !important;
}
.wc-block-components-shipping-rates-control__option:hover,
.wc-block-components-radio-control__option:hover {
  border-color: var(--caramel) !important;
  background: rgba(200,120,32,.04) !important;
}
.wc-block-components-radio-control__option input[type="radio"] {
  accent-color: var(--caramel) !important;
  width: 18px !important;
  height: 18px !important;
  flex-shrink: 0 !important;
}
.wc-block-components-radio-control__option-layout {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
}
.wc-block-components-radio-control__option-label {
  font-size: 14px !important;
  font-weight: 800 !important;
  color: var(--coffee) !important;
}
.wc-block-components-radio-control__option-checked {
  border-color: var(--caramel) !important;
  background: rgba(200,120,32,.07) !important;
}

/* Payment methods */
.wc-block-components-payment-method-label {
  font-size: 14px !important;
  font-weight: 800 !important;
  color: var(--coffee) !important;
}
.wc-block-components-payment-methods {
  background: var(--bg2) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 10px !important;
  overflow: hidden !important;
}
.wc-block-components-payment-method-label__img {
  max-height: 28px !important;
}

/* Place order button */
.wc-block-components-checkout-place-order-button,
.wc-block-checkout__place-order button,
.wp-block-woocommerce-checkout-order-summary-block ~ * button,
.wc-block-checkout__actions button[type="submit"] {
  width: 100% !important;
  padding: 17px 24px !important;
  background: var(--orange) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--r) !important;
  font-family: var(--fb) !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  cursor: pointer !important;
  box-shadow: 0 4px 16px rgba(232,146,26,.4) !important;
  margin-top: 18px !important;
  transition: background .2s, transform .15s !important;
}
.wc-block-components-checkout-place-order-button:hover,
.wc-block-checkout__actions button[type="submit"]:hover {
  background: var(--orange-h) !important;
  transform: translateY(-1px) !important;
}

/* Checkout sidebar — order summary card */
.wp-block-woocommerce-checkout-order-summary-block {
  background: var(--card) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 14px !important;
  padding: 22px 24px !important;
  overflow: hidden !important;
}
.wp-block-woocommerce-checkout-order-summary-heading-block {
  font-family: var(--fd) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--coffee) !important;
  padding-bottom: 12px !important;
  border-bottom: 1.5px solid var(--border) !important;
  margin-bottom: 14px !important;
  display: block !important;
}

/* Sidebar totals */
.wp-block-woocommerce-checkout-order-summary-subtotal-block .wc-block-components-totals-item,
.wp-block-woocommerce-checkout-order-summary-shipping-block .wc-block-components-totals-item,
.wp-block-woocommerce-checkout-order-summary-taxes-block .wc-block-components-totals-item {
  font-size: 14px !important;
  padding: 7px 0 !important;
}
.wp-block-woocommerce-checkout-order-summary-totals-block .wc-block-components-totals-footer-item {
  border-top: 2px solid var(--border) !important;
  padding-top: 12px !important;
  margin-top: 6px !important;
}
.wp-block-woocommerce-checkout-order-summary-totals-block .wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
  font-family: var(--fd) !important;
  font-size: 18px !important;
  color: var(--coffee) !important;
  font-weight: 700 !important;
}
.wp-block-woocommerce-checkout-order-summary-totals-block .wc-block-components-totals-footer-item .woocommerce-Price-amount {
  font-family: var(--fd) !important;
  font-size: 22px !important;
  color: var(--caramel) !important;
  font-weight: 700 !important;
}

/* Notices / errors */
.wc-block-components-notice-banner,
.wc-block-store-notice {
  border-radius: 10px !important;
  border-left: 4px solid var(--caramel) !important;
  background: var(--bg2) !important;
  color: var(--coffee) !important;
  padding: 14px 18px !important;
  font-size: 14px !important;
  margin-bottom: 16px !important;
}
.wc-block-components-notice-banner.is-error { border-left-color: var(--red) !important; background: #fbeae9 !important; color: var(--red) !important; }
.wc-block-components-notice-banner.is-success { border-left-color: var(--green) !important; background: var(--green-bg) !important; color: var(--green) !important; }

/* Validation errors */
.wc-block-components-validation-error {
  color: var(--red) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  margin-top: 4px !important;
}
.wc-block-components-text-input.has-error input,
.wc-block-components-text-input.has-error input:focus {
  border-color: var(--red) !important;
  box-shadow: 0 0 0 3px rgba(192,40,26,.1) !important;
}

/* Checkbox (terms) */
.wc-block-checkout__terms .wc-block-components-checkbox label,
.wc-block-components-checkbox label {
  font-size: 13px !important;
  color: var(--text2) !important;
}
.wc-block-components-checkbox input[type="checkbox"] {
  accent-color: var(--caramel) !important;
}

/* Loading spinner colour */
.wc-block-cart.is-loading { opacity: .85 !important; }


/* ═══════════════════════════════════════════════════
   CHECKOUT PAGE — Smart Cafe
   ═══════════════════════════════════════════════════ */

/* Wrapper */
.sc-checkout-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 24px 16px 60px;
}

/* Order number badge */
.sc-checkout-order-badge {
  display: inline-block;
  background: #fff3e0;
  color: #e65100;
  border: 1.5px solid #ffcc80;
  border-radius: 20px;
  padding: 5px 18px;
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  margin-bottom: 24px;
}

/* Two-column grid */
.sc-checkout-columns {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 28px;
  align-items: start;
}

/* ─── Sections ─────────────────────── */
.sc-co-section {
  background: #fff;
  border: 1.5px solid #e8e8e8;
  border-radius: 16px;
  padding: 24px 28px;
  margin-bottom: 20px;
}

.sc-co-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: #1a1a1a;
  margin: 0 0 20px;
  padding-bottom: 12px;
  border-bottom: 1.5px solid #f0f0f0;
}

/* ─── Form grid ─────────────────────── */
.sc-co-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 16px;
}

.sc-co-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.sc-co-field--full {
  grid-column: 1 / -1;
}

.sc-co-field label {
  font-size: 0.8rem;
  font-weight: 600;
  color: #555;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.sc-req {
  color: #e53935;
}

.sc-co-field input[type="text"],
.sc-co-field input[type="tel"],
.sc-co-field input[type="email"] {
  border: 1.5px solid #ddd;
  border-radius: 10px;
  padding: 11px 14px;
  font-size: 0.95rem;
  color: #1a1a1a;
  background: #fafafa;
  transition: border-color 0.2s, box-shadow 0.2s;
  outline: none;
  width: 100%;
  box-sizing: border-box;
}

.sc-co-field input:focus {
  border-color: #ff6f00;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(255,111,0,0.1);
}

.sc-co-field input.sc-input-error {
  border-color: #e53935;
}

/* ─── Delivery cards ───────────────── */
.sc-delivery-cards {
  display: flex;
  gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.sc-delivery-card {
  flex: 1;
  min-width: 140px;
  display: flex;
  align-items: center;
  gap: 12px;
  border: 2px solid #e0e0e0;
  border-radius: 14px;
  padding: 14px 16px;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
  background: #fafafa;
  user-select: none;
}

.sc-delivery-card input[type="radio"] {
  display: none;
}

.sc-delivery-card--active,
.sc-delivery-card:has(input:checked) {
  border-color: #ff6f00;
  background: #fff8f0;
  box-shadow: 0 0 0 3px rgba(255,111,0,0.08);
}

.sc-delivery-icon {
  font-size: 1.6rem;
  line-height: 1;
}

.sc-delivery-label {
  font-size: 0.88rem;
  color: #333;
  line-height: 1.4;
}

.sc-delivery-label strong {
  display: block;
  color: #1a1a1a;
}

/* Nova Poshta autocomplete fields */
.sc-np-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 16px;
}

.sc-autocomplete-wrap {
  position: relative;
}

.sc-autocomplete-list {
  position: absolute;
  top: calc(100% + 4px);
  left: 0; right: 0;
  background: #fff;
  border: 1.5px solid #ddd;
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.12);
  max-height: 220px;
  overflow-y: auto;
  z-index: 9999;
}

.sc-autocomplete-list div {
  padding: 10px 14px;
  font-size: 0.9rem;
  cursor: pointer;
  border-bottom: 1px solid #f0f0f0;
  transition: background 0.15s;
}

.sc-autocomplete-list div:last-child {
  border-bottom: none;
}

.sc-autocomplete-list div:hover,
.sc-autocomplete-list div.sc-ac-active {
  background: #fff3e0;
  color: #e65100;
}

.sc-autocomplete-list .sc-ac-loading,
.sc-autocomplete-list .sc-ac-empty {
  color: #888;
  font-style: italic;
  cursor: default;
}

.sc-autocomplete-list .sc-ac-loading:hover,
.sc-autocomplete-list .sc-ac-empty:hover {
  background: transparent;
  color: #888;
}

/* ─── Payment cards ────────────────── */
.sc-payment-cards {
  display: flex;
  gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.sc-payment-card {
  flex: 1;
  min-width: 130px;
  display: flex;
  align-items: center;
  gap: 12px;
  border: 2px solid #e0e0e0;
  border-radius: 14px;
  padding: 14px 16px;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
  background: #fafafa;
  user-select: none;
}

.sc-payment-card input[type="radio"] {
  display: none;
}

.sc-payment-card--active,
.sc-payment-card:has(input:checked) {
  border-color: #ff6f00;
  background: #fff8f0;
  box-shadow: 0 0 0 3px rgba(255,111,0,0.08);
}

.sc-pay-icon {
  font-size: 1.5rem;
  line-height: 1;
}

.sc-pay-label {
  font-size: 0.88rem;
  color: #333;
  line-height: 1.4;
}

.sc-pay-label strong {
  display: block;
  color: #1a1a1a;
}

/* Invoice fields */
.sc-invoice-fields {
  margin-top: 4px;
  padding: 16px;
  background: #f9f9f9;
  border-radius: 12px;
  border: 1.5px dashed #ccc;
}

/* Payment note */
.sc-payment-note {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: #777;
  margin-top: 14px;
}

.sc-pay-note-icon {
  font-size: 1rem;
}

/* ─── Right sidebar ─────────────────── */
.sc-order-summary {
  background: #fff;
  border: 1.5px solid #e8e8e8;
  border-radius: 16px;
  padding: 24px;
  position: sticky;
  top: 24px;
}

.sc-os-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: #1a1a1a;
  margin: 0 0 18px;
  padding-bottom: 12px;
  border-bottom: 1.5px solid #f0f0f0;
}

.sc-os-items {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 16px;
  max-height: 300px;
  overflow-y: auto;
}

.sc-os-item {
  display: flex;
  align-items: center;
  gap: 12px;
}

.sc-os-item-img {
  position: relative;
  flex-shrink: 0;
}

.sc-os-item-img img {
  width: 52px;
  height: 52px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid #eee;
}

.sc-os-qty-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  background: #ff6f00;
  color: #fff;
  font-size: 0.7rem;
  font-weight: 700;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.sc-os-item-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.sc-os-item-name {
  font-size: 0.82rem;
  font-weight: 600;
  color: #1a1a1a;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sc-os-item-price {
  font-size: 0.82rem;
  color: #ff6f00;
  font-weight: 700;
}

.sc-os-divider {
  height: 1px;
  background: #f0f0f0;
  margin: 4px 0 14px;
}

.sc-os-totals {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 20px;
}

.sc-os-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.9rem;
  color: #555;
}

.sc-os-row--total {
  font-size: 1.05rem;
  font-weight: 700;
  color: #1a1a1a;
  padding-top: 10px;
  border-top: 1.5px solid #f0f0f0;
}

.sc-os-row em {
  font-style: italic;
  color: #888;
  font-size: 0.82rem;
}

/* Confirm button */
.sc-place-order-btn {
  display: block;
  width: 100%;
  padding: 15px;
  background: linear-gradient(135deg, #ff8c00, #ff6f00);
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  text-align: center;
  letter-spacing: 0.02em;
  transition: transform 0.15s, box-shadow 0.15s, opacity 0.2s;
  box-shadow: 0 4px 16px rgba(255,111,0,0.35);
  margin-bottom: 10px;
}

.sc-place-order-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(255,111,0,0.45);
}

.sc-place-order-btn:active {
  transform: translateY(0);
}

.sc-place-order-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

/* Invoice download button */
.sc-download-invoice-btn {
  display: block;
  width: 100%;
  padding: 12px;
  background: #fff;
  color: #ff6f00;
  font-size: 0.92rem;
  font-weight: 700;
  border: 2px solid #ff6f00;
  border-radius: 12px;
  cursor: pointer;
  text-align: center;
  transition: background 0.2s;
  margin-bottom: 10px;
}

.sc-download-invoice-btn:hover {
  background: #fff8f0;
}

/* Back to cart */
.sc-back-to-cart {
  display: block;
  text-align: center;
  color: #888;
  font-size: 0.85rem;
  text-decoration: none;
  margin-top: 6px;
  transition: color 0.2s;
}

.sc-back-to-cart:hover {
  color: #ff6f00;
}

/* WC notices on checkout */
.sc-checkout-wrap .woocommerce-error,
.sc-checkout-wrap .woocommerce-message,
.sc-checkout-wrap .woocommerce-info {
  border-radius: 10px;
  margin-bottom: 20px;
}

/* ─── Mobile ─────────────────────────────────────── */
@media (max-width: 860px) {
  .sc-checkout-columns {
    grid-template-columns: 1fr;
  }

  .sc-checkout-right {
    order: -1; /* show summary above form on mobile */
  }

  .sc-order-summary {
    position: static;
  }

  .sc-np-fields {
    grid-template-columns: 1fr;
  }

  .sc-co-grid {
    grid-template-columns: 1fr;
  }

  .sc-co-field--full {
    grid-column: 1;
  }

  .sc-delivery-card,
  .sc-payment-card {
    min-width: 0;
    flex: 1 1 calc(50% - 6px);
  }

  .sc-os-items {
    max-height: 200px;
  }
}

@media (max-width: 480px) {
  .sc-co-section {
    padding: 18px 16px;
  }

  .sc-delivery-cards,
  .sc-payment-cards {
    flex-direction: column;
  }

  .sc-delivery-card,
  .sc-payment-card {
    flex: none;
  }
}
