/**
 * Netseg Ideal Pesca — Products Slider
 * v1.0.0
 *
 * 4 estilos partilham os mesmos cards e variáveis. Cada estilo só altera
 * a forma como o track é apresentado (flexbox horizontal, vertical, 3D, grid).
 *
 * Variáveis (controladas pelo widget Elementor):
 *   --nips-bg-night/day  fundo do widget
 *   --nips-accent        cor accent (default laranja Netseg)
 *   --nips-radius        raio dos cantos
 *   --nips-border-w      espessura da borda do widget
 *   --nips-gap           espaçamento entre cards
 *   --nips-vis-d/t/m     cards visíveis (desktop/tablet/mobile)
 *   --nips-image-ratio   aspect ratio das imagens
 *   --nips-card-h        altura fixa do card (opcional)
 *   --nips-shadow        sombra
 *   --nips-anim-ms       velocidade da animação
 */

.nips-root{
  --nips-bg-night: #0d2235;
  --nips-bg-day:   #f5f6f8;
  --nips-bg:       var(--nips-bg-night);
  --nips-accent:   #f08c00;
  --nips-radius:   10px;
  --nips-border-w: 1px;
  --nips-gap:      16px;
  --nips-vis-d:    4;
  --nips-vis-t:    3;
  --nips-vis-m:    2;
  --nips-image-ratio: 1 / 1;
  --nips-shadow:   0 4px 8px rgba(0,0,0,.08), 0 8px 20px rgba(0,0,0,.10);
  --nips-anim-ms:  500ms;

  position: relative;
  width: 100%;
  background: var(--nips-bg);
  border-radius: var(--nips-radius);
  border: var(--nips-border-w) solid currentColor;
  padding: 20px;
  font-family: 'Sora', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: rgba(255,255,255,.85);
  box-sizing: border-box;
}
.nips-root.nips-theme-day{
  --nips-bg: var(--nips-bg-day);
  color: rgba(13,34,53,.85);
}
.nips-root *,
.nips-root *::before,
.nips-root *::after { box-sizing: border-box; }

/* ─── Viewport (corte do overflow) ─── */
.nips-viewport{
  position: relative;
  overflow: hidden;
  width: 100%;
  border-radius: calc(var(--nips-radius) - 2px);
}

/* ─── Track (flex container que se move) ─── */
.nips-track{
  display: flex;
  gap: var(--nips-gap);
  transition: transform var(--nips-anim-ms) cubic-bezier(.25, .1, .25, 1);
  will-change: transform;
}

