/* =========================================
   VARIÁVEIS CSS (THEMING)
   ========================================= */
:root {
  --cor-primaria: #fa3304;
  --cor-primaria-hover: #c62804;
  --cor-secundaria: #a72204;
  --bg-body: #fbfbf8;
  --bg-card: #fbfbf8;
  --texto-titulo: #080404;
  --texto-corpo: #441c04;
  --borda-padrao: #a72204;
  --sucesso: #042004;
  --aviso: #c62804;
  --cor-pix: #1d961d;
  --cor-footer: #fffbeb;
}

/* =========================================
   1. GERAL E HEADER
   ========================================= */
body {
  /* Espaço para o Header Fixo */
  padding-top: 100px;
  background-color: var(--bg-body);
}

/* Ícones do Header */
.header-icon {
  font-size: 1.2rem;
  transition: color 0.2s ease;
  color: var(--texto-titulo);
  text-decoration: none;
}

.header-icon:hover {
  color: var(--cor-primaria) !important;
}

/* Barra de busca desktop */
.header-search-bar input {
  border-color: var(--borda-padrao);
  box-shadow: none !important;
}

/* Logo da Navbar */
.logo-navbar {
  height: 55px;
  width: 180px;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* Ajuste fino na tag 'a' pai da imagem */
.navbar-brand {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  display: flex;
  align-items: center;
}

/* Categorias na navbar - impedir transbordamento */
.navbar .d-lg-flex {
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  -ms-overflow-style: none;
  flex-wrap: nowrap;
  max-width: 100%;
}

.navbar .d-lg-flex::-webkit-scrollbar {
  display: none;
}

.navbar .d-lg-flex .nav-link {
  white-space: nowrap;
  flex-shrink: 0;
}

/* Centralizar logo no mobile com espaçamento */
@media (max-width: 991px) {
  .navbar-brand {
    margin-right: auto;
    margin-left: auto;
  }
}

/* Badge do Carrinho */
.carrinho-badge {
  position: absolute;
  top: -6px;
  right: -8px;
  background: var(--aviso);
  color: #fff;
  border-radius: 50%;
  font-size: 0.7rem;
  padding: 2px 6px;
  line-height: 1;
}

/* Menu Mobile (Gaveta Lateral) */
#menuMobile {
  width: 85vw;
  max-width: 300px;
}

#menuMobile .nav-link {
  padding: 15px 0;
  border-bottom: 1px solid #f1f1f1;
  color: var(--texto-titulo);
}

#menuMobile .nav-link.active {
  color: var(--cor-primaria);
  font-weight: 600;
}

/* Barra de anúncios */
.barra-anuncio {
  font-size: 0.9rem;
  font-weight: 500;
  letter-spacing: 0.5px;
  z-index: 1040;
  position: relative;
}

.barra-anuncio .anuncio-icon,
.carousel-anuncio-item .anuncio-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 6px;
  font-size: 1rem;
  line-height: 1;
}

/* Busca Mobile Expansível */
#mobileSearch {
  border-top: 1px solid #f1f1f1;
  top: 100%;
  z-index: 999;
}

/* Carrossel de anúncios no topo */
.top-bar-carousel {
  width: 100%;
  z-index: 1020;
  min-height: 35px;
  margin: 0;
  padding: 0;
}

.carousel-anuncio-item {
  text-align: center;
  padding: 8px 10px;
  font-size: 0.9rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 35px;
  color: #fff;
}

.carousel-anuncio-item a {
  color: inherit;
  text-decoration: none;
  transition: opacity 0.2s;
}

.carousel-anuncio-item a:hover {
  opacity: 0.8;
  text-decoration: underline;
}

/* Z-index para o Offcanvas (Menu/Filtros) ficar acima de tudo */
.offcanvas {
  z-index: 1090 !important;
}

/* =========================================
   2. CARD DE PRODUTO (VITRINE)
   ========================================= */
.card-produto {
  border: none;
  transition: transform 0.2s;
}

.card-produto:hover {
  transform: translateY(-5px);
}

