/* ===================================================================
   MH Recetas Carousel — Base Style v2.0
   Diseño mejorado: tarjetas con sombra, título siempre visible,
   hover elegante y controles más accesibles.
   =================================================================== */

/* Tokens scoped al wrapper (aliased al tema Comiweb) */
.mh-rc-wrap {
  --rc-gap:            14px !important;
  --rc-radius:         var(--cw-radius,      10px) !important;
  --rc-radius-sm:      var(--cw-radius-sm,   6px) !important;
  --rc-overlay-bg:     linear-gradient(0deg, rgba(0,0,0,0.72) 0%, rgba(0,0,0,0.28) 70%, transparent 100%) !important;
  --rc-title-size:     0.97rem !important;
  --rc-transition:     400ms cubic-bezier(.22,.9,.3,1) !important;
  --rc-control-size:   46px !important;
  --rc-control-offset: 10px !important;
  --rc-accent:         var(--cw-orange,      #E85D04) !important;
  --rc-accent-dark:    var(--cw-orange-dark, #C44B02) !important;
  font-family: var(--font-body, 'Nunito', sans-serif) !important;
}

/* ── Wrapper ─────────────────────────────────────────────────── */
.mh-rc-wrap {
  position: relative !important;
  width: 100% !important;
  overflow: visible !important;
  margin: 24px 0 !important;
  box-sizing: border-box !important;
  isolation: isolate !important;
  z-index: 1 !important;
  --rc-item-width: calc((100% - (var(--rc-gap) * 2)) / 3) !important;
  padding-left:  calc(var(--rc-control-size) + var(--rc-control-offset) + 8px) !important;
  padding-right: calc(var(--rc-control-size) + var(--rc-control-offset) + 8px) !important;
}

/* ── Viewport ─────────────────────────────────────────────────── */
.mh-rc-viewport {
  overflow: hidden !important;
  width: 100% !important;
  box-sizing: border-box !important;
  border-radius: var(--rc-radius) !important;
}

/* ── Track ────────────────────────────────────────────────────── */
.mh-rc-track {
  display: flex !important;
  gap: var(--rc-gap) !important;
  align-items: stretch !important;
  transition: transform var(--rc-transition) !important;
  will-change: transform !important;
  padding: 10px 4px 14px !important;
  box-sizing: border-box !important;
  flex-wrap: nowrap !important;
}

/* ── Item ─────────────────────────────────────────────────────── */
.mh-rc-item {
  flex: 0 0 var(--rc-item-width) !important;
  box-sizing: border-box !important;
  min-width: 160px !important;
  overflow: visible !important;
}

.mh-rc-link {
  display: block !important;
  text-decoration: none !important;
  outline-offset: 3px !important;
  border-radius: var(--rc-radius) !important;
}

/* ── Media card ───────────────────────────────────────────────── */
.mh-rc-media {
  width: 100% !important;
  aspect-ratio: 4 / 3 !important;
  background-size: cover !important;
  background-position: center !important;
  border-radius: var(--rc-radius) !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.10), 0 1px 4px rgba(0,0,0,0.06) !important;
  transition: transform .32s ease, box-shadow .32s ease !important;
  display: flex !important;
  align-items: flex-end !important;
  background-color: #f0ede8 !important;
}

.mh-rc-media .mh-rc-media__img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform .42s ease !important;
}

/* Hover: lift + zoom imagen */
.mh-rc-link:hover .mh-rc-media,
.mh-rc-link:focus .mh-rc-media {
  transform: translateY(-5px) !important;
  box-shadow: 0 16px 36px rgba(0,0,0,0.16), 0 4px 12px rgba(0,0,0,0.08) !important;
}
.mh-rc-link:hover .mh-rc-media .mh-rc-media__img,
.mh-rc-link:focus .mh-rc-media .mh-rc-media__img {
  transform: scale(1.06) !important;
}

/* ── Overlay: siempre visible en la parte inferior ────────────── */
.mh-rc-overlay {
  position: absolute !important;
  left: 0 !important; right: 0 !important; bottom: 0 !important;
  background: var(--rc-overlay-bg) !important;
  padding: 28px 14px 14px !important;
  box-sizing: border-box !important;
  z-index: 2 !important;
  border-radius: 0 0 var(--rc-radius) var(--rc-radius) !important;
}

/* ── Title ────────────────────────────────────────────────────── */
.mh-rc-title {
  color: #fff !important;
  font-weight: 700 !important;
  font-size: var(--rc-title-size) !important;
  line-height: 1.25 !important;
  width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  word-break: break-word !important;
  text-shadow: 0 1px 6px rgba(0,0,0,0.5) !important;
  letter-spacing: 0.01em !important;
}