/* ─── Card base (aplicado a todos os estilos) ─── */
.nips-card{
  flex: 0 0 calc((100% - (var(--nips-vis-d) - 1) * var(--nips-gap)) / var(--nips-vis-d));
  background: var(--nips-card-bg, #fff);
  color: var(--nips-card-text, #0d2235);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--nips-shadow);
  transition: transform .3s ease, box-shadow .3s ease;
  position: relative;
}
/* Defaults por tema — podem ser sobrepostos pelo widget se quiseres outras cores */
.nips-root.nips-theme-night{
  --nips-card-bg:    #ffffff;
  --nips-card-text:  #0d2235;
  --nips-image-bg:   #ffffff;
}
.nips-root.nips-theme-day{
  --nips-card-bg:    #ffffff;
  --nips-card-text:  #0d2235;
  --nips-image-bg:   #ffffff;
}
.nips-root.nips-theme-day .nips-card{
  border: 1px solid rgba(13,34,53,.08);
}

.nips-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 8px 16px rgba(0,0,0,.12), 0 16px 40px rgba(0,0,0,.16);
}
.nips-card--oos{ opacity: .65; }
.nips-card--oos:hover{ transform: none; }

/* Altura fixa opcional */
.nips-root[style*="--nips-card-h"] .nips-card{
  height: var(--nips-card-h);
}

/* ─── Imagem ─── */
.nips-card__image-wrap{
  display: block;
  position: relative;
  background: var(--nips-image-bg, #ffffff);
  aspect-ratio: var(--nips-image-ratio);
  overflow: hidden;
}
.nips-card__image{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform .4s ease;
}
.nips-card:hover .nips-card__image{
  transform: scale(1.05);
}

/* ─── Badges (sobrepostos à imagem) ─── */
.nips-badges{
  position: absolute;
  top: 8px;
  left: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  z-index: 2;
}
.nips-badge{
  display: inline-block;
  padding: 3px 8px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  border-radius: 3px;
  background: var(--nips-accent);
  color: #0d2235;
}
.nips-badge--featured{ background: #4a90e2; color: #fff; }
.nips-badge--new{      background: #16a085; color: #fff; }
.nips-badge--oos{      background: #6b7280; color: #fff; }

/* ─── Body ─── */
.nips-card__body{
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 6px;
}
.nips-card__content{
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}
.nips-card__cats{
  font-size: 10px;
  color: #6b7280;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.nips-card__title{
  font-size: 13px;
  font-weight: 600;
  color: #0d2235;
  text-decoration: none;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.nips-card__title:hover{ color: var(--nips-accent); }
.nips-card__rating{
  font-size: 11px;
}
.nips-card__rating .star-rating{ font-size: 11px; }
.nips-card__excerpt{
  font-size: 11px;
  color: #6b7280;
  line-height: 1.45;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.nips-card__footer{
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: auto;
}
.nips-card__price{
  font-size: 14px;
  font-weight: 600;
  color: var(--nips-accent);
}
.nips-card__price del{
  color: #9ca3af;
  font-weight: 400;
  font-size: 12px;
  margin-right: 4px;
}
.nips-card__price ins{
  text-decoration: none;
}
.nips-card__stock{
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.nips-stock--in{   color: #16a085; }
.nips-stock--out{  color: #c0392b; }
.nips-stock--back{ color: #f39c12; }

.nips-card__actions{
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.nips-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 12px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  text-decoration: none;
  flex: 1;
  min-width: 0;
  transition: background .15s ease, color .15s ease;
}
.nips-btn--view{
  background: rgba(13,34,53,.08);
  color: #0d2235;
}
.nips-btn--view:hover{
  background: rgba(13,34,53,.15);
}
.nips-btn--cart{
  background: var(--nips-accent);
  color: #0d2235;
}
.nips-btn--cart:hover{
  filter: brightness(1.05);
}

/* ─── Setas de navegação ─── */
.nips-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 50%;
  background: var(--nips-accent);
  color: #0d2235;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: filter .15s ease, transform .15s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
}
.nips-nav:hover{ filter: brightness(1.08); transform: translateY(-50%) scale(1.05); }
.nips-nav:disabled{ opacity: .4; cursor: not-allowed; }
.nips-nav svg{ width: 18px; height: 18px; }
.nips-nav-prev{ left: 4px; }
.nips-nav-next{ right: 4px; }

/* ─── Dots ─── */
.nips-dots{
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 14px;
}
.nips-dot{
  width: 8px;
  height: 4px;
  border-radius: 2px;
  background: rgba(255,255,255,.3);
  border: 0;
  cursor: pointer;
  padding: 0;
  transition: background .15s ease, width .2s ease;
}
.nips-dot--active{
  width: 24px;
  background: var(--nips-accent);
}
.nips-root.nips-theme-day .nips-dot{
  background: rgba(13,34,53,.2);
}
.nips-root.nips-theme-day .nips-dot--active{
  background: var(--nips-accent);
}

/* ═══════════════════════════════════════════════════════
   ESTILO A — Carrossel horizontal clássico
   (default — não precisa de regras especiais além das base)
   ═══════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════
   ESTILO B — Lista vertical contínua
   ═══════════════════════════════════════════════════════ */
.nips-style-b .nips-viewport{
  height: 480px;
}
.nips-style-b .nips-track{
  flex-direction: column;
  height: auto;
}
.nips-style-b .nips-card{
  flex: 0 0 auto;
  flex-direction: row;
  align-items: center;
  height: auto;
  padding: 8px;
  gap: 12px;
}
.nips-style-b .nips-card__image-wrap{
  flex-shrink: 0;
  width: 80px;
  aspect-ratio: 1 / 1;
  border-radius: 6px;
}
.nips-style-b .nips-card__body{
  padding: 0;
  flex: 1;
  min-width: 0;
}
.nips-style-b .nips-card:hover{
  transform: translateX(2px);
}
.nips-style-b .nips-card:hover .nips-card__image{
  transform: none;
}
/* Em vertical, setas em cima/baixo */
.nips-style-b .nips-nav-prev{
  top: 4px;
  left: 50%;
  transform: translateX(-50%) rotate(90deg);
}
.nips-style-b .nips-nav-next{
  top: auto;
  bottom: 4px;
  right: auto;
  left: 50%;
  transform: translateX(-50%) rotate(90deg);
}

/* ═══════════════════════════════════════════════════════
   ESTILO C — Coverflow 3D
   Card central destacado, laterais inclinados em perspectiva.
   ═══════════════════════════════════════════════════════ */
.nips-style-c .nips-viewport{
  perspective: 1200px;
  padding: 30px 0;
}
.nips-style-c .nips-track{
  align-items: center;
  justify-content: center;
  transform-style: preserve-3d;
  gap: 0;
}
.nips-style-c .nips-card{
  flex: 0 0 220px;
  margin: 0 -20px;
  transition: transform var(--nips-anim-ms) ease, opacity var(--nips-anim-ms) ease;
}
.nips-style-c .nips-card:not(.nips-card--center){
  opacity: .55;
  transform: scale(.85);
  filter: saturate(.7);
}
.nips-style-c .nips-card--side-left{
  transform: rotateY(35deg) scale(.85) translateX(-10px);
}
.nips-style-c .nips-card--side-right{
  transform: rotateY(-35deg) scale(.85) translateX(10px);
}
.nips-style-c .nips-card--side2-left{
  transform: rotateY(50deg) scale(.7) translateX(-30px);
  opacity: .25;
}
.nips-style-c .nips-card--side2-right{
  transform: rotateY(-50deg) scale(.7) translateX(30px);
  opacity: .25;
}
.nips-style-c .nips-card--center{
  z-index: 5;
  box-shadow: 0 12px 40px rgba(240,140,0,.35);
  border: 2px solid var(--nips-accent);
}

/* ═══════════════════════════════════════════════════════
   ESTILO D — Mosaico hover-reveal
   Grelha de imagens; hover revela título/preço/botão.
   ═══════════════════════════════════════════════════════ */
.nips-style-d .nips-viewport{ overflow: visible; }
.nips-style-d .nips-track{
  display: grid !important;
  grid-template-columns: repeat(var(--nips-vis-d), 1fr);
  transform: none !important;
}
.nips-style-d .nips-card{
  flex: none;
  position: relative;
  aspect-ratio: var(--nips-image-ratio);
}
.nips-style-d .nips-card__image-wrap{
  position: absolute;
  inset: 0;
  aspect-ratio: auto;
  height: 100%;
}
.nips-style-d .nips-card__body{
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(13,34,53,0) 50%, rgba(13,34,53,.92) 100%);
  padding: 0;
  justify-content: flex-end;
  transition: background .2s ease;
}
.nips-style-d .nips-card__content{
  padding: 12px 14px;
  color: #fff;
  transition: transform .25s ease;
}
.nips-style-d .nips-card__title{ color: #fff; }
.nips-style-d .nips-card__cats{ color: rgba(255,255,255,.7); }
.nips-style-d .nips-card__excerpt{
  color: rgba(255,255,255,.85);
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity .25s ease, max-height .25s ease;
}
.nips-style-d .nips-card:hover .nips-card__body{
  background: rgba(13,34,53,.92);
}
.nips-style-d .nips-card:hover .nips-card__excerpt{
  opacity: 1;
  max-height: 80px;
}
.nips-style-d .nips-card__actions{ flex-direction: column; }
.nips-style-d .nips-btn--view{
  background: var(--nips-accent);
  color: #0d2235;
}

/* No estilo D, dots e setas não fazem sentido (não há slide) */
.nips-style-d .nips-nav,
.nips-style-d .nips-dots{ display: none; }

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — tablet e mobile
   ═══════════════════════════════════════════════════════ */
@media (max-width: 1024px){
  .nips-card{
    flex: 0 0 calc((100% - (var(--nips-vis-t) - 1) * var(--nips-gap)) / var(--nips-vis-t));
  }
  .nips-style-d .nips-track{
    grid-template-columns: repeat(var(--nips-vis-t), 1fr);
  }
}

@media (max-width: 768px){
  .nips-root{ padding: 14px; }
  .nips-card{
    flex: 0 0 calc((100% - (var(--nips-vis-m) - 1) * var(--nips-gap)) / var(--nips-vis-m));
  }
  .nips-style-d .nips-track{
    grid-template-columns: repeat(var(--nips-vis-m), 1fr);
  }
  .nips-card__title{ font-size: 12px; }
  .nips-card__price{ font-size: 13px; }

  /* Em mobile, coverflow 3D vira carrossel normal */
  .nips-style-c .nips-card{
    flex: 0 0 calc((100% - (var(--nips-vis-m) - 1) * var(--nips-gap)) / var(--nips-vis-m));
    margin: 0;
    transform: none;
    opacity: 1;
    filter: none;
  }
  .nips-style-c .nips-track{ gap: var(--nips-gap); }

  /* Em mobile, vertical reduz altura */
  .nips-style-b .nips-viewport{ height: 380px; }
}

/* Mensagens de erro / vazio */
.nips-empty,
.nips-error{
  padding: 24px;
  text-align: center;
  color: rgba(255,255,255,.6);
  font-size: 13px;
  border: 1px dashed rgba(255,255,255,.15);
  border-radius: 8px;
}
.nips-root.nips-theme-day .nips-empty,
.nips-root.nips-theme-day .nips-error{
  color: rgba(13,34,53,.5);
  border-color: rgba(13,34,53,.15);
}
