/* =============================================================================
   Bluefin home page - "Open Market" redesign  (WS3 home rebuild)
   -----------------------------------------------------------------------------
   A modern, photo-forward marketplace look for the home page ONLY. Everything is
   scoped under .bf-home (the home <main>), so inner pages keep the existing
   broadsheet system untouched. Net-new components use bf-om-* class names; the
   PHP-generated category cards (.bf-category-card) and featured / recently-viewed
   carousels (.bf-carousel__*) are restyled in place via .bf-home overrides.

   Brand colors are referenced through the --bf-brand-* / --bf-color-* tokens (and
   color-mix on those tokens) so a storefront recolors the whole home page by
   overriding only its brand tokens. No hard-coded brand hex.

   Loaded after components.css/layout.css and before the legacy hozi stylesheets.
   No em dash (U+2014) anywhere (CI style guard).
   ============================================================================= */

/* ---------------------------------------------------------------------------
   Home scope: fonts, canvas, link discipline
   --------------------------------------------------------------------------- */
.bf-home {
  --bf-om-font-display: "Bricolage Grotesque", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --bf-om-font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  /* Cooler canvas tone for the home page only (scoped redefine of the alt surface). */
  --bf-color-surface-alt: #f5f7fa;
  /* Derive the home page's interactive + text colors from the CONFIGURED
     storefront brand (STORE_PRIMARY_COLOR -> --bf-brand-primary, and
     --bf-brand-accent), so each site recolors the whole look from its own brand
     instead of a baked-in palette. color-mix darkens the brand toward ink so the
     derived colors stay readable on light surfaces. */
  --bf-color-primary-hover: color-mix(in srgb, var(--bf-brand-primary) 78%, #000);
  --bf-color-primary-text: color-mix(in srgb, var(--bf-brand-primary) 70%, #000);
  --bf-color-accent-hover: color-mix(in srgb, var(--bf-brand-accent) 82%, #000);
  --bf-om-primary-strong: color-mix(in srgb, var(--bf-brand-primary) 68%, #000);
  --bf-om-primary-tint: color-mix(in srgb, var(--bf-brand-primary) 10%, #fff);
  background-color: var(--bf-color-surface-alt);
  font-family: var(--bf-om-font-body);
}

.bf-home h1,
.bf-home h2,
.bf-home h3,
.bf-home h4 {
  font-family: var(--bf-om-font-display);
  letter-spacing: -0.01em;
}

/* The home page builds its own link affordances per component, so neutralise the
   global bf-scope link color/underline for component anchors. */
.bf-home .bf-om-action,
.bf-home .bf-om-pill,
.bf-home .bf-category-card__title,
.bf-home .bf-carousel a,
.bf-home .bf-om-seeall {
  text-decoration: none;
}

.bf-home .bf-container {
  width: 100%;
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: 24px;
}

/* ---------------------------------------------------------------------------
   HERO  (signature: floating search + twin action cards over a soft gradient)
   --------------------------------------------------------------------------- */
.bf-om-hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(900px 420px at 12% -10%, color-mix(in srgb, var(--bf-brand-primary) 16%, transparent), transparent 60%),
    radial-gradient(760px 420px at 92% 0%, color-mix(in srgb, var(--bf-brand-accent) 14%, transparent), transparent 58%),
    linear-gradient(180deg, color-mix(in srgb, var(--bf-brand-primary) 8%, #ffffff) 0%, var(--bf-color-surface-alt) 78%);
}

.bf-om-hero__inner {
  padding: 54px 24px 56px;
}

.bf-om-hero__head {
  max-width: 720px;
  margin-bottom: 26px;
}

.bf-home .bf-om-hero__title {
  margin: 0;
  font-family: var(--bf-om-font-display);
  font-size: clamp(34px, 5vw, 52px);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.08;
  color: var(--bf-color-text);
}

.bf-om-grad {
  background: linear-gradient(100deg, var(--bf-color-primary-hover), var(--bf-brand-primary) 55%, var(--bf-brand-accent));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.bf-om-hero__sub {
  margin: 14px 0 0;
  font-size: clamp(16px, 1.6vw, 19px);
  color: var(--bf-color-text-muted);
  max-width: 560px;
}

/* Floating search bar */
.bf-om-search {
  position: relative;
  z-index: 3;
  display: grid;
  grid-template-columns: 1.7fr 1fr auto;
  gap: 10px;
  align-items: center;
  margin: 0 0 26px;
  padding: 12px;
  background: var(--bf-color-surface);
  border: 1px solid var(--bf-color-border);
  border-radius: var(--bf-radius-xl);
  box-shadow: var(--bf-shadow-lg);
}

.bf-om-search__field {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  background: var(--bf-color-surface-alt);
  border: 1px solid transparent;
  border-radius: var(--bf-radius-lg);
}

.bf-om-search__field:focus-within {
  border-color: var(--bf-brand-primary);
  background: var(--bf-color-surface);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--bf-brand-primary) 18%, transparent);
}

.bf-om-search__field svg {
  flex: none;
  color: var(--bf-color-text-muted);
}

.bf-home .bf-om-search__input,
.bf-home .bf-om-search__select {
  width: 100%;
  border: 0;
  background: transparent;
  font-family: var(--bf-om-font-body);
  font-size: 15.5px;
  color: var(--bf-color-text);
  outline: none;
}

.bf-home .bf-om-search__select {
  cursor: pointer;
}

.bf-home .bf-om-search__input::placeholder {
  color: var(--bf-color-text-muted);
}

.bf-home .bf-om-search__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  padding: 13px 26px;
  border: 0;
  border-radius: var(--bf-radius-lg);
  background: var(--bf-om-primary-strong);
  color: #ffffff;
  font-family: var(--bf-om-font-body);
  font-weight: 700;
  font-size: 15.5px;
  cursor: pointer;
  box-shadow: 0 4px 14px color-mix(in srgb, var(--bf-brand-primary) 38%, transparent);
  transition: background-color var(--bf-transition-fast), transform var(--bf-transition-fast);
}

.bf-home .bf-om-search__btn:hover {
  background: color-mix(in srgb, var(--bf-brand-primary) 58%, #000);
  transform: translateY(-1px);
}

/* Twin co-equal action cards */
.bf-om-twin {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.bf-om-action {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  gap: 18px;
  padding: 26px;
  background: var(--bf-color-surface);
  border: 1px solid var(--bf-color-border);
  border-radius: var(--bf-radius-xl);
  box-shadow: var(--bf-shadow-md);
  color: var(--bf-color-text);
  transition: transform var(--bf-transition-base), box-shadow var(--bf-transition-base), border-color var(--bf-transition-base);
}

.bf-om-action:hover {
  transform: translateY(-3px);
  box-shadow: var(--bf-shadow-lg);
  border-color: color-mix(in srgb, var(--bf-brand-primary) 35%, var(--bf-color-border));
  text-decoration: none;
}

.bf-om-action::after {
  content: "";
  position: absolute;
  right: -40px;
  top: -40px;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  opacity: 0.12;
  pointer-events: none;
}

.bf-om-action--buy::after { background: var(--bf-brand-primary); }
.bf-om-action--sell::after { background: var(--bf-brand-accent); }

.bf-om-action__ico {
  flex: none;
  width: 56px;
  height: 56px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  color: #ffffff;
  box-shadow: var(--bf-shadow-sm);
}

.bf-om-action--buy .bf-om-action__ico {
  background: linear-gradient(140deg, var(--bf-brand-primary), var(--bf-color-primary-hover));
}

.bf-om-action--sell .bf-om-action__ico {
  background: linear-gradient(140deg, color-mix(in srgb, var(--bf-brand-accent) 82%, #ffffff), var(--bf-brand-accent));
}

.bf-home .bf-om-action__title {
  display: block;
  margin: 0 0 4px;
  font-family: var(--bf-om-font-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--bf-color-text);
}

.bf-om-action p {
  margin: 0;
  color: var(--bf-color-text-muted);
  font-size: 14.5px;
}

.bf-om-action__go {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
  font-weight: 600;
  font-size: 14.5px;
  color: var(--bf-color-primary-hover);
}

.bf-om-action--sell .bf-om-action__go {
  color: var(--bf-color-accent-hover);
}

/* ---------------------------------------------------------------------------
   CATEGORY PILL RAIL  (horizontal scroll)
   --------------------------------------------------------------------------- */
.bf-om-pillrail-wrap {
  background: var(--bf-color-surface);
  border-block: 1px solid var(--bf-color-border);
}

.bf-om-pillrail {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 14px 24px;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.bf-om-pillrail::-webkit-scrollbar { display: none; }

.bf-home .bf-om-pill {
  flex: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 16px;
  white-space: nowrap;
  border: 1px solid var(--bf-color-border);
  border-radius: var(--bf-radius-pill);
  background: var(--bf-color-surface);
  color: var(--bf-color-text);
  font-weight: 500;
  font-size: 14px;
  transition: border-color var(--bf-transition-fast), background-color var(--bf-transition-fast), color var(--bf-transition-fast);
}

.bf-home .bf-om-pill:hover {
  border-color: var(--bf-brand-primary);
  background: color-mix(in srgb, var(--bf-brand-primary) 8%, var(--bf-color-surface));
  color: var(--bf-color-primary-hover);
  text-decoration: none;
}

.bf-home .bf-om-pill--active {
  background: var(--bf-color-secondary);
  border-color: var(--bf-color-secondary);
  color: var(--bf-color-text-inverse);
}

.bf-home .bf-om-pill--active:hover {
  background: var(--bf-color-ink-hover);
  color: var(--bf-color-text-inverse);
}

/* ---------------------------------------------------------------------------
   SECTION SCAFFOLD
   --------------------------------------------------------------------------- */
.bf-om-sec {
  padding: 44px 0;
}

.bf-om-sec__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 22px;
  flex-wrap: wrap;
}

.bf-home .bf-om-sec__head h2 {
  margin: 4px 0 0;
  font-size: clamp(24px, 2.6vw, 30px);
  font-weight: 700;
  color: var(--bf-color-text);
}

.bf-om-sec__head .bf-kicker {
  margin: 0;
}

.bf-home .bf-om-seeall {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  font-weight: 600;
  font-size: 14.5px;
  color: var(--bf-color-primary-hover);
}

.bf-home .bf-om-seeall:hover {
  color: var(--bf-color-text);
}

/* ---------------------------------------------------------------------------
   CATEGORY TILES  (restyle the PHP-generated .bf-category-card to image-led cards)
   --------------------------------------------------------------------------- */
.bf-home .bf-category-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.bf-home .bf-category-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--bf-color-surface);
  border: 1px solid var(--bf-color-border);
  border-radius: var(--bf-radius-lg);
  box-shadow: var(--bf-shadow-sm);
  color: var(--bf-color-text);
  cursor: pointer;
  transition: transform var(--bf-transition-base), box-shadow var(--bf-transition-base);
}

.bf-home .bf-category-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--bf-shadow-md);
}

.bf-home .bf-category-card__frame {
  overflow: hidden;
}

.bf-home .bf-category-card__media {
  height: 118px;
  background-color: var(--bf-color-surface-sunken);
  background-size: cover;
  background-position: center;
  transition: transform var(--bf-transition-base);
}

.bf-home .bf-category-card:hover .bf-category-card__media {
  transform: scale(1.04);
}

.bf-home .bf-category-card__plate {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  padding: 14px 16px 16px;
  background: var(--bf-color-surface);
  border-top: 0;
  color: var(--bf-color-text);
}

.bf-home .bf-category-card__heading {
  margin: 0;
}

.bf-home .bf-category-card__title {
  appearance: none;
  margin: 0;
  padding: 0;
  border: 0;
  background: none;
  text-align: left;
  cursor: pointer;
  font-family: var(--bf-om-font-display);
  font-weight: 700;
  font-size: 17px;
  line-height: 1.2;
  color: var(--bf-color-text);
}

.bf-home .bf-category-card__title:hover {
  color: var(--bf-color-primary-hover);
  text-decoration: none;
}

.bf-home .bf-category-card__count {
  margin-top: 3px;
  font-size: 13px;
  font-weight: 500;
  color: var(--bf-color-text-muted);
}

.bf-home .bf-category-card__count b {
  color: var(--bf-color-primary-hover);
  font-weight: 700;
}

.bf-home .bf-category-card__links {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
}

.bf-home .bf-category-card__links li {
  margin: 0;
}

.bf-home .bf-category-card__links a {
  display: inline-block;
  padding: 4px 10px;
  border: 1px solid var(--bf-color-border);
  border-radius: var(--bf-radius-pill);
  background: var(--bf-color-surface-alt);
  color: var(--bf-color-text);
  font-size: 12.5px;
  font-weight: 500;
}

.bf-home .bf-category-card__links a:hover {
  border-color: var(--bf-brand-primary);
  color: var(--bf-color-primary-hover);
  text-decoration: none;
}

/* Lead tile spans two columns and two rows */
.bf-home .bf-category-grid .bf-category-card--lead {
  grid-column: span 2;
  grid-row: span 2;
}

.bf-home .bf-category-card--lead .bf-category-card__frame {
  flex: 1 1 auto;
  display: flex;
}

.bf-home .bf-category-card--lead .bf-category-card__media {
  width: 100%;
  height: 100%;
  min-height: 230px;
}

.bf-home .bf-category-card--lead .bf-category-card__plate {
  padding: 22px 24px 24px;
}

.bf-home .bf-category-card--lead .bf-category-card__title {
  font-size: 24px;
}

/* ---------------------------------------------------------------------------
   FEATURED + RECENTLY VIEWED  (restyle the PHP-generated .bf-carousel into a
   responsive grid of photo cards)
   --------------------------------------------------------------------------- */
.bf-home .bf-carousel {
  margin: 0;
}

.bf-home .bf-carousel__title {
  margin: 0 0 18px;
  font-family: var(--bf-om-font-display);
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 700;
  text-align: left;
  color: var(--bf-color-text);
}

/* The PHP emits a Bootstrap .row of anchors; override to a responsive card grid. */
.bf-home .bf-carousel .featured-ad-row.row {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 18px;
  margin: 0 !important;
}

.bf-home .bf-carousel .featured-ad-row.row > a {
  display: block;
  margin: 0;
  color: var(--bf-color-text);
}

.bf-home .bf-carousel .featured-ad-row.row > a > [class*="col-"] {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  padding: 0 !important;
}

.bf-home .bf-carousel__card {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  background: var(--bf-color-surface);
  border: 1px solid var(--bf-color-border);
  border-radius: var(--bf-radius-lg);
  box-shadow: var(--bf-shadow-sm);
  text-align: left;
  color: var(--bf-color-text);
  transition: transform var(--bf-transition-base), box-shadow var(--bf-transition-base);
}

.bf-home .bf-carousel .featured-ad-row.row > a:hover .bf-carousel__card {
  transform: translateY(-3px);
  box-shadow: var(--bf-shadow-md);
  text-decoration: none;
}

.bf-home .bf-carousel__card-img {
  width: 100%;
  height: 168px;
  object-fit: cover;
  display: block;
  background: var(--bf-color-surface-sunken);
}

.bf-home .bf-carousel__card-body {
  padding: 12px 14px 14px;
}

.bf-home .bf-carousel__card-title {
  margin: 0 0 4px;
  font-family: var(--bf-om-font-display);
  font-weight: 700;
  font-size: 15.5px;
  line-height: 1.25;
  color: var(--bf-color-text);
}

/* The card's leading category label (rendered as <strong>/<center> by the PHP). */
.bf-home .bf-carousel__card center,
.bf-home .bf-carousel__card > strong,
.bf-home .bf-carousel__card-body strong {
  display: block;
  text-align: left;
  margin: 0 0 4px;
  font-size: 11.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--bf-color-primary-hover);
}

.bf-home .bf-carousel__card-boxed {
  padding: 12px 14px 14px;
}

/* ---------------------------------------------------------------------------
   AD SLOTS  (restyle the PHP-generated .bf-adband / .bf-adrail for the canvas)
   --------------------------------------------------------------------------- */
.bf-home .bf-adband {
  background: var(--bf-color-surface);
  border-block: 1px solid var(--bf-color-border);
  padding: 18px 0;
}

/* Sponsored 300x250 units render as a slim centered band, side by side, rather
   than a tall side rail (avoids the wide empty column / wasted space). */
.bf-om-sec--ads {
  padding: 28px 0;
}

.bf-home .bf-adrail {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 24px;
  align-items: center;
  justify-content: center;
}

.bf-home .bf-adrail img {
  border-radius: var(--bf-radius-md);
  box-shadow: var(--bf-shadow-sm);
}

/* ---------------------------------------------------------------------------
   POST-AN-AD CTA
   --------------------------------------------------------------------------- */
.bf-om-postcta {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  padding: 38px 40px;
  border-radius: var(--bf-radius-xl);
  background:
    linear-gradient(120deg, var(--bf-color-secondary), color-mix(in srgb, var(--bf-color-secondary) 55%, var(--bf-brand-primary)));
  color: var(--bf-color-text-inverse);
  box-shadow: var(--bf-shadow-md);
}

.bf-om-postcta::after {
  content: "";
  position: absolute;
  right: -60px;
  top: -60px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--bf-brand-accent) 55%, transparent), transparent 70%);
  pointer-events: none;
}

