/*
Theme Name:   Back2Basics Child
Theme URI:    https://back2basics.in
Description:  Astra Child Theme for Back2Basics — A2 Milk & Organic Products
Author:       Dellos
Author URI:   https://dellos.in
Template:     astra
Version:      1.0.1
Text Domain:  back2basics-child
*/

/* =====================================================
   BACK2BASICS — ASTRA CHILD THEME
   Primary: #213927  (deep forest green)
   Accent:  #c8a55a  (warm gold)
   Light:   #f7f4ef  (cream off-white)
   ===================================================== */

:root {
  --b2b-green:       #213927;
  --b2b-green-dark:  #192c1e;
  --b2b-green-mid:   #2d4f36;
  --b2b-green-light: #e8f0ea;
  --b2b-gold:        #c8a55a;
  --b2b-gold-light:  #d9bc7e;
  --b2b-cream:       #f7f4ef;
  --b2b-cream-dark:  #ede8df;
  --b2b-text:        #1a1a1a;
  --b2b-muted:       #666666;
  --b2b-white:       #ffffff;
  --b2b-radius:      6px;
  --b2b-font-head:   'Playfair Display', Georgia, serif;
  --b2b-font-body:   'DM Sans', system-ui, sans-serif;
}

/* ── GOOGLE FONTS ─────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,600;0,700;1,500&family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600&display=swap');

/* ── BASE ─────────────────────────────────────────── */
body {
  font-family: var(--b2b-font-body) !important;
  background-color: var(--b2b-white);
  color: var(--b2b-text);
}

h1, h2, h3, h4, h5, h6,
.entry-title,
.woocommerce-loop-product__title,
.product_title {
  font-family: var(--b2b-font-head) !important;
  color: var(--b2b-green);
}

/* ── HEADER ───────────────────────────────────────── */
.site-header,
#masthead,
.ast-header-wrap {
  background-color: var(--b2b-green) !important;
}

/* Logo area */
.site-branding .site-title a,
.site-title a {
  color: var(--b2b-white) !important;
}

/* Nav links */
.main-navigation a,
.ast-builder-menu-1 .menu-item a,
#primary-menu > .menu-item > a {
  color: rgba(255,255,255,0.85) !important;
  font-family: var(--b2b-font-body) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em;
}
.main-navigation a:hover,
#primary-menu > .menu-item > a:hover,
.main-navigation .current-menu-item > a {
  color: var(--b2b-gold) !important;
}

/* Dropdown menus */
.main-navigation .sub-menu {
  background: var(--b2b-green-dark) !important;
  border-top: 2px solid var(--b2b-gold);
}
.main-navigation .sub-menu a {
  color: rgba(255,255,255,0.8) !important;
}
.main-navigation .sub-menu a:hover {
  color: var(--b2b-gold) !important;
  background: rgba(255,255,255,0.05) !important;
}

/* Mobile menu toggle */
.ast-mobile-menu-trigger .menu-toggle-icon,
.ast-mobile-menu-trigger .menu-toggle-icon::before,
.ast-mobile-menu-trigger .menu-toggle-icon::after {
  background: var(--b2b-white) !important;
}

/* Cart icon in header */
.ast-cart-menu-wrap .count {
  background-color: var(--b2b-gold) !important;
  color: #000 !important;
}

