/* ═══════════════════════════════════════════════════════════════
   Gir Amritphal – Single Product CSS v4
   Mobile-first · Conversion-optimised · Premium feel
   Fonts: Cormorant Garamond (headings) + DM Sans (body)
   ═══════════════════════════════════════════════════════════════ */

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

/* ── TOKENS ─────────────────────────────────────────────────── */
:root {
  --gold:          #C9972E;
  --gold-light:    #F7EDD4;
  --gold-dark:     #8B6914;
  --cream:         #FDFAF4;
  --cream-deep:    #F5EDD8;
  --green:         #1E4D35;
  --green-mid:     #2D6B4A;
  --green-light:   #E8F3EC;
  --brown:         #2C1A0E;
  --brown-mid:     #5C3D1E;
  --muted:         #6B5B45;
  --border:        #E2D5B8;
  --white:         #FFFFFF;
  --radius:        10px;
  --shadow-sm:     0 2px 12px rgba(44,26,14,.08);
  --shadow-md:     0 4px 24px rgba(44,26,14,.12);
  --font-head:     'Cormorant Garamond', Georgia, serif;
  --font-body:     'DM Sans', system-ui, sans-serif;
}

/* ── BASE ────────────────────────────────────────────────────── */
body.single-product {
  font-family: var(--font-body);
  background: var(--cream);
  color: var(--brown);
}

/* ── PAGE WRAP ───────────────────────────────────────────────── */
.gira-page-wrap {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ── BREADCRUMB ──────────────────────────────────────────────── */
.gira-breadcrumb,
.gira-breadcrumb .woocommerce-breadcrumb {
  padding: 14px 0;
  font-size: 12.5px;
  color: var(--muted);
  font-family: var(--font-body);
}
.gira-breadcrumb a,
.gira-breadcrumb .woocommerce-breadcrumb a {
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
}
.gira-breadcrumb a:hover { color: var(--gold-dark); }

/* ── MAIN 2-COL GRID ─────────────────────────────────────────── */
.gira-product-main {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 52px;
  padding: 8px 0 56px;
  align-items: start;
}

/* ══════════════════════════════════════════════════════════════
   GALLERY
   ══════════════════════════════════════════════════════════════ */
.gira-gallery-col {
  position: sticky;
  top: 100px;
}

/* Remove any numbered list styling */
.woocommerce-product-gallery ol,
.woocommerce-product-gallery ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  counter-reset: none !important;
}
.woocommerce-product-gallery li::before,
.woocommerce-product-gallery li::marker {
  display: none !important;
  content: none !important;
}

/* Main image */
.woocommerce-product-gallery__wrapper {
  margin: 0 0 12px !important;
}
.woocommerce-product-gallery__wrapper .woocommerce-product-gallery__image:first-child {
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--white);
}
.woocommerce-product-gallery__wrapper .woocommerce-product-gallery__image:first-child img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}
.woocommerce-product-gallery:hover .woocommerce-product-gallery__image:first-child img {
  transform: scale(1.03);
}