.card-produto .card-img-top {
  height: 250px;
  object-fit: contain;
  padding: 10px;
  background-color: var(--bg-card);
}

/* Badges (Oferta, Frete Grátis) */
.card-produto .badge-overlay {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 5px;
}

/* Tipografia de Preços */
.card-produto .preco-antigo {
  font-size: 0.85rem;
  color: #999;
  text-decoration: line-through;
}

.card-produto .preco-pix {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--cor-pix);
}

.card-produto .texto-parcelas {
  font-size: 0.75rem;
  color: var(--texto-corpo);
}

.card-produto .produto-nome {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.6em;
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--texto-titulo);
  text-decoration: none;
}

/* =========================================
   3. PÁGINA DE PRODUTO (DETALHES)
   ========================================= */
.carousel-item img {
  object-fit: contain;
  max-height: 500px;
  width: 100%;
}

/* Carousel principal de banners (responsivo) */
#carouselBanners .carousel-item img {
  width: 100%;
  object-fit: cover;
}

/* Container de miniaturas - evitar transbordamento */
.d-md-flex.flex-wrap {
  flex-wrap: wrap !important;
  overflow: visible;
  align-content: flex-start;
}

.d-md-flex.flex-wrap .btn {
  flex-shrink: 0;
  overflow: hidden;
}

/* Botões de Variação (Tamanhos) */
input[name="variacao_id"] {
  display: none;
}

.variacao-label {
  border: 1px solid var(--borda-padrao);
  padding: 10px 15px;
  border-radius: 5px;
  cursor: pointer;
  margin-right: 5px;
  user-select: none;
  background-color: var(--bg-card);
  transition: all 0.2s;
}

input[name="variacao_id"]:checked + .variacao-label {
  background-color: var(--texto-titulo);
  color: #fff;
  border-color: var(--texto-titulo);
}

.variacao-label.disabled {
  opacity: 0.5;
  background-color: var(--bg-body);
  text-decoration: line-through;
  cursor: not-allowed;
}

/* Botão Comprar Sticky (Mobile) */
.sticky-comprar {
  z-index: 1000;
  border-top: 1px solid var(--borda-padrao);
  padding-bottom: env(safe-area-inset-bottom);
}

/* Lista de fretes */
.frete-list {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.frete-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid var(--borda-padrao);
}

.frete-item:last-child {
  border-bottom: none;
}

.frete-preco {
  color: var(--sucesso);
  font-weight: 700;
  margin-right: 8px;
}

.frete-prazo {
  color: var(--cor-secundaria);
}

/* Animação de erro (Tremer) */
.shake {
  animation: shake 0.35s;
}

@keyframes shake {
  0% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(-4px);
  }
  50% {
    transform: translateX(4px);
  }
  75% {
    transform: translateX(-4px);
  }
  100% {
    transform: translateX(0);
  }
}

/* =========================================
   4. PÁGINA SOBRE (GLOBAL)
   ========================================= */
.hero-sobre {
  background-color: var(--bg-body);
  padding: 60px 20px;
  text-align: center;
  border-radius: 0 0 50px 50px;
  margin-bottom: 40px;
}

.card-info-sobre {
  transition: transform 0.3s ease;
  border-radius: 15px;
  background: var(--bg-card);
}

.card-info-sobre:hover {
  transform: translateY(-5px);
}

.icon-sobre {
  font-size: 2rem;
  color: var(--bs-primary);
  margin-bottom: 15px;
  display: block;
}

/* =========================================
   5. MÍDIA QUERIES (MOBILE VS DESKTOP)
   ========================================= */

