/* =========================================================
   Oophar — Consolidated Fixes & Overrides
   Loaded last. Uses specificity, not !important.
   ========================================================= */

/* ==========================================================
   1. LOGO — Constrain WP custom logo output
   ========================================================== */

.site-logo,
.custom-logo-link {
  display: inline-flex;
  align-items: center;
  line-height: 0;
  flex-shrink: 0;
}
.site-logo img,
.custom-logo-link img {
  height: 34px;
  width: auto;
  max-width: 150px;
  display: block;
  object-fit: contain;
}
@media (min-width: 1024px) {
  .site-logo img,
  .custom-logo-link img {
    height: 40px;
    max-width: 180px;
  }
}

/* ==========================================================
   2. HEADER — Mobile tightening
   ========================================================== */

@media (max-width: 639px) {
  .header-inner { gap: var(--space-2); padding-inline: var(--space-3); }
  .header-action-btn { width: 40px; height: 40px; }
  .header-action-btn svg { width: 20px; height: 20px; }
}

/* ==========================================================
   3. TRUST BAR — handled in layout.css
   ========================================================== */

/* ==========================================================
   4. WOOCOMMERCE PRODUCT GRID — Override WC float layout
   ========================================================== */

.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  list-style: none;
  padding: 0;
  margin: 0;
  float: none;
  clear: both;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after { display: none; }

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  float: none;
  width: auto;
  margin: 0;
  clear: none;
  display: flex;
  flex-direction: column;
}

@media (min-width: 640px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1024px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products { grid-template-columns: repeat(4, 1fr); }
}

/* ==========================================================
   5. PRODUCT CARD — Consistent image ratio & coral button
   ========================================================== */

.woocommerce ul.products li.product img {
  aspect-ratio: 1 / 1;
  object-fit: cover;
  width: 100%;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.6em;
  font-size: var(--font-size-sm);
  font-weight: 700;
  padding: var(--space-3) var(--space-3) var(--space-1);
  margin: 0;
  color: var(--clr-heading);
  line-height: 1.45;
  letter-spacing: -0.01em;
}
.woocommerce ul.products li.product .price {
  padding: var(--space-1) var(--space-3) var(--space-3);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}
/* Current price — dominant */
.woocommerce ul.products li.product .price .woocommerce-Price-amount {
  font-size: var(--font-size-lg);
  font-weight: 800;
  color: var(--clr-coral);
  font-family: var(--font-display);
  letter-spacing: -0.01em;
}
/* Strikethrough original price */
.woocommerce ul.products li.product .price del .woocommerce-Price-amount {
  font-size: var(--font-size-sm);
  font-weight: 400;
  color: var(--clr-text-light);
}
/* Discount % — green pill */
.woocommerce ul.products li.product .price .discount-pct {
  font-size: var(--font-size-xs);
  font-weight: 800;
  color: #fff;
  background: var(--clr-success);
  padding: 2px var(--space-2);
  border-radius: var(--radius-full);
}
/* Default glassmorphic styles from woocommerce.css will now apply cleanly. */
/* Sale badge */
.woocommerce ul.products li.product .onsale {
  position: absolute;
  top: var(--space-2);
  left: var(--space-2);
  z-index: 2;
  margin: 0;
  min-width: auto;
  min-height: auto;
  padding: 3px var(--space-2);
  font-size: 0.65rem;
  border-radius: var(--radius-full);
  background: var(--clr-coral);
  color: #fff;
  font-weight: 800;
  letter-spacing: 0.03em;
}
/* Mobile: tighter cards */
@media (max-width: 479px) {
  .woocommerce ul.products { gap: var(--space-3); }
  .woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: 0.72rem; }
  .woocommerce ul.products li.product .button,
  .woocommerce ul.products li.product a.button {
    min-height: 40px;
    font-size: 0.68rem;
    margin: auto var(--space-2) var(--space-2);
    width: calc(100% - var(--space-4));
  }
}

/* ==========================================================
   6. SECTION SPACING — Reduce on mobile
   ========================================================== */

@media (max-width: 767px) {
  .section { padding-block: var(--space-8); }
  .section-header { margin-bottom: var(--space-5); }
  .section-header__title { font-size: var(--font-size-xl); }
}

