/* ==========================================================================
   H'line Dubai — woocommerce.css
   Brand styling for WooCommerce: archive controls, buttons, notices,
   single product, cart, checkout. Uses the theme design tokens.
   ========================================================================== */

.wc-main { min-height: 40vh; }

/* ---------- Buttons ---------- */
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce .button,
.woocommerce #place_order, .woocommerce button.button.alt {
  background: var(--color-accent); color: #fff;
  border-radius: var(--radius); padding: 14px 28px;
  font-size: 13px; letter-spacing: .12em; text-transform: uppercase; font-weight: 500;
  border: 1px solid transparent; transition: background var(--transition);
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce .button:hover, .woocommerce #place_order:hover, .woocommerce button.button.alt:hover {
  background: var(--color-accent-dk); color: #fff;
}
.woocommerce .button.added::after { display: none; }
.woocommerce a.added_to_cart { color: var(--color-accent); border-bottom: 1px solid currentColor; }

/* ---------- Prices ---------- */
.woocommerce .price, .woocommerce .price .amount, .woocommerce ins .amount { color: var(--color-price); font-weight: 500; text-decoration: none; }
.woocommerce del { color: var(--color-muted); opacity: .8; }

/* ---------- Form fields ---------- */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce .select2-container--default .select2-selection--single,
.woocommerce select, .woocommerce input[type="text"], .woocommerce input[type="email"],
.woocommerce input[type="tel"], .woocommerce input[type="password"], .woocommerce input[type="number"] {
  border: 1px solid var(--color-line-dk); border-radius: var(--radius);
  padding: 12px 14px; font-size: 14px; background: #fff; line-height: 1.4;
}
.woocommerce form .form-row label { font-size: 12px; letter-spacing: .06em; text-transform: uppercase; color: var(--color-ink-soft); }

/* ---------- Archive controls ---------- */
.woocommerce .woocommerce-result-count { font-size: 13px; color: var(--color-muted); margin: 0; }
.woocommerce .woocommerce-ordering select, .woocommerce-ordering .orderby {
  border: 1px solid var(--color-line-dk); padding: 9px 14px; font-size: 13px; background: #fff;
}
.woocommerce-ordering { margin: 0; }

/* pagination (matches the static .pagination) */
.woocommerce nav.woocommerce-pagination { margin-block-start: 48px; text-align: center; border: 0; }
.woocommerce nav.woocommerce-pagination ul { display: inline-flex; gap: 8px; border: 0; }
.woocommerce nav.woocommerce-pagination ul li { border: 0; margin: 0; }
.woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span {
  min-width: 38px; height: 38px; display: grid; place-items: center;
  border: 1px solid var(--color-line); font-size: 14px; padding: 0;
}
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--color-ink); color: #fff; border-color: var(--color-ink); }

/* ---------- Notices ---------- */
.woocommerce-message, .woocommerce-info, .woocommerce-error, .woocommerce-noreviews {
  border-top-color: var(--color-accent); background: var(--color-surface);
  font-size: 14px; border-radius: var(--radius);
}
.woocommerce-message::before, .woocommerce-info::before { color: var(--color-accent); }

/* ---------- Single product ---------- */
.woocommerce div.product { display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px; align-items: start; }
.woocommerce div.product .woocommerce-product-gallery { float: none; width: auto; }
.woocommerce div.product .summary { margin: 0; }
.woocommerce div.product .product_title { font-family: var(--font-serif); font-size: clamp(24px, 3vw, 34px); margin-block: 6px 12px; }
.woocommerce div.product p.price, .woocommerce div.product span.price { font-size: 22px; margin-block-end: 16px; }
.woocommerce div.product .woocommerce-product-details__short-description { color: var(--color-ink-soft); font-size: 14px; line-height: 1.8; }
.woocommerce div.product form.cart { margin-block: 22px; display: flex; gap: 12px; align-items: stretch; flex-wrap: wrap; }
.woocommerce div.product form.cart .quantity .qty { width: 70px; height: 100%; min-height: 50px; text-align: center; border: 1px solid var(--color-line-dk); }
.woocommerce div.product form.cart .button { flex: 1; min-width: 200px; }
.woocommerce .product_meta { font-size: 13px; color: var(--color-muted); margin-block-start: 18px; }
.woocommerce .product_meta > span { display: block; margin-block-end: 4px; }

