/* Home page layout */
.home-shell {
  width: min(112rem, 100%);
  margin: 0 auto;
  padding: 1.1rem 1rem 0;
}

.cd-slider.home-hero-slider {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 7;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid color-mix(in srgb, var(--bg-300) 70%, #fff 30%);
  box-shadow: 0 18px 30px rgba(2, 22, 52, .1);
  margin-bottom: 2.2rem;
  touch-action: pan-y;
  cursor: grab;
  user-select: none;
}

.cd-slider.home-hero-slider.is-clickable {
  cursor: pointer;
}

.cd-slider.home-hero-slider.is-clickable.is-dragging {
  cursor: grabbing;
}

.cd-slider.home-hero-slider.is-empty {
  cursor: default;
  min-height: clamp(220px, 42vw, 768px);
}

.home-hero-skeleton {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  overflow: hidden;
}

.home-hero-skeleton::before,
.home-hero-skeleton::after {
  content: "";
  position: absolute;
  inset: 0;
}

.home-hero-skeleton::before {
  background:
    radial-gradient(65% 90% at 8% 24%, color-mix(in srgb, var(--accent-500, #0ea5e9) 26%, transparent) 0%, transparent 72%),
    radial-gradient(58% 88% at 92% 14%, color-mix(in srgb, var(--success-500, #22c55e) 20%, transparent) 0%, transparent 72%),
    linear-gradient(180deg, color-mix(in srgb, var(--bg-300) 68%, #fff 32%) 0%, color-mix(in srgb, var(--bg-200) 85%, #fff 15%) 100%);
  opacity: .95;
}

.home-hero-skeleton::after {
  background:
    linear-gradient(transparent 0 58%, rgba(255,255,255,.14) 58% 58.7%, transparent 58.7% 100%),
    linear-gradient(90deg, transparent 0 6%, rgba(255,255,255,.18) 6% 36%, transparent 36% 100%);
  opacity: .45;
}

.cd-slider.home-hero-slider.is-dragging {
  cursor: grabbing;
}

.cd-slider.home-hero-slider .slides {
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
  height: 100%;
}

.cd-slider.home-hero-slider .slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: scale(1.02);
  transition: opacity .55s ease, transform .55s ease;
  pointer-events: none;
}

.cd-slider.home-hero-slider .slide.current {
  opacity: 1;
  transform: translate3d(var(--drag-offset, 0), 0, 0) scale(1);
  pointer-events: auto;
  z-index: 1;
}

.cd-slider.home-hero-slider .slide > picture {
  display: block;
  width: 100%;
  height: 100%;
}

.cd-slider.home-hero-slider .slide.is-image-only > picture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.cd-slider.home-hero-slider .image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  -webkit-user-drag: none;
  user-select: none;
}

.cd-slider.home-hero-slider.is-single-slide {
  cursor: default;
}

.cd-slider.home-hero-slider.is-single-slide .controls,
.cd-slider.home-hero-slider.is-single-slide .hero-progress,
.cd-slider.home-hero-slider.is-single-slide .hero-thumb-rail {
  display: none;
}

/* ============================================================
   PREMIUM SLIDER THEMES
   ============================================================ */

/* --- TEMA 1: CAPTION STRIP (caption_strip) --- */
.layout-caption_strip .hero-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.01) 0%, rgba(0,0,0,0.12) 100%);
}
.layout-caption_strip .hero-content {
  position: absolute; left: 0; right: 0; bottom: 0;
  max-width: none; padding: 22px 28px;
  background: rgba(255, 255, 255, 0.93);
  backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px);
  color: #162a43; z-index: 3;
}
.layout-caption_strip .hero-content p { color: #4d6077; max-width: 60ch; }
.layout-caption_strip .hero-target-label {
  border-color: rgba(10, 116, 214, .15);
  background: rgba(10, 116, 214, .08);
  color: var(--primary-100);
}
.layout-caption_strip .hero-cta {
  background: var(--primary-100);
  color: #fff;
}

/* --- TEMA 2: CORNER BADGE (corner_badge) --- */
.layout-corner_badge .hero-gradient { display: none; }
.layout-corner_badge .hero-content {
  position: absolute; left: 24px; top: 24px;
  max-width: min(340px, 48%);
  background: rgba(255, 255, 255, 0.94);
  padding: 20px 20px 18px;
  border-radius: 24px;
  box-shadow: 0 12px 22px rgba(10, 24, 44, .08);
  color: #162a43; z-index: 3;
}
.layout-corner_badge .hero-content p { color: #596b80; }

/* --- TEMA 1: CLÁSICO MODERNO (modern_overlay) --- */
.layout-modern_overlay .hero-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(108deg, rgba(255, 255, 255, 0.93) 8%, rgba(255, 255, 255, 0.34) 46%, transparent 100%);
}
.layout-modern_overlay .hero-content {
  position: absolute; left: clamp(14px, 3vw, 34px); bottom: clamp(14px, 3vw, 34px);
  max-width: min(600px, 92%); z-index: 3; color: #1a1a1a;
}
.layout-modern_overlay .hero-content p { color: #444; }

/* --- TEMA 4: CATALOG PANEL (catalog_panel) --- */
.layout-catalog_panel {
  background: linear-gradient(135deg, #f6f9ff 0%, #eaf1ff 100%);
}
.layout-catalog_panel .slide > picture {
  position: absolute; right: 18px; top: 18px; bottom: 18px;
  width: 56%; border-radius: 28px; overflow: hidden;
  box-shadow: 0 18px 26px rgba(6, 24, 48, .1);
}
.layout-catalog_panel .hero-gradient {
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 8% 18%, rgba(10, 116, 214, .08) 0%, transparent 34%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.94) 0%, rgba(255, 255, 255, 0.82) 42%, rgba(255, 255, 255, 0) 72%);
}
.layout-catalog_panel .hero-content {
  position: absolute; left: 24px; top: 50%; transform: translateY(-50%);
  width: min(36%, 460px); z-index: 3; color: #162a43;
  background: rgba(255, 255, 255, 0.74);
  backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px);
  padding: 28px; border-radius: 28px;
  box-shadow: 0 10px 20px rgba(15, 32, 56, .08);
}
.layout-catalog_panel .hero-content p { color: #506278; }

/* --- TEMA 5: PRODUCT SPOTLIGHT (product_spotlight) --- */
.layout-product_spotlight {
  background: linear-gradient(135deg, #0b233f 0%, #17406a 58%, #2b679b 100%);
}
.layout-product_spotlight .slide::before {
  content: '';
  position: absolute; right: 4%; top: 8%; bottom: 8%; width: 40%;
  border-radius: 38px;
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .14);
  z-index: 1;
}
.layout-product_spotlight .slide > picture {
  position: absolute; right: 4%; top: 8%; bottom: 8%;
  width: 40%; z-index: 2;
}
.layout-product_spotlight .image {
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(0, 0, 0, .18));
}
.layout-product_spotlight .hero-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(6, 18, 35, .18) 0%, rgba(6, 18, 35, .04) 52%, transparent 100%);
}
.layout-product_spotlight .hero-content {
  position: absolute; left: clamp(18px, 4vw, 40px); top: 50%; transform: translateY(-50%);
  width: min(38%, 480px); z-index: 3; color: #fff;
}
.layout-product_spotlight .hero-content h2,
.layout-product_spotlight .hero-content p { color: #fff; }
.layout-product_spotlight .hero-target-label {
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.12);
  color: #fff;
}
.layout-product_spotlight .hero-cta {
  background: #fff;
  color: #153354;
  box-shadow: 0 14px 24px rgba(255,255,255,.18);
}

/* --- TEMA 6: PROMO SHEET (promo_sheet) --- */
.layout-promo_sheet .hero-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.01) 0%, rgba(0,0,0,0.1) 100%);
}
.layout-promo_sheet .hero-content {
  position: absolute; left: 22px; right: 22px; bottom: 22px;
  max-width: none; z-index: 3; color: #162a43;
  background: rgba(255, 255, 255, .93);
  padding: 22px 24px;
  border-radius: 28px;
  box-shadow: 0 10px 20px rgba(15, 32, 56, .08);
}
.layout-promo_sheet .hero-content p { color: #51647d; max-width: 58ch; }

/* --- TEMA 7: ETIQUETA FLOTANTE (minimal_tag) --- */
.layout-minimal_tag .hero-gradient { display: none; }
.layout-minimal_tag .hero-content {
  position: absolute; left: 30px; bottom: 30px;
  background: #fff; padding: 30px; border-radius: 30px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.1); border: 1px solid rgba(0,0,0,0.05);
  max-width: 450px; color: #1a1a1a;
}
.layout-minimal_tag .hero-content p { color: #666; }

/* --- TEMA 8: FRAME STAGE (frame_stage) --- */
.layout-frame_stage {
  background: linear-gradient(135deg, #f5f2ee 0%, #edf3fb 100%);
}
.layout-frame_stage .slide > picture {
  position: absolute; left: 35%; right: 20px; top: 20px; bottom: 20px;
  border-radius: 30px; overflow: hidden;
  box-shadow: 0 20px 28px rgba(8, 24, 46, .1);
}
.layout-frame_stage .hero-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(245, 242, 238, .94) 0%, rgba(245, 242, 238, .8) 34%, rgba(245, 242, 238, 0) 66%);
}
.layout-frame_stage .hero-content {
  position: absolute; left: 24px; top: 50%; transform: translateY(-50%);
  width: min(28%, 360px); z-index: 3; color: #162a43;
}
.layout-frame_stage .hero-content p { color: #51647d; }

/* --- TEMA 9: CRISTAL ESQUINA (glass_float) --- */
.layout-glass_float .hero-gradient { display: none; }
.layout-glass_float .hero-content {
  position: absolute; right: 30px; top: 30px;
  background: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  padding: 40px; border-radius: 30px;
  border: 1px solid rgba(255,255,255,0.4);
  box-shadow: 0 25px 50px rgba(0,0,0,0.08);
  max-width: 500px; color: #1a1a1a;
}

/* --- TEMA 10: ENFOQUE INFERIOR (clean_bottom) --- */
.layout-clean_bottom .hero-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(transparent 40%, rgba(0,0,0,0.8));
}
.layout-clean_bottom .hero-content {
  position: absolute; left: 0; right: 0; bottom: 40px;
  text-align: center; color: #fff; z-index: 3;
}
.layout-clean_bottom .hero-content h2,
.layout-clean_bottom .hero-content p { margin-inline: auto; color: #fff; }
.layout-clean_bottom .hero-cta { background: #fff; color: var(--primary-100); }

/* --- TEMA 11: DIVISION ELEGANTE (split_side) --- */
.layout-split_side .hero-gradient {
  position: absolute; left: 0; top: 0; bottom: 0; width: 40%;
  background: #fff; z-index: 2;
}
.layout-split_side .image { width: 65%; margin-left: auto; }
.layout-split_side .hero-content {
  position: absolute; left: 5%; top: 50%; transform: translateY(-50%);
  width: 35%; z-index: 3; color: #1a1a1a;
}

/* --- TEMA 12: CLASICO DIVIDIDO (classic_split) --- */
.layout-classic_split .hero-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0.7) 40%, transparent 100%);
}
.layout-classic_split .hero-content {
  position: absolute; left: 60px; top: 50%; transform: translateY(-50%);
  max-width: 500px; z-index: 3; color: #1a1a1a;
}