/* THUMBNAILS — horizontal 4-col grid, no numbers */
.flex-control-nav.flex-control-thumbs {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.flex-control-nav.flex-control-thumbs li {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  list-style: none !important;
  counter-increment: none !important;
}
.flex-control-nav.flex-control-thumbs li::before,
.flex-control-nav.flex-control-thumbs li::marker {
  display: none !important;
  content: none !important;
}
.flex-control-nav.flex-control-thumbs li img {
  display: block !important;
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  border-radius: 8px !important;
  border: 2px solid transparent !important;
  cursor: pointer !important;
  transition: border-color .2s !important;
}
.flex-control-nav.flex-control-thumbs li img.flex-active,
.flex-control-nav.flex-control-thumbs li img:hover {
  border-color: var(--gold) !important;
}

/* Sale badge */
.woocommerce-product-gallery .onsale {
  background: var(--green) !important;
  border-radius: 6px !important;
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
}

/* ══════════════════════════════════════════════════════════════
   PRODUCT INFO COL
   ══════════════════════════════════════════════════════════════ */
.gira-info-col {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.gira-brand-tag {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  color: var(--gold-dark);
  text-transform: uppercase;
  letter-spacing: .14em;
  margin-bottom: 10px;
}

/* PRODUCT TITLE — Cormorant Garamond, premium */
.gira-info-col .product_title,
.gira-info-col h1.product_title {
  font-family: var(--font-head) !important;
  font-size: 34px !important;
  font-weight: 600 !important;
  color: var(--brown) !important;
  line-height: 1.2 !important;
  letter-spacing: -0.01em !important;
  margin: 0 0 10px !important;
}

/* STAR RATING */
.woocommerce-product-rating {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 0 0 16px !important;
}
.star-rating::before,
.star-rating span::before { color: #E8A020 !important; }
.woocommerce-review-link {
  font-size: 13px !important;
  color: var(--gold-dark) !important;
  text-decoration: underline !important;
  font-family: var(--font-body) !important;
}

/* PRICE */
.gira-info-col p.price {
  background: var(--cream-deep) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 14px 18px !important;
  margin: 0 0 10px !important;
  display: block !important;
  line-height: 1.3 !important;
}
.gira-info-col p.price .woocommerce-Price-amount {
  font-family: var(--font-head) !important;
  font-size: 32px !important;
  font-weight: 700 !important;
  color: var(--brown) !important;
}
.gira-info-col p.price del { font-size: 16px !important; color: var(--muted) !important; margin-left: 10px !important; }
.gira-info-col p.price del .woocommerce-Price-amount { font-size: 16px !important; color: var(--muted) !important; }
.gira-info-col p.price ins { text-decoration: none !important; }

/* PER DAY */
.gira-per-day {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--green);
  background: var(--green-light);
  border-radius: 20px;
  padding: 6px 14px;
  margin: 0 0 16px;
}

/* SHORT DESCRIPTION */
.woocommerce-product-details__short-description {
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  color: var(--muted) !important;
  line-height: 1.75 !important;
  margin: 0 0 20px !important;
}
.woocommerce-product-details__short-description p { margin: 0 !important; }

/* ADD TO CART */
form.cart {
  display: flex !important;
  gap: 10px !important;
  align-items: stretch !important;
  margin: 0 0 12px !important;
}
.quantity input.qty {
  width: 64px !important;
  height: 52px !important;
  text-align: center !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius) !important;
  font-family: var(--font-body) !important;
  font-size: 17px !important;
  font-weight: 600 !important;
  color: var(--brown) !important;
  background: var(--white) !important;
}
button.single_add_to_cart_button,
input.single_add_to_cart_button {
  flex: 1 !important;
  background: var(--green) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: var(--radius) !important;
  height: 52px !important;
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: .04em !important;
  cursor: pointer !important;
  transition: background .2s !important;
}
button.single_add_to_cart_button:hover { background: #163a28 !important; }

/* HIDE SKU / CATEGORY / TAGS */
.product_meta { display: none !important; }

/* TRUST BADGES */
.gira-trust-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 16px 0;
}
.gira-trust-badge {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 12px 8px;
  text-align: center;
  transition: border-color .2s;
}
.gira-trust-badge:hover { border-color: var(--gold); }
.gira-trust-badge .tb-icon { font-size: 22px; display: block; margin-bottom: 5px; }
.gira-trust-badge .tb-text {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  color: var(--brown-mid);
  line-height: 1.4;
}

/* OFFERS BOX */
.gira-offers-box {
  background: linear-gradient(135deg, var(--cream-deep), var(--gold-light));
  border: 1px solid var(--gold);
  border-radius: var(--radius);
  padding: 14px 16px;
  margin: 4px 0 12px;
}
.gira-offers-box .offers-title {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  color: var(--brown);
  margin-bottom: 9px;
}
.gira-offers-box .offer-item {
  font-family: var(--font-body);
  font-size: 12.5px;
  color: var(--brown-mid);
  padding: 3px 0;
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
}
.gira-offers-box .offer-item::before { content: '✦'; color: var(--gold); font-size: 9px; flex-shrink: 0; }
.gira-offers-box .offer-code {
  background: var(--brown);
  color: var(--gold-light);
  font-size: 10.5px;
  font-weight: 700;
  border-radius: 4px;
  padding: 2px 7px;
  letter-spacing: .06em;
}

/* DELIVERY STRIP */
.gira-delivery-row {
  background: var(--green-light);
  border-radius: var(--radius);
  padding: 11px 14px;
  margin: 4px 0 12px;
  display: flex;
  align-items: center;
  gap: 11px;
  font-family: var(--font-body);
  font-size: 13px;
}
.gira-delivery-row .delivery-icon { font-size: 20px; flex-shrink: 0; }
.gira-delivery-row strong { color: var(--green); }

/* WHATSAPP */
.gira-whatsapp-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  border: 2px solid #25D366;
  background: var(--white);
  color: #1a7a42;
  border-radius: var(--radius);
  height: 46px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  text-decoration: none !important;
  margin: 4px 0 0;
  transition: background .2s;
}
.gira-whatsapp-btn:hover { background: #f0fff6; color: #1a7a42; }

/* ══════════════════════════════════════════════════════════════
   TABS
   ══════════════════════════════════════════════════════════════ */
.gira-tabs-wrap {
  background: var(--white);
  border-radius: 16px;
  padding: 36px 40px;
  margin: 0 0 40px;
  box-shadow: var(--shadow-sm);
}
.gira-tabs-nav {
  display: flex;
  border-bottom: 1.5px solid var(--border);
  margin-bottom: 32px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  gap: 0;
}
.gira-tabs-nav::-webkit-scrollbar { display: none; }
.gira-tab-btn {
  background: none;
  border: none;
  border-bottom: 2.5px solid transparent;
  padding: 10px 20px;
  font-family: var(--font-body);
  font-size: 13.5px;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  margin-bottom: -1.5px;
  white-space: nowrap;
  transition: color .2s, border-color .2s;
}
.gira-tab-btn.active { color: var(--brown); border-bottom-color: var(--gold); }
.gira-tab-btn:hover:not(.active) { color: var(--brown-mid); }
.gira-tab-panel { display: none; }
.gira-tab-panel.active { display: block; }
.gira-tab-intro {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--muted);
  max-width: 680px;
  margin-bottom: 24px;
  line-height: 1.75;
}

