/**
 * Homepage-only stylesheet entry point.
 *
 * Each homepage section stays modular while sharing the existing design-token
 * and component foundations supplied by main.css.
 */
/**
 * Homepage Hero slider shell.
 *
 * The static first slide works without JavaScript. Data hooks and hidden slide
 * states provide a stable contract for a future progressively enhanced slider.
 */
/**
 * Mobile-first responsive and accessibility mixins.
 *
 * Mixins centralize media queries, token emission, focus treatment, touch
 * targets, reduced motion, high contrast, and container behavior.
 */
/**
 * Mobile-first breakpoint map.
 *
 * CSS custom properties are emitted for documentation and script parity.
 * Sass mixins consume the map because custom properties cannot drive media
 * query conditions.
 */
.c-hero-slider {
  position: relative;
}

.c-hero-slider__track {
  display: grid;
}

.c-hero-slider__slide {
  display: grid;
  gap: var(--space-5);
  min-inline-size: 0;
}

.c-hero-slider__slide[hidden] {
  display: none;
}

.c-hero-slider__slide > .c-hero-content {
  grid-row: 2;
}

.c-hero-slider__slide > .home-hero__visual {
  grid-row: 1;
}

@media (min-width: 64rem) {
  .c-hero-slider__slide {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: var(--space-7);
    align-items: center;
  }
  .c-hero-slider__slide > .c-hero-content {
    grid-row: 1;
    grid-column: 1;
  }
  .c-hero-slider__slide > .home-hero__visual {
    grid-row: 1;
    grid-column: 2;
  }
}
@media (min-width: 120rem) {
  .c-hero-slider__slide {
    gap: var(--space-10);
  }
}
/**
 * Homepage Hero editorial content.
 *
 * Type, rhythm, campaign metadata, and trust indicators consume only the
 * shared runtime design tokens and logical properties.
 */
.c-hero-content {
  display: grid;
  gap: var(--space-3);
  align-content: center;
  min-inline-size: 0;
}

.c-hero-content__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  align-items: center;
}

.c-hero-content__promotion,
.c-hero-content__eyebrow {
  color: var(--color-text-secondary);
  font-size: var(--font-size-label);
  font-weight: var(--font-weight-label);
  line-height: var(--line-height-label);
  letter-spacing: var(--letter-spacing-label);
}

.c-hero-content__eyebrow {
  margin: 0;
  text-transform: uppercase;
}

.c-hero-content__title {
  max-inline-size: var(--container-max);
  margin: 0;
  color: var(--color-text-primary);
  font-size: var(--font-size-display-m);
  font-weight: var(--font-weight-display-m);
  line-height: var(--line-height-display-m);
  letter-spacing: var(--letter-spacing-display-m);
  text-wrap: balance;
}

.c-hero-content__description {
  max-inline-size: var(--container-max);
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-lead);
  font-weight: var(--font-weight-lead);
  line-height: var(--line-height-lead);
  letter-spacing: var(--letter-spacing-lead);
  text-wrap: pretty;
}

.c-hero-content__trust-statement {
  display: flex;
  gap: var(--space-1);
  align-items: flex-start;
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-small);
  line-height: var(--line-height-small);
}

.c-hero-content__trust-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1) var(--space-2);
  margin: 0;
  padding: 0;
  list-style: none;
}

.c-hero-content__trust-badge {
  display: inline-flex;
  gap: var(--space-1);
  align-items: center;
  color: var(--color-muted);
  font-size: var(--font-size-caption);
  line-height: var(--line-height-caption);
}

/**
 * Homepage Hero search composition.
 *
 * The shell supports product categories, keywords, future media-input tools,
 * and discoverability links without requiring AJAX or JavaScript.
 */
.c-hero-search {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-2);
  background-color: var(--color-card);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-card);
}

.c-hero-search__form {
  display: grid;
  gap: var(--space-1);
}

.c-hero-search__category,
.c-hero-search__keyword {
  min-inline-size: 0;
}

.c-hero-search__tools {
  display: flex;
  gap: var(--space-1);
}

.c-hero-search__tools > .c-button {
  flex: 1;
}