/* --- TEMA 13: CINEMATICO TOTAL (cinematic_full) --- */
.layout-cinematic_full .hero-gradient {
  position: absolute; inset: 0;
  background: radial-gradient(circle at 20% 50%, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.8) 100%);
}
.layout-cinematic_full .hero-content {
  position: absolute; left: 10%; bottom: 15%;
  color: #fff; z-index: 3; text-shadow: 0 2px 10px rgba(0,0,0,0.3);
}
.layout-cinematic_full .hero-content h2,
.layout-cinematic_full .hero-content p { color: #fff; }

/* --- TEMA 14: BORDE A BORDE (edge_to_edge) --- */
.layout-edge_to_edge .hero-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.6) 0%, transparent 50%);
}
.layout-edge_to_edge .hero-content {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 40px; text-align: center; color: #fff; z-index: 3;
}
.layout-edge_to_edge .hero-content h2,
.layout-edge_to_edge .hero-content p { margin-inline: auto; color: #fff; }

/* --- TEMA 15: MINIMO LIMPIO (minimal_clean) --- */
.layout-minimal_clean .hero-gradient { display: none; }
.layout-minimal_clean .hero-content {
  position: absolute; left: 50px; top: 50px;
  background: #fff; padding: 25px; border-radius: 12px;
  box-shadow: 0 8px 18px rgba(0,0,0,0.04); color: #1a1a1a;
}

/* --- TEMA 16: ENFOQUE CRISTAL (glass_focus) --- */
.layout-glass_focus .hero-gradient {
  position: absolute; inset: 0;
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  background: rgba(255,255,255,0.1);
}
.layout-glass_focus .hero-content {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  background: rgba(255, 255, 255, 0.75);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  padding: 50px; border-radius: 40px; border: 1px solid rgba(255,255,255,0.3);
  text-align: center; max-width: 600px; color: #1a1a1a;
}

/* --- TEMA 17: FOCO DERECHA (spotlight_right) --- */
.layout-spotlight_right .hero-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(-90deg, rgba(255,255,255,0.9) 0%, transparent 60%);
}
.layout-spotlight_right .hero-content {
  position: absolute; right: 60px; top: 50%; transform: translateY(-50%);
  text-align: right; max-width: 500px; color: #1a1a1a;
}
.layout-spotlight_right .hero-content h2,
.layout-spotlight_right .hero-content p { margin-left: auto; }

/* --- Navigation & Common UI --- */
.cd-slider.home-hero-slider .hero-target-label {
  display: inline-flex; align-items: center; min-height: 26px; padding: 0 10px; border-radius: 999px;
  font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  border: 1px solid rgba(0, 0, 0, .1); background: var(--primary-10); color: var(--primary-100); margin-bottom: .55rem;
}

.cd-slider.home-hero-slider .hero-content h2 { margin: 0; font-size: clamp(1.25rem, 2.7vw, 2.35rem); line-height: 1.18; font-weight: 800; letter-spacing: .2px; }
.cd-slider.home-hero-slider .hero-content p { margin: .66rem 0 0; font-size: clamp(.88rem, 1.15vw, 1.05rem); line-height: 1.62; max-width: 64ch; }

.cd-slider.home-hero-slider .hero-cta {
  display: inline-flex; align-items: center; justify-content: center; gap: .4rem; margin-top: 1rem;
  min-height: 44px; padding: 0 1.1rem; border-radius: 999px;
  background: var(--primary-100); color: #fff; font-weight: 700; text-decoration: none;
  transition: all 0.3s ease; box-shadow: 0 8px 16px var(--primary-20);
}
.cd-slider.home-hero-slider .hero-cta:hover { transform: translateY(-2px); box-shadow: 0 12px 22px var(--primary-30); }

.cd-slider.home-hero-slider .slide.is-image-only .hero-gradient {
  display: none;
}

.cd-slider.home-hero-slider.layout-catalog_panel .slide.is-image-only > picture,
.cd-slider.home-hero-slider.layout-frame_stage .slide.is-image-only > picture,
.cd-slider.home-hero-slider.layout-product_spotlight .slide.is-image-only > picture {
  position: absolute;
  inset: 0;
  width: auto;
  height: auto;
  border-radius: 0;
  box-shadow: none;
}

.cd-slider.home-hero-slider.layout-product_spotlight .slide.is-image-only::before {
  display: none;
}

.cd-slider.home-hero-slider.layout-catalog_panel .slide.is-image-only .image,
.cd-slider.home-hero-slider.layout-frame_stage .slide.is-image-only .image,
.cd-slider.home-hero-slider.layout-product_spotlight .slide.is-image-only .image {
  object-fit: cover;
  filter: none;
}

.cd-slider.home-hero-slider .hero-progress { position: absolute; left: 0; right: 0; top: 0; height: 4px; background: rgba(255, 255, 255, .2); z-index: 5; overflow: hidden; display: none; }
.cd-slider.home-hero-slider .hero-progress-value { display: block; width: 0; height: 100%; background: linear-gradient(90deg, var(--accent-100), var(--primary-100), #fff); }
.cd-slider.home-hero-slider.layout-progress_line .hero-progress { display: block; }

.cd-slider.home-hero-slider .controls {
  position: absolute; right: clamp(14px, 3vw, 32px); bottom: clamp(14px, 3vw, 32px);
  display: flex; align-items: center; gap: .6rem; z-index: 4; padding: 7px 10px; border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .28); background: rgba(7, 17, 36, .44); backdrop-filter: blur(8px);
}

.cd-slider.home-hero-slider .controls .prev, .cd-slider.home-hero-slider .controls .next { width: 34px; height: 34px; border: 0; border-radius: 50%; cursor: pointer; background: rgba(255, 255, 255, .18); color: #fff; position: relative; }
.cd-slider.home-hero-slider .controls .prev::before, .cd-slider.home-hero-slider .controls .next::before { content: ''; position: absolute; top: 50%; left: 50%; width: 8px; height: 8px; border: solid currentColor; border-width: 0 2px 2px 0; }
.cd-slider.home-hero-slider .controls .prev::before { transform: translate(-42%, -50%) rotate(135deg); }
.cd-slider.home-hero-slider .controls .next::before { transform: translate(-58%, -50%) rotate(-45deg); }
.cd-slider.home-hero-slider .counter {
  --counter-progress-angle: 0deg;
  position: relative;
  width: 54px;
  height: 54px;
  min-width: 54px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  text-align: center;
  color: #f2f7ff;
  font-variant-numeric: tabular-nums;
}

.cd-slider.home-hero-slider .counter::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    conic-gradient(var(--primary-100) 0deg var(--counter-progress-angle), color-mix(in srgb, var(--bg-100) 20%, transparent) var(--counter-progress-angle) 360deg);
}

.cd-slider.home-hero-slider .counter::after {
  content: '';
  position: absolute;
  inset: 4px;
  border-radius: inherit;
  border: 1px solid rgba(255, 255, 255, .16);
  background: rgba(7, 17, 36, .78);
}

.cd-slider.home-hero-slider .counter-value {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: baseline;
  gap: 1px;
  line-height: 1;
}

.cd-slider.home-hero-slider .counter-current {
  font-size: .92rem;
  font-weight: 900;
}

.cd-slider.home-hero-slider .counter-separator,
.cd-slider.home-hero-slider .counter-total {
  font-size: .62rem;
  font-weight: 700;
  opacity: .8;
}

.home-shop {
  width: 100%;
  padding: clamp(1.55rem, 2.6vw, 2.35rem) 0 clamp(1.2rem, 2.4vw, 2rem);
  scroll-margin-top: 1rem;
}

.home-shop__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .82rem;
  margin-bottom: clamp(.9rem, 1.7vw, 1.25rem);
}

.home-shop__heading {
  max-width: 720px;
  display: grid;
  gap: .28rem;
  min-width: 0;
}

.home-shop__heading h2 {
  margin: 0;
  font-size: clamp(1.34rem, 1.75vw, 1.82rem);
  color: var(--text-100);
  line-height: 1.1;
  letter-spacing: 0;
  font-weight: 850;
}