/* BENEFITS */
.gira-benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.gira-benefit-card {
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 22px 16px;
  text-align: center;
  transition: box-shadow .2s, transform .2s;
}
.gira-benefit-card:hover { box-shadow: var(--shadow-sm); transform: translateY(-2px); }
.gira-benefit-card .benefit-icon { font-size: 30px; display: block; margin-bottom: 12px; }
.gira-benefit-card .benefit-title {
  font-family: var(--font-head);
  font-size: 17px;
  font-weight: 600;
  color: var(--brown);
  margin-bottom: 7px;
}
.gira-benefit-card .benefit-desc {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--muted);
  line-height: 1.6;
}

/* PROCESS */
.gira-process-steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  position: relative;
  padding-top: 8px;
}
.gira-process-steps::before {
  content: '';
  position: absolute;
  top: 42px; left: 10%; right: 10%;
  height: 2px;
  background: linear-gradient(to right, var(--gold), var(--green));
  z-index: 0;
}
.gira-step { text-align: center; position: relative; z-index: 1; padding: 0 6px; }
.gira-step .step-circle {
  width: 68px; height: 68px;
  border-radius: 50%;
  background: var(--white);
  border: 3px solid var(--gold);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px;
  margin: 0 auto 14px;
  box-shadow: 0 0 0 6px var(--cream);
}
.gira-step .step-title {
  font-family: var(--font-head);
  font-size: 13px; font-weight: 600;
  color: var(--brown); margin-bottom: 5px;
}
.gira-step .step-desc {
  font-family: var(--font-body);
  font-size: 11.5px; color: var(--muted); line-height: 1.5;
}

