/* ============================================================
   Brightly — WooCommerce overrides
   Restyles shop / cart / checkout to match the design system.
   Loads AFTER WooCommerce's own styles (depends on woocommerce-general).
   ============================================================ */

/* Buttons */
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce .button.alt, .wc-block-components-button {
  display: inline-flex; align-items: center; justify-content: center;
  box-sizing: border-box; vertical-align: middle;
  background: var(--color-ink) !important; color: var(--color-on-dark) !important;
  border: 1px solid var(--color-ink) !important; border-radius: var(--radius-pill) !important;
  min-height: var(--control-h); height: auto !important; padding: 14px 28px !important;
  font-family: var(--font-sans) !important; font-weight: var(--fw-medium) !important;
  font-size: 16px !important; line-height: 1.12 !important; letter-spacing: -0.01em !important;
  text-align: center !important; white-space: normal !important; overflow-wrap: anywhere;
  box-shadow: var(--shadow-sm) !important; text-transform: none !important;
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease) !important;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce .button.alt:hover, .wc-block-components-button:hover {
  transform: translateY(-2px); box-shadow: var(--shadow-md) !important;
}
.woocommerce a.button:focus-visible, .woocommerce button.button:focus-visible, .woocommerce input.button:focus-visible,
.woocommerce .button.alt:focus-visible, .wc-block-components-button:focus-visible {
  outline: 2px solid var(--color-accent-deep) !important;
  outline-offset: 2px;
}
.woocommerce a.button.disabled, .woocommerce button.button:disabled, .woocommerce button.button:disabled[disabled],
.woocommerce input.button:disabled, .woocommerce input.button:disabled[disabled] {
  opacity: 0.48 !important; cursor: not-allowed; transform: none;
}
.woocommerce a.button.wc-backward,
.woocommerce .button:not(.alt):not(.single_add_to_cart_button) {
  background: var(--color-surface) !important; color: var(--color-ink) !important;
  border: 1px solid var(--color-ink) !important;
}
.woocommerce ul.products li.product .button {
  background: var(--color-ink) !important; color: var(--color-on-dark) !important;
  border-color: var(--color-ink) !important;
}
.woocommerce #place_order, .woocommerce .checkout-button.button.alt {
  width: 100%; font-size: 18px !important; letter-spacing: -0.01em !important; padding: 16px 24px !important;
}

/* Product cards */
.woocommerce ul.products { gap: 26px; }
.woocommerce ul.products li.product {
  background: var(--color-surface); border: 1px solid var(--color-border-faint);
  border-radius: var(--radius-card); box-shadow: var(--shadow-sm); padding: 14px;
  transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease);
}
.woocommerce ul.products li.product:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.woocommerce ul.products li.product a img {
  border-radius: 12px; margin-bottom: 14px; aspect-ratio: 1 / 1; object-fit: cover; background: var(--color-page-soft);
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-sans); font-size: 1.05rem; font-weight: var(--fw-semibold);
  color: var(--color-ink); padding: 0 4px; overflow-wrap: anywhere;
}
.woocommerce ul.products li.product .price { padding: 0 4px; }
.woocommerce ul.products li.product .button { margin-top: 12px; width: 100%; }
.woocommerce span.onsale {
  background: var(--color-accent) !important; color: var(--color-ink) !important;
  border-radius: var(--radius-pill) !important; padding: 5px 10px !important;
  font-family: var(--font-sans); font-size: 12px; font-weight: var(--fw-light);
  letter-spacing: -0.24px; min-height: 0; min-width: 0; line-height: 1.2;
}