.home-shop__action {
  min-height: 42px;
  padding: 0 1rem;
  border-radius: 999px;
  background: var(--surface-card);
  color: var(--primary-100);
  box-shadow: 0 1px 2px color-mix(in srgb, var(--text-100) 5%, transparent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-size: .9rem;
  font-weight: 800;
  white-space: nowrap;
  transition: transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}

.home-shop__action:hover,
.home-shop__action:focus-visible {
  background: var(--primary-100);
  color: #fff;
  box-shadow: 0 3px 10px color-mix(in srgb, var(--primary-100) 10%, transparent);
  outline: none;
}

.shop-container {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: clamp(.5rem, .72vw, .72rem);
  padding: 0;
  justify-content: stretch;
  align-items: stretch;
}

.shop-container .box {
  border: 0;
  border-radius: 16px;
  overflow: hidden;
  background: var(--surface-card);
  box-shadow: 0 1px 3px color-mix(in srgb, var(--text-100) 6%, transparent);
  transition: box-shadow .18s ease, background-color .18s ease;
  display: grid;
  grid-template-rows: auto minmax(116px, 1fr) auto;
  gap: .46rem;
  min-height: 0;
  width: 100%;
  isolation: isolate;
  padding: .55rem;
  cursor: pointer;
}

.shop-container .box:hover,
.shop-container .box:focus-within {
  box-shadow: 0 3px 10px color-mix(in srgb, var(--text-100) 7%, transparent);
}

.shop-container .box.is-live-unavailable {
  box-shadow: 0 1px 2px color-mix(in srgb, var(--text-100) 5%, transparent);
}

.shop-container .box.is-live-low-stock {
  box-shadow: 0 1px 2px color-mix(in srgb, var(--warning, #f59e0b) 10%, transparent);
}

.shop-container .box-img a {
  display: block;
  position: relative;
  aspect-ratio: 1 / 1;
  background: color-mix(in srgb, var(--surface-muted) 68%, var(--surface-card) 32%);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: none;
}

.shop-container .box-img a::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(100deg,
      color-mix(in srgb, var(--surface-muted) 84%, var(--surface-card) 16%) 18%,
      color-mix(in srgb, var(--surface-card) 76%, var(--surface-muted) 24%) 48%,
      color-mix(in srgb, var(--surface-muted) 84%, var(--surface-card) 16%) 82%);
  background-size: 230% 100%;
  opacity: 0;
  transition: opacity .42s cubic-bezier(0.22, 1, 0.36, 1);
}

.shop-container .box-img a.is-image-loading::before {
  opacity: 1;
  animation: homeProductImageSkeleton 1.35s ease-in-out infinite;
}

.shop-container .box-img a.is-image-ready::before {
  opacity: 0;
  animation: none;
}

@keyframes homeProductImageSkeleton {
  from { background-position: 200% 0; }
  to { background-position: -200% 0; }
}

.shop-container .box-img,
.shop-container .title-price,
.shop-container .product-price {
  min-width: 0;
}

.shop-container .box-img picture {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 1;
}

.shop-container .box-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  padding: 0;
  opacity: 1;
  transform: scale(1);
  filter: none;
  transition:
    opacity .42s ease .06s,
    transform .52s cubic-bezier(0.22, 1, 0.36, 1),
    filter .42s ease;
}

.shop-container .box-img a.is-image-loading .home-product-thumb {
  opacity: 0.01;
  transform: scale(0.996);
  filter: saturate(.96);
}

.shop-container .box-img a.is-image-ready .home-product-thumb {
  opacity: 1;
  transform: scale(1);
  filter: none;
}

.shop-container .box-img img.is-fallback {
  object-fit: contain;
  padding: .92rem;
  transform: none;
}

.home-product-badge {
  position: absolute;
  z-index: 4;
  top: 8px;
  left: 8px;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  font-size: .64rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  background: #d94444;
  color: #fff;
  box-shadow: none;
}

.home-product-badge.is-hidden {
  display: none;
}

.home-product-badge.is-offer {
  background: #d94444;
  color: #fff;
  box-shadow: none;
}

.home-product-badge.is-stockout {
  background: #7a4a00;
  color: #fff7df;
  box-shadow: none;
}

.home-product-badge.is-unavailable {
  background: #475569;
  color: #fff;
  box-shadow: none;
}

.home-product-low-stock-badge {
  position: absolute;
  z-index: 4;
  right: 8px;
  top: 8px;
  max-width: calc(100% - 16px);
  min-height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #fff1bf;
  color: #664000;
  font-size: .62rem;
  font-weight: 820;
  line-height: 1;
  white-space: nowrap;
  box-shadow: 0 1px 2px rgba(102, 64, 0, .12);
}

.home-product-low-stock-badge svg {
  width: 13px;
  height: 13px;
  flex: 0 0 auto;
}

.home-product-low-stock-badge.is-hidden {
  display: none;
}

.shop-container .title-price {
  display: grid;
  align-content: start;
  gap: .34rem;
  min-width: 0;
  padding: .02rem .08rem 0;
}

.shop-container .title-price h3 {
  margin: 0;
  font-size: .92rem;
  line-height: 1.3;
  color: var(--text-100);
  font-weight: 820;
  letter-spacing: 0;
  min-height: 2.6em;
}

.shop-container .home-product-title-link {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: inherit;
  text-decoration: none;
}

.shop-container .home-product-title-link:hover,
.shop-container .home-product-title-link:focus-visible {
  color: color-mix(in srgb, var(--primary-100) 88%, var(--text-100) 12%);
  outline: none;
}

.shop-container .product-meta {
  margin: 0;
  font-size: .72rem;
  color: var(--text-200);
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 1.35em;
}

.shop-container .title-price h3 + .home-product-condition-stack,
.shop-container .title-price h3 + .home-product-condition-note {
  margin-top: .02rem;
}

.shop-container .home-product-condition-stack {
  display: flex;
  align-items: center;
  gap: .28rem;
  flex-wrap: wrap;
  margin-top: .02rem;
}

.shop-container .home-product-condition-stack.is-empty {
  display: none;
}

.shop-container .home-product-condition-pill,
.shop-container .home-product-stock-pill,
.shop-container .home-product-warranty-pill {
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  padding: 0 .48rem;
  border-radius: 999px;
  font-size: .62rem;
  line-height: 1;
  font-weight: 780;
  letter-spacing: .01em;
  border: 0;
}

.shop-container .home-product-condition-pill {
  color: #064889;
  background: #dbeeff;
}

.shop-container .home-product-stock-pill {
  color: #425466;
  background: #edf2f7;
}

.shop-container .home-product-stock-pill.is-low-stock {
  color: #664000;
  background: #fff1bf;
}

.shop-container .home-product-warranty-pill {
  color: #0b6534;
  background: #dff6e9;
}

.shop-container .home-product-condition-note {
  margin: .02rem 0 0;
  font-size: .68rem;
  line-height: 1.35;
  color: #187240;
  display: inline-flex;
  align-items: center;
  gap: .34rem;
  font-weight: 650;
}

.shop-container .home-product-condition-note::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: currentColor;
  flex: 0 0 auto;
}

.shop-container .home-product-condition-note.is-empty {
  display: none;
}

.shop-container .home-product-swatches {
  display: flex;
  align-items: center;
  gap: .4rem;
  overflow-x: auto;
  padding: .14rem .04rem .18rem;
  margin-top: .02rem;
  scrollbar-width: thin;
}

.shop-container .home-product-swatch {
  width: 32px;
  height: 32px;
  border-radius: 11px;
  border: 0;
  background: var(--surface-card);
  padding: 2px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  cursor: pointer;
  position: relative;
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--surface-border-strong) 88%, transparent),
    0 1px 2px color-mix(in srgb, var(--text-100) 5%, transparent);
  transition: background-color .18s ease, box-shadow .18s ease;
}

.shop-container .home-product-swatch::before {
  display: none;
}

.shop-container .home-product-swatch::after {
  display: none;
}

.shop-container .home-product-swatch:hover,
.shop-container .home-product-swatch:focus-visible {
  background: color-mix(in srgb, var(--primary-300) 7%, var(--surface-card) 93%);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--primary-100) 32%, var(--surface-border-strong) 68%),
    0 1px 3px color-mix(in srgb, var(--primary-100) 7%, transparent);
  outline: none;
}

.shop-container .home-product-swatch.is-active {
  background: color-mix(in srgb, var(--primary-300) 10%, var(--surface-card) 90%);
  box-shadow:
    inset 0 0 0 2px var(--primary-100),
    0 2px 6px color-mix(in srgb, var(--primary-100) 10%, transparent);
}

.shop-container .home-product-swatch picture,
.shop-container .home-product-swatch__img {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: inherit;
}

.shop-container .home-product-swatch__img {
  object-fit: cover;
  background: var(--surface-muted);
}

.shop-container .home-product-swatch__img.is-fallback {
  object-fit: contain;
  padding: .28rem;
}

.shop-container .home-product-color {
  margin: 0;
  font-size: .68rem;
  color: var(--text-200);
  line-height: 1.25;
  min-height: 1.05em;
  text-transform: capitalize;
}

.shop-container .product-price {
  padding: .14rem .08rem .02rem;
  display: flex;
  align-items: flex-end;
  gap: .46rem;
  flex-wrap: wrap;
  margin-top: auto;
  min-height: 36px;
  font-variant-numeric: tabular-nums;
}

.shop-container .product-price .precio-normal {
  color: var(--text-200);
  text-decoration: line-through;
  font-size: .78rem;
  line-height: 1.15;
  opacity: .82;
}

.shop-container .product-price .precio-oferta {
  color: color-mix(in srgb, var(--danger) 86%, var(--text-100) 14%);
  font-weight: 880;
  font-size: 1.04rem;
  line-height: 1.15;
  min-height: 24px;
  display: inline-flex;
  align-items: center;
}

.shop-container .product-price .precio-unico {
  color: color-mix(in srgb, var(--primary-100) 88%, var(--text-100) 12%);
  font-weight: 880;
  font-size: 1.04rem;
  line-height: 1.15;
  min-height: 24px;
  display: inline-flex;
  align-items: center;
}

.shop-container .product-price .precio-unico.is-unavailable-label {
  color: #8a5700;
  font-size: .94rem;
  font-weight: 840;
  letter-spacing: .01em;
}

.home-about {
  margin-top: clamp(1.2rem, 2.6vw, 2.2rem);
  border-radius: 24px;
  background: var(--surface-card);
  box-shadow: 0 10px 28px color-mix(in srgb, var(--text-100) 4%, transparent);
  display: grid;
  grid-template-columns: minmax(210px, 340px) minmax(0, 1fr);
  gap: clamp(1rem, 2.4vw, 2rem);
  align-items: center;
  padding: clamp(1rem, 2.6vw, 2.2rem);
}

.home-about-media {
  min-width: 0;
  display: grid;
  place-items: center;
}

.home-about-logo-card {
  width: min(100%, 300px);
  min-height: 238px;
  padding: clamp(1rem, 2vw, 1.35rem);
  border-radius: 22px;
  background: color-mix(in srgb, var(--surface-muted) 72%, var(--surface-card) 28%);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 1rem;
}

.home-about-logo-picture {
  width: min(100%, 210px);
  display: grid;
  place-items: center;
}