/* COMPARE TABLE */
.gira-compare-wrap { overflow-x: auto; border-radius: 12px; }
.gira-compare-table { width: 100%; border-collapse: collapse; min-width: 480px; }
.gira-compare-table th {
  background: var(--brown); color: var(--gold-light);
  padding: 13px 16px;
  font-family: var(--font-body); font-size: 13px; font-weight: 600;
  text-align: left; letter-spacing: .02em;
}
.gira-compare-table th:first-child { border-radius: 10px 0 0 0; }
.gira-compare-table th:last-child  { border-radius: 0 10px 0 0; }
.gira-compare-table td {
  padding: 12px 16px; border-bottom: 1px solid var(--border);
  font-family: var(--font-body); font-size: 13px; color: var(--brown);
}
.gira-compare-table tr:nth-child(even) td { background: var(--cream); }
.gira-compare-table td.is-good { color: var(--green-mid); font-weight: 600; }
.gira-compare-table td.col-other { color: var(--muted); }

/* REVIEWS */
.gira-reviews-summary {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 28px; margin-bottom: 28px; align-items: center;
}
.review-score-box {
  background: var(--cream-deep); border: 1px solid var(--border);
  border-radius: 12px; padding: 20px; text-align: center;
}
.review-big {
  font-family: var(--font-head);
  font-size: 54px; font-weight: 700; color: var(--brown); line-height: 1; display: block;
}
.review-stars-big { font-size: 20px; color: #E8A020; margin: 6px 0; }
.review-count { font-family: var(--font-body); font-size: 13px; color: var(--muted); }
.review-bars { display: flex; flex-direction: column; gap: 7px; }
.review-bar-row { display: flex; align-items: center; gap: 10px; font-family: var(--font-body); font-size: 13px; }
.rbl { width: 36px; color: var(--muted); flex-shrink: 0; }
.rbt { flex: 1; height: 7px; background: var(--border); border-radius: 4px; overflow: hidden; }
.rbf { height: 100%; background: var(--gold); border-radius: 4px; }
.rbp { width: 34px; text-align: right; color: var(--muted); flex-shrink: 0; }

/* Native WC reviews */
#reviews #comments { padding-top: 20px; }
#reviews ol.commentlist { list-style: none; margin: 0; padding: 0; }
#reviews ol.commentlist li.comment {
  background: var(--cream); border: 1px solid var(--border);
  border-radius: 10px; padding: 16px; margin-bottom: 12px;
}
#reviews ol.commentlist li .comment-text { background: none; border: none; padding: 0; margin: 0; }
#reviews .woocommerce-review__author { font-family: var(--font-body); font-weight: 600; color: var(--brown); }
#reviews .woocommerce-review__dash { display: none; }
#reviews .woocommerce-review__published-date { font-size: 12px; color: var(--muted); margin-left: 8px; }
#reviews .description p { font-family: var(--font-body); font-size: 14px; color: var(--muted); line-height: 1.7; margin: 8px 0 0; }

/* DESCRIPTION */
.gira-desc-content { font-family: var(--font-body); font-size: 14.5px; color: var(--muted); line-height: 1.85; max-width: 720px; }
.gira-desc-content p { margin-bottom: 16px; }

/* ══════════════════════════════════════════════════════════════
   RELATED PRODUCTS — fix duplicate heading + broken grid
   ══════════════════════════════════════════════════════════════ */

/* Hide WooCommerce's auto-generated "Related products" heading */
.gira-related-wrap .related.products > h2,
.gira-related-wrap .related > h2,
.gira-related-wrap h2.woocommerce-loop-product__title {
  display: none !important;
}

.gira-section-heading {
  font-family: var(--font-head);
  font-size: 28px; font-weight: 600;
  color: var(--brown); margin-bottom: 24px; letter-spacing: -.01em;
}
.gira-related-wrap { padding: 0 0 60px; }