.c-hero-search__submit {
  inline-size: 100%;
}

.c-hero-search__suggestions {
  display: grid;
  gap: var(--space-1);
  padding-block-start: var(--space-1);
  border-block-start: var(--border-width) solid var(--color-border);
}

.c-hero-search__suggestion-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  align-items: center;
}

.c-hero-search__suggestion-label {
  color: var(--color-muted);
  font-size: var(--font-size-caption);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-caption);
}

@media (min-width: 48rem) {
  .c-hero-search__form {
    grid-template-columns: minmax(0, 1fr) minmax(0, 2fr) auto auto;
    align-items: center;
  }
  .c-hero-search__tools > .c-button {
    flex: none;
  }
  .c-hero-search__submit {
    inline-size: auto;
  }
}
/**
 * Homepage Hero call-to-action composition.
 *
 * Button visuals come from the reusable button component; this module controls
 * responsive grouping only.
 */
.c-hero-buttons {
  display: grid;
  gap: var(--space-1);
}

.c-hero-buttons > .c-button {
  inline-size: 100%;
}

.c-hero-buttons__video {
  color: var(--color-text-secondary);
}

@media (min-width: 48rem) {
  .c-hero-buttons {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
  .c-hero-buttons > .c-button {
    inline-size: auto;
  }
}
/**
 * Homepage Hero quick-category shortcuts.
 *
 * The grid accepts either an optimized thumbnail or an icon shell and remains
 * keyboard, RTL, and touch friendly.
 */
.c-hero-categories__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-1);
  margin: 0;
  padding: 0;
  list-style: none;
}

.c-hero-categories__item {
  min-inline-size: 0;
}

.c-hero-categories__link {
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-1);
  align-items: center;
  min-block-size: var(--touch-target-min);
  padding: var(--space-1);
  color: var(--color-text-primary);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-small);
  text-decoration: none;
  background-color: var(--color-surface);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: color calc(var(--duration-fast) * var(--motion-duration-scale)) var(--ease-standard), border-color calc(var(--duration-fast) * var(--motion-duration-scale)) var(--ease-standard), box-shadow calc(var(--duration-fast) * var(--motion-duration-scale)) var(--ease-standard);
}

.c-hero-categories__link:hover {
  color: var(--color-hover);
  border-color: var(--color-hover);
  box-shadow: var(--shadow-hover);
}

.c-hero-categories__media {
  display: grid;
  place-items: center;
  inline-size: var(--touch-target-min);
  block-size: var(--touch-target-min);
  overflow: hidden;
  color: var(--color-text-secondary);
  background-color: var(--color-card);
  border-radius: var(--radius-md);
}

.c-hero-categories__media img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.c-hero-categories__label {
  min-inline-size: 0;
}

.c-hero-categories__link > .c-badge {
  grid-column: 1/-1;
  justify-self: start;
}

@media (min-width: 48rem) {
  .c-hero-categories__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
/**
 * Reusable homepage section header.
 *
 * Provides consistent hierarchy, supporting copy, CTA placement, and a
 * decorative divider without coupling the component to category content.
 */
.c-section-header {
  display: grid;
  gap: var(--space-2);
  align-items: end;
}

.c-section-header__content {
  display: grid;
  gap: var(--space-1);
  max-inline-size: var(--container-max);
}

.c-section-header__eyebrow {
  margin: 0;
  color: var(--color-primary);
  font-size: var(--font-size-label);
  font-weight: var(--font-weight-label);
  line-height: var(--line-height-label);
  letter-spacing: var(--letter-spacing-label);
  text-transform: uppercase;
}

.c-section-header__title {
  margin: 0;
  color: var(--color-text-primary);
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-h2);
  line-height: var(--line-height-h2);
  letter-spacing: var(--letter-spacing-h2);
  text-wrap: balance;
}

.c-section-header__description {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-body-large);
  line-height: var(--line-height-body-large);
  text-wrap: pretty;
}

.c-section-header__cta {
  justify-self: start;
}

