/* Purpose: Resources shop — header offset, filter pills, card grid, worksheet rows. */

.resources { padding-top: clamp(8rem, 16vh, 12rem); }
.resources__head { margin-bottom: var(--space-10); }
.resources__empty { text-align: center; color: var(--color-text-muted); padding: var(--space-16) 0; }

/* Filter pills */
.res-filter { display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: center; margin-bottom: var(--space-12); }
.res-filter__pill {
  padding: 0.55rem 1.3rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-sm); letter-spacing: var(--tracking-wide); text-transform: uppercase;
  color: var(--color-text-muted);
  transition: all var(--duration-base) var(--ease-out);
}
.res-filter__pill:hover { border-color: var(--color-primary); color: var(--color-primary-dark); }
.res-filter__pill.is-active { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-surface); }

.res-group { margin-bottom: var(--space-16); }
.res-group__title { font-size: var(--text-2xl); margin-bottom: var(--space-6); }

/* Grid cards */
.res-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
@media (max-width: 1023px) { .res-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 539px)  { .res-grid { grid-template-columns: 1fr; } }

.res-card {
  background: var(--color-surface);
  border: var(--border-thin);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out);
}
.res-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.res-card__media { display: block; aspect-ratio: 1 / 1; background: var(--color-bg-alt); overflow: hidden; }
.res-card__img { width: 100%; height: 100%; object-fit: cover; }
.res-card__placeholder {
  width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--color-primary-soft), var(--color-primary));
  color: var(--color-surface);
}
.res-card__placeholder svg { width: 56px; height: 56px; opacity: 0.8; }
.res-card__body { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-4); flex: 1; }
.res-card__title { font-size: var(--text-lg); }
.res-card__meta { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.res-card__price { font-family: var(--font-heading); font-size: var(--text-xl); color: var(--color-primary-dark); }
.res-card__btn { padding: 0.5rem 1.2rem; }

/* Worksheet PDF rows */
.res-rows { display: grid; gap: var(--space-2); }
.res-row {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: var(--space-5);
  padding: var(--space-4) var(--space-5);
  background: var(--color-surface);
  border: var(--border-thin);
  border-radius: var(--radius-md);
  transition: border-color var(--duration-base), box-shadow var(--duration-base);
}
.res-row:hover { border-color: var(--color-primary); box-shadow: var(--shadow-sm); }
.res-row__icon { color: var(--color-secondary); }
.res-row__icon svg { width: 28px; height: 28px; }
.res-row__title { font-size: var(--text-md); }
.res-row__price { font-family: var(--font-heading); font-size: var(--text-lg); color: var(--color-primary-dark); }
.res-row__btn { padding: 0.5rem 1.3rem; }
@media (max-width: 639px) {
  .res-row { grid-template-columns: auto 1fr auto; row-gap: var(--space-2); }
  .res-row__price { grid-column: 2; justify-self: start; font-size: var(--text-base); }
}

/* ---------- Digital delivery note ---------- */
.saarthi-digital-note {
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: color-mix(in srgb, var(--color-primary) 10%, transparent);
  border-left: 2px solid var(--color-primary);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  color: var(--color-text);
}

/* ---------- WooCommerce single product + cart (on-theme) ---------- */
.woocommerce .single-product__wrap, .woocommerce-page .container { }
.single-product div.product { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4.5rem); align-items: start; }
.single-product div.product .woocommerce-product-gallery {
  width: 100% !important; float: none !important; margin: 0 !important;
  align-self: start;
  background: var(--color-surface);
  border: var(--border-thin);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}