/* Cart */
.woocommerce-cart .cart_totals, .woocommerce table.shop_table {
  background: var(--color-surface);
  border: 1px solid var(--color-border-soft); border-radius: var(--radius-card); border-collapse: separate;
  box-shadow: var(--shadow-sm); overflow: hidden;
}
.woocommerce table.shop_table th, .woocommerce table.shop_table td {
  border-top-color: var(--color-border-faint); font-family: var(--font-sans);
  font-weight: var(--fw-light); color: var(--color-ink);
}
.woocommerce .quantity .qty, .woocommerce .coupon .input-text {
  height: var(--control-h); border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-box); background: var(--color-surface);
  font-family: var(--font-sans); font-size: 16px; color: var(--color-ink); padding: 0 16px; text-align: center;
}
.woocommerce-cart table.cart td.actions .coupon { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.woocommerce-cart table.cart td.actions .coupon .input-text { min-width: min(260px, 100%); }
.woocommerce-cart .cart-collaterals .cart_totals {
  padding: clamp(18px, 3vw, 28px);
}
.woocommerce-cart .cart-collaterals .cart_totals h2 { font-size: 1.35rem; margin-top: 0; }

/* Checkout */
.woocommerce-checkout #order_review, .woocommerce-checkout #payment {
  background: var(--color-surface); border: 1px solid var(--color-border-soft); border-radius: var(--radius-card);
  box-shadow: var(--shadow-sm); overflow: hidden;
}
.woocommerce form .form-row label, .woocommerce-checkout label {
  font-family: var(--font-sans); font-size: 14px; font-weight: var(--fw-medium);
  letter-spacing: -0.28px; color: var(--color-ink);
}
.woocommerce-checkout h3 {
  font-family: var(--font-sans); font-size: 24px; font-weight: var(--fw-medium); color: var(--color-ink-pure);
}

/* Inputs / selects */
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea,
.woocommerce-checkout input[type="text"], .woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"], .woocommerce form .form-row select,
.woocommerce .select2-container--default .select2-selection--single {
  min-height: var(--control-h); background: var(--color-surface);
  border: 1px solid var(--color-border-soft) !important; border-radius: var(--radius-box) !important;
  padding: 0 16px; font-family: var(--font-sans); font-weight: var(--fw-light);
  font-size: 16px; color: var(--color-ink); box-shadow: none;
}
.woocommerce form .form-row input.input-text::placeholder { color: rgba(18,18,18,0.45); }
.woocommerce form .form-row input.input-text:focus, .woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus,
.woocommerce .select2-container--default.select2-container--focus .select2-selection--single {
  outline: none; border-color: var(--color-accent-deep) !important; box-shadow: 0 0 0 3px var(--color-accent-soft) !important;
}

/* Radios / checkboxes */
.woocommerce input[type="radio"] {
  width: 18px; height: 18px; border: 1px solid var(--color-control);
  border-radius: var(--radius-pill); accent-color: var(--color-ink);
}
.woocommerce input[type="checkbox"] {
  width: 18px; height: 18px; border: 1px solid var(--color-control);
  border-radius: var(--radius-box); accent-color: var(--color-ink);
}

/* Payment method rows → option-row pattern */
.woocommerce-checkout #payment ul.payment_methods li {
  border: 1px solid var(--color-border-faint); border-radius: var(--radius-box);
  padding: 14px 16px; min-height: var(--row-h); display: flex; align-items: center; flex-wrap: wrap;
  gap: 8px 10px; margin: 0 0 10px;
}

/* Notices */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  border-radius: var(--radius-box); border-top: none;
  font-family: var(--font-sans); font-weight: var(--fw-light);
}
.woocommerce-message { border-left: 3px solid var(--color-accent); background: var(--color-page); }

/* Constrain Woo page content (shop / product / cart / checkout / account).
   The homepage stays full-bleed; these pages get a centered column. */
body.woocommerce-page .site-content,
body.woocommerce-cart .site-content,
body.woocommerce-checkout .site-content {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(28px, 5vw, 56px) var(--inset-x) var(--space-section);
}
.woocommerce-products-header { margin-bottom: 28px; }
.woocommerce-breadcrumb {
  color: var(--color-ink-muted); font-size: 0.95rem; margin: 0 0 12px;
}
.woocommerce-products-header__title.page-title,
.woocommerce div.product .product_title {
  font-size: clamp(1.9rem, 3.6vw, 2.6rem); font-weight: var(--fw-semibold); letter-spacing: -0.03em;
}
body.post-type-archive-product .woocommerce-products-header {
  padding: clamp(18px, 3vw, 28px) 0 clamp(12px, 2vw, 18px);
  border-bottom: 1px solid var(--color-border-hair);
}
body.post-type-archive-product .woocommerce-result-count {
  color: var(--color-ink-muted); margin: 0 0 22px;
}
body.post-type-archive-product .woocommerce-ordering {
  margin: 0 0 22px;
}
body.post-type-archive-product .woocommerce-ordering select {
  min-height: 44px; padding: 0 42px 0 14px;
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-pill);
  background: var(--color-surface);
  color: var(--color-ink);
  font-family: var(--font-sans); font-size: 0.95rem;
  box-shadow: none;
}