.home-about-logo-picture img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.home-about-logo-caption {
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--surface-card);
  color: var(--text-200);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .74rem;
  font-weight: 800;
  text-align: center;
}

.home-about-content {
  min-width: 0;
  display: grid;
  gap: .85rem;
}

.about-text h2 {
  margin: 0;
  max-width: 780px;
  font-size: clamp(1.28rem, 2.1vw, 2rem);
  color: var(--text-100);
  line-height: 1.12;
}

.about-text p {
  margin: 0;
  max-width: 820px;
  color: var(--text-200);
  line-height: 1.62;
  font-size: .95rem;
}

.home-about-intro {
  color: var(--text-100);
}

.home-about-points {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .55rem;
  padding-top: .1rem;
}

.home-about-point {
  min-height: 36px;
  padding: 0 .82rem;
  border-radius: 999px;
  background: var(--surface-muted);
  color: var(--text-100);
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-size: .82rem;
  font-weight: 800;
  white-space: nowrap;
}

.home-about-point svg {
  width: 18px;
  height: 18px;
  color: #0052a8;
  flex: 0 0 auto;
}

.home-about-content .home-about-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: start;
  margin-top: .15rem;
  min-height: 44px;
  padding: 0 1.05rem;
  border-radius: 14px;
  background: #0052a8;
  color: #ffffff;
  text-decoration: none;
  font-weight: 850;
  box-shadow: 0 6px 14px rgba(0, 82, 168, .14);
  transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease;
}

.home-about-content .home-about-action:hover,
.home-about-content .home-about-action:focus-visible {
  transform: translateY(-1px);
  background: #00458f;
  color: #ffffff;
  box-shadow: 0 8px 18px rgba(0, 82, 168, .18);
  text-decoration: none;
  outline: none;
}