/* ── BUTTONS ──────────────────────────────────────── */
.ast-btn,
.button,
button,
input[type="submit"],
input[type="button"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .cart .button,
.woocommerce .cart input.button {
  background-color: var(--b2b-green) !important;
  color: var(--b2b-white) !important;
  border: 2px solid var(--b2b-green) !important;
  border-radius: var(--b2b-radius) !important;
  font-family: var(--b2b-font-body) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  letter-spacing: 0.03em;
  padding: 12px 24px !important;
  transition: background-color 0.25s, color 0.25s, transform 0.2s !important;
}
.ast-btn:hover,
.button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce .cart .button:hover,
.woocommerce .cart input.button:hover {
  background-color: var(--b2b-green-mid) !important;
  color: var(--b2b-white) !important;
  transform: translateY(-1px);
}

/* Add to cart specifically */
.woocommerce a.button.add_to_cart_button,
.woocommerce button.single_add_to_cart_button {
  background-color: var(--b2b-green) !important;
  border-color: var(--b2b-green) !important;
}
.woocommerce a.button.add_to_cart_button:hover,
.woocommerce button.single_add_to_cart_button:hover {
  background-color: var(--b2b-gold) !important;
  border-color: var(--b2b-gold) !important;
  color: #000 !important;
}

/* Outline / ghost button variant */
.woocommerce a.button.alt,
.woocommerce button.button.alt {
  background-color: var(--b2b-gold) !important;
  border-color: var(--b2b-gold) !important;
  color: #000 !important;
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background-color: var(--b2b-gold-light) !important;
  border-color: var(--b2b-gold-light) !important;
}

/* ── LINKS ────────────────────────────────────────── */
a {
  color: var(--b2b-green);
}
a:hover {
  color: var(--b2b-gold);
}

/* ── WOOCOMMERCE PRODUCT GRID ─────────────────────── */
.woocommerce ul.products li.product {
  background: var(--b2b-white);
  border: 1px solid #ececec;
  border-radius: 10px;
  overflow: hidden;
  transition: box-shadow 0.3s, transform 0.3s;
  padding: 0 0 20px !important;
}
.woocommerce ul.products li.product:hover {
  box-shadow: 0 8px 32px rgba(33,57,39,0.12);
  transform: translateY(-4px);
}
.woocommerce ul.products li.product img {
  border-radius: 0;
  margin-bottom: 0;
  transition: transform 0.4s;
}
.woocommerce ul.products li.product:hover img {
  transform: scale(1.04);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--b2b-font-head) !important;
  font-size: 17px !important;
  font-weight: 600;
  color: var(--b2b-green) !important;
  padding: 14px 16px 4px !important;
}

.woocommerce ul.products li.product .price {
  color: var(--b2b-green) !important;
  font-size: 16px !important;
  font-weight: 600;
  padding: 0 16px;
}
.woocommerce ul.products li.product .price ins {
  color: var(--b2b-gold) !important;
}

.woocommerce ul.products li.product a.button {
  margin: 12px 16px 0 !important;
  width: calc(100% - 32px) !important;
  text-align: center;
}

/* ── SINGLE PRODUCT PAGE ──────────────────────────── */
.woocommerce div.product .product_title {
  font-family: var(--b2b-font-head) !important;
  font-size: clamp(24px, 3vw, 36px) !important;
  color: var(--b2b-green) !important;
  margin-bottom: 12px;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--b2b-green) !important;
  font-size: 24px !important;
  font-weight: 700;
}

/* Variation select */
.woocommerce div.product .variations select {
  border: 2px solid var(--b2b-green-light) !important;
  border-radius: var(--b2b-radius) !important;
  padding: 10px 14px !important;
  font-family: var(--b2b-font-body) !important;
  color: var(--b2b-text);
}
.woocommerce div.product .variations select:focus {
  border-color: var(--b2b-green) !important;
  outline: none;
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--b2b-font-body) !important;
  color: var(--b2b-muted);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--b2b-green) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
  border-color: var(--b2b-green) !important;
}

/* ── CART & CHECKOUT ──────────────────────────────── */
.woocommerce-cart table.cart td,
.woocommerce-cart table.cart th {
  font-family: var(--b2b-font-body) !important;
}

.woocommerce-checkout #payment div.payment_box {
  background: var(--b2b-green-light) !important;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
  border: 1.5px solid #ddd !important;
  border-radius: var(--b2b-radius) !important;
  padding: 10px 14px !important;
  font-family: var(--b2b-font-body) !important;
  transition: border-color 0.2s;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--b2b-green) !important;
  outline: none;
  box-shadow: 0 0 0 3px rgba(33,57,39,0.1) !important;
}