/* --- MOBILE (< 768px): Scroll Horizontal --- */
@media (max-width: 767.98px) {
  /* Ajuste Logo Mobile */
  .logo-navbar {
    height: 40px;
    width: 130px;
  }

  /* Ajuste Banners/Carousel */
  .carousel-item img {
    height: auto !important;
    min-height: 250px;
    max-height: 600px;
    width: 100% !important;
    object-fit: cover;
    aspect-ratio: 4 / 5;
  }

  /* Carousel principal de banners (mobile) */
  #carouselBanners .carousel-item img {
    min-height: 300px;
    object-fit: cover;
  }

  .container-fluid.p-0-mobile {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .carousel-control-prev,
  .carousel-control-next {
    width: 10%;
  }

  /* Container de Produtos (Scroll Lateral) */
  .mobile-scroll-container {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    gap: 15px;
    padding-bottom: 20px;
    margin-bottom: 30px;
    scrollbar-width: none;
  }

  .mobile-scroll-container::-webkit-scrollbar {
    display: none;
  }

  .mobile-scroll-container > div,
  .mobile-scroll-container .col {
    flex: 0 0 60% !important;
    max-width: 320px !important;
    width: auto !important;

    display: block !important;
    scroll-snap-align: start;
  }

  #marcas .mobile-scroll-container > div {
    flex: 0 0 auto !important;
    width: auto !important;
    margin-right: 10px !important;
  }

  /* Grade mobile 2 colunas (opcional) */
  .mobile-grid-2,
  .mobile-scroll-container.mobile-grid-2 {
    display: flex;
    flex-wrap: wrap;
    padding-left: 5px;
    padding-right: 5px;
    justify-content: space-between;
  }

  .mobile-scroll-container.mobile-grid-2 {
    overflow-x: visible !important;
    overflow-y: visible !important;
    scroll-snap-type: none;
    gap: 10px;
    padding-bottom: 0;
    margin-bottom: 15px;
  }

  .mobile-grid-2 > div,
  .mobile-grid-2 .col,
  .mobile-scroll-container.mobile-grid-2 > div,
  .mobile-scroll-container.mobile-grid-2 .col {
    flex: 0 0 48% !important;
    max-width: 48% !important;
    margin-right: 0 !important;
    margin-bottom: 15px !important;
  }

  .card-produto .card-img-top {
    height: 250px !important;
    min-height: 0 !important;
    object-fit: contain;
    padding: 5px;
  }

  .card-produto .card-body {
    padding: 8px;
  }

  .card-produto .produto-nome {
    font-size: 0.85rem;
    min-height: 2.5em;
  }

  .card-produto .preco-pix {
    font-size: 0.9rem;
  }
}

/* Carousel principal de banners (desktop) */
@media (min-width: 768px) {
  #carouselBanners .carousel-item img {
    height: 500px;
    object-fit: cover;
  }
}

/* --- DESKTOP (>= 768px): Grid Tradicional --- */
@media (min-width: 768px) {
  /* Container de Produtos (Grid) */
  .mobile-scroll-container {
    display: flex !important;
    flex-wrap: wrap !important;
    overflow-x: visible !important;
    overflow-y: visible !important;
    justify-content: flex-start !important;
    gap: 20px;
    padding-bottom: 0 !important;
  }

  /* Configuração dos Cards no Desktop (4 por linha) */
  .mobile-scroll-container > div,
  .mobile-scroll-container .col {
    flex: 0 0 auto !important;
    width: 23% !important; /* 4 itens por linha */
    max-width: 280px !important;
    display: block !important;
    margin-right: 0 !important;
    margin-bottom: 20px !important;
  }

  /* Ajuste para telas médias (Notebooks) */
  @media (max-width: 1200px) {
    .mobile-scroll-container > div,
    .mobile-scroll-container .col {
      width: 31% !important; /* 3 itens por linha */
    }
  }

  /* --- MARCAS NO DESKTOP --- */
  #marcas .mobile-scroll-container {
    display: flex !important;
    flex-wrap: wrap !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    gap: 15px;
  }

  #marcas .mobile-scroll-container > div,
  #marcas .mobile-scroll-container .col {
    flex: 0 0 auto !important;
    width: auto !important;
    display: block !important;
    margin-bottom: 10px !important;
  }

  #marcas .mobile-scroll-container .marca-item {
    width: auto !important;
  }
}

/* =========================================
   6. STICKY HEADER (SCROLL)
   ========================================= */

/* Removemos position:fixed da navbar, pois agora quem é fixo é a tag <header> pai */
.navbar {
  transition: all 0.3s ease-in-out;
  width: 100%;
  background-color: var(--bg-card);
  /* position: fixed;  <-- REMOVIDO */
  /* top: 0;           <-- REMOVIDO */
  /* z-index: 1050;    <-- REMOVIDO */
}