.c-section-header__divider {
  display: block;
  grid-column: 1/-1;
  inline-size: 100%;
  block-size: var(--border-width);
  background-color: var(--color-border);
}

@media (min-width: 48rem) {
  .c-section-header {
    grid-template-columns: minmax(0, 1fr) auto;
  }
  .c-section-header__cta {
    justify-self: end;
  }
}
/**
 * Featured Category responsive grid.
 *
 * The default progression is two columns on mobile, three on tablet/laptop,
 * and four on desktop. A dormant modifier prepares horizontal mobile overflow.
 */
.c-category-grid {
  --category-grid-desktop-columns: 4;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--grid-gap);
  margin: 0;
  padding: 0;
  list-style: none;
}

.c-category-grid__item {
  min-inline-size: 0;
}

.c-category-grid--columns-2 {
  --category-grid-desktop-columns: 2;
}

.c-category-grid--columns-3 {
  --category-grid-desktop-columns: 3;
}

.c-category-grid--columns-4 {
  --category-grid-desktop-columns: 4;
}

.c-category-grid--mobile-scroll {
  grid-template-columns: none;
  grid-auto-columns: minmax(var(--grid-item-min), 80%);
  grid-auto-flow: column;
  padding-block-end: var(--space-1);
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline proximity;
  scrollbar-width: thin;
}

.c-category-grid--mobile-scroll > .c-category-grid__item {
  scroll-snap-align: start;
}

@media (min-width: 48rem) {
  .c-category-grid,
  .c-category-grid--mobile-scroll {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-auto-columns: auto;
    grid-auto-flow: row;
    padding-block-end: var(--space-0);
    overflow-x: visible;
    scroll-snap-type: none;
  }
}
@media (min-width: 80rem) {
  .c-category-grid,
  .c-category-grid--mobile-scroll {
    grid-template-columns: repeat(var(--category-grid-desktop-columns), minmax(0, 1fr));
  }
}
/**
 * Featured Category card component.
 *
 * Extends the reusable card, media, icon, badge, and typography primitives.
 * Motion is progressive, tokenized, and disabled for reduced-motion users.
 */
.c-category-card {
  --media-ratio: 1 / 1;
  min-inline-size: 0;
  overflow: clip;
  transition: border-color calc(var(--duration-normal) * var(--motion-duration-scale)) var(--ease-standard), box-shadow calc(var(--duration-normal) * var(--motion-duration-scale)) var(--ease-standard), translate calc(var(--duration-normal) * var(--motion-duration-scale)) var(--ease-standard);
}

.c-category-card__link {
  position: relative;
  display: grid;
  min-block-size: var(--touch-target-min);
  color: inherit;
  text-decoration: none;
  border-radius: inherit;
}

.c-category-card__media {
  margin: 0;
  background-color: var(--color-surface);
}

.c-category-card__media picture {
  display: block;
  inline-size: 100%;
  block-size: 100%;
}

.c-category-card__image {
  scale: var(--motion-scale-rest);
  transition: scale calc(var(--duration-slow) * var(--motion-duration-scale)) var(--ease-smooth);
}

.c-category-card__image-placeholder {
  display: grid;
  place-items: center;
  inline-size: 100%;
  block-size: 100%;
  color: var(--color-muted);
  background-color: var(--color-surface);
}

.c-category-card__body {
  position: relative;
  z-index: var(--z-base);
  text-align: start;
}

.c-category-card__heading {
  display: flex;
  gap: var(--space-1);
  align-items: center;
}

.c-category-card__icon {
  --icon-size: var(--space-4);
  color: var(--color-primary);
  background-color: var(--color-surface);
  border-radius: var(--radius-circle);
}

.c-category-card__icon img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
}

.c-category-card__title {
  min-inline-size: 0;
  margin: 0;
  color: var(--color-text-primary);
}