.gira-related-wrap ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px !important;
  list-style: none !important;
  padding: 0 !important; margin: 0 !important;
  float: none !important; width: 100% !important;
}
.gira-related-wrap ul.products::after,
.gira-related-wrap ul.products::before { display: none !important; }

.gira-related-wrap ul.products li.product {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  transition: box-shadow .25s, transform .25s !important;
  float: none !important;
  width: auto !important; margin: 0 !important; padding: 0 !important;
  display: flex !important; flex-direction: column !important;
}
.gira-related-wrap ul.products li.product:hover {
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-3px) !important;
}
.gira-related-wrap ul.products li.product a img {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  display: block !important;
}
.gira-related-wrap ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-head) !important;
  font-size: 16px !important; font-weight: 600 !important;
  color: var(--brown) !important;
  padding: 14px 16px 4px !important; margin: 0 !important;
}
.gira-related-wrap ul.products li.product .price {
  display: block !important;
  padding: 0 16px 12px !important;
  font-family: var(--font-body) !important;
  font-size: 15px !important; font-weight: 700 !important;
  color: var(--gold-dark) !important; margin: 0 !important;
}
.gira-related-wrap ul.products li.product a.button,
.gira-related-wrap ul.products li.product .button {
  display: block !important;
  background: var(--green) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: 8px !important;
  font-family: var(--font-body) !important;
  font-size: 13px !important; font-weight: 600 !important;
  margin: 0 16px 16px !important;
  padding: 10px 0 !important;
  text-align: center !important;
  text-decoration: none !important;
  width: calc(100% - 32px) !important;
  transition: background .2s !important;
}
.gira-related-wrap ul.products li.product a.button:hover { background: #163a28 !important; }

/* ══════════════════════════════════════════════════════════════
   STICKY MOBILE BAR
   ══════════════════════════════════════════════════════════════ */
.gira-sticky-bar {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--white);
  border-top: 1px solid var(--border);
  padding: 10px 16px;
  box-shadow: 0 -4px 20px rgba(0,0,0,.12);
  z-index: 9999;
  gap: 10px;
  align-items: center;
}
.gira-sticky-bar .sticky-price {
  flex: 1;
  font-family: var(--font-head);
  font-size: 20px; font-weight: 700;
  color: var(--brown); line-height: 1.2;
}
.gira-sticky-bar .sticky-price small {
  font-family: var(--font-body);
  font-size: 11px; color: var(--muted); font-weight: 400; display: block;
}
.gira-sticky-bar .sticky-btn {
  background: var(--green); color: var(--white);
  border: none; border-radius: 8px;
  padding: 11px 20px;
  font-family: var(--font-body); font-size: 14px; font-weight: 600;
  cursor: pointer; transition: background .2s;
}
.gira-sticky-bar .sticky-btn:hover { background: #163a28; }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 960px) {
  .gira-product-main { grid-template-columns: 1fr; gap: 28px; padding-bottom: 40px; }
  .gira-gallery-col { position: static; }
  .gira-info-col .product_title,
  .gira-info-col h1.product_title { font-size: 28px !important; }
  .gira-tabs-wrap { padding: 24px 20px; }
  .gira-benefits-grid { grid-template-columns: 1fr 1fr; }
  .gira-process-steps { grid-template-columns: 1fr 1fr; gap: 24px; }
  .gira-process-steps::before { display: none; }
  .gira-reviews-summary { grid-template-columns: 1fr; }
  .gira-related-wrap ul.products { grid-template-columns: repeat(2, 1fr) !important; }
  .gira-sticky-bar { display: flex; }
  body.single-product { padding-bottom: 72px; }
}