/* ── Chip de categoría (opcional, se puede añadir desde PHP) ──── */
.mh-rc-cat {
  display: inline-block !important;
  font-size: 0.68rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #fff !important;
  background: var(--rc-accent) !important;
  border-radius: 4px !important;
  padding: 2px 7px !important;
  margin-bottom: 5px !important;
}

/* ── Controls ─────────────────────────────────────────────────── */
.mh-rc-prev,
.mh-rc-next {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: #fff !important;
  color: var(--rc-accent) !important;
  border: 2px solid rgba(232,93,4,0.18) !important;
  width: var(--rc-control-size) !important;
  height: var(--rc-control-size) !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 40 !important;
  box-shadow: 0 4px 14px rgba(0,0,0,0.10) !important;
  font-size: 1.3rem !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  transition: background .2s, color .2s, transform .2s, box-shadow .2s !important;
}
.mh-rc-prev { left: var(--rc-control-offset) !important; }
.mh-rc-next { right: var(--rc-control-offset) !important; }

.mh-rc-prev:hover,
.mh-rc-next:hover {
  background: var(--rc-accent) !important;
  color: #fff !important;
  border-color: var(--rc-accent) !important;
  transform: translateY(-50%) scale(1.08) !important;
  box-shadow: 0 8px 22px rgba(232,93,4,0.28) !important;
}

.mh-rc-prev[disabled],
.mh-rc-next[disabled] {
  opacity: 0.3 !important;
  cursor: default !important;
  pointer-events: none !important;
  transform: translateY(-50%) !important;
}

/* Controls inside for small screens */
.mh-rc-wrap.mh-rc-controls-inside {
  padding-left: 14px !important;
  padding-right: 14px !important;
}
.mh-rc-wrap.mh-rc-controls-inside .mh-rc-prev { left: 8px !important; }
.mh-rc-wrap.mh-rc-controls-inside .mh-rc-next { right: 8px !important; }

/* ── Dots indicadores ─────────────────────────────────────────── */
.mh-rc-dots {
  display: flex !important;
  justify-content: center !important;
  gap: 6px !important;
  margin-top: 14px !important;
}
.mh-rc-dot {
  width: 7px !important; height: 7px !important;
  border-radius: 50% !important;
  background: #ddd !important;
  border: none !important;
  cursor: pointer !important;
  padding: 0 !important;
  transition: background .2s, transform .2s !important;
}
.mh-rc-dot.is-active {
  background: var(--rc-accent) !important;
  transform: scale(1.3) !important;
}

/* ── Empty state ──────────────────────────────────────────────── */
.mh-rc-empty {
  padding: 32px !important;
  text-align: center !important;
  color: #888 !important;
  font-style: italic !important;
}

/* ================================================================
   RESPONSIVE BREAKPOINTS
   ================================================================ */

@media (max-width: 480px) {
  :root {
    --rc-gap: 10px !important;
    --rc-title-size: 0.93rem !important;
    --rc-control-size: 38px !important;
    --rc-control-offset: 6px !important;
  }
  .mh-rc-wrap {
    --rc-item-width: 100% !important;
    padding-left:  calc(var(--rc-control-size) + var(--rc-control-offset) + 4px) !important;
    padding-right: calc(var(--rc-control-size) + var(--rc-control-offset) + 4px) !important;
    margin: 16px 0 !important;
  }
  .mh-rc-overlay { padding: 22px 10px 10px !important; }
}

@media (min-width: 481px) and (max-width: 899px) {
  :root { --rc-gap: 12px !important; --rc-title-size: 1rem !important; }
  .mh-rc-wrap { --rc-item-width: calc((100% - var(--rc-gap)) / 2) !important; }
  .mh-rc-item { min-width: 200px !important; }
}

@media (min-width: 900px) {
  :root { --rc-gap: 14px !important; --rc-title-size: 0.97rem !important; }
  .mh-rc-wrap { --rc-item-width: calc((100% - (var(--rc-gap) * 2)) / 3) !important; }
  .mh-rc-item { min-width: 240px !important; }
}

@media (min-width: 1200px) {
  :root { --rc-gap: 16px !important; --rc-title-size: 1rem !important; }
  .mh-rc-wrap { --rc-item-width: calc((100% - (var(--rc-gap) * 2)) / 3) !important; }
  .mh-rc-item { min-width: 260px !important; }
}

/* ── Reduced motion ───────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .mh-rc-track,
  .mh-rc-media,
  .mh-rc-media .mh-rc-media__img,
  .mh-rc-prev,
  .mh-rc-next { transition: none !important; transform: none !important; }
}