/* ============================================================
   Brincar e Criar — CSS principal
   Design fiel ao mockup BeCUI.png
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;500;600;700;800&display=swap');

/* ---------- Reset & Base ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --amarelo:    #FFD93D;
  --laranja:    #FF6B35;
  --rosa:       #FF6B9D;
  --azul:       #4ECDC4;
  --azul-esc:   #2E86AB;
  --verde:      #6BCB77;
  --roxo:       #7B2FBE;
  --roxo-claro: #9B59B6;
  --vermelho:   #FF4757;
  --creme:      #FFF9F0;
  --branco:     #FFFFFF;
  --cinza-leve: #F8F4EE;
  --cinza-bdr:  #E8E0D5;
  --texto:      #2D2D2D;
  --texto-med:  #555555;
  --texto-leve: #888888;
  --sombra:     0 4px 16px rgba(0,0,0,0.10);
  --sombra-hover: 0 8px 28px rgba(0,0,0,0.16);
  --radius-card: 20px;
  --radius-lg:   28px;
  --radius-pill: 50px;
  --font: 'Baloo 2', 'Segoe UI', Arial, sans-serif;
}

html { font-size: 16px; }
body {
  font-family: var(--font);
  background: var(--creme);
  color: var(--texto);
  min-height: 100vh;
}
a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; }

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--creme); }
::-webkit-scrollbar-thumb { background: var(--cinza-bdr); border-radius: 3px; }

/* ============================================================
   HEADER
   ============================================================ */
.cabecalho {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--branco);
  box-shadow: 0 2px 12px rgba(0,0,0,0.09);
  border-radius: 0 0 18px 18px;
}
.cabecalho__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
  height: 70px;
  display: flex;
  align-items: center;
  gap: 32px;
}

/* Logo */
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  text-decoration: none;
}
.logo__img {
  height: 52px;
  width: auto;
}

/* Nav menu */
.nav-menu {
  display: flex;
  align-items: center;
  gap: 4px;
  list-style: none;
  flex: 1;
}
.nav-menu a {
  padding: 7px 14px;
  border-radius: var(--radius-pill);
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--texto);
  transition: background 0.18s, color 0.18s;
  white-space: nowrap;
}
.nav-menu a:hover,
.nav-menu a.ativo {
  background: var(--amarelo);
  color: var(--texto);
}

/* Icones direita */
.cabecalho__acoes {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
}
.cabecalho__acoes button,
.cabecalho__acoes a {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  background: var(--cinza-leve);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  transition: background 0.18s, transform 0.15s;
  color: var(--texto);
  text-decoration: none;
}
.cabecalho__acoes button:hover,
.cabecalho__acoes a:hover {
  background: var(--amarelo);
  transform: scale(1.1);
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  background: linear-gradient(135deg, #FFF5C2 0%, #FFE680 60%, #FFD93D 100%);
  border-radius: 0 0 40px 40px;
  margin-bottom: 40px;
  overflow: hidden;
}
.hero__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 52px 40px 44px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
}
.hero__conteudo { max-width: 560px; }

.hero__titulo {
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--texto);
  margin-bottom: 14px;
}
.hero__titulo em {
  font-style: normal;
  color: var(--laranja);
}
.hero__subtitulo {
  font-size: 1.05rem;
  color: var(--texto-med);
  margin-bottom: 28px;
  line-height: 1.55;
}
.hero__cta {
  display: inline-block;
  background: var(--laranja);
  color: var(--branco);
  font-size: 1rem;
  font-weight: 700;
  padding: 13px 32px;
  border-radius: var(--radius-pill);
  box-shadow: 0 4px 14px rgba(255,107,53,0.4);
  transition: transform 0.18s, box-shadow 0.18s;
}
.hero__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 7px 22px rgba(255,107,53,0.5);
  color: var(--branco);
}

.hero__destaques {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
}
.hero__destaque-item {
  background: rgba(255,255,255,0.6);
  border-radius: var(--radius-pill);
  padding: 5px 14px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--texto);
}