.home-footer-shell {
  margin-top: 2rem;
  border-top: 1px solid var(--surface-border);
  background:
    radial-gradient(580px 360px at -10% -20%, color-mix(in srgb, var(--primary-300) 20%, #fff 80%), transparent 62%),
    radial-gradient(520px 320px at 110% 120%, color-mix(in srgb, var(--primary-200) 12%, #fff 88%), transparent 68%),
    linear-gradient(150deg, var(--surface-card), var(--surface-page));
  color: var(--text-100);
}

.home-footer-grid {
  width: min(112rem, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  padding: 2rem 1rem 1.5rem;
}

.home-footer-col {
  border: 1px solid var(--surface-border);
  border-radius: 14px;
  background: var(--surface-card);
  padding: 14px;
}

.home-footer-col h3 {
  margin: 0;
  color: var(--text-100);
  font-size: 1rem;
}

.home-footer-col p,
.home-footer-col li,
.home-footer-col a {
  color: var(--text-200);
  font-size: .9rem;
  line-height: 1.65;
}

.home-footer-col li {
  display: flex;
  align-items: center;
  gap: .45rem;
}

.home-footer-col li svg,
.home-ssl-badge svg {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

.home-footer-col ul {
  list-style: none;
  margin: .6rem 0 0;
  padding: 0;
  display: grid;
  gap: .35rem;
}

.home-footer-col a {
  text-decoration: none;
}

.home-footer-col a:hover {
  color: var(--primary-100);
}

.home-ssl-badge {
  margin-top: .75rem;
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  border: 1px solid color-mix(in srgb, var(--success) 46%, var(--surface-border) 54%);
  color: color-mix(in srgb, var(--success) 78%, #000 22%);
  border-radius: 999px;
  min-height: 32px;
  padding: 0 .75rem;
  font-size: .78rem;
  font-weight: 700;
}

.home-footer-ssl-note {
  margin-top: .7rem;
  font-size: .78rem;
  color: var(--text-200);
}

.home-copyright {
  width: min(112rem, 100%);
  margin: 0 auto;
  border-top: 1px solid var(--surface-border);
  padding: .95rem 1rem 1.2rem;
  color: var(--text-200);
  font-size: .84rem;
  text-align: center;
}

@media (max-width: 1420px) {
  .shop-container {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

@media (max-width: 1024px) {
  .shop-container {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .home-footer-grid {
    grid-template-columns: 1fr 1fr;
  }

  .home-about {
    grid-template-columns: 1fr;
  }

  .home-about-media {
    place-items: start;
  }

  .home-about-logo-card {
    width: min(100%, 360px);
    min-height: 210px;
  }

  .cd-slider.home-hero-slider.layout-classic_split .hero-content {
    max-width: min(560px, 78%);
  }

  .cd-slider.home-hero-slider.layout-catalog_panel .hero-content,
  .cd-slider.home-hero-slider.layout-product_spotlight .hero-content {
    width: min(44%, 520px);
  }

  .cd-slider.home-hero-slider.layout-frame_stage .hero-content {
    width: min(32%, 380px);
  }
}

@media (max-width: 760px) {
  .home-shell {
    padding: .8rem .7rem 0;
  }

  .home-about {
    gap: 1rem;
    padding: 1rem;
    border-radius: 20px;
  }

  .home-about-media {
    place-items: stretch;
  }

  .home-about-logo-card {
    width: 100%;
    min-height: 168px;
    border-radius: 18px;
  }

  .home-about-logo-picture {
    width: min(100%, 168px);
  }

  .home-about-content {
    gap: .75rem;
  }

  .about-text h2 {
    font-size: 1.28rem;
  }

  .about-text p {
    font-size: .9rem;
    line-height: 1.55;
  }

  .home-about-points {
    display: grid;
    grid-template-columns: 1fr;
  }

  .home-about-point {
    justify-content: flex-start;
    white-space: normal;
  }

  .home-shop__header {
    align-items: flex-start;
  }

  .home-shop__heading {
    gap: .3rem;
  }

  .home-shop__heading h2 {
    font-size: clamp(1.45rem, 5.7vw, 1.75rem);
    line-height: 1.12;
  }

  .home-shop__action {
    min-height: 38px;
    padding-inline: .88rem;
    font-size: .84rem;
  }

  .shop-container {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .68rem;
  }

  .shop-container .box {
    grid-template-rows: auto minmax(104px, 1fr) auto;
    gap: .4rem;
  }

  .shop-container .title-price {
    padding-inline: .08rem;
    gap: .28rem;
  }

  .shop-container .title-price h3 {
    font-size: .86rem;
    line-height: 1.3;
  }

  .shop-container .product-meta,
  .shop-container .home-product-condition-note,
  .shop-container .home-product-color {
    font-size: .7rem;
  }

  .shop-container .home-product-condition-pill,
  .shop-container .home-product-stock-pill,
  .shop-container .home-product-warranty-pill {
    min-height: 20px;
    padding-inline: .44rem;
    font-size: .59rem;
  }

  .shop-container .home-product-swatch {
    width: 28px;
    height: 28px;
  }

  .shop-container .product-price {
    padding: .06rem .08rem 0;
    min-height: 30px;
  }

  .shop-container .product-price .precio-unico,
  .shop-container .product-price .precio-oferta {
    font-size: .96rem;
  }

  .cd-slider.home-hero-slider {
    --hero-mobile-control-space: 62px;
    aspect-ratio: 4 / 5;
    border-radius: 16px;
    background: var(--surface-card, #fff);
  }

  .cd-slider.home-hero-slider.is-single-slide {
    --hero-mobile-control-space: 0px;
  }

  .cd-slider.home-hero-slider:not(.layout-thumb_rail) .slides {
    height: calc(100% - var(--hero-mobile-control-space));
  }

  .cd-slider.home-hero-slider.is-single-slide:not(.layout-thumb_rail) .slides {
    height: 100%;
  }

  .cd-slider.home-hero-slider.layout-cinematic_full {
    aspect-ratio: 9 / 13;
  }

  .cd-slider.home-hero-slider.layout-edge_to_edge {
    aspect-ratio: 9 / 13;
  }

  .cd-slider.home-hero-slider.layout-caption_strip,
  .cd-slider.home-hero-slider.layout-catalog_panel,
  .cd-slider.home-hero-slider.layout-product_spotlight,
  .cd-slider.home-hero-slider.layout-frame_stage,
  .cd-slider.home-hero-slider.layout-promo_sheet {
    aspect-ratio: 4 / 5;
  }

  .cd-slider.home-hero-slider:not(.layout-thumb_rail) .controls {
    top: auto;
    right: auto;
    bottom: max(8px, env(safe-area-inset-bottom));
    left: 50%;
    transform: translateX(-50%);
    min-height: 46px;
    gap: .42rem;
    padding: 5px 7px;
    border: 0;
    background: var(--surface-card, #fff);
    box-shadow: 0 14px 28px -24px rgba(15, 23, 42, .48);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .cd-slider.home-hero-slider:not(.layout-thumb_rail) .controls .prev,
  .cd-slider.home-hero-slider:not(.layout-thumb_rail) .controls .next {
    width: 36px;
    height: 36px;
    background: color-mix(in srgb, var(--primary-100) 10%, var(--bg-200) 90%);
    color: var(--text-100);
  }

  .cd-slider.home-hero-slider:not(.layout-thumb_rail) .counter {
    width: 42px;
    height: 42px;
    min-width: 42px;
    color: var(--text-100);
  }

  .cd-slider.home-hero-slider:not(.layout-thumb_rail) .counter::after {
    inset: 4px;
    background: var(--surface-card, #fff);
    border-color: color-mix(in srgb, var(--primary-100) 18%, transparent);
  }

  .hero-content {
    left: 12px;
    bottom: 12px;
    max-width: 95%;
  }

  .cd-slider.home-hero-slider.layout-caption_strip .hero-content {
    left: 0;
    right: 0;
    bottom: 0;
    max-width: none;
    padding: 14px 14px 16px;
  }

  .cd-slider.home-hero-slider.layout-corner_badge .hero-content {
    top: 12px;
    left: 12px;
    right: 12px;
    max-width: 82%;
    padding: 16px;
  }

  .cd-slider.home-hero-slider.layout-catalog_panel .slide > picture,
  .cd-slider.home-hero-slider.layout-frame_stage .slide > picture {
    left: 12px;
    right: 12px;
    top: 12px;
    bottom: auto;
    width: auto;
    height: 52%;
    border-radius: 22px;
  }

  .cd-slider.home-hero-slider.layout-catalog_panel .hero-gradient,
  .cd-slider.home-hero-slider.layout-frame_stage .hero-gradient {
    background: linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.03) 26%, rgba(255,255,255,.92) 62%, rgba(255,255,255,.97) 100%);
  }

  .cd-slider.home-hero-slider.layout-catalog_panel .hero-content,
  .cd-slider.home-hero-slider.layout-frame_stage .hero-content {
    left: 12px;
    right: 12px;
    top: auto;
    bottom: 12px;
    width: auto;
    max-width: none;
    transform: none;
    padding: 18px;
    border-radius: 22px;
  }

  .cd-slider.home-hero-slider.layout-product_spotlight .slide::before {
    right: 12px;
    top: 12px;
    bottom: auto;
    width: 44%;
    height: 50%;
    border-radius: 24px;
  }

  .cd-slider.home-hero-slider.layout-product_spotlight .slide > picture {
    right: 12px;
    top: 12px;
    bottom: auto;
    width: 44%;
    height: 50%;
  }

  .cd-slider.home-hero-slider.layout-product_spotlight .hero-content {
    left: 12px;
    right: 12px;
    top: auto;
    bottom: 12px;
    width: auto;
    max-width: none;
    transform: none;
  }

  .cd-slider.home-hero-slider.layout-promo_sheet .hero-content {
    left: 12px;
    right: 12px;
    bottom: 12px;
    padding: 16px;
    border-radius: 22px;
  }

  .cd-slider.home-hero-slider.layout-minimal_clean .hero-content {
    top: 12px;
    bottom: auto;
    max-width: 95%;
  }

  .cd-slider.home-hero-slider.layout-glass_focus .hero-content {
    top: 12px;
    bottom: auto;
    max-width: 95%;
  }

  .cd-slider.home-hero-slider.layout-spotlight_right .hero-content {
    left: 12px;
    right: 12px;
    max-width: none;
  }

  .cd-slider.home-hero-slider.layout-classic_split .hero-gradient {
    background: linear-gradient(180deg, rgba(255, 255, 255, .82) 0%, rgba(255, 255, 255, .72) 42%, rgba(8, 26, 51, .18) 100%);
  }

  .cd-slider.home-hero-slider.layout-classic_split .hero-content {
    max-width: 95%;
  }

  .home-footer-grid {
    grid-template-columns: 1fr;
    padding: 1.5rem .72rem 1rem;
  }
}

@media (max-width: 360px) {
  .home-shell {
    padding: .56rem .52rem 0;
  }

  .cd-slider.home-hero-slider {
    --hero-mobile-control-space: 56px;
  }

  .cd-slider.home-hero-slider:not(.layout-thumb_rail) .controls {
    bottom: max(7px, env(safe-area-inset-bottom));
    min-height: 42px;
    gap: .32rem;
    padding: 4px 6px;
  }

  .cd-slider.home-hero-slider:not(.layout-thumb_rail) .controls .prev,
  .cd-slider.home-hero-slider:not(.layout-thumb_rail) .controls .next {
    width: 32px;
    height: 32px;
  }

  .cd-slider.home-hero-slider:not(.layout-thumb_rail) .counter {
    width: 38px;
    height: 38px;
    min-width: 38px;
  }

  .hero-content {
    left: 8px;
    right: 8px;
    bottom: 8px;
    max-width: none;
  }

  .cd-slider.home-hero-slider.layout-caption_strip .hero-content,
  .cd-slider.home-hero-slider.layout-promo_sheet .hero-content,
  .cd-slider.home-hero-slider.layout-catalog_panel .hero-content,
  .cd-slider.home-hero-slider.layout-frame_stage .hero-content {
    padding: 12px;
    border-radius: 18px;
  }

  .hero-content p {
    line-height: 1.45;
    margin-top: .5rem;
  }

  .hero-cta {
    width: 100%;
    min-height: 38px;
    margin-top: .72rem;
    padding: 0 .72rem;
  }

  .shop-container {
    gap: .58rem;
  }
}

@media (max-width: 520px) {
  .home-shop__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
    gap: .62rem;
    margin-bottom: .95rem;
  }

  .home-shop__heading {
    flex: 1 1 auto;
  }

  .home-shop__heading h2 {
    font-size: clamp(.98rem, 4.8vw, 1.36rem);
    white-space: nowrap;
  }

  .home-shop__action {
    flex: 0 0 auto;
    justify-self: start;
    min-height: 36px;
    padding-inline: .78rem;
    font-size: .8rem;
  }

  .shop-container {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .62rem;
  }

  .shop-container .box {
    grid-template-rows: auto minmax(98px, 1fr) auto;
    gap: .42rem;
    padding: .48rem;
    border-radius: 14px;
  }

  .shop-container .box-img a {
    aspect-ratio: 1 / 1;
    border-radius: 11px;
  }

  .shop-container .title-price h3 {
    font-size: .84rem;
    line-height: 1.28;
  }
}

@media (max-width: 430px) {
  .shop-container {
    grid-template-columns: 1fr;
    gap: .84rem;
  }

  .shop-container .box {
    grid-template-rows: auto auto auto;
    gap: .48rem;
    padding: .56rem;
  }

  .shop-container .title-price h3 {
    font-size: .96rem;
  }
}

@media (max-width: 220px) {
  .home-shell {
    padding: .46rem .36rem 0;
  }

  .home-shop__header {
    gap: .38rem;
  }

  .home-shop__heading h2 {
    font-size: clamp(.72rem, 6vw, .9rem);
  }

  .home-shop__action {
    min-height: 30px;
    padding-inline: .44rem;
    font-size: .64rem;
  }

  .hero-target-label {
    min-height: 20px;
    padding: 0 7px;
    font-size: .62rem;
  }

  .hero-content h2 {
    font-size: 1rem;
    line-height: 1.2;
  }

  .hero-content p {
    font-size: .73rem;
  }

  .home-product-badge {
    top: 6px;
    left: 6px;
    min-height: 20px;
    font-size: .58rem;
    padding: 0 6px;
  }

  .home-product-low-stock-badge {
    top: 6px;
    right: 6px;
    min-height: 20px;
    padding: 0 6px;
  }

  .home-product-low-stock-badge span {
    display: none;
  }

  .shop-container .title-price,
  .shop-container .product-price {
    padding-inline: 0;
  }
}

@media (max-width: 170px) {
  .cd-slider.home-hero-slider .controls {
    display: none;
  }

  .hero-content {
    left: 6px;
    right: 6px;
    bottom: 6px;
  }

  .hero-content h2 {
    font-size: .9rem;
  }
}

/* ============================================================
   HERO STRUCTURES V2
   ============================================================ */

.cd-slider.home-hero-slider .hero-copy-main {
  display: grid;
  gap: .66rem;
  min-width: 0;
}

.cd-slider.home-hero-slider .hero-topline,
.cd-slider.home-hero-slider .hero-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  flex-wrap: wrap;
}

.cd-slider.home-hero-slider .hero-count,
.cd-slider.home-hero-slider .hero-dock,
.cd-slider.home-hero-slider .hero-rail-current,
.cd-slider.home-hero-slider .hero-rail-total {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 .8rem;
  border-radius: 999px;
  border: 1px solid var(--surface-border);
  background: color-mix(in srgb, var(--surface-card) 92%, transparent);
  color: var(--text-100);
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.cd-slider.home-hero-slider .hero-rail {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  min-width: 48px;
}

.cd-slider.home-hero-slider .hero-rail-line {
  width: 1px;
  height: 56px;
  background: color-mix(in srgb, var(--text-100) 18%, transparent);
}

.cd-slider.home-hero-slider .hero-segments {
  display: flex;
  align-items: center;
  gap: .4rem;
  flex: 1 1 auto;
  min-width: min(220px, 100%);
}

.cd-slider.home-hero-slider .hero-segment {
  flex: 1 1 0;
  min-width: 18px;
  height: 4px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--bg-100) 24%, transparent);
}

.cd-slider.home-hero-slider .hero-segment.is-active {
  background: var(--primary-100);
}

.cd-slider.home-hero-slider .hero-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  min-height: 44px;
  padding: 0 1.15rem;
  margin-top: 0;
  border-radius: 999px;
  border: 1px solid transparent;
  text-decoration: none;
  font-weight: 700;
  box-shadow: none;
  transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}

.cd-slider.home-hero-slider .hero-cta--solid {
  background: var(--primary-100);
  color: var(--bg-100);
  border-color: var(--primary-100);
}

.cd-slider.home-hero-slider .hero-cta--light {
  background: var(--surface-card);
  color: var(--text-100);
  border-color: var(--surface-border);
}

.cd-slider.home-hero-slider .hero-cta--outline {
  background: transparent;
  color: var(--bg-100);
  border-color: color-mix(in srgb, var(--bg-100) 44%, transparent);
}

.cd-slider.home-hero-slider .hero-cta:hover {
  transform: translateY(-1px);
}

.cd-slider.home-hero-slider.variant-strip .hero-gradient {
  background: linear-gradient(180deg, transparent 0%, color-mix(in srgb, var(--text-100) 3%, transparent) 100%);
}

.cd-slider.home-hero-slider.variant-strip .hero-content {
  position: absolute;
  left: clamp(18px, 2vw, 28px);
  right: auto;
  bottom: clamp(18px, 2vw, 28px);
  max-width: min(360px, calc(100% - 128px));
  min-height: 0;
  padding: 8px 10px;
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  background: color-mix(in srgb, var(--surface-card) 82%, transparent);
  border: 1px solid var(--surface-border);
  border-radius: 999px;
  color: var(--text-100);
  box-shadow: none;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.cd-slider.home-hero-slider.layout-promo_sheet.variant-strip .hero-content {
  left: 22px;
  right: 22px;
  bottom: 22px;
  border: 1px solid var(--surface-border);
  border-radius: 24px;
  box-shadow: var(--surface-elev-1);
}

.cd-slider.home-hero-slider.variant-strip .hero-strip-chip-group {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  min-width: 0;
  flex-wrap: wrap;
}

.cd-slider.home-hero-slider.variant-strip .hero-strip-title {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 .82rem;
  border-radius: 999px;
  background: var(--bg-100);
  border: 1px solid var(--surface-border);
  color: var(--text-100);
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .03em;
  text-transform: uppercase;
  max-width: 22ch;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cd-slider.home-hero-slider.variant-strip .hero-footer {
  display: none;
}

.cd-slider.home-hero-slider.variant-strip .hero-count {
  display: none;
}

.cd-slider.home-hero-slider.variant-strip .hero-copy-main {
  display: none;
}

.cd-slider.home-hero-slider.variant-strip .hero-cta {
  min-height: 34px;
  padding: 0 .92rem;
  font-size: .82rem;
}

.cd-slider.home-hero-slider.variant-strip .hero-target-label,
.cd-slider.home-hero-slider.variant-card .hero-target-label,
.cd-slider.home-hero-slider.variant-editorial .hero-target-label,
.cd-slider.home-hero-slider.layout-modern_overlay.variant-stage .hero-target-label,
.cd-slider.home-hero-slider.layout-glass_focus.variant-stage .hero-target-label,
.cd-slider.home-hero-slider.layout-spotlight_right.variant-spotlight .hero-target-label {
  border-color: var(--surface-border);
  background: var(--bg-200);
  color: var(--text-100);
}

.cd-slider.home-hero-slider.variant-card .hero-gradient {
  display: none;
}

.cd-slider.home-hero-slider.variant-card .hero-content {
  position: absolute;
  left: 20px;
  top: 20px;
  bottom: auto;
  max-width: min(360px, 48%);
  padding: 18px;
  display: grid;
  gap: .8rem;
  background: color-mix(in srgb, var(--surface-card) 94%, transparent);
  border: 1px solid var(--surface-border);
  border-radius: 24px;
  box-shadow: var(--surface-elev-1);
  color: var(--text-100);
  backdrop-filter: none;
}

.cd-slider.home-hero-slider.layout-minimal_tag.variant-card .hero-content {
  top: auto;
  bottom: 20px;
}

.cd-slider.home-hero-slider.variant-card .hero-content h2,
.cd-slider.home-hero-slider.variant-card .hero-content p {
  color: var(--text-100);
}

.cd-slider.home-hero-slider.variant-card .hero-content p {
  color: var(--text-200);
}

.cd-slider.home-hero-slider.variant-editorial .hero-content {
  position: absolute;
  left: 24px;
  top: 50%;
  bottom: auto;
  transform: translateY(-50%);
  width: min(42%, 520px);
  max-width: none;
  padding: 20px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 1rem;
  background: color-mix(in srgb, var(--surface-card) 92%, transparent);
  border: 1px solid var(--surface-border);
  border-radius: 26px;
  color: var(--text-100);
  box-shadow: none;
}

.cd-slider.home-hero-slider.variant-editorial .hero-content h2,
.cd-slider.home-hero-slider.variant-editorial .hero-content p {
  color: var(--text-100);
}

.cd-slider.home-hero-slider.variant-editorial .hero-content p {
  color: var(--text-200);
}

.cd-slider.home-hero-slider.layout-frame_stage.variant-editorial .hero-content {
  background: none;
  border: 0;
  box-shadow: none;
  width: min(30%, 380px);
  padding: 0;
}

.cd-slider.home-hero-slider.layout-frame_stage.variant-editorial .hero-rail {
  padding: 10px 8px;
  border-radius: 999px;
  border: 1px solid var(--surface-border);
  background: color-mix(in srgb, var(--surface-card) 90%, transparent);
}

.cd-slider.home-hero-slider.variant-spotlight .hero-content {
  position: absolute;
  left: clamp(18px, 4vw, 40px);
  top: 50%;
  bottom: auto;
  transform: translateY(-50%);
  width: min(40%, 520px);
  max-width: none;
  padding: 0;
  display: grid;
  gap: .9rem;
  background: none;
  color: var(--bg-100);
}

.cd-slider.home-hero-slider.variant-spotlight .hero-content h2,
.cd-slider.home-hero-slider.variant-spotlight .hero-content p {
  color: var(--bg-100);
}

.cd-slider.home-hero-slider.variant-spotlight .hero-target-label,
.cd-slider.home-hero-slider.variant-spotlight .hero-count,
.cd-slider.home-hero-slider.variant-spotlight .hero-dock,
.cd-slider.home-hero-slider.layout-glass_float.variant-stage .hero-target-label,
.cd-slider.home-hero-slider.layout-glass_float.variant-stage .hero-count,
.cd-slider.home-hero-slider.layout-clean_bottom.variant-stage .hero-target-label,
.cd-slider.home-hero-slider.layout-clean_bottom.variant-stage .hero-count,
.cd-slider.home-hero-slider.layout-cinematic_full.variant-stage .hero-target-label,
.cd-slider.home-hero-slider.layout-cinematic_full.variant-stage .hero-count,
.cd-slider.home-hero-slider.layout-edge_to_edge.variant-stage .hero-target-label,
.cd-slider.home-hero-slider.layout-edge_to_edge.variant-stage .hero-count,
.cd-slider.home-hero-slider.variant-progress .hero-target-label {
  border-color: color-mix(in srgb, var(--bg-100) 24%, transparent);
  background: color-mix(in srgb, var(--bg-100) 12%, transparent);
  color: var(--bg-100);
}

.cd-slider.home-hero-slider.variant-progress .hero-count {
  border-color: color-mix(in srgb, var(--bg-100) 24%, transparent);
  background: color-mix(in srgb, var(--bg-100) 12%, transparent);
  color: var(--bg-100);
}

.cd-slider.home-hero-slider.layout-product_spotlight.variant-spotlight .hero-gradient {
  background: linear-gradient(90deg, color-mix(in srgb, var(--text-100) 24%, transparent) 0%, color-mix(in srgb, var(--text-100) 8%, transparent) 52%, transparent 100%);
}

.cd-slider.home-hero-slider.layout-spotlight_right.variant-spotlight .hero-gradient {
  background: linear-gradient(-90deg, color-mix(in srgb, var(--surface-card) 86%, transparent) 0%, transparent 62%);
}

.cd-slider.home-hero-slider.layout-spotlight_right.variant-spotlight .hero-content {
  left: auto;
  right: clamp(18px, 4vw, 40px);
  text-align: right;
  color: var(--text-100);
}

.cd-slider.home-hero-slider.layout-spotlight_right.variant-spotlight .hero-content h2,
.cd-slider.home-hero-slider.layout-spotlight_right.variant-spotlight .hero-content p {
  color: var(--text-100);
}

.cd-slider.home-hero-slider.layout-spotlight_right.variant-spotlight .hero-topline,
.cd-slider.home-hero-slider.layout-spotlight_right.variant-spotlight .hero-footer {
  justify-content: flex-end;
}

.cd-slider.home-hero-slider.variant-stage .hero-content {
  position: absolute;
  left: clamp(18px, 4vw, 40px);
  bottom: clamp(18px, 4vw, 40px);
  max-width: min(620px, 90%);
  padding: 0;
  display: grid;
  gap: .9rem;
  background: none;
  color: var(--text-100);
}

.cd-slider.home-hero-slider.layout-modern_overlay.variant-stage .hero-gradient {
  background: linear-gradient(108deg, color-mix(in srgb, var(--surface-card) 92%, transparent) 12%, color-mix(in srgb, var(--surface-card) 34%, transparent) 48%, transparent 100%);
}

.cd-slider.home-hero-slider.layout-modern_overlay.variant-stage .hero-content p {
  color: var(--text-200);
}

.cd-slider.home-hero-slider.layout-glass_float.variant-stage .hero-gradient {
  display: none;
}

.cd-slider.home-hero-slider.layout-glass_float.variant-stage .hero-content {
  left: auto;
  right: 24px;
  top: 24px;
  bottom: auto;
  max-width: min(420px, 48%);
  padding: 20px;
  background: color-mix(in srgb, var(--text-100) 20%, transparent);
  border: 1px solid color-mix(in srgb, var(--bg-100) 16%, transparent);
  border-radius: 26px;
  color: var(--bg-100);
}

.cd-slider.home-hero-slider.layout-glass_float.variant-stage .hero-content h2,
.cd-slider.home-hero-slider.layout-glass_float.variant-stage .hero-content p,
.cd-slider.home-hero-slider.layout-clean_bottom.variant-stage .hero-content h2,
.cd-slider.home-hero-slider.layout-clean_bottom.variant-stage .hero-content p,
.cd-slider.home-hero-slider.layout-cinematic_full.variant-stage .hero-content h2,
.cd-slider.home-hero-slider.layout-cinematic_full.variant-stage .hero-content p,
.cd-slider.home-hero-slider.layout-edge_to_edge.variant-stage .hero-content h2,
.cd-slider.home-hero-slider.layout-edge_to_edge.variant-stage .hero-content p {
  color: var(--bg-100);
}

.cd-slider.home-hero-slider.layout-glass_focus.variant-stage .hero-gradient {
  background: color-mix(in srgb, var(--text-100) 10%, transparent);
  backdrop-filter: blur(3px);
}

.cd-slider.home-hero-slider.layout-glass_focus.variant-stage .hero-content {
  left: 50%;
  top: 50%;
  bottom: auto;
  transform: translate(-50%, -50%);
  max-width: min(680px, calc(100% - 48px));
  padding: 24px;
  border-radius: 30px;
  border: 1px solid var(--surface-border);
  background: color-mix(in srgb, var(--surface-card) 90%, transparent);
  text-align: center;
}

.cd-slider.home-hero-slider.layout-glass_focus.variant-stage .hero-topline,
.cd-slider.home-hero-slider.layout-glass_focus.variant-stage .hero-footer {
  justify-content: center;
}

.cd-slider.home-hero-slider.layout-clean_bottom.variant-stage .hero-gradient,
.cd-slider.home-hero-slider.layout-cinematic_full.variant-stage .hero-gradient,
.cd-slider.home-hero-slider.layout-edge_to_edge.variant-stage .hero-gradient {
  background: linear-gradient(180deg, transparent 20%, color-mix(in srgb, var(--text-100) 62%, transparent) 100%);
}

.cd-slider.home-hero-slider.layout-clean_bottom.variant-stage .hero-content,
.cd-slider.home-hero-slider.layout-cinematic_full.variant-stage .hero-content,
.cd-slider.home-hero-slider.layout-edge_to_edge.variant-stage .hero-content {
  left: 24px;
  right: 24px;
  bottom: 24px;
  max-width: none;
  text-align: center;
}

.cd-slider.home-hero-slider.layout-clean_bottom.variant-stage .hero-topline,
.cd-slider.home-hero-slider.layout-clean_bottom.variant-stage .hero-footer,
.cd-slider.home-hero-slider.layout-cinematic_full.variant-stage .hero-topline,
.cd-slider.home-hero-slider.layout-cinematic_full.variant-stage .hero-footer,
.cd-slider.home-hero-slider.layout-edge_to_edge.variant-stage .hero-topline,
.cd-slider.home-hero-slider.layout-edge_to_edge.variant-stage .hero-footer {
  justify-content: center;
}

.cd-slider.home-hero-slider.variant-progress .hero-gradient {
  background: linear-gradient(180deg, color-mix(in srgb, var(--text-100) 12%, transparent) 0%, color-mix(in srgb, var(--text-100) 60%, transparent) 100%);
}

.cd-slider.home-hero-slider.variant-progress .hero-content {
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 20px;
  max-width: none;
  padding: 18px 20px;
  display: grid;
  gap: .9rem;
  background: color-mix(in srgb, var(--text-100) 18%, transparent);
  border: 1px solid color-mix(in srgb, var(--bg-100) 18%, transparent);
  border-radius: 22px;
  color: var(--bg-100);
  backdrop-filter: blur(8px);
}

.cd-slider.home-hero-slider.variant-progress .hero-content h2,
.cd-slider.home-hero-slider.variant-progress .hero-content p {
  color: var(--bg-100);
}

.cd-slider.home-hero-slider.variant-progress .hero-footer {
  justify-content: space-between;
}

.cd-slider.home-hero-slider.variant-progress .hero-progress {
  display: block;
  background: color-mix(in srgb, var(--bg-100) 18%, transparent);
}

.cd-slider.home-hero-slider.variant-progress .hero-progress-value {
  background: linear-gradient(90deg, var(--accent-100), var(--primary-100), var(--bg-100));
}

.cd-slider.home-hero-slider.variant-strip .controls {
  right: clamp(18px, 2vw, 28px);
  bottom: clamp(18px, 2vw, 28px);
  padding: 8px;
  gap: .44rem;
  border: 1px solid var(--surface-border);
  background: color-mix(in srgb, var(--surface-card) 94%, transparent);
  box-shadow: var(--surface-elev-1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.cd-slider.home-hero-slider.variant-strip .controls .prev,
.cd-slider.home-hero-slider.variant-strip .controls .next {
  background: var(--bg-200);
  color: var(--text-100);
}

.cd-slider.home-hero-slider.variant-strip .counter {
  color: var(--text-100);
  font-weight: 800;
}

.cd-slider.home-hero-slider.variant-strip .counter::after,
.cd-slider.home-hero-slider.variant-progress .counter::after {
  background: color-mix(in srgb, var(--surface-card) 96%, transparent);
  border-color: var(--surface-border);
}

.cd-slider.home-hero-slider.variant-strip .counter::before,
.cd-slider.home-hero-slider.variant-progress .counter::before {
  background:
    conic-gradient(var(--primary-100) 0deg var(--counter-progress-angle), color-mix(in srgb, var(--text-100) 12%, transparent) var(--counter-progress-angle) 360deg);
}

.cd-slider.home-hero-slider.variant-progress .controls {
  top: 20px;
  right: 20px;
  bottom: auto;
  background: color-mix(in srgb, var(--surface-card) 92%, transparent);
  border: 1px solid var(--surface-border);
}

.cd-slider.home-hero-slider.variant-progress .controls .prev,
.cd-slider.home-hero-slider.variant-progress .controls .next {
  background: var(--bg-200);
  color: var(--text-100);
}

.cd-slider.home-hero-slider.variant-progress .counter {
  color: var(--text-100);
}

@media (max-width: 760px) {
  .cd-slider.home-hero-slider.variant-strip .hero-content,
  .cd-slider.home-hero-slider.variant-progress .hero-content {
    left: 12px;
    right: 12px;
    bottom: 12px;
    grid-template-columns: 1fr;
  }

  .cd-slider.home-hero-slider.layout-caption_strip.variant-strip .hero-content {
    left: 12px;
    right: auto;
    bottom: 58px;
    min-height: auto;
    max-width: calc(100% - 120px);
    border-radius: 18px;
  }

  .cd-slider.home-hero-slider.layout-caption_strip.variant-strip .hero-strip-chip-group {
    gap: .42rem;
  }

  .cd-slider.home-hero-slider.variant-card .hero-content {
    left: 12px;
    right: 12px;
    top: 12px;
    max-width: calc(100% - 24px);
  }

  .cd-slider.home-hero-slider.layout-minimal_tag.variant-card .hero-content {
    top: auto;
    bottom: 12px;
  }

  .cd-slider.home-hero-slider.variant-editorial .hero-content {
    left: 12px;
    right: 12px;
    top: auto;
    bottom: 12px;
    width: auto;
    max-width: none;
    transform: none;
    grid-template-columns: 1fr;
  }

  .cd-slider.home-hero-slider.variant-editorial .hero-rail {
    flex-direction: row;
    justify-content: flex-start;
  }

  .cd-slider.home-hero-slider.variant-editorial .hero-rail-line {
    width: 44px;
    height: 1px;
  }

  .cd-slider.home-hero-slider.variant-spotlight .hero-content,
  .cd-slider.home-hero-slider.variant-stage .hero-content {
    left: 12px;
    right: 12px;
    bottom: 12px;
    top: auto;
    max-width: none;
    width: auto;
    transform: none;
    text-align: left;
  }

  .cd-slider.home-hero-slider.layout-glass_float.variant-stage .hero-content {
    top: 12px;
    bottom: auto;
    max-width: calc(100% - 24px);
  }

  .cd-slider.home-hero-slider.layout-glass_focus.variant-stage .hero-content {
    top: auto;
    transform: none;
  }

  .cd-slider.home-hero-slider.layout-spotlight_right.variant-spotlight .hero-topline,
  .cd-slider.home-hero-slider.layout-spotlight_right.variant-spotlight .hero-footer,
  .cd-slider.home-hero-slider.layout-clean_bottom.variant-stage .hero-topline,
  .cd-slider.home-hero-slider.layout-clean_bottom.variant-stage .hero-footer,
  .cd-slider.home-hero-slider.layout-cinematic_full.variant-stage .hero-topline,
  .cd-slider.home-hero-slider.layout-cinematic_full.variant-stage .hero-footer,
  .cd-slider.home-hero-slider.layout-edge_to_edge.variant-stage .hero-topline,
  .cd-slider.home-hero-slider.layout-edge_to_edge.variant-stage .hero-footer {
    justify-content: space-between;
  }

  .cd-slider.home-hero-slider.layout-spotlight_right.variant-spotlight .hero-content,
  .cd-slider.home-hero-slider.layout-clean_bottom.variant-stage .hero-content,
  .cd-slider.home-hero-slider.layout-cinematic_full.variant-stage .hero-content,
  .cd-slider.home-hero-slider.layout-edge_to_edge.variant-stage .hero-content {
    text-align: left;
  }

  .cd-slider.home-hero-slider:not(.layout-thumb_rail).variant-progress .controls,
  .cd-slider.home-hero-slider:not(.layout-thumb_rail).variant-strip .controls {
    top: auto;
    right: auto;
    bottom: max(8px, env(safe-area-inset-bottom));
    left: 50%;
    transform: translateX(-50%);
    min-height: 46px;
    gap: .42rem;
    padding: 5px 7px;
    border: 0;
    background: var(--surface-card, #fff);
    box-shadow: 0 14px 28px -24px rgba(15, 23, 42, .48);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

}

@media (max-width: 360px) {
  .cd-slider.home-hero-slider:not(.layout-thumb_rail).variant-progress .controls,
  .cd-slider.home-hero-slider:not(.layout-thumb_rail).variant-strip .controls {
    bottom: max(7px, env(safe-area-inset-bottom));
    min-height: 42px;
    gap: .32rem;
    padding: 4px 6px;
  }

  .cd-slider.home-hero-slider .hero-footer {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .cd-slider.home-hero-slider .hero-cta {
    width: 100%;
  }

  .cd-slider.home-hero-slider .hero-segments {
    min-width: 100%;
  }
}

.cd-slider.home-hero-slider .hero-thumb-rail {
  display: none;
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-gradient,
.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-progress {
  display: none;
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .controls {
  top: 18px;
  right: 18px;
  bottom: auto;
  padding: 8px;
  gap: .44rem;
  border: 1px solid var(--surface-border);
  background: color-mix(in srgb, var(--surface-card) 92%, transparent);
  box-shadow: var(--surface-elev-1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .controls .prev,
.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .controls .next {
  background: var(--bg-200);
  color: var(--text-100);
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .counter {
  color: var(--text-100);
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .counter::before {
  background:
    conic-gradient(var(--primary-100) 0deg var(--counter-progress-angle), color-mix(in srgb, var(--text-100) 12%, transparent) var(--counter-progress-angle) 360deg);
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .counter::after {
  background: color-mix(in srgb, var(--surface-card) 96%, transparent);
  border-color: var(--surface-border);
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb-rail {
  position: absolute;
  top: 18px;
  left: 18px;
  bottom: 18px;
  z-index: 4;
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 78px;
  padding: 10px 8px;
  overflow-y: auto;
  overflow-x: hidden;
  border-radius: 26px;
  border: 1px solid var(--surface-border);
  background: color-mix(in srgb, var(--surface-card) 88%, transparent);
  box-shadow: var(--surface-elev-1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  scrollbar-width: none;
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb-rail::-webkit-scrollbar {
  display: none;
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  min-width: 0;
  height: 58px;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--surface-border) 76%, transparent);
  border-radius: 18px;
  background: color-mix(in srgb, var(--surface-card) 92%, transparent);
  cursor: pointer;
  overflow: hidden;
  opacity: .68;
  transition: transform .24s ease, opacity .24s ease, border-color .24s ease, box-shadow .24s ease;
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb:hover,
.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb:focus-visible {
  opacity: .96;
  transform: translateX(2px);
  outline: none;
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb.is-active {
  opacity: 1;
  border-color: var(--primary-100);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary-100) 22%, transparent);
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb-picture,
.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb-image {
  display: block;
  width: 100%;
  height: 100%;
}

.cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb-image {
  object-fit: cover;
  object-position: center center;
}

@media (max-width: 760px) {
  .cd-slider.home-hero-slider.layout-thumb_rail {
    aspect-ratio: 4 / 5;
  }

  .cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .controls {
    top: 12px;
    right: 12px;
  }

  .cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb-rail {
    top: auto;
    right: 12px;
    bottom: 12px;
    left: 12px;
    width: auto;
    max-width: calc(100% - 24px);
    flex-direction: row;
    align-items: center;
    gap: 8px;
    padding: 8px;
    overflow-x: auto;
    overflow-y: hidden;
    border-radius: 22px;
  }

  .cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb {
    width: 58px;
    min-width: 58px;
    height: 72px;
    border-radius: 16px;
  }

  .cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb:hover,
  .cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb:focus-visible {
    transform: translateY(-1px);
  }
}

@media (max-width: 360px) {
  .cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .controls {
    top: 8px;
    right: 8px;
  }

  .cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb-rail {
    right: 8px;
    bottom: 8px;
    left: 8px;
    max-width: calc(100% - 16px);
    padding: 6px;
    gap: 6px;
    border-radius: 18px;
  }

  .cd-slider.home-hero-slider.layout-thumb_rail.variant-gallery .hero-thumb {
    width: 50px;
    min-width: 50px;
    height: 64px;
    border-radius: 14px;
  }
}

/* Home brands */
.home-brands {
    padding: 12px 0 0;
}

.home-brands--tail {
    margin-top: clamp(20px, 3vw, 34px);
}

.home-brands-shell {
    display: grid;
    gap: 18px;
    padding: clamp(16px, 2.2vw, 26px);
    border-radius: 24px;
    background: var(--surface-card);
    box-shadow: 0 10px 28px color-mix(in srgb, var(--text-100) 4%, transparent);
    overflow: hidden;
}

.home-brands-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    gap: 14px;
}

.home-brands-copy {
    min-width: 0;
    display: grid;
    gap: 4px;
}

.home-brands-kicker {
    color: var(--primary-100);
    font-size: .72rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.home-brands-copy h2 {
    margin: 0;
    color: var(--text-100);
    font-size: clamp(1.16rem, 1.75vw, 1.44rem);
    font-weight: 900;
    line-height: 1.12;
}

.home-brands-copy p {
    margin: 0;
    color: var(--text-200);
    font-size: .88rem;
    line-height: 1.4;
}

.home-brands-actions {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    min-width: 0;
}

.home-brands-total,
.home-brands-all-link {
    min-height: 34px;
    padding: 0 13px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    font-size: .8rem;
    font-weight: 800;
}

.home-brands-total {
    color: var(--text-200);
    background: color-mix(in srgb, var(--surface-muted) 76%, var(--surface-card) 24%);
}

.home-brands-nav {
    display: none;
    align-items: center;
    gap: 6px;
}

.home-brands.is-scrollable .home-brands-nav {
    display: inline-flex;
}

.home-brands-nav-btn {
    appearance: none;
    width: 36px;
    height: 36px;
    border: 0;
    border-radius: 12px;
    background: var(--surface-muted);
    color: var(--text-100);
    display: inline-grid;
    place-items: center;
    cursor: pointer;
    box-shadow: 0 1px 2px color-mix(in srgb, var(--text-100) 5%, transparent);
    transition: background-color .18s ease, color .18s ease, transform .18s ease, opacity .18s ease;
}

.home-brands-nav-btn:hover,
.home-brands-nav-btn:focus-visible {
    background: color-mix(in srgb, var(--primary-100) 10%, var(--surface-muted));
    color: var(--primary-100);
    transform: translateY(-1px);
    outline: none;
}

.home-brands-nav-btn:disabled {
    cursor: default;
    opacity: .42;
    transform: none;
}

.home-brands-nav-btn svg {
    width: 18px;
    height: 18px;
    display: block;
}

.home-brands-all-link {
    color: var(--primary-100);
    background: color-mix(in srgb, var(--primary-100) 8%, var(--surface-muted));
    text-decoration: none;
    transition: background-color .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
}

.home-brands-all-link:hover,
.home-brands-all-link:focus-visible {
    color: var(--primary-100);
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px color-mix(in srgb, var(--primary-100) 8%, transparent);
}

.home-brands-marquee {
    min-width: 0;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scrollbar-width: none;
    -ms-overflow-style: none;
    scroll-snap-type: x proximity;
    scroll-padding-inline: 12px;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-y;
    cursor: grab;
    margin-inline: -8px;
    padding: 10px 8px 14px;
}

.home-brands-marquee::-webkit-scrollbar {
    display: none;
}

.home-brands-marquee:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--primary-100) 38%, transparent);
    outline-offset: 4px;
    border-radius: 18px;
}

.home-brands-marquee.is-dragging {
    cursor: grabbing;
    scroll-snap-type: none;
    user-select: none;
}

.home-brands-marquee.is-dragging .home-brand-card {
    pointer-events: none;
}

.home-brands-track {
    width: max-content;
    min-width: 100%;
    display: flex;
    align-items: stretch;
    gap: 12px;
    padding-inline: 4px;
}

.home-brand-card {
    position: relative;
    flex: 0 0 clamp(154px, 14vw, 194px);
    min-width: 0;
    min-height: 142px;
    padding: 16px 14px 14px;
    border-radius: 22px;
    background: color-mix(in srgb, var(--surface-muted) 76%, var(--surface-card) 24%);
    box-shadow: 0 1px 2px color-mix(in srgb, var(--text-100) 5%, transparent);
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    align-items: start;
    justify-items: center;
    gap: 12px;
    color: inherit;
    text-decoration: none;
    scroll-snap-align: start;
    transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease;
}

.home-brand-card:hover,
.home-brand-card:focus-visible {
    transform: translateY(-1px);
    text-decoration: none;
    background: var(--surface-card);
    box-shadow: 0 8px 20px color-mix(in srgb, var(--text-100) 6%, transparent);
    outline: none;
}

.home-brand-card:hover .home-brand-cta,
.home-brand-card:focus-visible .home-brand-cta {
    opacity: 1;
    transform: translateY(0);
}

.home-brand-mark {
    width: 68px;
    height: 68px;
    border-radius: 22px;
    background: var(--surface-card);
    color: var(--primary-100);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    box-shadow: 0 1px 2px color-mix(in srgb, var(--text-100) 5%, transparent);
    font-size: 1.02rem;
    font-weight: 900;
    letter-spacing: .02em;
}

.home-brand-mark.has-image {
    background: var(--surface-card);
}

.home-brand-mark img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
    padding: 7px;
}

.home-brand-body {
    min-width: 0;
    display: grid;
    justify-items: center;
    align-content: center;
    gap: 8px;
    width: 100%;
    text-align: center;
}

.home-brand-name {
    color: var(--text-100);
    font-size: .94rem;
    font-weight: 850;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}

.home-brand-count {
    min-height: 26px;
    padding: 0 10px;
    border-radius: 999px;
    background: var(--surface-card);
    color: var(--text-200);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .72rem;
    font-weight: 750;
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.home-brand-cta {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 30px;
    height: 30px;
    border-radius: 11px;
    background: color-mix(in srgb, var(--primary-100) 9%, var(--surface-card));
    color: var(--primary-100);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: translateY(-2px);
    transition: opacity .18s ease, transform .18s ease, background-color .18s ease;
}

.home-brand-cta svg {
    width: 16px;
    height: 16px;
    display: block;
}

@media (max-width: 760px) {
    .home-brands {
        padding-top: 8px;
    }

    .home-brands--tail {
        margin-top: 20px;
    }

    .home-brands-shell {
        gap: 12px;
        padding: 15px;
        border-radius: 20px;
    }

    .home-brands-head {
        grid-template-columns: 1fr;
        align-items: start;
        gap: 10px;
    }

    .home-brands-actions {
        width: 100%;
        justify-content: space-between;
    }

    .home-brands-nav,
    .home-brands.is-scrollable .home-brands-nav {
        display: none;
    }

    .home-brands-copy h2 {
        font-size: 1.08rem;
    }

    .home-brands-copy p {
        font-size: .8rem;
    }

    .home-brands-marquee {
        margin-inline: -15px;
        padding: 9px 15px 13px;
        scroll-padding-inline: 15px;
    }

    .home-brand-card {
        width: min(46vw, 180px);
        flex-basis: min(46vw, 180px);
        min-height: 132px;
        padding: 14px 12px 13px;
        border-radius: 20px;
        gap: 10px;
    }

    .home-brand-mark {
        width: 60px;
        height: 60px;
        border-radius: 19px;
    }

    .home-brand-cta {
        display: none;
    }
}

@media (max-width: 360px) {
    .home-brands-shell {
        padding: 12px;
        border-radius: 18px;
    }

    .home-brands-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

    .home-brands-total,
    .home-brands-all-link {
        min-height: 34px;
        padding-inline: 10px;
        font-size: .76rem;
    }

    .home-brand-card {
        width: min(68vw, 164px);
        flex-basis: min(68vw, 164px);
        min-height: 122px;
    }

    .home-brand-mark {
        width: 54px;
        height: 54px;
        border-radius: 17px;
    }
}

@media (max-width: 220px) {
    .home-brands-shell {
        padding: 10px;
    }

    .home-brands-marquee {
        margin-inline: -10px;
        padding-inline: 10px;
        scroll-padding-inline: 10px;
    }

    .home-brands-actions {
        grid-template-columns: 1fr;
    }

    .home-brand-card {
        width: 124px;
        flex-basis: 124px;
        min-height: 112px;
        padding: 8px;
        gap: 7px;
        border-radius: 16px;
    }

    .home-brand-mark {
        width: 46px;
        height: 46px;
        border-radius: 14px;
        font-size: .76rem;
    }

    .home-brand-name {
        font-size: .78rem;
    }

    .home-brand-count {
        min-height: 22px;
        padding-inline: 7px;
        font-size: .66rem;
    }
}