.woocommerce-checkout h3 {
  font-family: var(--b2b-font-head) !important;
  color: var(--b2b-green);
}

/* Order total highlight */
.woocommerce-checkout .order-total td {
  color: var(--b2b-green) !important;
  font-weight: 700;
}

/* Place order button */
#place_order {
  background-color: var(--b2b-gold) !important;
  border-color: var(--b2b-gold) !important;
  color: #000 !important;
  font-size: 16px !important;
  padding: 16px 32px !important;
  width: 100% !important;
  letter-spacing: 0.04em;
}
#place_order:hover {
  background-color: var(--b2b-gold-light) !important;
  border-color: var(--b2b-gold-light) !important;
}

/* ── BREADCRUMBS ──────────────────────────────────── */
.woocommerce .woocommerce-breadcrumb,
.ast-breadcrumbs-wrap {
  font-family: var(--b2b-font-body) !important;
  font-size: 13px !important;
  color: var(--b2b-muted);
}
.woocommerce .woocommerce-breadcrumb a {
  color: var(--b2b-green) !important;
}

/* ── SALE BADGE ───────────────────────────────────── */
.woocommerce span.onsale {
  background-color: var(--b2b-gold) !important;
  color: #000 !important;
  font-family: var(--b2b-font-body) !important;
  font-weight: 700;
  border-radius: 4px;
}

/* ── NOTICES & MESSAGES ───────────────────────────── */
.woocommerce-message {
  border-top-color: var(--b2b-green) !important;
}
.woocommerce-message a.button {
  background-color: var(--b2b-green) !important;
}
.woocommerce-info {
  border-top-color: var(--b2b-gold) !important;
}

/* ── PAGINATION ───────────────────────────────────── */
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  border-color: var(--b2b-green-light) !important;
  color: var(--b2b-green) !important;
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--b2b-green) !important;
  color: var(--b2b-white) !important;
}

/* ── FOOTER ───────────────────────────────────────── */
.site-footer,
.ast-footer-overlay,
#colophon {
  background-color: var(--b2b-green-dark) !important;
  color: rgba(255,255,255,0.75) !important;
}
.site-footer a,
#colophon a {
  color: var(--b2b-gold) !important;
}
.site-footer a:hover,
#colophon a:hover {
  color: var(--b2b-gold-light) !important;
}
.site-footer .widget-title,
#colophon .widget-title {
  color: var(--b2b-white) !important;
  font-family: var(--b2b-font-head) !important;
}
.footer-widget-area {
  border-color: rgba(255,255,255,0.1) !important;
}

/* ── SHOP PAGE CATEGORY SECTION ───────────────────── */
.product-category a {
  color: var(--b2b-green) !important;
}

/* ── ORGANIC / FARM SECTION STYLING ───────────────── */
.b2b-cream-bg {
  background-color: var(--b2b-cream);
}
.b2b-green-bg {
  background-color: var(--b2b-green);
  color: var(--b2b-white);
}

/* ── STAR RATINGS ─────────────────────────────────── */
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before {
  color: var(--b2b-gold) !important;
}

/* ── MINI CART ────────────────────────────────────── */
.widget_shopping_cart .total strong {
  color: var(--b2b-green);
}
.widget_shopping_cart .buttons a {
  background-color: var(--b2b-green) !important;
  border-color: var(--b2b-green) !important;
  color: var(--b2b-white) !important;
}
.widget_shopping_cart .buttons a:last-child {
  background-color: var(--b2b-gold) !important;
  border-color: var(--b2b-gold) !important;
  color: #000 !important;
}

/* ── RESPONSIVE TWEAKS ────────────────────────────── */
@media (max-width: 768px) {
  .woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 15px !important;
  }
  .woocommerce div.product .product_title {
    font-size: 22px !important;
  }
}

/* =====================================================
   BUG FIXES — v1.1
   ===================================================== */