/* Ilustracao do hero — SVG animado */
.hero__ilustracao {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.hero__svg-wrap {
  width: 280px;
  height: 240px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ============================================================
   LAYOUT PRINCIPAL (2 colunas)
   ============================================================ */
.layout-principal {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px 56px;
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 32px;
  align-items: start;
}

/* ============================================================
   SIDEBAR DE FILTROS
   ============================================================ */
.sidebar {
  background: var(--branco);
  border-radius: var(--radius-lg);
  box-shadow: var(--sombra);
  padding: 24px;
  position: sticky;
  top: 86px;
}
.sidebar__titulo-secao {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--texto-leve);
  margin-bottom: 10px;
  margin-top: 20px;
}
.sidebar__titulo-secao:first-child { margin-top: 0; }
.sidebar__titulo-h {
  font-size: 1rem;
  font-weight: 800;
  color: var(--texto);
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--cinza-bdr);
}

/* Checkboxes de categoria */
.filtro-lista {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.filtro-lista label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.86rem;
  font-weight: 500;
  cursor: pointer;
  padding: 5px 8px;
  border-radius: 10px;
  transition: background 0.15s;
  color: var(--texto);
}
.filtro-lista label:hover { background: var(--cinza-leve); }
.filtro-lista input[type="checkbox"] {
  width: 15px;
  height: 15px;
  accent-color: var(--laranja);
  cursor: pointer;
  flex-shrink: 0;
}
.filtro-badge {
  margin-left: auto;
  background: var(--cinza-leve);
  border-radius: 20px;
  padding: 1px 7px;
  font-size: 0.73rem;
  color: var(--texto-med);
}

/* Faixa etaria — chips */
.filtro-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.filtro-chip {
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  border: 2px solid var(--cinza-bdr);
  background: transparent;
  font-size: 0.79rem;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font);
  transition: all 0.15s;
  color: var(--texto);
}
.filtro-chip:hover,
.filtro-chip.ativo {
  background: var(--laranja);
  border-color: var(--laranja);
  color: var(--branco);
}

/* Estrelas de avaliacao */
.filtro-estrelas {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.filtro-estrela-linha {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.84rem;
  cursor: pointer;
  padding: 3px 6px;
  border-radius: 8px;
  transition: background 0.15s;
}
.filtro-estrela-linha:hover { background: var(--cinza-leve); }
.filtro-estrela-linha input[type="radio"] {
  accent-color: var(--laranja);
}
.estrelas-cor { color: #FBBF24; }

/* Faixa de preco */
.filtro-preco {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.filtro-preco input[type="range"] {
  width: 100%;
  accent-color: var(--laranja);
}
.filtro-preco-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.8rem;
  color: var(--texto-med);
  font-weight: 600;
}

/* Botao limpar filtros */
.btn-limpar {
  display: block;
  width: 100%;
  margin-top: 20px;
  padding: 9px;
  background: var(--cinza-leve);
  border: none;
  border-radius: var(--radius-pill);
  font-family: var(--font);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--texto-med);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.btn-limpar:hover {
  background: var(--cinza-bdr);
  color: var(--texto);
}

/* ============================================================
   AREA PRINCIPAL (cards)
   ============================================================ */
.area-principal { min-width: 0; }

.area-topo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 22px;
  gap: 16px;
  flex-wrap: wrap;
}
.area-topo h2 {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--texto);
}
.area-topo__count {
  font-size: 0.88rem;
  color: var(--texto-leve);
  font-weight: 500;
}

/* Grid de cards */
.vitrine-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 20px;
}

/* ============================================================
   CARD DE EBOOK
   ============================================================ */
.card {
  background: var(--branco);
  border-radius: var(--radius-card);
  box-shadow: var(--sombra);
  overflow: hidden;
  transition: transform 0.2s, box-shadow 0.2s;
  display: flex;
  flex-direction: column;
}
.card:hover {
  transform: translateY(-5px);
  box-shadow: var(--sombra-hover);
}