.c-category-card__description {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: var(--color-text-secondary);
  font-size: var(--font-size-small);
  line-height: var(--line-height-small);
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.c-category-card__meta {
  flex-wrap: wrap;
  justify-content: space-between;
}

.c-category-card__count {
  color: var(--color-muted);
}

.c-category-card__ribbon {
  position: absolute;
  inset-block-start: var(--space-2);
  inset-inline-start: var(--space-2);
  z-index: var(--z-dropdown);
  min-block-size: var(--space-3);
  padding-block: calc(var(--space-1) / 2);
  padding-inline: var(--space-1);
  color: var(--color-on-primary);
  font-size: var(--font-size-caption);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-caption);
  background-color: var(--color-primary);
  border-radius: var(--radius-round);
  box-shadow: var(--shadow-sm);
}

.c-category-card__pattern {
  position: absolute;
  inset: 0;
  z-index: var(--z-base);
  pointer-events: none;
  background: radial-gradient(circle at center, color-mix(in srgb, var(--color-accent), transparent), transparent var(--space-2));
}

.c-category-card__ripple {
  position: absolute;
  inset-block-end: var(--space-2);
  inset-inline-end: var(--space-2);
  inline-size: var(--touch-target-min);
  block-size: var(--touch-target-min);
  pointer-events: none;
  background-color: color-mix(in srgb, var(--color-primary), transparent);
  border-radius: var(--radius-circle);
  scale: var(--motion-scale-hidden);
  transition: scale calc(var(--duration-normal) * var(--motion-duration-scale)) var(--ease-standard);
}

.c-category-card[data-ripple-active=true] .c-category-card__ripple {
  scale: var(--motion-scale-rest);
}

@media (hover: hover) {
  .c-category-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-hover);
    translate: 0 calc(var(--motion-distance-sm) * -1);
  }
  .c-category-card:hover .c-category-card__image {
    scale: var(--motion-scale-hover);
  }
}
.c-category-card:focus-within {
  border-color: var(--focus-ring-color);
  box-shadow: var(--shadow-focus);
}

@media (prefers-reduced-motion: reduce) {
  .c-category-card,
  .c-category-card__image,
  .c-category-card__ripple {
    transition-duration: var(--duration-instant);
  }
  .c-category-card:hover {
    translate: none;
  }
  .c-category-card:hover .c-category-card__image {
    scale: var(--motion-scale-rest);
  }
}
@media (forced-colors: active) {
  .c-category-card:focus-within {
    border-color: var(--color-high-contrast);
  }
  .c-category-card__pattern,
  .c-category-card__ripple {
    display: none;
  }
}
/**
 * Homepage Hero page composition.
 *
 * This module owns section framing, responsive media, decoration, floating
 * offer shells, the overlay, and the accessible scroll indicator.
 */
.home-hero {
  position: relative;
  isolation: isolate;
  overflow: clip;
  color: var(--color-text-primary);
  background-color: var(--color-background);
}

.home-hero__container {
  position: relative;
  padding-block: var(--section-space);
}

.home-hero__visual {
  position: relative;
  display: grid;
  align-content: center;
  min-inline-size: 0;
}

.home-hero__media {
  position: relative;
  z-index: var(--z-base);
  display: block;
  inline-size: 100%;
  margin: 0;
  overflow: hidden;
  background-color: var(--color-surface);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-xl);
}

.home-hero__media picture {
  display: block;
}

.home-hero__image {
  display: block;
  inline-size: 100%;
  block-size: auto;
  object-fit: cover;
}

.home-hero__media-placeholder {
  display: grid;
  gap: var(--space-2);
  place-items: center;
  min-block-size: var(--space-12);
  padding: var(--space-4);
  color: var(--color-muted);
  font-size: var(--font-size-small);
  line-height: var(--line-height-small);
  text-align: center;
}

.home-hero__gradient {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(to top, color-mix(in srgb, var(--color-overlay), transparent), transparent);
}

.home-hero__decoration {
  position: absolute;
  inset: 0;
  z-index: var(--z-base);
  pointer-events: none;
}

.home-hero__shape {
  position: absolute;
  display: block;
  inline-size: var(--space-10);
  block-size: var(--space-10);
  background-color: color-mix(in srgb, var(--color-accent), transparent);
  border-radius: var(--radius-circle);
}

.home-hero__shape--primary {
  inset-block-start: calc(var(--space-2) * -1);
  inset-inline-end: calc(var(--space-2) * -1);
}