/* Tabs, upsells and related products span the full width below the 2-col area */
.single-product div.product .woocommerce-tabs,
.single-product div.product .upsells,
.single-product div.product .related { grid-column: 1 / -1; }
.single-product div.product .woocommerce-product-gallery__wrapper { margin: 0; }
.single-product div.product .woocommerce-product-gallery__image { aspect-ratio: 1 / 1; }
.single-product div.product .woocommerce-product-gallery__image a { display: block; height: 100%; }
.single-product div.product .woocommerce-product-gallery__image img { width: 100%; height: 100%; object-fit: cover; }
.single-product div.product .entry-summary,
.single-product div.product .summary {
  width: 100% !important; float: none !important; margin: 0 !important; padding: 0 !important; clear: none !important;
}
.single-product div.product .product_title { font-size: var(--text-4xl); margin-bottom: var(--space-3); }
.single-product div.product .price { display: block; font-family: var(--font-heading); font-size: var(--text-2xl); color: var(--color-primary-dark) !important; margin-bottom: var(--space-4); }
.single-product div.product .woocommerce-product-details__short-description { color: var(--color-text-muted); margin-bottom: var(--space-5); max-width: 52ch; }
.single-product div.product form.cart { margin: 0 0 var(--space-5); display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.single-product .woocommerce-tabs { grid-column: 1 / -1; margin-top: var(--space-12); }
.single-product .woocommerce-tabs ul.tabs { padding: 0; }
.single-product .woocommerce-tabs .panel { padding-top: var(--space-4); color: var(--color-text-muted); max-width: 70ch; }
.single-product .product_meta { font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-4); }
.single-product div.product .single_add_to_cart_button,
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce ul.products li.product .button {
  background: var(--color-primary) !important; color: var(--color-surface) !important;
  border-radius: var(--radius-full) !important; padding: 0.85rem 1.8rem !important;
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
  font-family: var(--font-body); font-weight: var(--weight-medium); border: none !important;
  transition: background var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out);
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce ul.products li.product .button:hover { background: var(--color-primary-dark) !important; transform: translateY(-2px); }
.woocommerce ul.products li.product .button { width: 100%; text-align: center; }
.woocommerce .quantity input { padding: 0.6rem; border: 1px solid var(--color-border); border-radius: var(--radius-sm); }
@media (max-width: 767px) { .single-product div.product { grid-template-columns: 1fr; } }

.woocommerce-cart table.cart, .woocommerce table.shop_table { border-radius: var(--radius-md); border-color: var(--color-border); }
.woocommerce table.shop_table th { font-family: var(--font-heading); }
.woocommerce .cart_totals h2, .woocommerce-checkout h3 { font-family: var(--font-heading); }

/* ---------- WooCommerce shop archive (on-theme) ---------- */
.woocommerce-wrap .woocommerce-products-header__title,
.woocommerce-wrap .page-title { font-family: var(--font-heading); font-size: var(--text-4xl); margin-bottom: var(--space-2); }
.woocommerce-wrap .woocommerce-result-count { color: var(--color-text-muted); font-size: var(--text-sm); }
.woocommerce-wrap .woocommerce-ordering { margin-bottom: var(--space-6); }
.woocommerce-wrap .woocommerce-ordering select { padding: 0.5rem 0.8rem; border: 1px solid var(--color-border); border-radius: var(--radius-sm); background: var(--color-surface); }

.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
  list-style: none;
  margin: var(--space-8) 0 0 !important;
  padding: 0 !important;
}
/* Kill the clearfix pseudo-elements that create an empty grid cell */
.woocommerce ul.products::before, .woocommerce ul.products::after,
.woocommerce-page ul.products::before, .woocommerce-page ul.products::after { content: none !important; display: none !important; }
.woocommerce ul.products li.product::before { content: none !important; }
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important; margin: 0 !important; float: none !important;
  background: var(--color-surface);
  border: var(--border-thin);
  border-radius: var(--radius-lg);
  overflow: hidden;
  padding: var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-3);
  transition: transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out);
}
.woocommerce ul.products li.product:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.woocommerce ul.products li.product a img { border-radius: var(--radius-md); margin-bottom: var(--space-2); }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-family: var(--font-heading); font-size: var(--text-lg); padding: 0; }
.woocommerce ul.products li.product .price { color: var(--color-primary-dark) !important; font-family: var(--font-heading); font-size: var(--text-xl); }
.woocommerce ul.products li.product .button { margin-top: auto; }
@media (max-width: 1023px) { .woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 539px)  { .woocommerce ul.products, .woocommerce-page ul.products { grid-template-columns: 1fr; } }

/* Sold individually — hide the empty quantity wrapper on the product page */
.single-product div.product form.cart .quantity { display: none; }
