/* =====================================================================
   produto.css — página de produto
   ===================================================================== */

.breadcrumb { padding: 20px 0 4px; font-size: .8rem; color: var(--cor-texto-claro); }
.breadcrumb a:hover { color: var(--cor-acento); }
.breadcrumb span { color: var(--cor-texto); }

.produto {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    padding-top: 24px;
    padding-bottom: 56px;
}

/* Galeria */
.produto__principal {
    aspect-ratio: 3/4; border-radius: var(--raio); overflow: hidden;
    background: var(--cor-secundaria);
}
.produto__principal img { width: 100%; height: 100%; object-fit: cover; }
.produto__miniaturas { display: flex; gap: 10px; margin-top: 12px; }
.miniatura {
    width: 72px; height: 90px; border: 1px solid var(--cor-borda); border-radius: var(--raio);
    overflow: hidden; padding: 0; background: var(--cor-secundaria);
}
.miniatura.ativa { border-color: var(--cor-primaria); }
.miniatura img { width: 100%; height: 100%; object-fit: cover; }

/* Info */
.produto__cat { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--cor-texto-claro); }
.produto__nome { font-size: 2.2rem; margin: 6px 0 10px; }
.produto__avaliacao-resumo { display: flex; align-items: center; gap: 10px; font-size: .85rem; color: var(--cor-texto-claro); margin-bottom: 14px; }
.produto__preco { margin-bottom: 18px; }
.produto__preco strong { font-size: 1.8rem; color: var(--cor-acento); }
.produto__preco s { color: var(--cor-texto-claro); margin-right: 10px; font-size: 1.1rem; }
.produto__desc { color: var(--cor-texto-claro); margin-bottom: 24px; }

.produto__campo { margin-bottom: 22px; }
.produto__label { display: block; font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 10px; }
.produto__label span { color: var(--cor-acento); text-transform: none; letter-spacing: 0; }

/* Cores */
.cores { display: flex; gap: 10px; flex-wrap: wrap; }
.cor {
    width: 34px; height: 34px; border-radius: 999px; padding: 0;
    background: var(--cor); border: 2px solid var(--cor-borda);
    position: relative; transition: var(--transicao);
}
.cor.ativa { box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--cor-primaria); border-color: #fff; }

/* Tamanhos */
.tamanhos { display: flex; gap: 10px; flex-wrap: wrap; }
.tamanho {
    min-width: 48px; padding: 10px 14px; border: 1px solid var(--cor-borda);
    background: #fff; border-radius: var(--raio); font-weight: 600; transition: var(--transicao);
}
.tamanho:hover:not([disabled]) { border-color: var(--cor-primaria); }
.tamanho.ativa { background: var(--cor-primaria); color: #fff; border-color: var(--cor-primaria); }
.tamanho[disabled] { opacity: .4; text-decoration: line-through; cursor: not-allowed; }

/* Quantidade + compra */
.produto__compra { display: flex; gap: 12px; align-items: stretch; }
.qtd { display: flex; align-items: center; border: 1px solid var(--cor-borda); border-radius: var(--raio); overflow: hidden; }
.qtd button { width: 42px; border: 0; background: var(--cor-secundaria); font-size: 1.2rem; }
.qtd input { width: 52px; text-align: center; border: 0; font-size: 1rem; -moz-appearance: textfield; }
.qtd input::-webkit-outer-spin-button, .qtd input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.produto__compra .btn { flex: 1; }

/* Estrelas */
.estrelas { --nota: 0; display: inline-block; font-size: 1rem; line-height: 1; position: relative; color: var(--cor-borda); }
.estrelas::before { content: '★★★★★'; }
.estrelas::after {
    content: '★★★★★'; color: var(--cor-acento);
    position: absolute; left: 0; top: 0; overflow: hidden;
    width: calc(var(--nota) / 5 * 100%);
}

/* Abas */
.produto-abas { padding-bottom: 56px; }
.abas__nav { display: flex; gap: 8px; border-bottom: 1px solid var(--cor-borda); margin-bottom: 24px; }
.aba-btn { background: none; border: 0; padding: 14px 18px; font-weight: 600; color: var(--cor-texto-claro); border-bottom: 2px solid transparent; }
.aba-btn.ativa { color: var(--cor-primaria); border-bottom-color: var(--cor-primaria); }
.aba-painel { display: none; }
.aba-painel.ativo { display: block; }
.specs { display: grid; gap: 10px; max-width: 640px; }
.specs li { padding: 12px 16px; background: var(--cor-secundaria); border-radius: var(--raio); }
.avaliacao { padding: 18px 0; border-bottom: 1px solid var(--cor-borda); }
.avaliacao__topo { display: flex; align-items: center; gap: 12px; margin-bottom: 6px; }

@media (max-width: 860px) {
    .produto { grid-template-columns: 1fr; gap: 28px; }
    .produto__nome { font-size: 1.7rem; }
}