@media (max-width: 600px) {
  .gira-page-wrap { padding: 0 16px; }
  .gira-info-col .product_title,
  .gira-info-col h1.product_title { font-size: 24px !important; }
  .gira-info-col p.price .woocommerce-Price-amount { font-size: 26px !important; }
  form.cart { flex-wrap: wrap !important; }
  .quantity, .quantity input.qty { width: 100% !important; }
  button.single_add_to_cart_button { width: 100% !important; height: 50px !important; }
  .gira-trust-row { grid-template-columns: repeat(2, 1fr); }
  .gira-tabs-wrap { padding: 20px 16px; border-radius: 10px; }
  .gira-tab-btn { padding: 10px 14px; font-size: 12.5px; }
  .gira-benefits-grid { grid-template-columns: 1fr; gap: 12px; }
  .gira-process-steps { grid-template-columns: 1fr 1fr; gap: 16px; }
  .gira-step .step-circle { width: 52px; height: 52px; font-size: 20px; }
  .gira-related-wrap ul.products { grid-template-columns: 1fr !important; }
  .gira-section-heading { font-size: 22px; }
  /* 2x2 thumbs on small phones */
  .flex-control-nav.flex-control-thumbs { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ── MISC WC CLEANUP ─────────────────────────────────────────── */
.woocommerce div.product { margin: 0 !important; }
.woocommerce div.product .woocommerce-product-gallery { margin: 0 !important; }

/* ═══════════════════════════════════════════════════════════════
   PATCH v4.1 — Fix tab button style + gallery thumbnail strip
   ═══════════════════════════════════════════════════════════════ */

/* ── TAB BUTTONS: remove dark pill, use clean underline style ── */
.gira-tab-btn,
.gira-tabs-nav .gira-tab-btn {
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  border-bottom: 2.5px solid transparent !important;
  border-radius: 0 !important;
  padding: 10px 20px !important;
  font-family: var(--font-body) !important;
  font-size: 13.5px !important;
  font-weight: 600 !important;
  color: var(--muted) !important;
  cursor: pointer !important;
  margin-bottom: -1.5px !important;
  white-space: nowrap !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  outline: none !important;
  text-transform: none !important;
  letter-spacing: .02em !important;
  transition: color .2s, border-color .2s !important;
}
.gira-tab-btn.active,
.gira-tabs-nav .gira-tab-btn.active {
  background: none !important;
  background-color: transparent !important;
  color: var(--brown) !important;
  border-bottom: 2.5px solid var(--gold) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.gira-tab-btn:hover:not(.active) {
  color: var(--brown-mid) !important;
  background: none !important;
}

/* ── GALLERY THUMBNAIL STRIP: force horizontal grid, kill vertical list ── */

/* Kill any theme/WC list styling on the flex slider */
.woocommerce-product-gallery .flex-control-nav,
.woocommerce-product-gallery .flex-control-thumbs,
ol.flex-control-nav,
ol.flex-control-thumbs {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 8px !important;
  list-style: none !important;
  list-style-type: none !important;
  margin: 10px 0 0 0 !important;
  padding: 0 !important;
  float: none !important;
  width: 100% !important;
  counter-reset: none !important;
}

/* Kill the number pseudo-elements from theme's ol styling */
.woocommerce-product-gallery .flex-control-thumbs li,
ol.flex-control-thumbs li {
  display: block !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
  width: auto !important;
  list-style: none !important;
  list-style-type: none !important;
  counter-increment: none !important;
}
.woocommerce-product-gallery .flex-control-thumbs li::before,
.woocommerce-product-gallery .flex-control-thumbs li::after,
ol.flex-control-thumbs li::before,
ol.flex-control-thumbs li::after,
ol.flex-control-thumbs li::marker {
  content: none !important;
  display: none !important;
}

/* Thumbnail images */
.woocommerce-product-gallery .flex-control-thumbs li img,
ol.flex-control-thumbs li img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  border-radius: 8px !important;
  border: 2px solid transparent !important;
  cursor: pointer !important;
  transition: border-color .2s !important;
  margin: 0 !important;
  padding: 0 !important;
}
.woocommerce-product-gallery .flex-control-thumbs li img.flex-active,
ol.flex-control-thumbs li img.flex-active,
.woocommerce-product-gallery .flex-control-thumbs li img:hover,
ol.flex-control-thumbs li img:hover {
  border-color: var(--gold) !important;
  outline: none !important;
}

/* ── FREE DELIVERY: fix wrong amount showing ── */
.gira-delivery-row {
  background: var(--green-light) !important;
  border-radius: var(--radius) !important;
  padding: 11px 14px !important;
  margin: 4px 0 12px !important;
  display: flex !important;
  align-items: center !important;
  gap: 11px !important;
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  color: var(--brown) !important;
}

/* ── MOBILE: thumbnail 2x2 on small screens ── */
@media (max-width: 600px) {
  .woocommerce-product-gallery .flex-control-thumbs,
  ol.flex-control-thumbs {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ── HIDE WC default shipping/meta notices (we show our own) ── */
.woocommerce-product-details__short-description + .product_meta,
.woocommerce div.product .product_meta,
.wc-item-meta,
.shipping-calculator-form,
.woocommerce-shipping-calculator {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════
   PATCH v5.2 — Rating badge + Review cards
   ═══════════════════════════════════════════════════════════ */

/* ── RATING BADGE below product title ── */
.gira-rating-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 14px;
  font-family: var(--font-body);
  flex-wrap: wrap;
}
.gira-rating-badge .grb-stars {
  display: flex;
  gap: 1px;
}
.gira-rating-badge .grb-stars .star {
  font-size: 16px;
  line-height: 1;
}
.gira-rating-badge .grb-stars .star.filled { color: #E8A020; }
.gira-rating-badge .grb-stars .star.empty  { color: #D4C5A9; }
.gira-rating-badge .grb-score {
  font-size: 14px;
  font-weight: 700;
  color: var(--brown);
}
.gira-rating-badge .grb-sep {
  color: var(--border);
  font-size: 14px;
}
.gira-rating-badge .grb-count {
  font-size: 13px;
  color: var(--gold-dark);
  text-decoration: underline;
  cursor: pointer;
}

/* ── REVIEW CARDS ── */
.gira-reviews-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 32px;
}
.gira-review-card {
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px 18px;
  transition: box-shadow .2s;
}
.gira-review-card:hover { box-shadow: var(--shadow-sm); }
.gira-review-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.gira-review-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--gold-light);
  border: 2px solid var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-head);
  font-size: 16px;
  font-weight: 700;
  color: var(--gold-dark);
  flex-shrink: 0;
}
.gira-review-meta { flex: 1; }
.gira-review-name {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--brown);
  line-height: 1.3;
}
.gira-review-date {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--muted);
}
.gira-review-stars {
  font-size: 14px;
  color: #E8A020;
  letter-spacing: 1px;
  flex-shrink: 0;
}
.gira-review-text {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 8px;
}
.gira-review-product-tag {
  font-family: var(--font-body);
  font-size: 11.5px;
  color: var(--gold-dark);
  background: var(--gold-light);
  border-radius: 4px;
  padding: 2px 8px;
  display: inline-block;
  margin-bottom: 6px;
}
.gira-review-verified {
  font-family: var(--font-body);
  font-size: 11.5px;
  font-weight: 600;
  color: var(--green-mid);
}