/* ==========================================================
   7. OCCASION GRID — 4 cols always, compact on mobile
   ========================================================== */

@media (max-width: 479px) {
  .occasion-grid { gap: var(--space-2); }
  .occasion-card { padding: var(--space-3) var(--space-2); gap: var(--space-2); border-radius: var(--radius-lg); }
  .occasion-card__icon { width: 40px; height: 40px; }
  .occasion-card__icon svg { width: 20px; height: 20px; }
  .occasion-card__label { font-size: 0.65rem; line-height: 1.2; }
}

/* ==========================================================
   8. GIFT FINDER — Mobile stacking
   ========================================================== */

@media (max-width: 639px) {
  .gift-finder { padding: var(--space-6) var(--space-4); border-radius: var(--radius-xl); }
  .gift-finder__form { grid-template-columns: 1fr; }
}

/* ==========================================================
   9. TESTIMONIALS — Single col on small mobile
   ========================================================== */

@media (max-width: 479px) {
  .testimonials-grid { grid-template-columns: 1fr; }
  .testimonial-card { padding: var(--space-4); }
}

/* ==========================================================
   10. NEWSLETTER — Stack on mobile
   ========================================================== */

@media (max-width: 639px) {
  .newsletter { padding: var(--space-8) var(--space-4); border-radius: var(--radius-xl); }
  .newsletter__form { flex-direction: column; }
  .newsletter__input, .newsletter__btn { width: 100%; min-width: 0; }
}

/* ==========================================================
   11. FOOTER — Mobile stacking
   ========================================================== */

@media (max-width: 639px) {
  .site-footer { padding-top: var(--space-10); }
  .footer-grid { grid-template-columns: 1fr; gap: var(--space-6); padding-bottom: var(--space-8); }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: var(--space-3); }
}

/* ==========================================================
   12. CHECKOUT — Mobile
   ========================================================== */

@media (max-width: 1023px) {
  .checkout-layout,
  .woocommerce-checkout form.checkout {
    grid-template-columns: 1fr;
  }
  .woocommerce-checkout form.checkout #order_review_heading,
  .woocommerce-checkout form.checkout #order_review {
    grid-column: 1;
    grid-row: auto;
  }
}
@media (max-width: 479px) {
  .checkout-steps__label { font-size: 0.65rem; }
  .checkout-steps__number { width: 36px; height: 36px; font-size: var(--font-size-xs); }
}

/* ==========================================================
   13. MY ACCOUNT — Mobile nav horizontal scroll
   ========================================================== */

@media (max-width: 767px) {
  .woocommerce-MyAccount-content-wrapper {
    grid-template-columns: 1fr;
  }
  .woocommerce-MyAccount-navigation {
    position: static;
  }
  .woocommerce-MyAccount-navigation ul {
    display: flex;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .woocommerce-MyAccount-navigation ul::-webkit-scrollbar { display: none; }
  .woocommerce-MyAccount-navigation ul li {
    border-bottom: none;
    border-right: 1px solid var(--clr-border);
    flex-shrink: 0;
  }
  .woocommerce-MyAccount-navigation ul li a { white-space: nowrap; }
}

/* ==========================================================
   14. CART TABLE — Mobile responsive
   ========================================================== */

@media (max-width: 639px) {
  .woocommerce-cart-form { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  table.shop_table thead { display: none; }
  table.shop_table tbody tr {
    display: grid;
    grid-template-columns: 72px 1fr auto;
    grid-template-areas: "img name remove" "img price qty" "img subtotal subtotal";
    gap: var(--space-2);
    padding: var(--space-4);
    border-bottom: 1px solid var(--clr-border);
  }
  table.shop_table tbody td { padding: 0; border: none; }
  table.shop_table .product-thumbnail { grid-area: img; }
  table.shop_table .product-name      { grid-area: name; }
  table.shop_table .product-remove    { grid-area: remove; justify-self: end; }
  table.shop_table .product-price     { grid-area: price; }
  table.shop_table .product-quantity  { grid-area: qty; }
  table.shop_table .product-subtotal  { grid-area: subtotal; text-align: right; }
}

/* ==========================================================
   15. GENERAL — Prevent horizontal overflow
   ========================================================== */

body { overflow-x: hidden; max-width: 100vw; }
@media (max-width: 479px) { .container { padding-inline: var(--space-3); } }

/* ==========================================================
   16. BACK TO TOP — Don't overlap sticky ATC on mobile
   ========================================================== */

@media (max-width: 1023px) {
  .back-to-top { bottom: calc(var(--space-4) + 72px); right: var(--space-3); }
}

/* ==========================================================
   17. DARK MODE — Product cards & components
   ========================================================== */

[data-theme="dark"] .woocommerce ul.products li.product {
  background: var(--clr-bg-card);
  border-color: var(--clr-border);
}
[data-theme="dark"] .woocommerce ul.products li.product .woocommerce-loop-product__title {
  color: var(--clr-heading);
}
[data-theme="dark"] .occasion-card { background: var(--clr-bg-card); border-color: var(--clr-border); }
[data-theme="dark"] .testimonial-card { background: var(--clr-bg-card); }
[data-theme="dark"] .gift-finder { background: var(--clr-bg-card); border-color: var(--clr-border); }
[data-theme="dark"] .gift-finder__select { background: var(--clr-surface); color: var(--clr-text); border-color: var(--clr-border); }

/* ==========================================================
   18. WOOCOMMERCE BREADCRUMB
   ========================================================== */

.woo-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1);
  font-size: var(--font-size-sm);
  color: var(--clr-text-muted);
  padding: var(--space-4) 0;
  margin: 0;
}
.woo-breadcrumb a { color: var(--clr-text-muted); text-decoration: none; }
.woo-breadcrumb a:hover { color: var(--clr-coral); }
.woo-breadcrumb .sep { color: var(--clr-border); margin: 0 2px; }