/* ── 1. SHOP PAGE: breathing room left & right ─────── */
.woocommerce-page .woocommerce,
.woocommerce-shop .woocommerce,
body.post-type-archive-product .woocommerce,
.woocommerce ul.products,
.woocommerce-page ul.products {
  padding-left: 40px !important;
  padding-right: 40px !important;
}

/* Shop header row (results count + ordering) */
.woocommerce .woocommerce-products-header,
.woocommerce nav.woocommerce-breadcrumb,
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
  padding-left: 40px;
  padding-right: 40px;
}

/* Wrap the entire shop content area */
.woocommerce-page #content,
body.post-type-archive-product #content {
  max-width: 1280px;
  margin: 0 auto;
  padding-left: 40px;
  padding-right: 40px;
}

@media (max-width: 768px) {
  .woocommerce-page .woocommerce,
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  .woocommerce-page #content,
  body.post-type-archive-product #content {
    padding-left: 16px;
    padding-right: 16px;
  }
}

/* ── 2. SINGLE PRODUCT: constrain image gallery ─────── */
.woocommerce div.product {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 40px 60px;
}

/* Gallery column — cap width so it doesn't dominate */
.woocommerce div.product div.images,
.woocommerce div.product .woocommerce-product-gallery {
  width: 42% !important;
  max-width: 460px !important;
  float: left !important;
}

/* Summary column fills the rest */
.woocommerce div.product div.summary {
  width: 52% !important;
  float: right !important;
}

/* Gallery images themselves */
.woocommerce div.product .woocommerce-product-gallery__image img,
.woocommerce div.product div.images img {
  width: 100% !important;
  height: auto !important;
  max-height: 480px;
  object-fit: contain;
  border-radius: 10px;
}

/* Thumbnails strip */
.woocommerce div.product .flex-control-thumbs {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-top: 10px;
}
.woocommerce div.product .flex-control-thumbs li {
  width: calc(25% - 6px) !important;
  float: none !important;
  margin: 0 !important;
}
.woocommerce div.product .flex-control-thumbs li img {
  border-radius: 6px;
  max-height: 80px; object-fit: cover;
}

/* Clearfix after product layout */
.woocommerce div.product::after {
  content: ''; display: table; clear: both;
}

/* Full-width product description tabs below */
.woocommerce div.product .woocommerce-tabs {
  clear: both;
  padding-top: 40px;
}

@media (max-width: 768px) {
  .woocommerce div.product { padding: 24px 16px 40px; }
  .woocommerce div.product div.images,
  .woocommerce div.product .woocommerce-product-gallery {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
  }
  .woocommerce div.product div.summary {
    width: 100% !important;
    float: none !important;
    margin-top: 28px;
  }
}

/* ── 3. FOOTER: milk subscription button text fix ───── */
.b2b-ft-milk-btn,
.b2b-ft-milk-btn:link,
.b2b-ft-milk-btn:visited,
.b2b-ft-milk-btn:hover {
  color: #111111 !important;
  -webkit-text-fill-color: #111111 !important;
  opacity: 1 !important;
}

/* Also fix any Astra/WP global a colour overrides bleeding into footer */
.b2b-footer a.b2b-ft-milk-btn {
  color: #111111 !important;
}

/* =====================================================
   BUG FIXES v1.2 — Shop & Product page layout
   ===================================================== */

/* ── GLOBAL PAGE WRAPPER: add side breathing room ───── */
#b2b-page-wrap {
  padding-left: 0;
  padding-right: 0;
}
#content.site-content {
  max-width: 1280px;
  margin: 0 auto;
  padding: 40px 40px 60px;
  width: 100%;
}
@media (max-width: 768px) {
  #content.site-content { padding: 24px 16px 40px; }
}

/* ── SHOP / ARCHIVE PAGE ─────────────────────────────── */
/* Remove any Astra full-width overrides */
.woocommerce-page .ast-container,
.woocommerce-page .ast-row,
body.post-type-archive-product .ast-container {
  max-width: 100% !important;
  padding: 0 !important;
}