/* tabs */
.woocommerce div.product .woocommerce-tabs { grid-column: 1 / -1; margin-block-start: 16px; }
.woocommerce div.product .woocommerce-tabs ul.tabs { border: 0; padding: 0; display: flex; gap: 4px; flex-wrap: wrap; border-block-end: 1px solid var(--color-line); }
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li { background: transparent; border: 0; border-radius: 0; margin: 0; padding: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li::before, .woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a { padding: 12px 18px; color: var(--color-muted); font-size: 13px; letter-spacing: .06em; text-transform: uppercase; border-block-end: 2px solid transparent; margin-block-end: -1px; display: block; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--color-ink); border-block-end-color: var(--color-ink); }
.woocommerce div.product .woocommerce-tabs .panel { padding-block: 22px; color: var(--color-ink-soft); line-height: 1.8; font-size: 14px; }
.woocommerce div.product .woocommerce-tabs h2 { font-family: var(--font-serif); font-size: 22px; }

/* related */
.woocommerce .related.products, .woocommerce .up-sells { grid-column: 1 / -1; margin-block-start: 12px; }
.woocommerce .related.products > h2, .woocommerce .up-sells > h2, .woocommerce .cross-sells > h2 {
  font-family: var(--font-serif); font-size: clamp(22px, 3vw, 30px); margin-block-end: 22px;
}
.woocommerce .related.products h2::before, .cross-sells h2::before { content: "\2756"; color: var(--color-gold); font-size: .5em; vertical-align: middle; margin-inline-end: .5em; }

/* ---------- Cart ---------- */
.woocommerce table.shop_table { border: 1px solid var(--color-line); border-radius: var(--radius); }
.woocommerce table.shop_table th { font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--color-ink-soft); }
.woocommerce .cart_totals h2, .woocommerce-checkout h3 { font-family: var(--font-serif); font-size: 22px; }
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button { font-size: 14px; }
.woocommerce a.remove { color: var(--color-sale) !important; border-color: var(--color-sale); }
.woocommerce a.remove:hover { background: var(--color-sale) !important; color: #fff !important; }

/* ---------- Checkout ---------- */
.woocommerce-checkout #payment { background: var(--color-surface); border-radius: var(--radius); }
.woocommerce-checkout #payment div.payment_box { background: #fff; }
.woocommerce-checkout #payment ul.payment_methods { border-block-end: 1px solid var(--color-line); }
.woocommerce form .form-row.woocommerce-invalid input.input-text { border-color: var(--color-sale); }

/* ---------- My Account dashboard ---------- */
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) {
  display: grid; grid-template-columns: 240px 1fr; gap: 40px; align-items: start;
}
.woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; border: 1px solid var(--color-line); }
.woocommerce-MyAccount-navigation li { border-block-end: 1px solid var(--color-line); }
.woocommerce-MyAccount-navigation li:last-child { border-block-end: 0; }
.woocommerce-MyAccount-navigation li a { display: block; padding: 13px 18px; font-size: 14px; letter-spacing: .02em; }
.woocommerce-MyAccount-navigation li.is-active a { color: var(--color-accent); font-weight: 600; background: var(--color-surface); border-inline-start: 2px solid var(--color-gold); }
.woocommerce-MyAccount-content { min-height: 320px; font-size: 14.5px; line-height: 1.8; }
.woocommerce-MyAccount-content a { color: var(--color-accent); }
.auth { max-width: 460px; margin-inline: auto; }