/* ── REVIEW FORM: hide ReviewX native form (we use comments_template) ── */
.gira-review-form-wrap { margin-top: 28px; border-top: 1px solid var(--border); padding-top: 24px; }
.gira-review-form-wrap #reviews { margin: 0 !important; }
/* Hide ReviewX duplicate display inside tabs since we show our own cards above */
.gira-review-form-wrap .rvx-review-list-wrapper { display: none !important; }

/* ── LOAD MORE BUTTON ── */
.gira-load-more-btn {
  display: block;
  width: 100%;
  margin: 20px 0 28px;
  padding: 13px;
  background: none;
  border: 1.5px solid var(--gold);
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--gold-dark);
  cursor: pointer;
  transition: background .2s, color .2s;
}
.gira-load-more-btn:hover {
  background: var(--gold-light);
  color: var(--brown);
}

/* Hide reviews that are beyond first 6 until "load more" clicked */
.gira-review-hidden { display: none !important; }

/* ── REVIEW FORM SECTION ── */
.gira-review-form-wrap {
  margin-top: 28px;
  border-top: 1.5px solid var(--border);
  padding-top: 24px;
}
.gira-form-heading {
  font-family: var(--font-head);
  font-size: 22px;
  font-weight: 600;
  color: var(--brown);
  margin-bottom: 20px;
}