.home-hero__shape--secondary {
  inset-block-end: calc(var(--space-3) * -1);
  inset-inline-start: calc(var(--space-3) * -1);
  inline-size: var(--space-7);
  block-size: var(--space-7);
  background-color: color-mix(in srgb, var(--color-primary), transparent);
}

.home-hero__floating-elements {
  position: relative;
  z-index: var(--z-dropdown);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-1);
  margin-block-start: calc(var(--space-3) * -1);
  padding-inline: var(--space-2);
}

.home-hero__floating-card,
.home-hero__review-badge {
  min-inline-size: 0;
}

.home-hero__floating-card {
  grid-column: 1/-1;
}

.home-hero__floating-card .c-card__title {
  font-size: var(--font-size-body);
  line-height: var(--line-height-body);
}

.home-hero__discount-badge {
  align-self: start;
  justify-self: start;
}

.home-hero__review-badge {
  justify-self: stretch;
}

.home-hero__review-badge .c-card__body {
  padding: var(--space-2);
}

.home-hero__scroll-indicator {
  display: inline-flex;
  gap: var(--space-1);
  align-items: center;
  min-block-size: var(--touch-target-min);
  margin-block-start: var(--space-4);
  color: var(--color-text-secondary);
  font-size: var(--font-size-caption);
  line-height: var(--line-height-caption);
  text-decoration: none;
}

.home-hero__scroll-track {
  position: relative;
  inline-size: var(--space-1);
  block-size: var(--space-4);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-round);
}

.home-hero__scroll-marker {
  position: absolute;
  inset-block-start: var(--space-1);
  inset-inline-start: 50%;
  inline-size: var(--motion-distance-sm);
  block-size: var(--motion-distance-sm);
  background-color: var(--color-primary);
  border-radius: var(--radius-circle);
  translate: -50% 0;
  animation: fp-hero-scroll-indicator var(--duration-slower) var(--ease-smooth) infinite alternate;
}

@keyframes fp-hero-scroll-indicator {
  to {
    translate: -50% var(--motion-distance-md);
  }
}
@media (min-width: 48rem) {
  .home-hero__floating-elements {
    position: absolute;
    inset: 0;
    display: block;
    margin: 0;
    padding: 0;
    pointer-events: none;
  }
  .home-hero__floating-elements > * {
    position: absolute;
    pointer-events: auto;
  }
  .home-hero__floating-card {
    inset-block-end: var(--space-3);
    inset-inline-start: calc(var(--space-3) * -1);
    max-inline-size: var(--space-9);
  }
  .home-hero__discount-badge {
    inset-block-start: var(--space-3);
    inset-inline-end: calc(var(--space-2) * -1);
  }
  .home-hero__review-badge {
    inset-block-end: var(--space-4);
    inset-inline-end: calc(var(--space-2) * -1);
    max-inline-size: var(--space-8);
  }
}
@media (min-width: 80rem) {
  .home-hero__media {
    border-radius: var(--radius-2xl);
  }
}
@media (prefers-reduced-motion: reduce) {
  .home-hero__scroll-marker {
    animation: none;
  }
}
@media (forced-colors: active) {
  .home-hero__media,
  .home-hero__scroll-track {
    border-color: var(--color-high-contrast);
  }
  .home-hero__decoration,
  .home-hero__gradient {
    display: none;
  }
}
/**
 * Homepage Featured Categories composition.
 *
 * Page-level modifiers prepare future background and spacing Theme Options
 * while all values remain mapped to global design tokens.
 */
.home-featured-categories {
  --featured-categories-section-space: var(--section-space);
  color: var(--color-text-primary);
  background-color: var(--color-background);
}

.home-featured-categories--background-surface {
  background-color: var(--color-surface);
}

.home-featured-categories--spacing-compact {
  --featured-categories-section-space: var(--space-5);
}

.home-featured-categories--spacing-spacious {
  --featured-categories-section-space: var(--space-10);
}

.home-featured-categories__container {
  display: grid;
  gap: var(--space-5);
  padding-block: var(--featured-categories-section-space);
}