.bf-home .bf-om-postcta h2 {
  margin: 0;
  font-family: var(--bf-om-font-display);
  font-size: clamp(22px, 2.6vw, 30px);
  font-weight: 700;
  color: var(--bf-color-text-inverse);
}

.bf-om-postcta p {
  margin: 8px 0 0;
  font-size: 16px;
  color: color-mix(in srgb, var(--bf-color-text-inverse) 82%, transparent);
}

.bf-home .bf-om-postcta__btn {
  position: relative;
  z-index: 1;
  flex: none;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 15px 30px;
  border-radius: var(--bf-radius-pill);
  background: var(--bf-brand-accent);
  color: #ffffff;
  font-weight: 700;
  font-size: 16px;
  box-shadow: 0 6px 18px color-mix(in srgb, var(--bf-brand-accent) 45%, transparent);
  transition: background-color var(--bf-transition-fast), transform var(--bf-transition-fast);
}

.bf-home .bf-om-postcta__btn:hover {
  background: var(--bf-color-accent-hover);
  transform: translateY(-2px);
  text-decoration: none;
}

/* ---------------------------------------------------------------------------
   RESPONSIVE
   --------------------------------------------------------------------------- */
@media (max-width: 1020px) {
  .bf-home .bf-category-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .bf-home .bf-category-grid .bf-category-card--lead {
    grid-column: span 2;
    grid-row: span 1;
  }
  .bf-home .bf-category-card--lead .bf-category-card__media {
    min-height: 160px;
  }
}

@media (max-width: 620px) {
  .bf-om-hero__inner {
    padding: 34px 20px 40px;
  }
  .bf-om-search {
    grid-template-columns: 1fr;
  }
  .bf-om-twin {
    grid-template-columns: 1fr;
  }
  .bf-home .bf-category-grid {
    grid-template-columns: 1fr;
  }
  .bf-home .bf-category-grid .bf-category-card--lead {
    grid-column: span 1;
  }
  .bf-om-postcta {
    flex-direction: column;
    align-items: flex-start;
    padding: 28px 24px;
  }
}

/* ---------------------------------------------------------------------------
   Reduced motion
   --------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .bf-home .bf-om-action,
  .bf-home .bf-om-search__btn,
  .bf-home .bf-category-card,
  .bf-home .bf-category-card__media,
  .bf-home .bf-carousel__card,
  .bf-home .bf-om-postcta__btn {
    transition: none;
  }
}