/* Hide WooCommerce's OWN review list inside comments_template
   (we show our custom cards above, only need the form) */
#reviews #comments ol.commentlist { display: none !important; }
#reviews #comments h2 { display: none !important; }
#reviews .woocommerce-Reviews-title { display: none !important; }

/* Style the WC review form nicely */
#review_form_wrapper { margin: 0 !important; }
#review_form .comment-form { margin: 0 !important; }
#review_form .comment-form-author,
#review_form .comment-form-email { width: 48%; display: inline-block; }
#review_form .comment-form-author { margin-right: 2%; }
#review_form input[type="text"],
#review_form input[type="email"],
#review_form textarea {
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 10px 14px !important;
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  width: 100% !important;
  background: var(--white) !important;
  color: var(--brown) !important;
  transition: border-color .2s !important;
}
#review_form input:focus,
#review_form textarea:focus {
  border-color: var(--gold) !important;
  outline: none !important;
}
#review_form .form-submit input[type="submit"] {
  background: var(--green) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: var(--radius) !important;
  padding: 12px 28px !important;
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background .2s !important;
}
#review_form .form-submit input[type="submit"]:hover {
  background: #163a28 !important;
}

/* ═══════════════════════════════════════════════════════════════
   v5.4 — Review count badge below price + misc
   ═══════════════════════════════════════════════════════════════ */

/* ── REVIEW COUNT BADGE (between price and Add to Cart) ── */
.gira-review-count-badge {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--cream-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 14px;
  margin: 0 0 16px;
  flex-wrap: wrap;
  transition: border-color .2s;
}
.gira-review-count-badge:hover { border-color: var(--gold); }
.gira-review-count-badge .rcb-stars {
  color: #E8A020;
  font-size: 16px;
  letter-spacing: 1px;
  flex-shrink: 0;
}
.gira-review-count-badge .rcb-text {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--brown);
  flex: 1;
}
.gira-review-count-badge .rcb-text strong {
  color: var(--green);
  font-weight: 700;
}
.gira-review-count-badge .rcb-arrow {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--gold-dark);
  font-weight: 600;
  white-space: nowrap;
}

/* ── REVIEW PLATFORMS note ── */
.review-platforms {
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--muted);
  margin-top: 4px;
}

/* ── NO REVIEWS message ── */
.gira-no-reviews {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--muted);
  margin: 16px 0 24px;
  font-style: italic;
}

/* ── REVIEW NOTICE (not logged in / not purchased) ── */
.gira-review-notice {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--muted);
  background: var(--cream-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 16px;
  margin: 16px 0;
}
.gira-review-notice a {
  color: var(--green);
  font-weight: 600;
  text-decoration: underline;
}

/* ── Hide WC own review list, keep form only ── */
#reviews #comments ol.commentlist { display: none !important; }
#reviews #comments > h2 { display: none !important; }
#reviews .woocommerce-Reviews-title { display: none !important; }
#reviews .comment-reply-title { display: none !important; }

/* ── No reviews box ── */
.gira-no-reviews-box {
  background: var(--cream-deep);
  border: 1px dashed var(--border);
  border-radius: var(--radius);
  padding: 24px;
  text-align: center;
  margin-bottom: 24px;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--muted);
}

/* ── Review photo inside card ── */
.gira-review-photo {
  margin: 10px 0;
}
.gira-review-photo img {
  max-width: 120px;
  max-height: 120px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid var(--border);
}