/* Topo colorido do card */
.card__topo {
  height: 155px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.cat-atencao-foco    .card__topo { background: linear-gradient(135deg, #FFB347, #FF6B35); }
.cat-alfabetizacao   .card__topo { background: linear-gradient(135deg, #A8EDEA, #4ECDC4); }
.cat-matematica      .card__topo { background: linear-gradient(135deg, #C9F0A4, #6BCB77); }
.cat-coordenacao-logica  .card__topo { background: linear-gradient(135deg, #FFC3E0, #FF6B9D); }
.cat-coordenacao-motora  .card__topo { background: linear-gradient(135deg, #E9D5FF, #c026d3); }
.cat-socioemocional  .card__topo { background: linear-gradient(135deg, #F3B3F9, #9B59B6); }
.cat-criatividade    .card__topo { background: linear-gradient(135deg, #FDE68A, #F59E0B); }
.cat-diversao-temas  .card__topo { background: linear-gradient(135deg, #A5F3FC, #2E86AB); }

.card__topo-emoji {
  font-size: 5rem;
  line-height: 1;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.18));
  user-select: none;
}
.card__topo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Corpo do card */
.card__corpo {
  padding: 14px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  flex: 1;
}
.card__badge {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  align-self: flex-start;
}
.cat-atencao-foco    .card__badge { background: #FFEDD5; color: #c2410c; }
.cat-alfabetizacao   .card__badge { background: #CCFBF1; color: #0d6e64; }
.cat-matematica      .card__badge { background: #DCFCE7; color: #15803d; }
.cat-coordenacao-logica  .card__badge { background: #FCE7F3; color: #9d174d; }
.cat-coordenacao-motora  .card__badge { background: #F3E8FF; color: #7c3aed; }
.cat-socioemocional  .card__badge { background: #F5F3FF; color: #6b21a8; }
.cat-criatividade    .card__badge { background: #FEF9C3; color: #854d0e; }
.cat-diversao-temas  .card__badge { background: #E0F7FA; color: #0e7490; }

.card__titulo {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--texto);
  line-height: 1.3;
}
.card__estrelas {
  color: #FBBF24;
  font-size: 0.82rem;
  letter-spacing: 1px;
}
.card__etaria {
  font-size: 0.77rem;
  color: var(--texto-leve);
  font-weight: 500;
}
.card__preco-linha {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px solid var(--cinza-bdr);
}
.card__preco {
  font-size: 1.02rem;
  font-weight: 800;
  color: var(--texto);
}
.btn-ver {
  display: inline-block;
  padding: 7px 13px;
  border-radius: var(--radius-pill);
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--branco);
  transition: transform 0.15s, box-shadow 0.15s;
  white-space: nowrap;
}
.cat-atencao-foco    .btn-ver { background: var(--laranja); }
.cat-alfabetizacao   .btn-ver { background: var(--azul); }
.cat-matematica      .btn-ver { background: var(--verde); }
.cat-coordenacao-logica  .btn-ver { background: var(--rosa); }
.cat-coordenacao-motora  .btn-ver { background: #c026d3; }
.cat-socioemocional  .btn-ver { background: var(--roxo-claro); }
.cat-criatividade    .btn-ver { background: #d97706; }
.cat-diversao-temas  .btn-ver { background: var(--azul-esc); }
.btn-ver:hover { transform: scale(1.06); box-shadow: 0 3px 10px rgba(0,0,0,0.2); color: var(--branco); }

/* ============================================================
   EXPLORE POR CATEGORIA
   ============================================================ */
.secao-categorias {
  max-width: 1280px;
  margin: 0 auto 40px;
  padding: 0 24px;
}
.secao-categorias h2 {
  font-size: 1.35rem;
  font-weight: 800;
  margin-bottom: 18px;
  color: var(--texto);
}
.cat-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.cat-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: var(--radius-pill);
  font-size: 0.87rem;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s;
  text-decoration: none;
  color: var(--branco);
}
.cat-pill:hover { transform: translateY(-2px); box-shadow: 0 5px 14px rgba(0,0,0,0.18); color: var(--branco); }
.cat-pill--laranja  { background: var(--laranja); }
.cat-pill--azul     { background: var(--azul); }
.cat-pill--verde    { background: var(--verde); }
.cat-pill--rosa     { background: var(--rosa); }
.cat-pill--roxo     { background: var(--roxo-claro); }
.cat-pill--amarelo  { background: #d97706; }
.cat-pill--azulesc  { background: var(--azul-esc); }
.cat-pill--roxoesc  { background: #c026d3; }

.cat-pill__emoji { font-size: 1.05rem; }

/* ============================================================
   BANNER PROMOCIONAL
   ============================================================ */
.banner-promo {
  max-width: 1280px;
  margin: 0 auto 48px;
  padding: 0 24px;
}
.banner-promo__inner {
  background: linear-gradient(135deg, #7B2FBE 0%, #9B59B6 60%, #C084FC 100%);
  border-radius: var(--radius-lg);
  padding: 36px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.banner-promo__texto h3 {
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--branco);
  margin-bottom: 6px;
}
.banner-promo__texto p {
  font-size: 0.95rem;
  color: rgba(255,255,255,0.85);
}
.banner-promo__btn {
  display: inline-block;
  background: var(--branco);
  color: var(--roxo);
  font-weight: 700;
  font-size: 0.95rem;
  padding: 13px 28px;
  border-radius: var(--radius-pill);
  flex-shrink: 0;
  transition: transform 0.15s, box-shadow 0.15s;
  text-decoration: none;
}
.banner-promo__btn:hover {
  transform: scale(1.04);
  box-shadow: 0 5px 18px rgba(0,0,0,0.25);
  color: var(--roxo);
}

/* ============================================================
   RODAPE
   ============================================================ */
.rodape {
  background: #2D2D2D;
  color: rgba(255,255,255,0.9);
  padding: 52px 24px 28px;
}
.rodape__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 36px;
}
.rodape__col-logo img {
  height: 52px;
  width: auto;
  margin-bottom: 12px;
  filter: brightness(0) invert(1);
  opacity: 0.85;
}
.rodape__col-logo p {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.6;
}
.rodape__col h4 {
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.45);
  margin-bottom: 14px;
}
.rodape__col ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.rodape__col ul li a {
  font-size: 0.87rem;
  color: rgba(255,255,255,0.7);
  transition: color 0.15s;
}
.rodape__col ul li a:hover { color: var(--amarelo); }
.rodape__divisor {
  border: none;
  border-top: 1px solid rgba(255,255,255,0.1);
  max-width: 1280px;
  margin: 0 auto 20px;
}
.rodape__fundo {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 12px;
}
.rodape__fundo p {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.45);
}
.rodape__aviso {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.38);
  max-width: 580px;
  line-height: 1.55;
}

/* ============================================================
   CAPA PLACEHOLDER
   ============================================================ */
.capa-ph {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.capa-ph img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0; left: 0;
  z-index: 2;            /* capa real cobre o emoji de fallback (que só deve aparecer se a imagem falhar) */
  background: #fff;
}
.capa-ph__fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 4.5rem;
  line-height: 1;
  z-index: 1;
}

/* ============================================================
   LINK VOLTAR (paginas de produto)
   ============================================================ */
.link-voltar {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.87rem;
  font-weight: 600;
  color: var(--laranja);
  padding: 10px 20px;
  border-radius: var(--radius-pill);
  transition: background 0.15s;
  margin: 16px 0 0 24px;
}
.link-voltar:hover { background: #FFF3EB; color: var(--laranja); }

/* ============================================================
   PAGINA DE PRODUTO — hero
   ============================================================ */
.produto-hero {
  padding: 40px 24px;
  border-radius: 0 0 40px 40px;
  margin-bottom: 40px;
}
.cat-atencao-foco.produto-hero    { background: linear-gradient(135deg, #FFF0E0, #FFD6B5); }
.cat-alfabetizacao.produto-hero   { background: linear-gradient(135deg, #E0FAFA, #B2EFEC); }
.cat-matematica.produto-hero      { background: linear-gradient(135deg, #E5FAE9, #B2EBC2); }
.cat-coordenacao-logica.produto-hero  { background: linear-gradient(135deg, #FDE8F3, #F9BFD8); }
.cat-coordenacao-motora.produto-hero  { background: linear-gradient(135deg, #F3E8FF, #DDBFFF); }
.cat-socioemocional.produto-hero  { background: linear-gradient(135deg, #F5E8FF, #E2BFFF); }
.cat-criatividade.produto-hero    { background: linear-gradient(135deg, #FFFBE0, #FFE9A0); }
.cat-diversao-temas.produto-hero  { background: linear-gradient(135deg, #E0F7FA, #B2EBF2); }

.produto-hero__inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 48px;
  align-items: start;
}
.produto-hero__capa {
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: var(--sombra-hover);
  background: rgba(255,255,255,0.5);
  min-height: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.produto-hero__capa .capa-ph__fallback { font-size: 8rem; }
.produto-hero__capa img { width: 100%; height: auto; }
.produto-hero__info { display: flex; flex-direction: column; gap: 12px; }
.produto-hero__breadcrumb { font-size: 0.82rem; color: var(--texto-med); }
.produto-hero__breadcrumb a { color: var(--laranja); }
.produto-hero__breadcrumb a:hover { text-decoration: underline; }
.produto-hero__badge {
  display: inline-block;
  padding: 4px 14px;
  border-radius: var(--radius-pill);
  background: rgba(255,255,255,0.6);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--texto);
  align-self: flex-start;
}
.produto-hero__titulo {
  font-size: 2rem;
  font-weight: 800;
  line-height: 1.2;
  color: var(--texto);
}
.produto-hero__subtitulo {
  font-size: 1rem;
  color: var(--texto-med);
  line-height: 1.5;
}
.produto-hero__preco-area {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 6px;
}
.produto-hero__preco {
  font-size: 2rem;
  font-weight: 800;
  color: var(--laranja);
}
.produto-hero__preco-nota {
  font-size: 0.8rem;
  color: var(--texto-med);
  line-height: 1.4;
}
.btn-checkout {
  display: inline-block;
  background: var(--laranja);
  color: var(--branco);
  font-size: 1.05rem;
  font-weight: 700;
  padding: 16px 36px;
  border-radius: var(--radius-pill);
  box-shadow: 0 5px 18px rgba(255,107,53,0.45);
  transition: transform 0.18s, box-shadow 0.18s;
  text-align: center;
  align-self: flex-start;
}
.btn-checkout:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(255,107,53,0.55);
  color: var(--branco);
}
.garantia {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
  color: var(--texto-med);
  background: rgba(255,255,255,0.5);
  padding: 10px 16px;
  border-radius: 12px;
}

/* ============================================================
   PAGINA DE PRODUTO — detalhes
   ============================================================ */
.produto-detalhes {
  max-width: 1100px;
  margin: 0 auto 40px;
  padding: 0 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.produto-detalhes__bloco {
  background: var(--branco);
  border-radius: var(--radius-card);
  box-shadow: var(--sombra);
  padding: 28px;
}
.produto-detalhes__bloco h2 {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--texto);
  margin-bottom: 14px;
}
.produto-detalhes__desc {
  font-size: 0.92rem;
  color: var(--texto-med);
  line-height: 1.6;
}
.bullets {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-left: 0;
  list-style: none;
}
.bullets li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 0.9rem;
  color: var(--texto-med);
  line-height: 1.5;
}
.bullets li::before {
  content: '\2705';
  flex-shrink: 0;
}
dl { display: grid; grid-template-columns: auto 1fr; gap: 6px 16px; }
dt { font-size: 0.82rem; font-weight: 700; color: var(--texto-med); }
dd { font-size: 0.87rem; color: var(--texto); }

/* Garantia box */
.garantia-box {
  max-width: 1100px;
  margin: 0 auto 40px;
  padding: 0 24px;
}
.garantia-box__inner {
  background: linear-gradient(135deg, #FFF7ED, #FFEDD5);
  border-radius: var(--radius-card);
  padding: 28px;
  text-align: center;
  box-shadow: var(--sombra);
}
.garantia-box__emoji { font-size: 2.5rem; margin-bottom: 8px; }
.garantia-box__inner h3 { font-size: 1.1rem; font-weight: 700; margin-bottom: 8px; }
.garantia-box__inner p { font-size: 0.9rem; color: var(--texto-med); line-height: 1.55; max-width: 480px; margin: 0 auto; }

/* ============================================================
   CROSS-SELL
   ============================================================ */
.crosssell {
  background: var(--cinza-leve);
  padding: 48px 24px;
  margin-top: 24px;
}
.crosssell__inner { max-width: 1100px; margin: 0 auto; }
.crosssell__titulo {
  font-size: 1.3rem;
  font-weight: 800;
  margin-bottom: 6px;
}
.crosssell__desc {
  font-size: 0.92rem;
  color: var(--texto-med);
  margin-bottom: 24px;
}
.crosssell__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 20px;
}

/* produto-info-extra dl */
.produto-info-extra h3 {
  font-size: 0.95rem;
  font-weight: 700;
  margin-bottom: 10px;
  color: var(--texto);
}

/* ============================================================
   SECAO — util generico
   ============================================================ */
.secao { max-width: 1280px; margin: 0 auto; padding: 48px 24px; }
.secao__titulo { font-size: 1.4rem; font-weight: 800; margin-bottom: 6px; }
.secao__desc { font-size: 0.95rem; color: var(--texto-med); }

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width: 1024px) {
  .layout-principal { grid-template-columns: 220px 1fr; gap: 20px; }
  .vitrine-grid { grid-template-columns: repeat(auto-fill, minmax(185px, 1fr)); }
  .produto-hero__inner { grid-template-columns: 250px 1fr; gap: 28px; }
  .rodape__inner { grid-template-columns: 1fr 1fr; gap: 28px; }
}

@media (max-width: 768px) {
  .cabecalho__inner { height: 60px; padding: 0 16px; }
  .nav-menu { display: none; }
  .logo__img { height: 40px; }

  .hero__inner {
    grid-template-columns: 1fr;
    padding: 36px 20px 32px;
    text-align: center;
  }
  .hero__ilustracao { display: none; }
  .hero__destaques { justify-content: center; }

  .layout-principal {
    grid-template-columns: 1fr;
    padding: 0 16px 40px;
  }
  .sidebar { position: static; }

  .vitrine-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }

  .produto-hero__inner { grid-template-columns: 1fr; }
  .produto-detalhes { grid-template-columns: 1fr; }

  .banner-promo__inner { flex-direction: column; text-align: center; }
  .rodape__inner { grid-template-columns: 1fr 1fr; gap: 20px; }
}

@media (max-width: 480px) {
  .vitrine-grid { grid-template-columns: 1fr; }
  .rodape__inner { grid-template-columns: 1fr; }
  .hero__titulo { font-size: 1.5rem; }
  .crosssell__grid { grid-template-columns: 1fr; }
}


/* ============================================================
   EXTRAS — Prontidão de venda (gerado automaticamente)
   ============================================================ */

/* Cards indisponíveis */
.card--em-breve {
  opacity: 0.72;
  filter: grayscale(0.25);
}
.card--em-breve:hover {
  transform: none;
  box-shadow: var(--sombra);
}
.card__selo-em-breve {
  position: absolute;
  top: 10px;
  right: 10px;
  background: rgba(0,0,0,0.55);
  color: white;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  z-index: 2;
}
.btn-em-breve {
  display: inline-block;
  padding: 7px 13px;
  border-radius: var(--radius-pill);
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--texto-leve);
  background: var(--cinza-leve);
  border: 2px solid var(--cinza-bdr);
  cursor: not-allowed;
  white-space: nowrap;
}

/* Card disponível — destaque */
.card--disponivel {
  border: 2px solid var(--laranja);
  box-shadow: 0 4px 20px rgba(255,107,53,0.20);
}
.card__badge-destaque {
  position: absolute;
  top: 10px;
  left: 10px;
  background: var(--laranja);
  color: white;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  z-index: 2;
}
.btn-comprar {
  display: inline-block;
  padding: 7px 13px;
  border-radius: var(--radius-pill);
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--branco);
  background: var(--laranja);
  transition: transform 0.15s, box-shadow 0.15s;
  white-space: nowrap;
}
.btn-comprar:hover {
  transform: scale(1.06);
  box-shadow: 0 3px 10px rgba(255,107,53,0.35);
  color: var(--branco);
}
/* Card disponivel: botao de compra ocupa a largura toda (nao estoura/quebra o card) */
.card--disponivel .card__preco-linha { flex-wrap: wrap; row-gap: 10px; }
.card--disponivel .btn-comprar {
  flex: 1 1 100%;
  text-align: center;
  padding: 10px 14px;
}

/* Botão checkout indisponível */
.btn-checkout--em-breve {
  background: var(--cinza-leve) !important;
  color: var(--texto-leve) !important;
  box-shadow: none !important;
  cursor: not-allowed;
  pointer-events: none;
}

/* ---- FAIXA DESTAQUE (home) ---- */
.faixa-destaque {
  max-width: 1280px;
  margin: 0 auto 40px;
  padding: 0 24px;
}
.faixa-destaque__inner {
  background: linear-gradient(135deg, #FFF0E0 0%, #FFD6B5 60%, #FFB347 100%);
  border-radius: var(--radius-lg);
  padding: 36px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
  border: 2px solid var(--laranja);
  box-shadow: 0 6px 24px rgba(255,107,53,0.18);
}
.faixa-destaque__label {
  display: inline-block;
  background: var(--laranja);
  color: white;
  font-size: 0.78rem;
  font-weight: 700;
  padding: 4px 14px;
  border-radius: 20px;
  margin-bottom: 10px;
}
.faixa-destaque__titulo {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--texto);
  margin-bottom: 8px;
}
.faixa-destaque__desc {
  font-size: 0.92rem;
  color: var(--texto-med);
  margin-bottom: 18px;
  max-width: 480px;
  line-height: 1.5;
}
.faixa-destaque__acoes {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.btn-comprar-destaque {
  display: inline-block;
  background: var(--laranja);
  color: white;
  font-weight: 700;
  font-size: 1rem;
  padding: 13px 28px;
  border-radius: var(--radius-pill);
  box-shadow: 0 4px 14px rgba(255,107,53,0.4);
  transition: transform 0.15s, box-shadow 0.15s;
}
.btn-comprar-destaque:hover {
  transform: translateY(-2px);
  box-shadow: 0 7px 22px rgba(255,107,53,0.5);
  color: white;
}
.btn-ver-destaque {
  display: inline-block;
  background: rgba(255,255,255,0.7);
  color: var(--texto);
  font-weight: 700;
  font-size: 0.9rem;
  padding: 12px 22px;
  border-radius: var(--radius-pill);
  transition: background 0.15s;
}
.btn-ver-destaque:hover { background: rgba(255,255,255,0.95); }
.faixa-destaque__garantia {
  font-size: 0.82rem;
  color: var(--texto-med);
}
.faixa-destaque__capa {
  flex-shrink: 0;
  width: 180px;
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: var(--sombra-hover);
}
.faixa-destaque__capa img {
  width: 100%;
  height: auto;
  display: block;
}

/* ---- SELOS DO RODAPÉ ---- */
.rodape__selos {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 14px;
}
.rodape__selo {
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.20);
  border-radius: var(--radius-pill);
  padding: 4px 12px;
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(255,255,255,0.70);
}

/* Responsivo faixa destaque */
@media (max-width: 768px) {
  .faixa-destaque__inner { flex-direction: column; padding: 28px 24px; }
  .faixa-destaque__capa { width: 120px; align-self: flex-end; }
}
