
/* ==========================================================================
   Bold Theme — Storefront System v2 CSS Bundle
   ==========================================================================
   Brand:    bold red    #E63946
   Accent:   amber       #F4A261
   Heading:  Oswald (uppercase, condensed, 700)
   Body:     Inter
   Bg:       cream       #FAF7F2
   ========================================================================== */


/* ──────────────────────────────────────────────────────────────────────
   Section + Container — sharp edges, generous spacing
   ────────────────────────────────────────────────────────────────────── */

.sf-section {
  padding: var(--sf-space-section-y, 5rem) 1.5rem;
  background: var(--sf-color-surface, #ffffff);
}

.sf-section + .sf-section {
  border-top: 1px solid var(--sf-color-border, rgba(26, 26, 46, 0.08));
}

.sf-container {
  max-width: var(--sf-size-container-max, 1280px);
  margin: 0 auto;
}


/* ──────────────────────────────────────────────────────────────────────
   Buttons — chunky, square, uppercase
   ────────────────────────────────────────────────────────────────────── */

.sf-btn {
  display: inline-block;
  padding: 1rem 2.5rem;
  border-radius: var(--sf-radius-button, 0);
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  border: 0;
  cursor: pointer;
  transition: background var(--sf-motion-medium, 0.2s ease), transform var(--sf-motion-medium, 0.2s ease);
}

.sf-btn--filled {
  background: var(--sf-color-brand, #E63946);
  color: #ffffff;
}
.sf-btn--filled:hover {
  background: var(--sf-color-brand-hover, #c9202d);
  transform: translateY(-1px);
}

.sf-btn--outline {
  background: transparent;
  color: var(--sf-color-brand, #E63946);
  border: 2px solid var(--sf-color-brand, #E63946);
  padding: calc(1rem - 2px) calc(2.5rem - 2px);
}
.sf-btn--outline:hover {
  background: var(--sf-color-brand, #E63946);
  color: #ffffff;
}

.sf-btn--inverse {
  background: #ffffff;
  color: var(--sf-color-brand, #E63946);
}
.sf-btn--inverse:hover {
  background: var(--sf-color-bg, #FAF7F2);
}


/* ──────────────────────────────────────────────────────────────────────
   Hero — Bold Diagonal Split (theme-local layout)
   ────────────────────────────────────────────────────────────────────── */

.sf-hero {
  position: relative;
  overflow: hidden;
}

/* Bold's signature hero: text-side + media-side with diagonal cut.
 * The text side is left, image is right, and a triangular cream-colored
 * overlay clips into the image at the boundary creating the diagonal. */
.sf-hero--diagonal-split {
  display: grid;
  grid-template-columns: 55% 45%;
  min-height: 70vh;
  background: var(--sf-color-bg, #FAF7F2);
  padding: 0;
}

.sf-hero--diagonal-split__text-side {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 4rem 3.5rem 4rem 2rem;
  position: relative;
  z-index: 2;
}

.sf-hero--diagonal-split__text-inner {
  max-width: 560px;
  margin-left: auto;
}

.sf-hero--diagonal-split__accent-bar {
  width: 50px;
  height: 4px;
  background: var(--sf-color-brand, #E63946);
  margin-bottom: 2rem;
}

.sf-hero--diagonal-split__eyebrow {
  display: inline-block;
  margin-bottom: 1rem;
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--sf-color-brand, #E63946);
}

.sf-hero--diagonal-split__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h1, clamp(2.25rem, 5vw, 4rem));
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 1.05;
  font-weight: 700;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 1.5rem;
}

.sf-hero--diagonal-split__subtitle {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 1.05rem;
  line-height: 1.7;
  font-weight: 300;
  color: var(--sf-color-text-soft, #6b7280);
  max-width: 460px;
  margin: 0 0 2.5rem;
}

.sf-hero--diagonal-split__cta {
  margin-top: 0;
}

.sf-hero--diagonal-split__media-side {
  position: relative;
  overflow: hidden;
}

.sf-hero--diagonal-split__image,
.sf-hero--diagonal-split__video-iframe,
.sf-hero--diagonal-split__video-element {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: 0;
}

.sf-hero--diagonal-split__placeholder {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--sf-color-brand-dark, #1a1a2e), var(--sf-color-brand, #E63946));
}

/* The diagonal "cut" — a 100px-wide cream-colored triangle clipped to
 * cut into the image from the left edge. The polygon coordinates are:
 *   top-left (0,0) → top-right (80%,0) → bottom-left (0,100%)
 * which produces a right-triangle with the hypotenuse running from
 * top-right corner to bottom-left corner of the 100px-wide strip. */
.sf-hero--diagonal-split__diagonal {
  position: absolute;
  top: 0;
  left: -1px;
  bottom: 0;
  width: 100px;
  background: var(--sf-color-bg, #FAF7F2);
  clip-path: polygon(0 0, 80% 0, 0 100%);
  z-index: 1;
}

@media (max-width: 768px) {
  .sf-hero--diagonal-split {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .sf-hero--diagonal-split__text-side {
    padding: 3rem 1.5rem;
    order: 2;
  }
  .sf-hero--diagonal-split__media-side {
    order: 1;
    min-height: 300px;
  }
  .sf-hero--diagonal-split__diagonal {
    display: none; /* Diagonal makes no sense in single-column layout */
  }
}

/* Fallback hero styling for variants Pro Default uses (in case operator
 * picks a non-bold variant explicitly). Themes can't break out of this. */
.sf-hero--centered,
.sf-hero--split-left,
.sf-hero--split-right,
.sf-hero--video {
  display: flex;
  align-items: center;
  background: var(--sf-color-brand-dark, #1a1a2e);
  color: var(--sf-color-text-inverse, #ffffff);
  min-height: 60vh;
}
.sf-hero--centered {
  text-align: center;
}
.sf-hero__bg { position: absolute; inset: 0; }
.sf-hero__bg--image { background-size: cover; background-position: center; }
.sf-hero__video-iframe,
.sf-hero__video-element {
  position: absolute;
  top: 50%; left: 50%;
  width: 100%; height: 100%;
  min-width: 100%; min-height: 100%;
  transform: translate(-50%, -50%);
  object-fit: cover;
  border: 0;
}
.sf-hero__overlay {
  position: absolute;
  inset: 0;
  background: #000;
  opacity: 0.45;
}
.sf-hero__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--sf-size-container-max, 1280px);
  margin: 0 auto;
  padding: 4rem 2rem;
}
.sf-hero__eyebrow {
  display: inline-block;
  margin-bottom: 1rem;
  padding: 0.4rem 1rem;
  background: var(--sf-color-brand, #E63946);
  color: #ffffff;
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.sf-hero__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h1, clamp(2.25rem, 5vw, 4rem));
  text-transform: uppercase;
  letter-spacing: 0.02em;
  font-weight: 700;
  line-height: 1.05;
  color: var(--sf-color-text-inverse, #ffffff);
  margin: 0 0 1rem;
}
.sf-hero__subtitle {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 1.1rem;
  line-height: 1.65;
  font-weight: 300;
  max-width: 700px;
  margin: 0 0 1.6rem;
  color: rgba(255, 255, 255, 0.85);
}


/* ──────────────────────────────────────────────────────────────────────
   Value Props — clean center-aligned grid, minimal chrome
   ────────────────────────────────────────────────────────────────────── */

.sf-value_props {
  background: var(--sf-color-surface, #ffffff);
  border-top: 1px solid var(--sf-color-border, rgba(26, 26, 46, 0.08));
  border-bottom: 1px solid var(--sf-color-border, rgba(26, 26, 46, 0.08));
  padding: 4rem 2rem;
}

.sf-value_props__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 2rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  text-align: center;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 3rem;
}

.sf-value_props__grid,
.sf-value_props__cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 2.5rem;
  text-align: center;
}

.sf-value_props .sf-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  margin: 0 auto 1.25rem;
  color: var(--sf-color-brand, #E63946);
  font-size: 2rem;
}
.sf-value_props .sf-icon::before { content: '✓'; }
.sf-value_props .sf-icon--shield::before { content: '◇'; }
.sf-value_props .sf-icon--clock::before { content: '◷'; }
.sf-value_props .sf-icon--heart::before { content: '♡'; }
.sf-value_props .sf-icon--star::before { content: '★'; }
.sf-value_props .sf-icon--check::before { content: '✓'; }
.sf-value_props .sf-icon--certificate::before { content: '◈'; }

.sf-value_props__icon-image {
  display: block;
  width: 48px;
  height: 48px;
  margin: 0 auto 1.25rem;
}

.sf-value_props__name {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 0.4rem;
}

.sf-value_props__text {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.9rem;
  line-height: 1.65;
  font-weight: 400;
  color: var(--sf-color-text-soft, #6b7280);
  margin: 0;
}

.sf-value_props__item-link,
.sf-value_props__card-link {
  display: block;
  color: inherit;
  text-decoration: none;
}


/* ──────────────────────────────────────────────────────────────────────
   CTA — saturated red banner, white CTA button
   ────────────────────────────────────────────────────────────────────── */

.sf-cta {
  background: var(--sf-color-brand, #E63946);
  color: #ffffff;
  padding: 5rem 2rem;
  text-align: center;
}

.sf-cta__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  line-height: 1.15;
  color: #ffffff;
  margin: 0 0 1rem;
}

.sf-cta__text {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 1.1rem;
  line-height: 1.6;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.9);
  max-width: 700px;
  margin: 0 auto 2rem;
}

.sf-cta__button {
  /* Inverted: white bg with red text */
  background: #ffffff;
  color: var(--sf-color-brand, #E63946);
}
.sf-cta__button:hover {
  background: var(--sf-color-bg, #FAF7F2);
}

.sf-cta--inline .sf-cta__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  text-align: left;
  max-width: var(--sf-size-container-max, 1280px);
  margin: 0 auto;
}
.sf-cta--inline .sf-cta__title {
  font-size: 1.6rem;
  margin: 0 0 0.25rem;
}
.sf-cta--inline .sf-cta__text {
  font-size: 0.95rem;
  margin: 0;
  max-width: none;
}

.sf-cta--split-image {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  padding: 0;
  min-height: 320px;
}
.sf-cta--split-image .sf-cta__text-side {
  padding: 4rem 3rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.sf-cta--split-image .sf-cta__image-side {
  overflow: hidden;
}
.sf-cta__image,
.sf-cta__placeholder {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: rgba(255, 255, 255, 0.1);
}
@media (max-width: 768px) {
  .sf-cta--inline .sf-cta__inner {
    flex-direction: column;
    text-align: center;
  }
  .sf-cta--split-image {
    grid-template-columns: 1fr;
  }
}


/* ──────────────────────────────────────────────────────────────────────
   Featured Services — flat cards, big bold names, hover lift
   ────────────────────────────────────────────────────────────────────── */

.sf-featured_services {
  background: var(--sf-color-bg, #FAF7F2);
}

.sf-featured_services__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 1rem;
}

.sf-featured_services__intro {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 1.05rem;
  line-height: 1.65;
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  max-width: 700px;
  margin: 0 auto 3rem;
}

.sf-featured_services--card-grid .sf-featured_services__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.75rem;
}

.sf-featured_services__card {
  position: relative;
  background: var(--sf-color-surface, #ffffff);
  border-radius: 0;
  overflow: hidden;
  box-shadow: var(--sf-shadow-card, 0 2px 4px rgba(0, 0, 0, 0.04));
  transition: box-shadow var(--sf-motion-medium, 0.2s ease), transform var(--sf-motion-medium, 0.2s ease);
}
.sf-featured_services__card:hover {
  box-shadow: var(--sf-shadow-card-hover, 0 12px 28px rgba(0, 0, 0, 0.10));
  transform: translateY(-3px);
}

.sf-featured_services__card-link {
  color: inherit;
  text-decoration: none;
  display: block;
}

.sf-featured_services__media {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  background: var(--sf-color-brand-soft, rgba(230, 57, 70, 0.08));
  overflow: hidden;
}
.sf-featured_services__image,
.sf-featured_services__video-iframe,
.sf-featured_services__video-element {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: 0;
  display: block;
}

.sf-featured_services__body {
  padding: var(--sf-space-card-padding, 1.75rem);
}

.sf-featured_services__name {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.4rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 0.5rem;
}

.sf-featured_services__description {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.92rem;
  line-height: 1.65;
  color: var(--sf-color-text-soft, #6b7280);
  margin: 0 0 1rem;
}

.sf-featured_services__price {
  display: inline-block;
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--sf-color-brand, #E63946);
  margin: 0 0 1rem;
}

.sf-featured_services__button {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  background: var(--sf-color-brand, #E63946);
  color: #ffffff;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.sf-featured_services__empty {
  text-align: center;
  padding: 3rem;
  color: var(--sf-color-text-soft, #6b7280);
  font-style: italic;
}

/* ──────────────────────────────────────────────────────────────────────
   Testimonials — flat cards, big quote marks, no italic
   ────────────────────────────────────────────────────────────────────── */

.sf-testimonials {
  background: var(--sf-color-surface, #ffffff);
}

.sf-testimonials__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 3rem;
}

.sf-testimonials--cards-grid .sf-testimonials__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.75rem;
}

.sf-testimonials__card {
  background: var(--sf-color-bg, #FAF7F2);
  padding: var(--sf-space-card-padding, 1.75rem);
  border-radius: 0;
  border-left: 4px solid var(--sf-color-brand, #E63946);
  margin: 0;
}

.sf-testimonials__rating { margin-bottom: 1rem; letter-spacing: 0.15em; }
.sf-testimonials__star { display: inline-block; }
.sf-testimonials__star--filled { color: var(--sf-color-brand, #E63946); }
.sf-testimonials__star--empty { color: rgba(0, 0, 0, 0.15); }
.sf-testimonials__rating-numeric {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-weight: 700;
  color: var(--sf-color-brand, #E63946);
}

.sf-testimonials__headline {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.15rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 0.75rem;
}

.sf-testimonials__quote {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 1rem;
  line-height: 1.7;
  font-weight: 400;
  color: var(--sf-color-text, #1a1a2e);
  margin: 0 0 1.5rem;
}

.sf-testimonials__attribution {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}
.sf-testimonials__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
}
.sf-testimonials__author-block { display: flex; flex-direction: column; }
.sf-testimonials__author {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 0.95rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--sf-color-brand-dark, #1a1a2e);
}
.sf-testimonials__role,
.sf-testimonials__product {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.82rem;
  font-weight: 400;
  color: var(--sf-color-text-soft, #6b7280);
}
.sf-testimonials__verified-badge {
  display: inline-block;
  margin-top: 0.25rem;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--sf-color-brand, #E63946);
  text-transform: uppercase;
}

.sf-testimonials--stacked .sf-testimonials__list {
  max-width: 800px;
  margin: 0 auto;
}
.sf-testimonials--stacked .sf-testimonials__entry {
  padding: 2.5rem 0;
  border-bottom: 1px solid var(--sf-color-border, rgba(26, 26, 46, 0.08));
}
.sf-testimonials--stacked .sf-testimonials__entry:last-child { border-bottom: none; }
.sf-testimonials--stacked .sf-testimonials__quote-mark {
  display: block;
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 4rem;
  color: var(--sf-color-brand, #E63946);
  line-height: 0.5;
  margin-bottom: 0.75rem;
}
.sf-testimonials--stacked .sf-testimonials__quote { font-size: 1.3rem; line-height: 1.6; }

.sf-testimonials--slider .sf-testimonials__slider-wrap { position: relative; }
.sf-testimonials__track {
  display: flex;
  gap: 1.75rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 0 0 1rem;
  scrollbar-width: none;
}
.sf-testimonials__track::-webkit-scrollbar { display: none; }
.sf-testimonials__slide {
  flex: 0 0 calc(33.333% - 1.17rem);
  scroll-snap-align: start;
  background: var(--sf-color-bg, #FAF7F2);
  padding: var(--sf-space-card-padding, 1.75rem);
  border-radius: 0;
  border-left: 4px solid var(--sf-color-brand, #E63946);
  margin: 0;
}
@media (max-width: 1024px) { .sf-testimonials__slide { flex-basis: calc(50% - 0.875rem); } }
@media (max-width: 640px)  { .sf-testimonials__slide { flex-basis: 85%; } }
.sf-testimonials__nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  background: var(--sf-color-brand, #E63946);
  border: 0;
  border-radius: 0;
  font-size: 1.5rem;
  color: #ffffff;
  cursor: pointer;
  z-index: 2;
  transition: background var(--sf-motion-medium, 0.2s ease);
}
.sf-testimonials__nav-btn:hover { background: var(--sf-color-brand-hover, #c9202d); }
.sf-testimonials__nav-btn--prev { left: -22px; }
.sf-testimonials__nav-btn--next { right: -22px; }

.sf-testimonials__empty {
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  padding: 3rem;
  font-style: italic;
}


/* ──────────────────────────────────────────────────────────────────────
   Reviews — same shape as testimonials, slightly different field names
   ────────────────────────────────────────────────────────────────────── */

.sf-reviews {
  background: var(--sf-color-bg, #FAF7F2);
}

.sf-reviews__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 3rem;
}

.sf-reviews--cards-grid .sf-reviews__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.75rem;
}

.sf-reviews__card,
.sf-reviews__slide,
.sf-reviews__item {
  background: var(--sf-color-surface, #ffffff);
  padding: var(--sf-space-card-padding, 1.75rem);
  border-radius: 0;
  border-left: 4px solid var(--sf-color-brand, #E63946);
}

.sf-reviews__rating { margin-bottom: 1rem; letter-spacing: 0.15em; }
.sf-reviews__star { display: inline-block; }
.sf-reviews__star--filled { color: var(--sf-color-brand, #E63946); }
.sf-reviews__star--empty { color: rgba(0, 0, 0, 0.15); }
.sf-reviews__rating-numeric {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-weight: 700;
  color: var(--sf-color-brand, #E63946);
}

.sf-reviews__headline {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.15rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 0.75rem;
}

.sf-reviews__text {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--sf-color-text, #1a1a2e);
  margin: 0 0 1.5rem;
}

.sf-reviews__attribution { display: flex; align-items: center; gap: 0.85rem; }
.sf-reviews__avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.sf-reviews__author {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 0.95rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--sf-color-brand-dark, #1a1a2e);
}
.sf-reviews__product {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.82rem;
  font-weight: 400;
  color: var(--sf-color-text-soft, #6b7280);
}
.sf-reviews__verified-badge {
  display: inline-block;
  margin-top: 0.25rem;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--sf-color-brand, #E63946);
  text-transform: uppercase;
}

.sf-reviews--stacked .sf-reviews__stack { max-width: 800px; margin: 0 auto; }
.sf-reviews--stacked .sf-reviews__item {
  background: transparent;
  padding: 2.5rem 0;
  border-radius: 0;
  border-left: 0;
  border-bottom: 1px solid var(--sf-color-border, rgba(26, 26, 46, 0.08));
}
.sf-reviews--stacked .sf-reviews__item:last-child { border-bottom: none; }

.sf-reviews--slider .sf-reviews__slider-wrap { position: relative; }
.sf-reviews__track {
  display: flex;
  gap: 1.75rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 0 0 1rem;
  scrollbar-width: none;
}
.sf-reviews__track::-webkit-scrollbar { display: none; }
.sf-reviews__slide { flex: 0 0 calc(33.333% - 1.17rem); scroll-snap-align: start; }
@media (max-width: 1024px) { .sf-reviews__slide { flex-basis: calc(50% - 0.875rem); } }
@media (max-width: 640px)  { .sf-reviews__slide { flex-basis: 85%; } }
.sf-reviews__nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  background: var(--sf-color-brand, #E63946);
  border: 0;
  border-radius: 0;
  font-size: 1.5rem;
  color: #ffffff;
  cursor: pointer;
  z-index: 2;
  transition: background var(--sf-motion-medium, 0.2s ease);
}
.sf-reviews__nav-btn:hover { background: var(--sf-color-brand-hover, #c9202d); }
.sf-reviews__nav-btn--prev { left: -22px; }
.sf-reviews__nav-btn--next { right: -22px; }

.sf-reviews__empty {
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  padding: 3rem;
  font-style: italic;
}


/* ──────────────────────────────────────────────────────────────────────
   FAQ
   ────────────────────────────────────────────────────────────────────── */

.sf-faq { background: var(--sf-color-surface, #ffffff); }

.sf-faq__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 3rem;
}

.sf-faq--accordion .sf-faq__list { max-width: 800px; margin: 0 auto; }
.sf-faq__item {
  border-bottom: 1px solid var(--sf-color-border, rgba(26, 26, 46, 0.08));
}
.sf-faq__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 1.5rem 0;
  background: transparent;
  border: 0;
  cursor: pointer;
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.15rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--sf-color-brand-dark, #1a1a2e);
  text-align: left;
  transition: color var(--sf-motion-medium, 0.2s ease);
}
.sf-faq__question:hover { color: var(--sf-color-brand, #E63946); }
.sf-faq__icon {
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--sf-color-brand, #E63946);
  transition: transform var(--sf-motion-medium, 0.2s ease);
}
.sf-faq__item--open .sf-faq__icon { transform: rotate(45deg); }
.sf-faq__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--sf-motion-slow, 0.35s ease);
}
.sf-faq__item--open .sf-faq__answer { max-height: 800px; }
.sf-faq__answer-text {
  padding: 0 0 1.5rem;
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--sf-color-text-soft, #6b7280);
  margin: 0;
}

.sf-faq--two-column .sf-faq__columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  max-width: 1100px;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .sf-faq--two-column .sf-faq__columns { grid-template-columns: 1fr; }
}
.sf-faq__qa { margin-bottom: 2rem; }
.sf-faq__question-static {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.15rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 0.5rem;
}

.sf-faq__empty {
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  padding: 3rem;
  font-style: italic;
}


/* ──────────────────────────────────────────────────────────────────────
   Contact
   ────────────────────────────────────────────────────────────────────── */

.sf-contact { background: var(--sf-color-surface, #ffffff); }

.sf-contact__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 1rem;
}

.sf-contact__text {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 1.05rem;
  line-height: 1.65;
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  max-width: 700px;
  margin: 0 auto 3rem;
}

.sf-contact--centered .sf-contact__details {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2.5rem;
  max-width: 800px;
  margin: 0 auto;
}

.sf-contact__row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.95rem;
  color: var(--sf-color-text, #1a1a2e);
}

.sf-contact__icon { font-size: 1.1rem; color: var(--sf-color-brand, #E63946); }
.sf-contact__link {
  color: var(--sf-color-text, #1a1a2e);
  text-decoration: none;
  transition: color var(--sf-motion-medium, 0.2s ease);
}
.sf-contact__link:hover { color: var(--sf-color-brand, #E63946); }

.sf-contact--two-col .sf-contact__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}
@media (max-width: 768px) {
  .sf-contact--two-col .sf-contact__inner { grid-template-columns: 1fr; gap: 2rem; }
}
.sf-contact--two-col .sf-contact__title,
.sf-contact--two-col .sf-contact__text {
  text-align: left;
  margin-left: 0;
}
.sf-contact--two-col .sf-contact__card {
  background: var(--sf-color-bg, #FAF7F2);
  padding: 2.5rem;
  border-left: 4px solid var(--sf-color-brand, #E63946);
}
.sf-contact--two-col .sf-contact__details {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}


/* ──────────────────────────────────────────────────────────────────────
   Trust Bar
   ────────────────────────────────────────────────────────────────────── */

.sf-trust_bar {
  background: var(--sf-color-brand-dark, #1a1a2e);
  color: #ffffff;
  padding: 2rem 1.5rem;
}

.sf-trust_bar__items {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 3rem;
}

.sf-trust_bar__item { display: flex; align-items: center; gap: 0.6rem; }

.sf-trust_bar .sf-icon {
  color: var(--sf-color-brand, #E63946);
  font-size: 1.1rem;
}
.sf-trust_bar .sf-icon::before { content: '✓'; }
.sf-trust_bar .sf-icon--shield::before { content: '◇'; }
.sf-trust_bar .sf-icon--check::before { content: '✓'; }
.sf-trust_bar .sf-icon--star::before { content: '★'; }

.sf-trust_bar__label {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
}


/* ──────────────────────────────────────────────────────────────────────
   Rich Text
   ────────────────────────────────────────────────────────────────────── */

.sf-rich_text { background: var(--sf-color-surface, #ffffff); }

.sf-rich_text__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 2rem;
}

.sf-rich_text--standard .sf-rich_text__inner { max-width: 820px; margin: 0 auto; }
.sf-rich_text--narrow   .sf-rich_text__inner { max-width: 640px; margin: 0 auto; }

.sf-rich_text__paragraph {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 1.05rem;
  line-height: 1.8;
  color: var(--sf-color-text, #1a1a2e);
  margin: 0 0 1.25rem;
  white-space: pre-line;
}

.sf-rich_text--align-center { text-align: center; }
.sf-rich_text--align-right  { text-align: right; }
.sf-rich_text--align-left   { text-align: left; }


/* ──────────────────────────────────────────────────────────────────────
   Press
   ────────────────────────────────────────────────────────────────────── */

.sf-press {
  background: var(--sf-color-bg, #FAF7F2);
  padding: 3.5rem 1.5rem;
}

.sf-press__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  margin: 0 0 2.5rem;
}

.sf-press--logos-row .sf-press__logos {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 3rem;
}
.sf-press__logo-image {
  max-height: 40px;
  width: auto;
  filter: grayscale(100%);
  opacity: 0.7;
  transition: opacity var(--sf-motion-medium, 0.2s ease), filter var(--sf-motion-medium, 0.2s ease);
}
.sf-press__logo-image:hover {
  opacity: 1;
  filter: grayscale(0);
}
.sf-press__logo-name {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.2rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--sf-color-text-soft, #6b7280);
}

.sf-press--cards .sf-press__cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.75rem;
}
.sf-press__card {
  background: var(--sf-color-surface, #ffffff);
  padding: 2rem;
  border-radius: 0;
  border-left: 4px solid var(--sf-color-brand, #E63946);
}
.sf-press__card-image {
  max-height: 32px;
  width: auto;
  margin-bottom: 1.25rem;
}
.sf-press__card-quote {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--sf-color-text, #1a1a2e);
  margin: 0;
}


/* ──────────────────────────────────────────────────────────────────────
   Gallery
   ────────────────────────────────────────────────────────────────────── */

.sf-gallery { background: var(--sf-color-surface, #ffffff); }

.sf-gallery__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 1rem;
}

.sf-gallery__intro {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  max-width: 700px;
  margin: 0 auto 3rem;
}

.sf-gallery--grid .sf-gallery__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}
.sf-gallery--masonry .sf-gallery__masonry { column-count: 3; column-gap: 1rem; }
.sf-gallery--masonry .sf-gallery__tile { break-inside: avoid; margin-bottom: 1rem; }
@media (max-width: 1024px) { .sf-gallery--masonry .sf-gallery__masonry { column-count: 2; } }
@media (max-width: 640px)  { .sf-gallery--masonry .sf-gallery__masonry { column-count: 1; } }

.sf-gallery__tile,
.sf-gallery__slide { margin: 0; }
.sf-gallery__image {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0;
  transition: opacity var(--sf-motion-medium, 0.2s ease);
}
.sf-gallery__tile-link:hover .sf-gallery__image { opacity: 0.85; }
.sf-gallery__caption {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.85rem;
  color: var(--sf-color-text-soft, #6b7280);
  text-align: center;
  margin: 0.75rem 0 0;
}

.sf-gallery--carousel .sf-gallery__slider-wrap { position: relative; }
.sf-gallery__track {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
}
.sf-gallery__track::-webkit-scrollbar { display: none; }
.sf-gallery__slide { flex: 0 0 calc(33.333% - 0.67rem); scroll-snap-align: start; }
@media (max-width: 1024px) { .sf-gallery__slide { flex-basis: calc(50% - 0.5rem); } }
@media (max-width: 640px)  { .sf-gallery__slide { flex-basis: 85%; } }
.sf-gallery__nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  background: var(--sf-color-brand, #E63946);
  border: 0;
  border-radius: 0;
  font-size: 1.5rem;
  color: #ffffff;
  cursor: pointer;
  z-index: 2;
}
.sf-gallery__nav-btn--prev { left: -22px; }
.sf-gallery__nav-btn--next { right: -22px; }

.sf-gallery__empty {
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  padding: 3rem;
  font-style: italic;
}

/* ──────────────────────────────────────────────────────────────────────
   Team
   ────────────────────────────────────────────────────────────────────── */

.sf-team { background: var(--sf-color-bg, #FAF7F2); }

.sf-team__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 1rem;
}

.sf-team__intro {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  max-width: 700px;
  margin: 0 auto 3rem;
}

.sf-team--cards .sf-team__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.75rem;
}

.sf-team__card {
  background: var(--sf-color-surface, #ffffff);
  border-radius: 0;
  overflow: hidden;
  text-align: center;
  transition: transform var(--sf-motion-medium, 0.2s ease), box-shadow var(--sf-motion-medium, 0.2s ease);
}
.sf-team__card:hover {
  transform: translateY(-3px);
  box-shadow: var(--sf-shadow-card-hover, 0 12px 28px rgba(0, 0, 0, 0.10));
}
.sf-team__card-link { color: inherit; text-decoration: none; display: block; }
.sf-team__photo-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  background: var(--sf-color-brand-soft, rgba(230, 57, 70, 0.08));
  overflow: hidden;
}
.sf-team__photo { width: 100%; height: 100%; object-fit: cover; }

.sf-team__body { padding: 1.5rem 1.25rem; }

.sf-team__name {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.25rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 0.25rem;
}

.sf-team__role {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sf-color-brand, #E63946);
  margin: 0 0 0.75rem;
}

.sf-team__bio {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.9rem;
  line-height: 1.65;
  color: var(--sf-color-text-soft, #6b7280);
  margin: 0;
}

.sf-team__contacts {
  display: flex;
  justify-content: center;
  gap: 1rem;
  padding: 0 1.25rem 1.5rem;
}

.sf-team__contact {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--sf-color-text-soft, #6b7280);
  text-decoration: none;
  transition: color var(--sf-motion-medium, 0.2s ease);
}
.sf-team__contact:hover { color: var(--sf-color-brand, #E63946); }


/* ──────────────────────────────────────────────────────────────────────
   Pricing
   ────────────────────────────────────────────────────────────────────── */

.sf-pricing { background: var(--sf-color-surface, #ffffff); }

.sf-pricing__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 1rem;
}

.sf-pricing__intro {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  max-width: 700px;
  margin: 0 auto 3rem;
}

.sf-pricing--cards .sf-pricing__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.75rem;
  align-items: stretch;
}

.sf-pricing__card {
  position: relative;
  background: var(--sf-color-surface, #ffffff);
  border: 2px solid var(--sf-color-border, rgba(26, 26, 46, 0.08));
  border-radius: 0;
  padding: 2.5rem 2rem;
  text-align: center;
  display: flex;
  flex-direction: column;
}
.sf-pricing__card--featured {
  border-color: var(--sf-color-brand, #E63946);
  border-width: 2px;
  background: var(--sf-color-bg, #FAF7F2);
  transform: scale(1.03);
}
.sf-pricing__badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  padding: 0.4rem 1rem;
  background: var(--sf-color-brand, #E63946);
  color: #ffffff;
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.sf-pricing__name {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.5rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 0.5rem;
}
.sf-pricing__price-row { margin: 0.5rem 0 1rem; }
.sf-pricing__price {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 3.2rem;
  font-weight: 700;
  color: var(--sf-color-brand-dark, #1a1a2e);
}
.sf-pricing__period {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.85rem;
  color: var(--sf-color-text-soft, #6b7280);
}
.sf-pricing__description {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.92rem;
  line-height: 1.65;
  color: var(--sf-color-text-soft, #6b7280);
  margin: 0 0 1.5rem;
}
.sf-pricing__features {
  list-style: none;
  padding: 0;
  margin: 0 0 2rem;
  text-align: left;
  flex: 1;
}
.sf-pricing__feature {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.5rem 0;
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.92rem;
  color: var(--sf-color-text, #1a1a2e);
}
.sf-pricing__feature-bullet {
  color: var(--sf-color-brand, #E63946);
  flex-shrink: 0;
  font-weight: 700;
}


/* ──────────────────────────────────────────────────────────────────────
   Collections
   ────────────────────────────────────────────────────────────────────── */

.sf-collections { background: var(--sf-color-surface, #ffffff); }

.sf-collections__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 3rem;
}

.sf-collections--icon-grid .sf-collections__icon-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 2rem;
  text-align: center;
}
.sf-collections__cell-image {
  width: 80px;
  height: 80px;
  border-radius: 0;
  object-fit: cover;
  margin: 0 auto 1rem;
}
.sf-collections__cell-icon {
  display: inline-flex;
  width: 80px;
  height: 80px;
  align-items: center;
  justify-content: center;
  background: var(--sf-color-brand, #E63946);
  border-radius: 0;
  margin-bottom: 1rem;
  color: #ffffff;
}
.sf-collections__cell-icon::before { content: '◇'; font-size: 1.4rem; }
.sf-collections__cell-name {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.15rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 0.4rem;
}
.sf-collections__cell-text {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.88rem;
  color: var(--sf-color-text-soft, #6b7280);
  margin: 0;
}
.sf-collections__cell-link { display: block; color: inherit; text-decoration: none; }

.sf-collections--image-cards .sf-collections__cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.75rem;
}
.sf-collections__card {
  background: var(--sf-color-bg, #FAF7F2);
  border-radius: 0;
  overflow: hidden;
  text-align: center;
  transition: transform var(--sf-motion-medium, 0.2s ease);
}
.sf-collections__card:hover { transform: translateY(-3px); }
.sf-collections__card-link { color: inherit; text-decoration: none; display: block; }
.sf-collections__card-media {
  aspect-ratio: 4 / 3;
  background: var(--sf-color-brand-soft, rgba(230, 57, 70, 0.08));
}
.sf-collections__card-image { width: 100%; height: 100%; object-fit: cover; }
.sf-collections__card-body { padding: 1.5rem; }
.sf-collections__card-name {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.3rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 0.4rem;
}
.sf-collections__card-text {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.92rem;
  color: var(--sf-color-text-soft, #6b7280);
  margin: 0;
}


/* ──────────────────────────────────────────────────────────────────────
   Product Card — sharp corners, big bold names, red accent on hover
   ────────────────────────────────────────────────────────────────────── */

.sf-product-card {
  position: relative;
  background: var(--sf-color-surface, #ffffff);
  border-radius: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--sf-motion-medium, 0.2s ease), transform var(--sf-motion-medium, 0.2s ease);
}
.sf-product-card:hover {
  box-shadow: var(--sf-shadow-card-hover, 0 12px 28px rgba(0, 0, 0, 0.10));
  transform: translateY(-3px);
}
.sf-product-card__badge {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  padding: 0.35rem 0.85rem;
  background: var(--sf-color-brand, #E63946);
  color: #ffffff;
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.sf-product-card__media {
  aspect-ratio: 4 / 5;
  background: var(--sf-color-brand-soft, rgba(230, 57, 70, 0.08));
  overflow: hidden;
}
.sf-product-card__media-link { display: block; width: 100%; height: 100%; }
.sf-product-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--sf-motion-slow, 0.35s ease);
}
.sf-product-card:hover .sf-product-card__image { transform: scale(1.04); }
.sf-product-card__body {
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.sf-product-card__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: 1.05rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  margin: 0 0 0.5rem;
  flex: 1;
}
.sf-product-card__title a {
  color: var(--sf-color-brand-dark, #1a1a2e);
  text-decoration: none;
  transition: color var(--sf-motion-medium, 0.2s ease);
}
.sf-product-card__title a:hover { color: var(--sf-color-brand, #E63946); }
.sf-product-card__price-row {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  margin: 0 0 1rem;
}
.sf-product-card__price {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--sf-color-brand, #E63946);
}
.sf-product-card__compare-price {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.92rem;
  color: var(--sf-color-text-soft, #6b7280);
  text-decoration: line-through;
}
.sf-product-card__cta {
  display: block;
  width: 100%;
  padding: 0.85rem 1rem;
  background: var(--sf-color-brand-dark, #1a1a2e);
  color: #ffffff;
  border: 0;
  border-radius: 0;
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--sf-motion-medium, 0.2s ease);
}
.sf-product-card__cta:hover { background: var(--sf-color-brand, #E63946); }


/* ──────────────────────────────────────────────────────────────────────
   Featured Products / Recommendations / Product Grid — list shells
   ────────────────────────────────────────────────────────────────────── */

.sf-featured_products,
.sf-recommendations,
.sf-product_grid { background: var(--sf-color-surface, #ffffff); }

.sf-featured_products__title,
.sf-recommendations__title,
.sf-product_grid__title {
  font-family: var(--sf-font-heading, 'Oswald', sans-serif);
  font-size: var(--sf-size-h2, clamp(2rem, 4vw, 2.5rem));
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--sf-color-brand-dark, #1a1a2e);
  margin: 0 0 1rem;
}

.sf-featured_products__intro,
.sf-recommendations__intro,
.sf-product_grid__intro {
  font-family: var(--sf-font-body, 'Inter', sans-serif);
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  max-width: 700px;
  margin: 0 auto 3rem;
}

.sf-featured_products--grid .sf-featured_products__grid,
.sf-recommendations--grid .sf-recommendations__grid,
.sf-product_grid--default .sf-product_grid__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1.5rem;
}

.sf-featured_products__empty,
.sf-recommendations__empty,
.sf-product_grid__empty {
  text-align: center;
  color: var(--sf-color-text-soft, #6b7280);
  padding: 3rem;
  font-style: italic;
}

.sf-featured_products--carousel .sf-featured_products__slider-wrap,
.sf-recommendations--carousel .sf-recommendations__slider-wrap { position: relative; }
.sf-featured_products__track,
.sf-recommendations__track {
  display: flex;
  gap: 1.25rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
}
.sf-featured_products__track::-webkit-scrollbar,
.sf-recommendations__track::-webkit-scrollbar { display: none; }
.sf-featured_products__slide,
.sf-recommendations__slide {
  flex: 0 0 calc(25% - 0.94rem);
  scroll-snap-align: start;
}
@media (max-width: 1024px) {
  .sf-featured_products__slide,
  .sf-recommendations__slide { flex-basis: calc(33.333% - 0.83rem); }
}
@media (max-width: 640px) {
  .sf-featured_products__slide,
  .sf-recommendations__slide { flex-basis: 75%; }
}

.sf-featured_products__nav-btn,
.sf-recommendations__nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  background: var(--sf-color-brand, #E63946);
  border: 0;
  border-radius: 0;
  font-size: 1.5rem;
  color: #ffffff;
  cursor: pointer;
  z-index: 2;
  transition: background var(--sf-motion-medium, 0.2s ease);
}
.sf-featured_products__nav-btn:hover,
.sf-recommendations__nav-btn:hover { background: var(--sf-color-brand-hover, #c9202d); }
.sf-featured_products__nav-btn--prev,
.sf-recommendations__nav-btn--prev { left: -22px; }
.sf-featured_products__nav-btn--next,
.sf-recommendations__nav-btn--next { right: -22px; }