/* ---------- Order received / thank you ---------- */
.woocommerce-order { max-width: 760px; margin-inline: auto; }
.woocommerce-thankyou-order-received {
  font-family: var(--font-serif); font-size: clamp(24px, 3vw, 34px); color: var(--color-accent);
  text-align: center; margin-block-end: 24px;
}
.woocommerce-thankyou-order-received::before { content: "\2756 "; color: var(--color-gold); }
.woocommerce ul.order_details { display: flex; flex-wrap: wrap; gap: 0; border: 1px solid var(--color-line); padding: 0; margin: 0 0 32px; list-style: none; }
.woocommerce ul.order_details li { flex: 1 1 auto; border: 0; border-inline-end: 1px solid var(--color-line); padding: 16px 20px; font-size: 12px; letter-spacing: .06em; text-transform: uppercase; color: var(--color-muted); }
.woocommerce ul.order_details li strong { display: block; font-size: 16px; color: var(--color-ink); text-transform: none; letter-spacing: 0; margin-block-start: 6px; }

/* ---------- Cart / Checkout / Account page layout ---------- */
.woocommerce-cart .page-content, .woocommerce-account .page-content { max-width: 1100px; margin-inline: auto; }
.woocommerce-checkout .page-content { max-width: 1140px; margin-inline: auto; }
.woocommerce-cart-form { overflow-x: auto; }
.woocommerce table.shop_table { width: 100%; }
.woocommerce .cart-collaterals { width: 100%; display: flex; justify-content: flex-end; margin-block-start: 28px; }
.woocommerce .cart-collaterals .cart_totals { float: none; width: 100%; max-width: 420px; }
.woocommerce .cart_totals .checkout-button { display: block; text-align: center; }
.woocommerce .wc-proceed-to-checkout a.checkout-button { background: var(--color-accent); color: #fff; }
.woocommerce .wc-proceed-to-checkout a.checkout-button:hover { background: var(--color-accent-dk); }

@media (min-width: 861px) {
  .woocommerce-checkout form.checkout { display: grid; grid-template-columns: 1fr 400px; gap: 0 40px; align-items: start; }
  .woocommerce-checkout #customer_details { grid-column: 1; grid-row: 1 / span 2; float: none; width: auto; }
  .woocommerce-checkout #order_review_heading { grid-column: 2; grid-row: 1; margin-block: 0 16px; }
  .woocommerce-checkout #order_review { grid-column: 2; grid-row: 2; }
  .woocommerce-checkout .col2-set .col-1, .woocommerce-checkout .col2-set .col-2 { float: none; width: auto; }
}
.woocommerce-checkout #order_review { border: 1px solid var(--color-line); padding: 22px; border-radius: var(--radius); }
.woocommerce form .form-row { margin-block-end: 14px; }

/* Force proper (non-stacked) WooCommerce tables on desktop */
.woocommerce table.shop_table { table-layout: auto; }
.woocommerce table.shop_table img { width: 70px; height: auto; }
@media (min-width: 769px) {
  .woocommerce table.shop_table_responsive thead,
  .woocommerce-page table.shop_table_responsive thead { display: table-header-group !important; }
  .woocommerce table.shop_table_responsive tbody,
  .woocommerce-page table.shop_table_responsive tbody { display: table-row-group !important; }
  .woocommerce table.shop_table_responsive tbody th { display: table-cell !important; }
  .woocommerce table.shop_table_responsive tr,
  .woocommerce-page table.shop_table_responsive tr { display: table-row !important; }
  .woocommerce table.shop_table_responsive td,
  .woocommerce-page table.shop_table_responsive td { display: table-cell !important; text-align: start; }
  .woocommerce table.shop_table_responsive td::before,
  .woocommerce-page table.shop_table_responsive td::before { display: none !important; content: "" !important; }
}

/* ---------- Responsive ---------- */
@media (max-width: 1024px) { .woocommerce div.product { grid-template-columns: 1fr; gap: 32px; } }
@media (max-width: 860px) {
  .woocommerce .col2-set, .woocommerce-page .col2-set { width: 100%; float: none; }
  .woocommerce div.product form.cart .button { min-width: 100%; }
  .woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) { grid-template-columns: 1fr; }
  .woocommerce ul.order_details { flex-direction: column; }
  .woocommerce ul.order_details li { border-inline-end: 0; border-block-end: 1px solid var(--color-line); }
}
