/* ============================================================
   FH Collection V2 — Modern Redesign
   Extracted from inline + v2 design (rounded, floating drawer)
   ============================================================ */

/* ── CSS Variables ── */
:root {
  --fh-radius: 8px;
  --fh-radius-xl: 16px;
  --fh-shadow: 0 4px 12px rgba(0,0,0,0.08);
  --fh-shadow-lg: 0 8px 24px rgba(0,0,0,0.12);
  --fh-transition: 0.2s ease;
}

/* ── Collection Grid Layout ── */
.collection { display: grid; grid-template-columns: minmax(0,1fr); }
@media (min-width:1000px) {
  .collection--with-sidebar { grid-template-columns: var(--collection-sidebar-width,240px) minmax(0,1fr); gap: 2.5rem; }
}

/* ── Banner ── */
.fh-coll-banner { display: grid; grid-template-columns: 1fr; gap: 0; align-items: stretch; }
.fh-coll-banner__left { background: var(--fh-coll-bg, #faf8f6); padding: 28px 52px; display: flex; align-items: center; justify-content: center; }
.fh-coll-banner__left .prose,
.fh-coll-banner__content { margin: 0 auto; max-width: 560px; text-align: center; }
.fh-coll-banner__left h1,
.fh-coll-banner__title { font-weight: 300; font-size: 25px; line-height: 1.06; letter-spacing: .03em; margin: 0 0 16px; text-transform: capitalize; }
.fh-coll-banner__left .collection-description,
.fh-coll-banner__desc { margin-top: 0; line-height: 1.8; font-size: 15px; font-weight: 300; opacity: .92; }
.fh-coll-banner__right { position: relative; overflow: hidden; height: clamp(260px,46vw,360px); }
.fh-coll-banner__img { display: block; width: 100%; height: 100%; object-fit: cover; }
@media (min-width:900px) {
  .fh-coll-banner { grid-template-columns: 40% 60%; }
  .fh-coll-banner__right { height: clamp(340px,26vw,520px); }
}
@media (max-width:899px) {
  .fh-breadcrumb { display: none !important; }
  .fh-coll-banner { display: flex; flex-direction: column; }
  .fh-coll-banner__right { order: 1; }
  .fh-coll-banner__left { order: 2; padding: 22px 24px; }
  .fh-coll-banner__left h1,
  .fh-coll-banner__title { font-size: clamp(20px,9vw,25px); margin-bottom: 12px; }
  .fh-coll-banner__left .collection-description,
  .fh-coll-banner__desc { font-size: 13px; line-height: 1.65; }
}

/* ── Breadcrumbs ── */
.fh-breadcrumb { font-size: 11px; letter-spacing: 0.02em; }
.fh-breadcrumb a { color: rgba(0,0,0,0.4); text-decoration: none; transition: color 0.15s; }
.fh-breadcrumb a:hover { color: rgba(0,0,0,0.8); }

/* ── Toolbar ── */
.collection-toolbar {
  min-height: 3em;
  box-shadow: 0 1px rgb(var(--border-color,217 215 213)), 0 -1px rgb(var(--border-color,217 215 213));
  background-color: rgb(var(--background,250 248 246));
  display: flex; align-items: center;
  position: sticky; top: var(--sticky-area-height,0px); z-index: 2;
  margin-bottom: 1.5rem;
}
.collection-toolbar__button-list { display: flex; }
.collection-toolbar__button {
  padding-block: .75rem; opacity: .5; transition: opacity var(--fh-transition);
  background: none; border: none; cursor: pointer;
  font-family: var(--heading-font-family); font-size: var(--text-xxs,.6875rem);
  letter-spacing: .18em; text-transform: uppercase; color: inherit;
}
.collection-toolbar__button:hover,
.collection-toolbar__button.is-active { opacity: 1; }
.collection-toolbar__button-container { width: 100%; position: relative; }
.collection-toolbar__button-container + .collection-toolbar__button-container {
  border-inline-start: 1px solid rgb(var(--border-color,217 215 213));
}
.collection-toolbar__layout-switch-list {
  border-inline-start: 1px solid rgb(var(--border-color,217 215 213));
  justify-content: flex-end; align-items: center; gap: 1rem; padding-inline: 1.25rem; display: flex;
}
@media (min-width:700px) {
  .collection-toolbar { flex-direction: row-reverse; justify-content: space-between; }
  .collection-toolbar__button { padding-block: 1.125rem; }
  .collection-toolbar__button-list { flex-direction: row-reverse; flex: 0 0 auto; }
  .collection-toolbar__button-container { border-inline-start: 1px solid rgb(var(--border-color,217 215 213)); }
  .collection-toolbar__button-container:has(#sort-by-trigger) { width: 18rem; flex: 0 0 18rem; }
  .collection-toolbar__button-container > .collection-toolbar__button { width: 100%; padding-inline: 2.875rem; display: flex; justify-content: center; align-items: center; }
  .collection-toolbar__layout-switch-list { border-inline-width: 0 1px; padding-inline: 1.875rem; }
  .collection-toolbar__products-count { position: absolute; inset-block-start: 50%; inset-inline-start: 50%; transform: translate(-50%,-50%); }
}
.collection-toolbar__layout-switch-list[data-device="mobile"] { display: none; }
.collection-toolbar__layout-switch-list[data-device="desktop"] { display: flex; }
@media (max-width:699px) {
  .collection-toolbar__layout-switch-list[data-device="mobile"] { display: flex; }
  .collection-toolbar__layout-switch-list[data-device="desktop"] { display: none; }
  .collection-toolbar__products-count { display: none; }
}
.collection-toolbar__filter-container { display: none; }
@media (max-width:999px) { .collection-toolbar__filter-container { display: block; } }

/* ── Sort Popover ── */
.sort-popover {
  display: none; position: absolute; top: 100%; left: -1px; right: -1px;
  background: #FAF8F6; border: 1px solid rgb(var(--border-color,217 215 213));
  border-radius: 0 0 var(--fh-radius) var(--fh-radius);
  box-shadow: var(--fh-shadow);
  z-index: 2; margin-top: 0; overflow: hidden;
}
.sort-popover.is-open { display: block; }
.sort-popover__header { padding: 1rem 1.25rem .75rem; font-family: var(--heading-font-family); font-size: var(--text-sm); text-transform: uppercase; letter-spacing: .18em; border-bottom: 1px solid rgb(var(--border-color,217 215 213)); }
.sort-popover__option {
  display: block; width: 100%; padding: .65rem 1.25rem; border: none; background: none;
  text-align: left; font-family: inherit; font-size: var(--text-sm); cursor: pointer;
  color: inherit; opacity: .7; transition: opacity .15s, background .15s;
}
.sort-popover__option:hover { opacity: 1; background: rgb(var(--border-color,217 215 213) / .2); }
.sort-popover__option.is-selected { opacity: 1; font-weight: 600; }

/* Sort — mobile: bottom sheet with rounded top */
@media (max-width:999px) {
  .sort-popover {
    position: fixed !important; top: auto !important; bottom: 0 !important;
    left: 0 !important; right: 0 !important; width: 100% !important;
    border: none; border-radius: var(--fh-radius-xl) var(--fh-radius-xl) 0 0;
    box-shadow: 0 -4px 20px rgba(0,0,0,0.1);
    z-index: 1003; transform: translateY(100%);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
    display: block !important; padding-bottom: env(safe-area-inset-bottom, 1rem);
  }
  .sort-popover.is-open { transform: translateY(0) !important; }
  .sort-popover__header-mobile {
    display: flex; align-items: center; justify-content: center; position: relative;
    padding: 1.25rem; border-bottom: 1px solid rgb(var(--border-color,217 215 213));
    font-family: var(--heading-font-family); font-size: 1rem; text-transform: uppercase;
    letter-spacing: .12em; font-weight: 400;
  }
  .sort-popover__header-mobile button {
    position: absolute; right: 1.25rem; top: 50%; transform: translateY(-50%);
    background: none; border: 1px solid rgb(var(--border-color,217 215 213));
    width: 36px; height: 36px; border-radius: 9999px; cursor: pointer; padding: 0;
    display: inline-flex; align-items: center; justify-content: center;
    transition: border-color var(--fh-transition), background var(--fh-transition);
  }
  .sort-popover__header-mobile button:hover { background: rgba(0,0,0,0.03); border-color: #ccc; }
  .sort-popover__option { padding: .875rem 1.5rem; font-size: 1rem; }
  .sort-overlay { display: none; position: fixed; inset: 0; z-index: 1002; background: rgba(0,0,0,0.4); backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px); }
  .sort-overlay.is-open { display: block; }
}
@media (min-width:1000px) { .sort-popover__header-mobile { display: none; } .sort-overlay { display: none !important; } }

/* ── Facets Sidebar (Desktop) ── */
.facets-sidebar { position: sticky; top: calc(var(--sticky-area-height,80px) + 3.5rem); align-self: start; padding-right: .5rem; }
@media (max-width:999px) { .facets-sidebar { display: none; } }
.facets-sidebar .accordion__toggle {
  list-style: none; cursor: pointer; justify-content: space-between; align-items: center;
  column-gap: .625rem; padding-block: 1.5rem; display: flex;
}
.facets-sidebar .accordion__toggle::-webkit-details-marker { display: none; }
.facets-sidebar .accordion__toggle svg { flex-shrink: 0; transition: transform .2s ease; }
.facets-sidebar details[open] > .accordion__toggle svg { transform: rotate(180deg); }
.facets-sidebar .accordion__content { margin-block-start: -.25rem; padding-block-end: 1.25rem; padding-inline-end: 1.25rem; }
.facets-sidebar .accordion-list > accordion-disclosure > details { display: block; }
.facets-sidebar .accordion-list > accordion-disclosure:last-child > details { border-bottom: none; }
.facets-sidebar .link-faded,
.facets-sidebar a {
  color: rgba(0,0,0,.5); font-size: var(--text-sm,.8125rem);
  transition: color .2s ease, padding-left .25s ease;
  display: flex; align-items: center; gap: 6px;
}
.facets-sidebar .link-faded:hover,
.facets-sidebar a:hover { color: #000 !important; opacity: 1 !important; }

/* Filter active dot */
.fh-filter-dot { font-size: 8px; line-height: 1; opacity: 0; width: 0; overflow: hidden; transition: opacity .25s ease, width .25s ease, margin .25s ease; margin-right: -6px; }
.fh-filter-link.is-active .fh-filter-dot { opacity: 1; width: 10px; margin-right: 0; }
.fh-filter-link.is-active { color: #000; padding-left: 2px; }
.fh-filter-link--color.is-active { font-weight: 600; padding-left: 0; }

/* ── Color Dots ── */
.fh-color-dot { width: 16px; height: 16px; border-radius: 9999px; flex: 0 0 16px; border: 1px solid rgba(0,0,0,0.12); display: inline-block; vertical-align: middle; background: #cfc7bc; }
.fh-color-dot--black { background: #1c1c1c; }
.fh-color-dot--white { background: #f7f5ef; border-color: rgba(0,0,0,0.18); }
.fh-color-dot--gray, .fh-color-dot--grey { background: #9a9a9a; }
.fh-color-dot--beige { background: #d8c3a5; }
.fh-color-dot--brown { background: #7a5a43; }
.fh-color-dot--orange { background: #d9853b; }
.fh-color-dot--yellow { background: #d4af37; }
.fh-color-dot--green { background: #8fa27a; }
.fh-color-dot--turquoise { background: #58b7b2; }
.fh-color-dot--blue { background: #6f8fa8; }
.fh-color-dot--pink { background: #d8a7ad; }
.fh-color-dot--red { background: #b84b4b; }
.fh-color-dot--purple { background: #7e648a; }
.fh-color-dot--neutral { background: #c5beb5; }
.fh-color-dot--cream { background: #efe6d6; }
.fh-color-dot--navy { background: #334a64; }

/* Color filter: 3-column grid (desktop sidebar) */
.accordion__content:has(.fh-color-dot) { display: grid !important; grid-template-columns: repeat(3,1fr); gap: 10px 6px !important; }
.accordion__content:has(.fh-color-dot) a { flex-direction: column; align-items: center; text-align: center; gap: 5px !important; font-size: .7rem; line-height: 1.2; padding: 4px 2px; border-radius: 4px; transition: background .15s, color .2s; }
.accordion__content:has(.fh-color-dot) a:hover { background: rgba(0,0,0,.04); }
.accordion__content:has(.fh-color-dot) .fh-color-dot { width: 22px; height: 22px; flex: 0 0 22px; }

/* Color filter: mobile drawer (side by side) */
.facets-drawer__body .accordion__content:has(.fh-color-dot) { grid-template-columns: repeat(3,1fr); gap: 14px 6px !important; }
.facets-drawer__body .accordion__content:has(.fh-color-dot) a { flex-direction: row; align-items: center; text-align: left; gap: 10px !important; font-size: .75rem; padding: 2px 4px; justify-content: flex-start; }
.facets-drawer__body .accordion__content:has(.fh-color-dot) .fh-color-dot { width: 20px; height: 20px; flex: 0 0 20px; }

/* ── Filter Drawer (Mobile — LEFT, floating, rounded) ── */
.facets-drawer-overlay {
  display: none; position: fixed; inset: 0; z-index: 1002;
  background: rgba(0,0,0,0.4);
  backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px);
}
.facets-drawer-overlay.is-open { display: block; }
.facets-drawer {
  position: fixed;
  top: 12px; left: 12px; bottom: 12px;
  width: min(340px, calc(85vw - 24px));
  z-index: 1003;
  background: rgb(var(--background,250 248 246));
  border-radius: var(--fh-radius-xl);
  transform: translateX(calc(-100% - 12px));
  transition: transform .35s cubic-bezier(.4,0,.2,1);
  display: flex; flex-direction: column;
  box-shadow: var(--fh-shadow-lg);
  overflow: hidden;
}
.facets-drawer.is-open { transform: translateX(0); }
.facets-drawer__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 20px 16px; flex-shrink: 0;
}
.facets-drawer__header h4 {
  font-family: var(--heading-font-family); font-size: 15px;
  text-transform: uppercase; letter-spacing: .12em; font-weight: 400; margin: 0;
}
.facets-drawer__close {
  appearance: none; background: #fff; cursor: pointer; padding: 0; color: inherit; line-height: 0;
  width: 36px; height: 36px; border-radius: 9999px;
  border: 1px solid rgb(var(--border-color,217 215 213));
  display: inline-flex; align-items: center; justify-content: center;
  transition: border-color var(--fh-transition), background var(--fh-transition);
}
.facets-drawer__close:hover { border-color: #ccc; background: rgba(0,0,0,0.03); }
.facets-drawer__body {
  flex: 1; overflow-y: auto; padding: 0 20px;
  -webkit-overflow-scrolling: touch;
}
.facets-drawer__body::-webkit-scrollbar { width: 4px; }
.facets-drawer__body::-webkit-scrollbar-thumb { background: rgb(var(--border-color,217 215 213)); border-radius: 4px; }
.facets-drawer__body .accordion__toggle {
  list-style: none; cursor: pointer; justify-content: space-between; align-items: center;
  column-gap: .625rem; padding-block: 1.25rem; display: flex;
  font-size: 13px; font-weight: 500; border-bottom: 1px solid rgb(var(--border-color,217 215 213));
}
.facets-drawer__body .accordion__toggle::-webkit-details-marker { display: none; }
.facets-drawer__body .accordion__toggle svg { flex-shrink: 0; transition: transform .2s ease; }
.facets-drawer__body details[open] > .accordion__toggle { border-bottom-color: transparent; }
.facets-drawer__body details[open] > .accordion__toggle svg { transform: rotate(180deg); }
.facets-drawer__body .accordion__content { margin-block-start: -.25rem; padding-block-end: 1.25rem; }
.facets-drawer__body .accordion-list > accordion-disclosure > details { display: block; }
.facets-drawer__body .accordion-list > accordion-disclosure:last-child > details { border-bottom: none; }
.facets-drawer__body .link-faded,
.facets-drawer__body a {
  color: rgba(0,0,0,.5); font-size: 13px;
  transition: color .2s, padding-left .25s;
  display: flex; align-items: center; gap: 6px; text-decoration: none; padding: 3px 0;
}
.facets-drawer__body .link-faded:hover,
.facets-drawer__body a:hover { color: #000 !important; }
.facets-drawer__footer {
  padding: 16px 20px; border-top: 1px solid rgb(var(--border-color,217 215 213)); flex-shrink: 0;
}
.facets-drawer__footer .button {
  width: 100%; border-radius: var(--fh-radius);
}

/* ── Product Grid ── */
.collection__product-list { display: grid; grid-template-columns: repeat(var(--items-per-row,4),1fr); gap: 1.25rem; }
@media (max-width:999px) { .collection__product-list { --items-per-row: 3; } }
@media (max-width:699px) { .collection__product-list { --items-per-row: 2; gap: .75rem; } }

/* ── Pagination ── */
.collection__pagination { display: flex; justify-content: center; align-items: center; gap: .5rem; margin-top: var(--section-stack-gap); font-size: var(--text-sm); }
.collection__pagination a,
.collection__pagination span {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px; padding: 4px 8px; text-decoration: none;
  border: 1px solid transparent; border-radius: var(--fh-radius);
  transition: all var(--fh-transition);
}
.collection__pagination a:hover {
  border-color: rgb(var(--border-color,217 215 213));
  background: rgba(0,0,0,0.02);
}
.collection__pagination .current {
  font-weight: 600; color: var(--fh-primary, #62858a);
  border-color: var(--fh-primary, #62858a);
}

/* ── Header/Count ── */
.collection__header { text-align: center; margin-bottom: var(--section-stack-gap); }