/* ==========================================================
   19. PRODUCT TYPE BADGE
   ========================================================== */

.product-type-badge {
  display: inline-block;
  padding: 2px var(--space-2);
  font-size: 0.65rem;
  font-weight: 700;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: var(--space-2) var(--space-3) 0;
}
.badge-digital  { background: #ede9fe; color: #7c3aed; }
.badge-physical { background: #dcfce7; color: var(--clr-success); }

/* ==========================================================
   20. CHECKOUT LAYOUT
   ========================================================== */

.checkout-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: start;
}
@media (min-width: 1024px) {
  .checkout-layout { grid-template-columns: 1fr 400px; }
}
.checkout-order-col #order_review {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  position: sticky;
  top: calc(var(--header-height) + var(--space-4));
}

/* ==========================================================
   21. VISUAL HIERARCHY — Global improvements
   ========================================================== */

/* Stronger section separation */
.section + .section {
  border-top: 1px solid var(--clr-border);
}
/* Alternating section backgrounds for rhythm */
.section:nth-child(even) {
  background: var(--clr-bg-alt);
}

/* Consistent container padding on all sections */
.section > .container {
  padding-block: 0;
}

/* ==========================================================
   22. TYPOGRAPHY — Hierarchy fixes
   ========================================================== */

/* Body text — slightly larger for readability */
body {
  font-size: 1rem;
  line-height: 1.65;
}

/* Description text — better line length */
.woocommerce-product-details__short-description,
.entry-content p,
.woocommerce-tabs .panel p {
  max-width: 68ch;
  line-height: 1.8;
  font-size: var(--font-size-sm);
  color: var(--clr-text);
}

/* ==========================================================
   23. PRODUCT CARD — Shadow & elevation hierarchy
   ========================================================== */

.woocommerce ul.products li.product {
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base), border-color var(--transition-base);
}
.woocommerce ul.products li.product:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
  border-color: rgba(255,61,85,.15);
}

/* ==========================================================
   24. SINGLE PRODUCT — Gallery improvements
   ========================================================== */

/* Larger thumbnails */
.woocommerce-product-gallery ol.flex-control-nav.flex-control-thumbs li {
  width: 80px;
  height: 80px;
}
.woocommerce-product-gallery ol.flex-control-nav.flex-control-thumbs li img {
  width: 80px !important;
  height: 80px !important;
  border-radius: var(--radius-lg);
}

/* ==========================================================
   25. CART — Total price emphasis
   ========================================================== */

.cart_totals table .order-total td .woocommerce-Price-amount {
  font-size: var(--font-size-2xl);
  font-weight: 800;
  color: var(--clr-coral);
  font-family: var(--font-display);
  letter-spacing: -0.02em;
}