/* O Header pai agora controla a fixação */
header.fixed-top {
  z-index: 1050;
  width: 100%;
  top: 0;
}

/* Quando rolar, aplicamos sombra na navbar interna */
.navbar.scrolled {
  /* background-color: #ffffff !important; já é branco */
  /* box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); <-- Removido daqui, pois o shadow está no header pai agora */
  padding-top: 5px !important;
  padding-bottom: 5px !important;
}

/* =========================================
   7. DEPOIMENTOS
   ========================================= */
.mobile-scroll-depoimentos {
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.mobile-scroll-depoimentos::-webkit-scrollbar {
  display: none;
}

.card-depoimento {
  border-radius: 16px;
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease;
  background-color: var(--bg-body);
}

.card-depoimento:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.08) !important;
}

.gradient-overlay {
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.8) 0%,
    rgba(0, 0, 0, 0) 100%
  );
  border-radius: 0 0 16px 16px;
}

.bi-quote {
  font-size: 3rem;
  line-height: 1;
}

@media (max-width: 768px) {
  .card-depoimento {
    min-height: 280px;
  }

  .mobile-scroll-depoimentos .col-10 {
    flex: 0 0 85%;
    max-width: 85%;
  }
}

/* =========================================
   SELETOR DINÂMICO DE TAMANHO E COR
   ========================================= */

/* Input escondido para radio buttons */
#tamanhos-container input[type="radio"],
#cores-container input[type="radio"] {
  display: none;
}

/* Botões de Tamanho */
#tamanhos-container label,
#cores-container label {
  cursor: pointer;
  transition: all 0.3s ease;
  user-select: none;
  border: 2px solid var(--borda-padrao);
  padding: 8px 16px;
  border-radius: 6px;
  background-color: var(--bg-card);
  font-weight: 500;
  font-size: 0.95rem;
}

#tamanhos-container label:hover,
#cores-container label:hover {
  border-color: var(--cor-primaria);
  background-color: #f8f9ff;
}

/* Tamanho selecionado */
#tamanhos-container input[type="radio"]:checked + label,
#cores-container input[type="radio"]:checked + label {
  background-color: var(--texto-titulo);
  color: #fff;
  border-color: var(--texto-titulo);
}

/* Opção desabilitada */
#tamanhos-container label.disabled,
#cores-container label.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background-color: var(--bg-body);
}

#tamanhos-container input[type="radio"]:disabled + label,
#cores-container input[type="radio"]:disabled + label {
  opacity: 0.5;
  cursor: not-allowed;
  background-color: var(--bg-body);
}

/* Animação de shake quando não selecionado */
@keyframes shake {
  0%,
  100% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(-5px);
  }
  75% {
    transform: translateX(5px);
  }
}

#tamanhos-container.shake,
#cores-container.shake {
  animation: shake 0.4s;
}

/* =========================================
   SOBRESCRITA DE COMPONENTES BOOTSTRAP
   ========================================= */

/* Botões Primários */
.btn-primary {
  background-color: var(--cor-primaria);
  border-color: var(--cor-primaria);
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
  background-color: var(--cor-primaria-hover);
  border-color: var(--cor-primaria-hover);
}

/* Textos Primários */
.text-primary {
  color: var(--cor-primaria) !important;
}

/* Fundos Primários */
.bg-primary {
  background-color: var(--cor-primaria) !important;
}

/* Navbar */
.navbar {
  background-color: var(--bg-card) !important;
}

/* Cards Padrão */
.card {
  background-color: var(--bg-card);
  border-color: var(--borda-padrao);
}

.card-body {
  color: var(--texto-corpo);
}

.card-title {
  color: var(--texto-titulo);
}

/* Textos de Sucesso (Verdes) */
.text-success {
  color: var(--sucesso) !important;
}

.bg-success {
  background-color: var(--sucesso) !important;
}

/* Linhas/Divisores */
hr {
  border-color: var(--borda-padrao);
}

