/*
Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
Click nbfs://nbhost/SystemFileSystem/Templates/Other/CascadeStyleSheet.css to edit this template
*/
/* 
    Created on : 12-Aug-2023, 11:05:37 am
    Author     : naeem.tabsyst
*/

.floverfy-product-listing-card-img-container img {
  object-fit: contain;
  object-position: center;
  height: 172px;
  min-height: 170px;
  width: 160px;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.floverfy-product-listing-card {
  box-shadow: 0px 0px 35px 0px rgba(0, 0, 0, 0.05);
}

.floverfy-product-listing-card:not([data-card_type="list"]) {
  box-shadow: 0px 0px 35px 0px rgba(0, 0, 0, 0.05);
}
.variants-container {
  border: 0.5px solid var(--fv-border-default);
  height: 250px;
}

.variants-container .product-content-wrap {
  padding: 5px;
}
.floverfy-product-listing-card-name,
.pname-listing a {
  text-decoration: none;
  /*color:var(--fv-text-black);*/
  color: #151515;
  /*text-transform: uppercase;*/
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  height: 3.9rem;
  font-size: 16px;
  font-weight: 600;
  line-height: normal;
  letter-spacing: -0.18px;
}
.floverfy-prodt-flavour-name {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
.floverfy-product-listing-card-content {
  padding: 19px;
}
.floverfy-product-listing-card-brand-name {
  text-decoration: none;
  font-size: 14px;
  white-space: nowrap;
  width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block;
  text-align: left;
  font-weight: 400;
  line-height: normal;
  /* letter-spacing: 1.4px; */
}
.floverfy-product-listing-card-brand-name a {
  text-decoration: none;
  color: #151515;
}
.old-price-listing {
  text-decoration: line-through !important;
  color: #15151580;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: -0.18px;
}
.new-price-listing {
  color: #151515;
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  letter-spacing: -0.18px;
}
.floverfy-product-grid {
  /* border: 0.5px solid var(--fv-border-default); */
}
@media (min-width: 992px) {
    
  .floverfy-product-grid {
    border: none;
  }

  .floverfy-product-listing-card {
    box-shadow: 0px 0px 35px 0px rgba(0, 0, 0, 0.05);
  }
  
}

.floverfy-mobile-filter-sticky {
  width: 100%;
  position: fixed;
  height: 62px;
  padding: 15px 20px 15px 20px;
  bottom: 0;
  z-index: 100;
  background-color: rgb(var(--fv-bg-secondary-rgb));
}

/* ── Hide old fixed-bottom mobile bar on mobile — replaced by fv-mob-filter-bar ── */
@media (max-width: 991.98px) {
  /* Collapse the sticky container but keep offcanvas children accessible in DOM */
  .floverfy-mobile-filter-sticky {
    position: static !important;
    height: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    background: transparent !important;
    z-index: auto !important;
  }
  /* Hide only the button rows — not the offcanvas panels inside */
  .floverfy-mobile-filter-hidden-actions,
  .floverfy-mobile-filter-shown-actions {
    display: none !important;
  }
}

/* ── New in-flow mobile filter/sort bar ── */
.fv-mob-filter-bar {
  border-top: 1px solid var(--ink-200, #e5e7eb);
  border-bottom: 1px solid var(--ink-200, #e5e7eb);
  padding: 10px 0;
  margin-left: -12px;
  margin-right: -12px;
  padding-left: 12px;
  padding-right: 12px;
  overflow-x: auto;
  flex-wrap: nowrap;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none; /* hide scrollbar on Firefox */
}
.fv-mob-filter-bar::-webkit-scrollbar {
  display: none; /* hide scrollbar on Chrome/Safari */
}
.fv-mob-filter-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 9px 16px;
  background: #fff;
  border: 1px solid var(--ink-200, #e5e7eb);
  border-radius: 8px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--ink-900, #111);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.fv-mob-filter-btn:hover,
.fv-mob-sort-btn:hover {
  border-color: var(--navy, #1a3147);
  background: var(--ink-50, #f9fafb);
}
.fv-mob-sort-btn {
  justify-content: space-between;
}
.br-05 {
  border-right: 0.5px solid var(--fv-border-default);
}
.bl-05 {
  border-left: 0.5px solid var(--fv-border-default);
}

.floverfy-sticky-filters-container {
  position: fixed;
  top: 0;
  z-index: 101;
  width: 100%;
  padding: 0px;
  height: calc(100vh - 62px);
  overflow-x: auto;
  background-color: white;
}

/*old*/

.filter-section-view-less {
  max-height: 150px;
  overflow-y: auto;
  padding: 5px;
}
.filter-section-view-less::-webkit-scrollbar-thumb {
  border-radius: 10px;
  background-color: #fff;
  background-image: -webkit-gradient(
    linear,
    40% 0%,
    75% 84%,
    from(var(--fv-main-website-theme)),
    to(var(--fv-main-website-theme)),
    color-stop(0.6, var(--fv-main-website-theme))
  );
}
.filter-section-view-less::-webkit-scrollbar-track {
  -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.1);
  background-color: #f5f5f5;
  border-radius: 10px;
}

.filter-section-view-less::-webkit-scrollbar {
  width: 10px;
  background-color: #f5f5f5;
}
.selected-filter-badge-item-wrap {
  padding: 5px;
  border-radius: 5px;
  background-color: gainsboro;
  margin-right: 2px;
  margin-bottom: 2px;
}
.selected-filter-badge-item-wrap > .badge-filter-name,
.badge-filter-remove {
  font-weight: bold;
}
/* .selected-filter-badge-item-wrap[data-type="category"] {
  background-color: var(--fv-main-website-theme) !important;
  color: white;
} */
.selected-filter-badge-item-wrap[data-type="brand"] {
  /* background-color: #db8cd7 !important;
  color: white; */
}
.brand-series-links-container {
  /*border: 1px solid;*/
  /*font-size: 0.6rem;*/
  padding-right: 2px;
  /*border-radius: 5px;*/
  height: 1rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 2px 4px 2px 4px;
  border-right: 1px solid;
}
.brand-series-links-container:first-child {
  border-left: 1px solid;
}
.brand-series-link {
  font-size: 12px !important;
  font-weight: normal;
}
.brand-series-row {
  /*gap: 2px;*/
}
/*old end*/

.floverfy-product-listing-card-img-container {
  padding-top: 1.1875rem;
}












/* ══════════════════════════════════════
   PRODUCT CARD  — START
   ══════════════════════════════════════ */

/* Card shell */
.product-card {
  background: #fff;
  border: 1px solid var(--ink-200, #e5e5e5);
  border-radius: 14px;
  overflow: hidden;
  display: flex !important;
  flex-direction: column !important;
  position: relative;
  box-shadow: none !important;
  margin-bottom: 0;
  transition: box-shadow 0.2s, border-color 0.2s, transform 0.2s;
  height: 100%;
}
.product-card:hover {
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.10) !important;
  border-color: var(--teal-600, #1aa69f);
  transform: translateY(-2px);
}

/* Image area — scoped to win over old responsive @media rules */
.product-card .card-image {
  position: relative;
  background: #fff;
  border-bottom: 1px solid var(--ink-200, #e5e5e5);
  aspect-ratio: 1 / 1;
  display: grid !important;
  place-items: center;
  padding: 22px !important;
  min-height: unset !important;
  border-radius: 0 !important;
  overflow: hidden;
  flex-shrink: 0;
}

.product-card .card-image img {
  max-width: 90%;
  max-height: 90%;
  width: auto !important;
  height: auto !important;
  max-height: unset;
  object-fit: contain;
  position: relative;
  z-index: 1;
}

/* Badge overlays */
.product-card .fv-product-badge-top-left { z-index: 2; }
.product-card .fv-product-badge-top-right { z-index: 2; }
.product-card .fv-product-badge-bottom-left { z-index: 2; }
.product-card .fv-product-badge-bottom-right { z-index: 2; }

/* Below-image badge row: reordered AFTER card-body using CSS order.
   DOM order: img -> [badge div] -> card-body -> shop-btn
   Visual order via CSS: img(1) -> card-body(2) -> [badge as flavour text](3) -> shop-btn(4) */
.product-card .card-image + div {
  order: 3;
  min-height: 0 !important;
  max-height: 0;
  overflow: hidden;
  padding: 0;
  flex-shrink: 0;
}
.product-card .card-image + div:has(span) {
  max-height: 22px;
  padding: 0 14px 8px;
  display: block !important;
  font-size: 11.5px;
  color: var(--ink-600, #555);
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
/* Strip badge pill styling => plain flavour-line grey text */
.product-card .card-image + div .badge,
.product-card .card-image + div span {
  background: none !important;
  color: var(--ink-600, #555) !important;
  border-radius: 0 !important;
  padding: 0 !important;
  font-size: 11.5px !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  border: none !important;
  display: inline !important;
}

/* Explicit flex order for card children */
.product-card .card-image { order: 1; }
.product-card .card-body  { order: 2; }
.product-card .shop-btn   { order: 4; }

/* Equal-height cards: Bootstrap col wrappers become flex so height:100% fills row */
.floverfy-product-grid > [class*="col"] {
  display: flex;
  flex-direction: column;
}

/* @media (max-width: 767px) {
  .floverfy-product-grid > [class*="col"] {
    padding : .25rem !important;
  }
} */

/* ── Mobile: tighter gap between product cards ── */
/* @media (min-width: 768px) {
  .floverfy-product-grid > [class*="col"] {
    padding : .5rem !important;
  }
} */


/* Card body — scope beats Bootstrap .card-body padding:1rem */
.product-card .card-body {
  position: relative;
  z-index: 2;
  padding: 12px 14px 0 !important;
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto;
  gap: 6px;
  background: #fff;
  border-radius: 0 !important;
}

/* Product name */
.product-card .card-name {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 13.5px !important;
  font-weight: 600 !important;
  color: var(--ink-900, #111) !important;
  line-height: 1.35 !important;
  margin-bottom: 0;
  height: 36px;
}
.product-card .card-name a {
  text-decoration: none;
  color: var(--ink-900, #111);
}

/* Rating row */
.product-card .product-rate-cover {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  color: var(--ink-600, #555);
  min-height: 18px;
  margin-bottom: 0;
}
/* Star track */
.product-card .product-rate {
  display: inline-flex;
  align-items: center;
  position: relative;
  width: 65px;
  height: 12px;
  overflow: hidden;
}
.product-card .product-rate::before {
  content: "★★★★★";
  position: absolute;
  top: 0; left: 0;
  color: #e5e5e5;
  font-size: 13px;
  letter-spacing: 1px;
  line-height: 1;
}
.product-card .product-rating {
  position: absolute;
  top: 0; left: 0;
  height: 100%;
  overflow: hidden;
  white-space: nowrap;
  color: rgb(226, 165, 43);
  font-size: 13px;
  letter-spacing: 1px;
  line-height: 1;
}
.product-card .product-rating::before {
  content: "★★★★★";
}

/* Price row */
.product-card .card-price {
  display: flex !important;
  align-items: baseline;
  gap: 6px;
  flex-wrap: wrap;
  font-size: 18px !important;
  font-weight: 800 !important;
  letter-spacing: -0.01em;
  color: var(--ink-900, #111) !important;
  margin-bottom: 0;
}
.product-card .card-price .fv-listing-sale-price-container {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
}
.product-card .card-price .old-price-listing {
  font-size: 12px !important;
  color: var(--ink-400, #999) !important;
  text-decoration: line-through !important;
  font-weight: 400 !important;
}
.product-card .card-price .fv-listing-perc-off {
  font-size: 11px;
  font-weight: 700;
  color: var(--teal-600, #1aa69f);
  background: rgba(26, 166, 159, 0.12);
  border-radius: 4px;
  padding: 2px 6px;
  letter-spacing: 0;
}

/* Tags / brand options — rendered as specs grid */
.product-card .card-brand-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
  border: 1px solid var(--ink-200, #e5e5e5);
  border-radius: 8px;
  overflow: hidden;
  height: 28px;
  margin-bottom: 0;
  gap: 0;
}
.product-card .brand-tag,
.brand-tag {
  padding: 7px 0;
  text-align: center;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ink-700, #333);
  background: var(--ink-50, #f5f6f7);
  border: none;
  border-radius: 0;
  border-right: 1px solid var(--ink-200, #e5e5e5);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.product-card .brand-tag:last-child {
  border-right: none;
}


/* CTA button */
.product-card .shop-btn,
.shop-btn {
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-top: auto;
  padding: 12px 0;
  font-size: 13px;
  font-weight: 600;
  color: #fff !important;
  background: var(--navy, #0f2236) !important;
  border: none !important;
  border-top: 1px solid var(--ink-200, #e5e5e5) !important;
  border-radius: 0 !important;
  cursor: pointer;
  text-align: center;
  text-decoration: none !important;
  letter-spacing: 0.02em;
  transition: background 0.18s;
}
.product-card .shop-btn:hover,
.shop-btn:hover {
  background: var(--teal-600, #1aa69f) !important;
  color: #fff !important;
}
.product-card .shop-btn:active { transform: scale(0.98); }

/* Misc legacy */
.product-options {
  display: flex;
  gap: 8px;
  margin-bottom: 0;
  flex-wrap: wrap;
}
.option-tag {
  background: var(--ink-50, #f5f6f7);
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ink-700, #333);
}
.card-price-original {
  text-decoration: line-through;
  color: var(--ink-400, #999);
  font-size: 13px;
  font-weight: 400;
}

/* ══════════════════════════════════════
   PRODUCT CARD  — END
   ══════════════════════════════════════ */


.grid-view-card {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 16px;
}

@media (max-width: 639px) {
  .grid-view-card {
    grid-template-columns: 1fr;
    margin: 0 16px;
  }
}

@media (min-width: 640px) {
  .grid-view-card {
    grid-template-columns: repeat(2, 1fr);
        margin: 0 32px;
  }
}

@media (min-width: 768px) {
  .grid-view-card {
    grid-template-columns: repeat(3, 1fr);
    margin: 0 48px;
  }
}

@media (min-width: 1024px) {
  .grid-view-card {
    grid-template-columns: repeat(5, 1fr);
    margin: 0 68px;
  }
}

@media (min-width: 1280px) {
      .grid-view-card {
        grid-template-columns: repeat(6, 1fr);
      }
    }

/* ═════════════════════════════════════════════════════
   Sidebar Filter Panel  (.fv-sidebar-filter-panel)
   Matches the "Puff count / Brand / Price / Flavour" reference design
   ═════════════════════════════════════════════════════ */

.fv-sidebar-filter-panel {
  background: #fff;
  /* border: 1px solid var(--ink-200, #e5e7eb); */
  border-radius: 12px;
  overflow: hidden;
}

/* Panel header ("Filters" title) */
.fv-sfp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 18px 14px;
  border-bottom: 1px solid var(--ink-200, #e5e7eb);
}
.fv-sfp-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--ink-900, #111);
  letter-spacing: 0.01em;
}
.fv-sfp-close { color: var(--ink-500, #6b7280); font-size: 16px; }

/* Each filter section */
.fv-sfp-section {
  border-bottom: 1px solid var(--ink-200, #e5e7eb);
}
.fv-sfp-section:last-child { border-bottom: none; }

/* Section header row (click to collapse) */
.fv-sfp-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 18px;
  cursor: pointer;
  user-select: none;
  transition: background 0.12s;
}
.fv-sfp-section-header:hover { background: var(--ink-50, #f9fafb); }

.fv-sfp-section-title {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ink-900, #111);
}
.fv-sfp-toggle-icon {
  font-size: 17px;
  font-weight: 400;
  color: var(--ink-500, #6b7280);
  line-height: 1;
}

/* Section body (checkbox list area) */
.fv-sfp-section-body {
  padding: 4px 18px 14px;
  max-height: 260px;
  overflow-y: auto;
}

/* ── Make filter checkboxes look like the reference design ── */
/* The JS filter system injects label+checkbox rows — target them */
.fv-sfp-section-body label,
.fv-sfp-section-body .form-check-label {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 13.5px;
  color: var(--ink-800, #1f2937);
  padding: 5px 0;
  cursor: pointer;
  line-height: 1.4;
}
.fv-sfp-section-body input[type="checkbox"] {
  width: 16px;
  height: 16px;
  border: 1.5px solid var(--ink-300, #d1d5db);
  border-radius: 3px;
  accent-color: var(--teal-600, #1aa69f);
  flex-shrink: 0;
  cursor: pointer;
}
/* Count badge in parentheses */
.fv-sfp-section-body .filter-count,
.fv-sfp-section-body .fv-filter-count {
  color: var(--teal-600, #1aa69f);
  font-size: 12.5px;
  margin-left: 2px;
}

/* Price slider overrides inside panel */
.fv-sidebar-filter-panel .price-filter-inner { padding: 0 2px; }
.fv-sidebar-filter-panel .caption {
  font-size: 12px;
  color: var(--ink-600, #4b5563);
}
.fv-sidebar-filter-panel .text-brand { color: var(--teal-600, #1aa69f) !important; }

/* Scrollbar styling for filter lists */
.fv-sfp-section-body::-webkit-scrollbar { width: 4px; }
.fv-sfp-section-body::-webkit-scrollbar-track { background: transparent; }
.fv-sfp-section-body::-webkit-scrollbar-thumb { background: var(--ink-200, #e5e7eb); border-radius: 99px; }

/* ═════════════════════════════════════════════════════
   Active Filter Chips  (.fv-active-filter-chip)
   Pill-style selected-filter badges (Hayati × | Clear all)
   ═════════════════════════════════════════════════════ */

.selected-filters-badge-container {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

/* Base pill chip */
.fv-active-filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 13px;
  background: rgba(15, 34, 54, 0.06);
  border: 1px solid rgba(15, 34, 54, 0.18);
  color: var(--navy, #1a3147);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
  line-height: 1.4;
  cursor: default;
  text-decoration: none;
}

/* The × remove button inside each chip */
.fv-chip-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 2px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  color: var(--navy, #1a3147);
  opacity: 0.55;
  text-decoration: none;
  transition: opacity 0.15s;
}
.fv-chip-remove:hover { opacity: 1; color: var(--navy, #1a3147); }

/* "Clear all" chip — outlined, neutral style */
.fv-chip-clear {
  background: transparent;
  border-color: var(--ink-300, #d1d5db);
  color: var(--ink-700, #374151);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.fv-chip-clear:hover {
  background: var(--ink-50, #f9fafb);
  border-color: var(--ink-400, #9ca3af);
}



/* ── Page heading override for product listing pages ── */
@media (max-width: 767px) {
  .categoryHeader {
    margin: 0;
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.1;
    color: #0f2236;
  }
}
@media (min-width: 768px) {
  .categoryHeader {
    margin: 0;
    font-size: 36px;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.1;
    color: #0f2236;
  }
}

.prodtFilterCount {
    font-size: 13px;
    color: #7089a6;
}

/* ── Mobile: h1 + product count inline ── */
/* Flex row wrapping the h1 and the mobile count copy */
.pv-category-header-row {
    display: flex;
    align-items: flex-start;        /* count stays top-aligned when title wraps */
    justify-content: space-between;
    gap: 10px;                      /* guaranteed space between title and count */
}

/* h1 is allowed to shrink and wrap — min-width:0 prevents flex overflow */
.pv-category-header-row .categoryHeader {
    min-width: 0;
    flex: 1 1 auto;
}

/* Mobile-only count copy: hidden on desktop */
.pv-mob-count {
    display: none;
}

@media (max-width: 767px) {
    /* Show the inline count on mobile */
    .pv-mob-count {
        display: inline-flex;
        align-items: center;
        gap: 3px;
        font-size: 12px;
        color: #7089a6;
        white-space: nowrap;
        flex-shrink: 0;
    }

    /* Hide the original count in the sort-bar on mobile (replaced by inline copy) */
    .d-flex .prodtFilterCount:not(.pv-mob-count) {
        display: none !important;
    }
}

/* ═════════════════════════════════════════════════════
   FAQ Section  (.fv-faq-section)
   Two-column card grid with smooth open/close toggle
   ═════════════════════════════════════════════════════ */

.fv-faq-section {
  padding: 48px 32px 64px;
  border-top: 1px solid #dbe1e9;
  background: #fff;
}

.fv-faq-inner {
  margin: 0 auto;
}

/* Header block */
.fv-faq-head {
  text-align: center;
  margin-bottom: 28px;
}
.fv-faq-eyebrow {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--navy, #1a3147);
  font-weight: 700;
  margin-bottom: 8px;
}
.fv-faq-title {
  margin: 0;
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink-900, #111);
}

/* Two-column grid */
.fv-faq-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 767px) {
  .fv-faq-section { padding: 32px 16px 48px; }
  .fv-faq-grid { grid-template-columns: 1fr; }
}

/* Individual card */
.fv-faq-card {
  border: 1px solid #dbe1e9;
  border-radius: 12px;
  overflow: hidden;
  transition: background 0.2s;
}

/* Toggle button */
.fv-faq-btn {
  width: 100%;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 16px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  text-align: left;
  color: var(--ink-900, #111);
}
.fv-faq-btn:focus { outline: none; }

.fv-faq-q {
  font-size: 14.5px;
  font-weight: 700;
  line-height: 1.4;
}

/* Circle icon */
.fv-faq-icon {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 1px solid var(--ink-300, #d1d5db);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  transition: transform 0.25s, background 0.2s, color 0.2s;
}

/* Collapsible answer body */
.fv-faq-body {
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.fv-faq-body-inner {
  padding: 0 20px 18px;
  font-size: 13.5px;
  line-height: 1.65;
  color: var(--ink-700, #374151);
}

/* ═════════════════════════════════════════════════════
   Breadcrumb  (.fv-breadcrumb-container)
   Inline row: Home / Category / <strong>Current</strong>
   ═════════════════════════════════════════════════════ */

.fv-breadcrumb-container {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  list-style: none;
  padding: 0;
  margin: 0 0 6px;
  font-size: 12px;
  color: var(--ink-500, #6b7280);
}

.fv-breadcrumb-item {
  display: inline-flex;
  align-items: center;
}

/* Separator "/" injected by CSS — no HTML change needed */
.fv-breadcrumb-item + .fv-breadcrumb-item::before {
  content: "/";
  margin: 0 4px;
  color: var(--ink-300, #d1d5db);
  font-weight: 400;
}

/* Ancestor links */
.fv-breadcrumb-link {
  color: var(--ink-500, #6b7280);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.15s;
}
.fv-breadcrumb-link:hover {
  color: var(--navy, #1a3147);
  text-decoration: none;
}

/* Current page (last item) — generator outputs <span> with same class */
.fv-breadcrumb-item:last-child .fv-breadcrumb-link {
  font-weight: 700;
  color: var(--ink-900, #111);
  pointer-events: none;
}