/* Force the product grid width and columns */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  float: none !important;
}
/* Override Astra's columns-4 class */
.woocommerce ul.products.columns-4,
.woocommerce ul.products.columns-3 {
  grid-template-columns: repeat(3, 1fr) !important;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
  clear: none !important;
}

/* Results count + ordering row */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
  margin-bottom: 24px;
}

/* ── SINGLE PRODUCT PAGE ──────────────────────────────── */
/* Force layout off Astra's full-bleed container */
.single-product #content.site-content {
  padding: 40px 40px 60px;
}
.woocommerce div.product {
  display: grid !important;
  grid-template-columns: 42% 1fr !important;
  gap: 56px !important;
  align-items: start !important;
  padding: 0 !important;
  max-width: 100% !important;
}
/* Image column */
.woocommerce div.product div.images,
.woocommerce div.product .woocommerce-product-gallery {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  grid-column: 1 !important;
  grid-row: 1 !important;
}
/* Summary column */
.woocommerce div.product div.summary {
  width: 100% !important;
  float: none !important;
  grid-column: 2 !important;
  grid-row: 1 !important;
  margin: 0 !important;
}
/* Tabs go full width below both */
.woocommerce div.product .woocommerce-tabs {
  grid-column: 1 / -1 !important;
  clear: none !important;
  padding-top: 40px;
}
/* Related products also full width */
.woocommerce .related.products,
.woocommerce .up-sells {
  grid-column: 1 / -1 !important;
  clear: none !important;
}

/* Cap image height — stop it from dominating */
.woocommerce div.product .woocommerce-product-gallery__image,
.woocommerce div.product .woocommerce-product-gallery__image a {
  display: block;
}
.woocommerce div.product .woocommerce-product-gallery__image img,
.woocommerce div.product div.images img {
  width: 100% !important;
  max-height: 500px !important;
  height: auto !important;
  object-fit: contain !important;
  border-radius: 10px;
}

/* Mobile: stack single product */
@media (max-width: 768px) {
  .woocommerce div.product {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }
  .woocommerce div.product div.images,
  .woocommerce div.product .woocommerce-product-gallery {
    grid-column: 1 !important; grid-row: 1 !important;
  }
  .woocommerce div.product div.summary {
    grid-column: 1 !important; grid-row: 2 !important;
  }
  .woocommerce ul.products.columns-4,
  .woocommerce ul.products.columns-3,
  .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .single-product #content.site-content { padding: 24px 16px 40px; }
}
@media (max-width: 480px) {
  .woocommerce ul.products {
    grid-template-columns: 1fr !important;
  }
}

/* =====================================================
   BUG FIXES v1.3 — confirmed working selectors
   ===================================================== */

/* ── Desktop page padding — confirmed via inspect ────── */
@media (min-width: 769px) {
  .woocommerce #b2b-page-wrap,
  .woocommerce-page #b2b-page-wrap,
  .single-product #b2b-page-wrap,
  .post-type-archive-product #b2b-page-wrap {
    padding-left: 80px;
    padding-right: 80px;
  }
}

/* ── Product image height cap ─────────────────────────
   Force the gallery wrapper and img to a fixed height
   so tall/portrait images don't dominate the layout.
   object-fit: cover keeps it cropped cleanly.         */
.woocommerce-product-gallery,
.woocommerce div.product div.images {
  max-height: 420px !important;
  overflow: hidden !important;
  border-radius: 10px;
}
.woocommerce-product-gallery .woocommerce-product-gallery__image,
.woocommerce div.product div.images .woocommerce-product-gallery__image {
  max-height: 420px !important;
  overflow: hidden !important;
}
.woocommerce-product-gallery img,
.woocommerce div.product div.images img {
  width: 100% !important;
  height: 420px !important;
  max-height: 420px !important;
  object-fit: cover !important;
  object-position: center top !important;
  border-radius: 10px;
  display: block !important;
}