/* Links */
a {
  color: var(--cor-primaria);
}

a:hover {
  color: var(--cor-primaria-hover);
}

/* Inputs e Forms */
.form-control,
.form-select {
  border-color: var(--borda-padrao);
  color: var(--texto-corpo);
  background-color: var(--bg-card);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--cor-primaria);
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* Badges */
.badge-primary {
  background-color: var(--cor-primaria);
}

.badge-success {
  background-color: var(--sucesso);
}
/* =========================================
   BENEFÍCIOS - SCROLL HORIZONTAL
   ========================================= */
@keyframes scroll-benefits {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

.benefits-section {
  background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
  border-top: 1px solid #e9ecef;
  border-bottom: 1px solid #e9ecef;
}

.benefits-scroller {
  overflow: hidden;
  width: 100%;
  padding: 0;
}

.benefits-track {
  display: flex;
  gap: 20px;
  width: max-content;
  padding: 10px 20px;
  animation: scroll-benefits 25s linear infinite;
}

.benefits-track:hover {
  animation-play-state: paused;
}

.benefit-card {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 15px;
  background: #fff;
  padding: 15px 25px;
  border-radius: 50px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  min-width: 280px;
  white-space: nowrap;
  transition: all 0.3s ease;
}

.benefit-card:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}

.benefit-icon {
  font-size: 1.8rem;
  color: var(--cor-primaria);
  flex-shrink: 0;
}

.benefit-icon i {
  display: block;
}

.benefit-content {
  flex: 1;
}

.benefit-title {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--texto-titulo);
  margin: 0;
}

.benefit-subtitle {
  font-size: 0.8rem;
  color: #6c757d;
  margin: 2px 0 0;
}

/* Responsivo: Em mobile, reduzir tamanho */
@media (max-width: 576px) {
  .benefit-card {
    min-width: 230px;
    padding: 12px 18px;
    gap: 12px;
  }

  .benefit-icon {
    font-size: 1.5rem;
  }

  .benefit-title {
    font-size: 0.85rem;
  }

  .benefit-subtitle {
    font-size: 0.75rem;
  }

  .benefits-track {
    gap: 15px;
    animation: scroll-benefits 20s linear infinite;
  }
}

/* =========================================
   CARROSSEL INFINITO - MARCAS
   ========================================= */
.carousel-infinito {
  position: relative;
  overflow: hidden;
  background-color: transparent;
  padding: 20px 0;
}

.carousel-track {
  display: flex;
  gap: 1.5rem;
  will-change: transform;
  transition: transform 0.01s linear;
}

.marca-item {
  flex-shrink: 0;
  min-width: 100px;
  animation-play-state: running;
}

.carousel-infinito:hover .carousel-track {
  animation-play-state: paused;
}

/* Suporte a redimensionamento responsivo */
@media (max-width: 768px) {
  .carousel-track {
    gap: 1rem;
  }

  .marca-item {
    min-width: 80px;
  }
}
/* =========================================
   CTA INSTAGRAM
   ========================================= */
.instagram-cta {
  border-top: 1px solid #e9ecef;
  border-bottom: 1px solid #e9ecef;
}

.btn-instagram {
  background: linear-gradient(
    45deg,
    #f09433 0%,
    #e6683c 25%,
    #dc2743 50%,
    #cc2366 75%,
    #bc1888 100%
  );
  color: white;
  border: none;
  padding: 10px 25px;
  font-weight: 600;
  border-radius: 50px;
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease;
  display: inline-block;
  text-decoration: none;
}

.btn-instagram:hover {
  color: white;
  transform: translateY(-3px);
  box-shadow: 0 5px 15px rgba(220, 39, 67, 0.4);
  text-decoration: none;
}

.btn-instagram:focus {
  color: white;
  text-decoration: none;
  box-shadow: 0 5px 15px rgba(220, 39, 67, 0.4);
}

.icone-insta-destaque {
  background: -webkit-linear-gradient(
    45deg,
    #f09433,
    #e6683c,
    #dc2743,
    #cc2366,
    #bc1888
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 15px;
  display: inline-block;
}