/* ==========================================================
   26. CHECKOUT — Form grouping & readability
   ========================================================== */

/* Group related fields visually */
.woocommerce-checkout .form-row {
  margin-bottom: var(--space-5);
}
.woocommerce-checkout .form-row label {
  font-size: var(--font-size-sm);
  font-weight: 700;
  color: var(--clr-heading);
  margin-bottom: var(--space-2);
  letter-spacing: 0.01em;
}

/* ==========================================================
   27. MOBILE — Sticky ATC bar improvements
   ========================================================== */

@media (max-width: 1023px) {
  .sticky-atc-bar {
    padding: var(--space-3) var(--space-4);
    gap: var(--space-3);
  }
  .sticky-atc-bar__btn {
    min-width: 140px;
    min-height: 48px;
    font-size: var(--font-size-sm);
    border-radius: var(--radius-full);
    box-shadow: 0 4px 16px rgba(255,61,85,.4);
  }
}

/* ==========================================================
   28. TRUST BADGES — Product page
   ========================================================== */

.product-trust-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  padding: var(--space-4) 0;
  border-top: 1px solid var(--clr-border);
}
.product-trust-badge {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-xs);
  color: var(--clr-text-muted);
  font-weight: 600;
}
.product-trust-badge span:first-child {
  font-size: 1rem;
}

/* ==========================================================
   29. BUTTON HOVER — Consistent feedback across all buttons
   ========================================================== */

.btn,
.woocommerce .button,
.woocommerce button.button {
  -webkit-tap-highlight-color: transparent;
}
.btn:focus-visible,
.woocommerce .button:focus-visible {
  outline: 3px solid var(--clr-coral);
  outline-offset: 3px;
}

/* ==========================================================
   30. OCCASION CARDS — Better hover state
   ========================================================== */

.occasion-card {
  box-shadow: var(--shadow-sm);
}
.occasion-card:hover {
  box-shadow: 0 8px 24px rgba(255,61,85,.2);
}

/* ==========================================================
   31. MINI CART — Checkout button prominence
   ========================================================== */

.mini-cart__footer .btn-primary {
  min-height: 52px;
  font-size: var(--font-size-base);
  font-weight: 800;
  box-shadow: 0 6px 24px rgba(255,61,85,.4);
  letter-spacing: 0.01em;
}

/* ==========================================================
   32. DARK MODE — Header fix
   ========================================================== */

[data-theme="dark"] .primary-nav__link {
  color: var(--clr-text);
}
[data-theme="dark"] .primary-nav__link:hover,
[data-theme="dark"] .primary-nav__item.current-menu-item .primary-nav__link {
  color: var(--clr-coral);
}
[data-theme="dark"] .header-action-btn {
  color: var(--clr-text);
}
[data-theme="dark"] .header-action-btn:hover {
  background: var(--clr-surface);
  color: var(--clr-coral);
}
[data-theme="dark"] .header-action-btn.cart-btn {
  background: var(--clr-coral);
  color: #fff;
}

/* ==========================================================
   33. PAGE HERO — WooCommerce pages
   ========================================================== */

/* WC page hero — compact, no overflow */
.woocommerce-cart .page-hero,
.woocommerce-checkout .page-hero,
.woocommerce-account .page-hero,
.woocommerce-page .page-hero {
  padding-block: var(--space-8);
  overflow: hidden;
}
/* Breadcrumb inside hero */
.page-hero .woo-breadcrumb,
.page-hero .woocommerce-breadcrumb {
  color: rgba(255,255,255,.65);
  justify-content: center;
  margin-bottom: var(--space-3);
}
.page-hero .woo-breadcrumb a,
.page-hero .woocommerce-breadcrumb a {
  color: rgba(255,255,255,.65);
}
.page-hero .woo-breadcrumb a:hover,
.page-hero .woocommerce-breadcrumb a:hover {
  color: #fff;
}
.page-hero .woo-breadcrumb .sep,
.page-hero .woocommerce-breadcrumb .sep {
  color: rgba(255,255,255,.3);
}

/* ==========================================================
   34-39. WC LAYOUT — handled in woocommerce.css
   ========================================================== */