/* Single product layout */
.woocommerce div.product {
  display: grid; grid-template-columns: minmax(420px, 1.08fr) minmax(360px, 0.92fr);
  gap: clamp(42px, 7vw, 92px); align-items: start;
}
.woocommerce div.product div.images,
.woocommerce-page div.product div.images,
.woocommerce div.product div.summary,
.woocommerce-page div.product div.summary {
  float: none; width: 100%; clear: none; margin: 0;
}
.woocommerce div.product .woocommerce-product-gallery {
  margin-bottom: 0; max-width: 560px;
}
.woocommerce div.product .woocommerce-product-gallery__wrapper {
  margin: 0; background: var(--color-page-soft); border-radius: var(--radius-card);
}
.woocommerce div.product .woocommerce-product-gallery img {
  width: 100%; border-radius: var(--radius-card); box-shadow: none; aspect-ratio: 1 / 1; object-fit: cover;
}
.woocommerce div.product .summary {
  padding-top: clamp(8px, 2vw, 22px); max-width: 520px;
}
.woocommerce div.product .product_title {
  max-width: none; margin-bottom: 18px; font-size: clamp(2.35rem, 4vw, 3.55rem); line-height: 1.02;
}
.woocommerce div.product p.price, .woocommerce div.product span.price {
  font-size: clamp(1.45rem, 2vw, 1.8rem); font-weight: var(--fw-regular); color: var(--color-ink);
  margin: 0 0 22px;
}
.woocommerce div.product .woocommerce-product-details__short-description {
  max-width: 42ch; margin: 0 0 22px; font-size: 1.08rem; line-height: 1.62; color: var(--color-ink);
}
.woocommerce div.product .woocommerce-product-details__short-description p { margin: 0; }
.woocommerce div.product .woocommerce-tabs {
  grid-column: 1 / -1; margin-top: clamp(24px, 4vw, 44px);
}
/* Related/up-sell product rows must span the full width (not be crammed into one
   grid column), so the cards are full size and their buttons don't wrap. */
.woocommerce div.product .related.products,
.woocommerce div.product .upsells.products {
  grid-column: 1 / -1; margin-top: clamp(32px, 5vw, 64px); clear: both;
}
.woocommerce div.product .related.products > h2,
.woocommerce div.product .upsells.products > h2 { margin-bottom: 28px; }
/* Loop add-to-cart buttons stay on one line. */
.woocommerce ul.products li.product .button { white-space: nowrap !important; padding-left: 18px !important; padding-right: 18px !important; }
.woocommerce div.product form.cart {
  display: flex; gap: 14px; align-items: stretch; flex-wrap: wrap; margin: 26px 0 0;
}
.woocommerce div.product form.cart .quantity { margin: 0; display: flex; }
.woocommerce div.product form.cart .quantity .qty { min-width: 64px; height: auto; }
.woocommerce div.product form.cart .button { min-width: 180px; }
.woocommerce div.product .product_meta {
  color: var(--color-ink-muted); font-size: 0.9rem; border-top: 1px solid var(--color-border-faint);
  margin-top: 34px; padding-top: 18px; line-height: 1.7;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  border-bottom: 1px solid var(--color-border-faint); padding: 0; margin: 0 0 28px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.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 {
  background: transparent; border: 0; border-radius: 0; padding: 0; margin: 0 24px 0 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a { padding: 0 0 12px; font-weight: var(--fw-medium); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--color-accent-deep); box-shadow: inset 0 -2px 0 var(--color-accent);
}
.woocommerce div.product .woocommerce-Tabs-panel {
  max-width: 860px; font-size: 1.04rem; line-height: 1.72;
}
.woocommerce div.product .woocommerce-Tabs-panel h2 {
  font-size: clamp(1.5rem, 2vw, 1.9rem); margin: 0 0 14px;
}
@media (max-width: 800px) {
  .woocommerce div.product { grid-template-columns: 1fr; gap: 32px; }
  .woocommerce div.product .woocommerce-product-gallery,
  .woocommerce div.product .summary { max-width: none; }
  .woocommerce div.product .product_title { max-width: none; font-size: clamp(2rem, 9vw, 2.8rem); }
  .woocommerce div.product .woocommerce-tabs { margin-top: 16px; }
}

/* Checkout layout */
.woocommerce-checkout form.checkout {
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(320px, 0.82fr);
  gap: clamp(24px, 4vw, 48px); align-items: start;
}
.woocommerce-checkout #customer_details,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review { float: none; width: 100%; }
.woocommerce-checkout #customer_details { grid-column: 1; }
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review { grid-column: 2; }
.woocommerce-checkout #order_review_heading { margin: 0 0 14px; }
.woocommerce .col2-set .col-1, .woocommerce-page .col2-set .col-1,
.woocommerce .col2-set .col-2, .woocommerce-page .col2-set .col-2 {
  float: none; width: 100%;
}

/* My Account */
body.woocommerce-account.logged-in .woocommerce {
  display: grid; grid-template-columns: 240px minmax(0, 1fr);
  gap: clamp(24px, 4vw, 44px); align-items: start;
}
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content {
  float: none; width: auto;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none; margin: 0; padding: 8px;
  background: var(--color-surface); border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-card); box-shadow: var(--shadow-sm);
}
.woocommerce-account .woocommerce-MyAccount-navigation li a {
  display: block; padding: 11px 12px; border-radius: var(--radius-box);
  color: var(--color-ink-muted); font-weight: var(--fw-medium);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover {
  background: var(--color-accent-soft); color: var(--color-ink);
}
.woocommerce-account .woocommerce-MyAccount-content {
  background: var(--color-surface); border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-card); box-shadow: var(--shadow-sm);
  padding: clamp(22px, 4vw, 36px);
}

/* Global type */
.woocommerce, .woocommerce-page {
  font-family: var(--font-sans); font-weight: var(--fw-regular);
  color: var(--color-ink); letter-spacing: -0.011em;
}
.woocommerce .price, .woocommerce-Price-amount { color: var(--color-ink); font-weight: var(--fw-light); }

/* RUO line on single product pages */
.product-ruo {
  font-size: 12px; font-weight: var(--fw-light); color: var(--color-ink-muted);
  letter-spacing: -0.24px; margin: 16px 0 0;
}

/* Researcher affirmation (checkout + signup) */
.brightly-affirmation { margin: 18px 0; }
.brightly-affirmation__label {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 14px; line-height: 1.45; font-weight: var(--fw-light) !important;
  color: var(--color-ink); cursor: pointer; width: auto; height: auto; border: 0;
}
.brightly-affirmation__label input { margin-top: 3px; flex: 0 0 auto; }
.brightly-affirmation__label a { text-decoration: underline; }

/* Placeholder gateway message */
.woocommerce-checkout #payment .payment_box {
  background: var(--color-page); border-radius: var(--radius-box);
  font-size: 13px; color: var(--color-ink-muted);
}

@media (max-width: 900px) {
  .woocommerce-checkout form.checkout,
  body.woocommerce-account.logged-in .woocommerce { grid-template-columns: 1fr; }
  .woocommerce-checkout #customer_details,
  .woocommerce-checkout #order_review_heading,
  .woocommerce-checkout #order_review { grid-column: 1; }
}

@media (max-width: 600px) {
  .woocommerce ul.products[class*="columns-"] li.product,
  .woocommerce-page ul.products[class*="columns-"] li.product {
    width: 100% !important; margin: 0 0 18px !important;
  }
  .woocommerce-cart table.cart td.actions .coupon .input-text,
  .woocommerce-cart table.cart td.actions .coupon .button,
  .woocommerce-cart table.cart td.actions > .button {
    width: 100% !important;
  }
  .woocommerce div.product form.cart .button { flex: 1 1 220px; }
  .woocommerce div.product .woocommerce-tabs ul.tabs li { margin-right: 18px; }
}
