/* ==================================================================
   MODA MIX — ESTILO PRINCIPAL DA LOJA
   Identidade: preto premium + dourado + branco
   Tipografia editorial (serifada no display + sans no corpo)
   ================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,600;0,700;1,500&family=Poppins:wght@300;400;500;600;700&display=swap');

:root{
    /* Paleta */
    --preto:        #0F0F0F;
    --preto-suave:  #1A1A1A;
    --preto-card:   #181818;
    --dourado:      #C9A227;
    --dourado-claro:#E2C25E;
    --dourado-escuro:#9C7C1B;
    --branco:       #FFFFFF;
    --cinza-claro:  #B8B8B8;
    --cinza-borda:  #2B2B2B;
    --vermelho:     #C0392B;
    --verde:        #3FA76A;

    /* Tipografia */
    --fonte-display: 'Playfair Display', Georgia, serif;
    --fonte-corpo: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    /* Espacamentos */
    --container: 1280px;
    --raio: 2px;
    --sombra: 0 10px 30px rgba(0,0,0,.45);
    --transicao: .3s cubic-bezier(.4,0,.2,1);
}

*{ margin:0; padding:0; box-sizing:border-box; }

html{ scroll-behavior:smooth; overflow-x:clip; }

body{
    background:var(--preto);
    color:var(--branco);
    font-family:var(--fonte-corpo);
    font-size:15px;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
img{ max-width:100%; display:block; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
input, select, textarea{ font-family:inherit; }

h1,h2,h3,h4{ font-family:var(--fonte-display); font-weight:600; letter-spacing:.3px; }

.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 24px; }

.eyebrow{
    display:inline-flex; align-items:center; gap:10px;
    font-size:12px; letter-spacing:3px; text-transform:uppercase;
    color:var(--dourado); margin-bottom:14px; font-weight:500;
}
.eyebrow::before{ content:''; width:28px; height:1px; background:var(--dourado); }

.titulo-secao{
    font-size:clamp(26px,3.4vw,40px);
    color:var(--branco);
    margin-bottom:6px;
}
.subtitulo-secao{ color:var(--cinza-claro); font-size:14px; margin-bottom:36px; max-width:560px; }

.cabecalho-secao{ display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:16px; margin-bottom:32px; }

/* Scrollbar fina dourada */
::-webkit-scrollbar{ width:8px; }
::-webkit-scrollbar-track{ background:var(--preto); }
::-webkit-scrollbar-thumb{ background:var(--dourado-escuro); border-radius:4px; }

/* Foco visível para acessibilidade */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible{
    outline:2px solid var(--dourado); outline-offset:2px;
}

/* ------------------------------------------------------------------
   BOTÕES
------------------------------------------------------------------ */
.btn{
    display:inline-flex; align-items:center; justify-content:center; gap:10px;
    padding:14px 30px; font-size:13px; letter-spacing:1.5px; text-transform:uppercase;
    font-weight:600; border-radius:var(--raio); transition:var(--transicao);
    border:1px solid transparent; white-space:nowrap;
}
.btn-dourado{ background:var(--dourado); color:var(--preto); }
.btn-dourado:hover{ background:var(--dourado-claro); transform:translateY(-2px); box-shadow:0 8px 20px rgba(201,162,39,.35); }
.btn-outline{ background:transparent; color:var(--branco); border-color:var(--branco); }
.btn-outline:hover{ background:var(--branco); color:var(--preto); }
.btn-outline-dourado{ background:transparent; color:var(--dourado); border-color:var(--dourado); }
.btn-outline-dourado:hover{ background:var(--dourado); color:var(--preto); }
.btn-bloco{ width:100%; }
.btn-sm{ padding:9px 18px; font-size:11px; }
.btn:disabled{ opacity:.5; cursor:not-allowed; }

/* ------------------------------------------------------------------
   TOPO / ANÚNCIO
------------------------------------------------------------------ */
.topo-anuncio{
    background:var(--dourado); color:var(--preto);
    text-align:center; font-size:12.5px; letter-spacing:1px; font-weight:600;
    padding:9px 16px;
}

/* ------------------------------------------------------------------
   CABEÇALHO / NAVEGAÇÃO
------------------------------------------------------------------ */
.cabecalho{
    position:sticky; top:0; z-index:1000;
    background:rgba(15,15,15,.92); backdrop-filter:blur(10px);
    border-bottom:1px solid var(--cinza-borda);
}
.barra-nav{ display:flex; align-items:center; justify-content:space-between; padding:18px 24px; gap:24px; }

.logo{ font-family:var(--fonte-display); font-size:26px; font-weight:700; letter-spacing:1px; color:var(--branco); }
.logo span{ color:var(--dourado); }

.menu-principal{ display:flex; gap:34px; }
.menu-principal a{
    font-size:13px; letter-spacing:1.5px; text-transform:uppercase; font-weight:500;
    color:var(--branco); position:relative; padding:6px 0; transition:color var(--transicao);
}
.menu-principal a::after{
    content:''; position:absolute; left:0; bottom:0; width:0; height:1px; background:var(--dourado);
    transition:width var(--transicao);
}
.menu-principal a:hover{ color:var(--dourado); }
.menu-principal a:hover::after{ width:100%; }

.acoes-cabecalho{ display:flex; align-items:center; gap:20px; }
.acoes-cabecalho a, .acoes-cabecalho button{
    color:var(--branco); font-size:18px; position:relative; transition:color var(--transicao);
    min-width:18px; min-height:18px; display:inline-flex; align-items:center; justify-content:center;
}
.acoes-cabecalho a:hover, .acoes-cabecalho button:hover{ color:var(--dourado); }

.contador-carrinho{
    position:absolute; top:-8px; right:-10px; background:var(--dourado); color:var(--preto);
    font-size:10px; font-weight:700; width:18px; height:18px; border-radius:50%;
    display:flex; align-items:center; justify-content:center; font-family:var(--fonte-corpo);
}

.busca-caixa{ display:flex; align-items:center; background:var(--preto-suave); border:1px solid var(--cinza-borda); border-radius:30px; padding:8px 16px; gap:8px; min-width:230px; }
.busca-caixa input{ background:none; border:none; color:var(--branco); width:100%; font-size:13px; }
.busca-caixa input::placeholder{ color:#777; }
.busca-caixa button{ color:var(--cinza-claro); }

.btn-menu-mobile{ display:none; color:var(--branco); font-size:22px; min-width:24px; min-height:24px; line-height:1; }

/* Menu mobile (drawer) */
.menu-mobile{
    position:fixed; top:0; right:0; width:82%; max-width:340px; height:100%;
    background:var(--preto-suave); z-index:1200; padding:30px 26px;
    transform:translateX(100%); transition:transform .35s ease;
    overflow-y:auto; border-left:1px solid var(--cinza-borda);
}
.menu-mobile.aberto{ transform:translateX(0); }
.menu-mobile a{ display:block; padding:14px 0; font-size:15px; letter-spacing:1px; text-transform:uppercase; border-bottom:1px solid var(--cinza-borda); color:var(--branco); }
.fechar-menu-mobile{ color:var(--branco); font-size:22px; margin-bottom:20px; display:block; }
.overlay-escuro{ position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:1100; display:none; }
.overlay-escuro.ativo{ display:block; }

/* ------------------------------------------------------------------
   BANNER PRINCIPAL (HERO)
------------------------------------------------------------------ */
.hero-slider{ position:relative; height:78vh; min-height:480px; max-height:780px; overflow:hidden; background:var(--preto); }
.hero-slide{
    position:absolute; inset:0; opacity:0; transition:opacity 1s ease; display:flex; align-items:center;
    background-size:cover; background-position:center;
}
.hero-slide.ativo{ opacity:1; }
.hero-slide::before{ content:''; position:absolute; inset:0; background:linear-gradient(90deg, rgba(15,15,15,.92) 10%, rgba(15,15,15,.45) 60%, rgba(15,15,15,.15) 100%); }
.hero-conteudo{ position:relative; z-index:2; max-width:560px; padding:0 24px 0 60px; }
.hero-conteudo .eyebrow{ color:var(--dourado); }
.hero-conteudo h1{ font-size:clamp(34px,5.5vw,64px); color:var(--branco); line-height:1.1; margin-bottom:18px; }
.hero-conteudo p{ color:var(--cinza-claro); font-size:16px; margin-bottom:30px; max-width:420px; }

.hero-dots{ position:absolute; bottom:30px; left:60px; z-index:3; display:flex; gap:10px; }
.hero-dots button{ width:34px; height:3px; background:rgba(255,255,255,.35); transition:var(--transicao); }
.hero-dots button.ativo{ background:var(--dourado); }
.hero-setas{ position:absolute; bottom:26px; right:60px; z-index:3; display:flex; gap:10px; }
.hero-setas button{ width:42px; height:42px; border:1px solid rgba(255,255,255,.4); border-radius:50%; color:var(--branco); display:flex; align-items:center; justify-content:center; transition:var(--transicao); }
.hero-setas button:hover{ border-color:var(--dourado); color:var(--dourado); }

/* ------------------------------------------------------------------
   CATEGORIAS (HOME)
------------------------------------------------------------------ */
.secao{ padding:80px 0; }
.secao-suave{ background:var(--preto-suave); }

.grade-categorias{ display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }
.cartao-categoria{
    position:relative; aspect-ratio:3/4; border-radius:var(--raio); overflow:hidden;
    background:linear-gradient(160deg, var(--preto-card), #232323);
    border:1px solid var(--cinza-borda); display:flex; align-items:flex-end; padding:22px;
    transition:var(--transicao);
}
.cartao-categoria::before{
    content:''; position:absolute; top:16px; right:16px; width:30px; height:30px;
    border-top:1px solid var(--dourado); border-right:1px solid var(--dourado); opacity:0; transition:var(--transicao);
}
.cartao-categoria:hover{ transform:translateY(-6px); border-color:var(--dourado); }
.cartao-categoria:hover::before{ opacity:1; }
.cartao-categoria i{ font-size:30px; color:var(--dourado); position:absolute; top:24px; left:22px; }
.cartao-categoria span{ font-family:var(--fonte-display); font-size:19px; color:var(--branco); position:relative; z-index:2; }

/* ------------------------------------------------------------------
   CARDS DE PRODUTO (grid catálogo / destaques)
------------------------------------------------------------------ */
.grade-produtos{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px 22px; }

.cartao-produto{ position:relative; background:var(--preto-card); border:1px solid var(--cinza-borda); border-radius:var(--raio); overflow:hidden; transition:var(--transicao); }
.cartao-produto:hover{ box-shadow:var(--sombra); transform:translateY(-4px); }

.cartao-produto .moldura-img{ position:relative; aspect-ratio:3/4; overflow:hidden; background:#202020; }
.cartao-produto .moldura-img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.cartao-produto:hover .moldura-img img{ transform:scale(1.07); }

/* Cantos dourados — elemento de assinatura visual */
.cartao-produto .canto{ position:absolute; width:22px; height:22px; opacity:0; transition:var(--transicao); z-index:3; }
.cartao-produto .canto.tl{ top:10px; left:10px; border-top:2px solid var(--dourado); border-left:2px solid var(--dourado); }
.cartao-produto .canto.br{ bottom:10px; right:10px; border-bottom:2px solid var(--dourado); border-right:2px solid var(--dourado); }
.cartao-produto:hover .canto{ opacity:1; }

.etiqueta{ position:absolute; top:12px; left:12px; z-index:4; background:var(--dourado); color:var(--preto); font-size:11px; font-weight:700; letter-spacing:.5px; padding:4px 10px; border-radius:2px; }
.etiqueta.nova{ background:var(--branco); }
.etiqueta.esgotado{ background:#444; color:#aaa; }

.acao-rapida{ position:absolute; right:12px; top:12px; z-index:4; display:flex; flex-direction:column; gap:8px; opacity:0; transform:translateX(8px); transition:var(--transicao); }
.cartao-produto:hover .acao-rapida{ opacity:1; transform:translateX(0); }
.acao-rapida button, .acao-rapida a{ width:36px; height:36px; background:rgba(15,15,15,.85); border:1px solid var(--cinza-borda); color:var(--branco); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:14px; transition:var(--transicao); }
.acao-rapida button:hover, .acao-rapida a:hover{ background:var(--dourado); color:var(--preto); border-color:var(--dourado); }

.info-produto{ padding:18px; }
.info-produto .categoria-mini{ font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--dourado); margin-bottom:6px; display:block; }
.info-produto h3{ font-family:var(--fonte-corpo); font-weight:500; font-size:14.5px; color:var(--branco); margin-bottom:8px; min-height:38px; }
.info-produto h3 a:hover{ color:var(--dourado); }
.faixa-preco{ display:flex; align-items:baseline; gap:8px; }
.preco-atual{ font-family:var(--fonte-display); font-size:18px; color:var(--dourado); font-weight:600; }
.preco-antigo{ font-size:13px; color:#777; text-decoration:line-through; }
.badge-desconto{ font-size:11px; color:var(--verde); font-weight:600; margin-left:auto; }
.avaliacao-mini{ display:flex; gap:3px; color:var(--dourado); font-size:11px; margin-top:6px; }

.btn-add-carrinho{ width:100%; margin-top:14px; padding:10px; background:transparent; border:1px solid var(--cinza-borda); color:var(--branco); font-size:11.5px; letter-spacing:1px; text-transform:uppercase; border-radius:var(--raio); transition:var(--transicao); }
.btn-add-carrinho:hover{ background:var(--dourado); border-color:var(--dourado); color:var(--preto); }

/* ------------------------------------------------------------------
   FAIXA DE BENEFÍCIOS
------------------------------------------------------------------ */
.faixa-beneficios{ display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--cinza-borda); border-bottom:1px solid var(--cinza-borda); }
.item-beneficio{ display:flex; align-items:center; gap:14px; padding:26px 22px; border-right:1px solid var(--cinza-borda); }
.item-beneficio:last-child{ border-right:none; }
.item-beneficio i{ font-size:24px; color:var(--dourado); }
.item-beneficio strong{ display:block; font-size:13.5px; color:var(--branco); }
.item-beneficio span{ font-size:12px; color:var(--cinza-claro); }

/* ------------------------------------------------------------------
   PROMO / NEWSLETTER
------------------------------------------------------------------ */
.faixa-promo{ background:linear-gradient(135deg, var(--preto-suave), var(--preto)); border:1px solid var(--dourado-escuro); border-radius:4px; padding:54px; text-align:center; position:relative; overflow:hidden; }
.faixa-promo h2{ font-size:clamp(24px,3.4vw,36px); margin-bottom:12px; }
.faixa-promo p{ color:var(--cinza-claro); margin-bottom:26px; }
.faixa-promo .contador{ display:flex; justify-content:center; gap:18px; margin-bottom:30px; }
.faixa-promo .contador div{ background:var(--preto-card); border:1px solid var(--cinza-borda); padding:14px 18px; border-radius:4px; min-width:70px; }
.faixa-promo .contador strong{ display:block; font-size:24px; color:var(--dourado); font-family:var(--fonte-display); }
.faixa-promo .contador span{ font-size:10px; letter-spacing:1px; text-transform:uppercase; color:var(--cinza-claro); }

/* ------------------------------------------------------------------
   AVALIAÇÕES
------------------------------------------------------------------ */
.grade-avaliacoes{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.cartao-avaliacao{ background:var(--preto-card); border:1px solid var(--cinza-borda); border-radius:4px; padding:26px; }
.cartao-avaliacao .estrelas{ color:var(--dourado); font-size:13px; margin-bottom:14px; }
.cartao-avaliacao p{ color:var(--cinza-claro); font-size:14px; margin-bottom:18px; font-style:italic; }
.cartao-avaliacao .autor{ display:flex; align-items:center; gap:12px; }
.cartao-avaliacao .avatar{ width:38px; height:38px; border-radius:50%; background:var(--dourado); color:var(--preto); display:flex; align-items:center; justify-content:center; font-weight:700; font-family:var(--fonte-display); }
.cartao-avaliacao .autor strong{ font-size:13.5px; display:block; }
.cartao-avaliacao .autor span{ font-size:11.5px; color:#888; }

/* ------------------------------------------------------------------
   INSTAGRAM
------------------------------------------------------------------ */
.grade-instagram{ display:grid; grid-template-columns:repeat(6,1fr); gap:6px; }
.item-instagram{ position:relative; aspect-ratio:1/1; overflow:hidden; }
.item-instagram img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.item-instagram::after{ content:'\f16d'; font-family:'Font Awesome 6 Brands'; position:absolute; inset:0; background:rgba(201,162,39,.0); color:#fff; display:flex; align-items:center; justify-content:center; font-size:22px; opacity:0; transition:var(--transicao); }
.item-instagram:hover::after{ opacity:1; background:rgba(201,162,39,.55); }
.item-instagram:hover img{ transform:scale(1.1); }

/* ------------------------------------------------------------------
   RODAPÉ
------------------------------------------------------------------ */
.rodape{ background:#000; border-top:1px solid var(--cinza-borda); padding:70px 0 0; }
.rodape-grade{ display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr; gap:40px; padding-bottom:50px; }
.rodape h4{ font-size:14px; letter-spacing:1.5px; text-transform:uppercase; color:var(--dourado); margin-bottom:20px; font-family:var(--fonte-corpo); font-weight:600; }
.rodape p{ color:var(--cinza-claro); font-size:13.5px; line-height:1.8; }
.rodape ul li{ margin-bottom:11px; }
.rodape ul li a{ color:var(--cinza-claro); font-size:13.5px; transition:var(--transicao); }
.rodape ul li a:hover{ color:var(--dourado); padding-left:4px; }
.rodape-social{ display:flex; gap:12px; margin-top:18px; }
.rodape-social a{ width:36px; height:36px; border:1px solid var(--cinza-borda); border-radius:50%; display:flex; align-items:center; justify-content:center; transition:var(--transicao); }
.rodape-social a:hover{ background:var(--dourado); border-color:var(--dourado); color:var(--preto); }
.rodape-form{ display:flex; margin-top:6px; border:1px solid var(--cinza-borda); border-radius:30px; overflow:hidden; }
.rodape-form input{ flex:1; background:none; border:none; padding:12px 16px; color:#fff; font-size:13px; }
.rodape-form button{ background:var(--dourado); color:var(--preto); padding:0 18px; }
.rodape-base{ border-top:1px solid var(--cinza-borda); padding:20px 0; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px; }
.rodape-base p{ color:#777; font-size:12px; }
.bandeiras{ display:flex; gap:8px; font-size:24px; color:#666; }

/* ------------------------------------------------------------------
   BREADCRUMB
------------------------------------------------------------------ */
.trilha{ padding:18px 0; font-size:12.5px; color:#888; }
.trilha a{ color:#888; }
.trilha a:hover{ color:var(--dourado); }
.trilha span{ color:var(--dourado); }

/* ------------------------------------------------------------------
   CATÁLOGO / FILTROS
------------------------------------------------------------------ */
.layout-catalogo{ display:grid; grid-template-columns:260px 1fr; gap:40px; align-items:flex-start; }

.painel-filtros{ background:var(--preto-card); border:1px solid var(--cinza-borda); border-radius:4px; padding:24px; position:sticky; top:100px; }
.fechar-painel-filtros{ display:none; }
.grupo-filtro{ border-bottom:1px solid var(--cinza-borda); padding-bottom:18px; margin-bottom:18px; }
.grupo-filtro:last-child{ border-bottom:none; margin-bottom:0; }
.grupo-filtro h5{ font-size:13px; letter-spacing:1px; text-transform:uppercase; margin-bottom:14px; color:var(--branco); font-family:var(--fonte-corpo); font-weight:600; }
.opcao-filtro{ display:flex; align-items:center; gap:9px; margin-bottom:10px; font-size:13.5px; color:var(--cinza-claro); cursor:pointer; }
.opcao-filtro input{ accent-color:var(--dourado); width:15px; height:15px; }
.opcao-filtro:hover{ color:var(--branco); }

.swatch-cores{ display:flex; flex-wrap:wrap; gap:8px; }
.swatch-cor{ width:26px; height:26px; border-radius:50%; border:2px solid transparent; cursor:pointer; position:relative; box-shadow:0 0 0 1px var(--cinza-borda); }
.swatch-cor.selecionado{ border-color:var(--dourado); }
.swatch-cor input{ position:absolute; opacity:0; inset:0; cursor:pointer; }

.tags-tamanho{ display:flex; flex-wrap:wrap; gap:8px; }
.tag-tamanho{ border:1px solid var(--cinza-borda); padding:6px 12px; font-size:12.5px; border-radius:3px; cursor:pointer; color:var(--cinza-claro); position:relative; }
.tag-tamanho input{ position:absolute; opacity:0; inset:0; cursor:pointer; }
.tag-tamanho.selecionado{ border-color:var(--dourado); color:var(--dourado); }

.faixa-preco-slider{ padding:6px 0; }
.faixa-preco-slider input[type=range]{ width:100%; accent-color:var(--dourado); }
.valores-preco{ display:flex; justify-content:space-between; font-size:12.5px; color:var(--cinza-claro); margin-top:6px; }

.barra-resultados{ display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; flex-wrap:wrap; gap:14px; }
.barra-resultados p{ color:var(--cinza-claro); font-size:13.5px; }
.select-ordenar{ background:var(--preto-card); border:1px solid var(--cinza-borda); color:var(--branco); padding:10px 14px; border-radius:3px; font-size:13px; }

.btn-filtros-mobile{ display:none; }

/* Paginação */
.paginacao{ display:flex; justify-content:center; gap:8px; margin-top:50px; }
.paginacao a, .paginacao span{ width:38px; height:38px; display:flex; align-items:center; justify-content:center; border:1px solid var(--cinza-borda); border-radius:3px; font-size:13px; color:var(--cinza-claro); }
.paginacao a:hover{ border-color:var(--dourado); color:var(--dourado); }
.paginacao .ativa{ background:var(--dourado); color:var(--preto); border-color:var(--dourado); }

/* ------------------------------------------------------------------
   PÁGINA DE PRODUTO
------------------------------------------------------------------ */
.layout-produto{ display:grid; grid-template-columns:1fr 1fr; gap:54px; }

.galeria-produto{ display:flex; gap:14px; min-width:0; }
.miniaturas-produto{ display:flex; flex-direction:column; gap:10px; width:80px; flex-shrink:0; }
.miniaturas-produto img{ aspect-ratio:1/1; object-fit:cover; border:1px solid var(--cinza-borda); border-radius:3px; cursor:pointer; transition:var(--transicao); }
.miniaturas-produto img.ativa{ border-color:var(--dourado); }
.imagem-principal-zoom{ flex:1; min-width:0; position:relative; overflow:hidden; border-radius:4px; border:1px solid var(--cinza-borda); aspect-ratio:3/4; cursor:zoom-in; background:#1c1c1c; }
.imagem-principal-zoom img{ width:100%; height:100%; object-fit:cover; transition:transform .25s; transform-origin:center; }

.info-produto-detalhe .categoria-mini{ font-size:12px; letter-spacing:2px; text-transform:uppercase; color:var(--dourado); }
.info-produto-detalhe h1{ font-size:30px; margin:10px 0 14px; }
.info-produto-detalhe .estrelas-avaliacao{ display:flex; align-items:center; gap:10px; margin-bottom:18px; color:var(--dourado); font-size:13px; }
.info-produto-detalhe .estrelas-avaliacao span{ color:var(--cinza-claro); }
.preco-grande{ display:flex; align-items:baseline; gap:14px; margin-bottom:22px; }
.preco-grande .atual{ font-family:var(--fonte-display); font-size:32px; color:var(--dourado); }
.preco-grande .antigo{ font-size:18px; color:#777; text-decoration:line-through; }
.descricao-curta-produto{ color:var(--cinza-claro); font-size:14.5px; line-height:1.8; margin-bottom:26px; padding-bottom:26px; border-bottom:1px solid var(--cinza-borda); }

.seletor-opcao{ margin-bottom:22px; }
.seletor-opcao label{ display:block; font-size:12.5px; letter-spacing:1px; text-transform:uppercase; margin-bottom:10px; color:var(--branco); }
.seletor-opcao .valor-selecionado{ color:var(--dourado); font-weight:500; text-transform:none; }

.linha-quantidade{ display:flex; align-items:center; gap:18px; margin-bottom:26px; }
.controle-qtd{ display:flex; align-items:center; border:1px solid var(--cinza-borda); border-radius:3px; }
.controle-qtd button{ width:42px; height:44px; color:var(--branco); font-size:16px; }
.controle-qtd button:hover{ color:var(--dourado); }
.controle-qtd input{ width:48px; text-align:center; background:none; border:none; color:var(--branco); font-size:14px; }
.aviso-estoque{ font-size:12.5px; color:var(--verde); }
.aviso-estoque.baixo{ color:var(--dourado); }
.aviso-estoque.esgotado{ color:var(--vermelho); }

.linha-acoes-produto{ display:flex; gap:14px; margin-bottom:30px; }
.linha-acoes-produto .btn{ flex:1; }

.lista-info-extra{ display:flex; flex-direction:column; gap:12px; font-size:13px; color:var(--cinza-claro); }
.lista-info-extra li{ display:flex; align-items:center; gap:10px; }
.lista-info-extra i{ color:var(--dourado); width:16px; }

/* Tabela de tamanhos (modal) */
.tabela-tamanhos{ width:100%; border-collapse:collapse; font-size:13px; margin-top:10px; }
.tabela-tamanhos th, .tabela-tamanhos td{ border:1px solid var(--cinza-borda); padding:9px 12px; text-align:center; color:var(--cinza-claro); }
.tabela-tamanhos th{ color:var(--dourado); background:var(--preto-suave); }
.link-tabela-tamanhos{ font-size:12.5px; color:var(--dourado); text-decoration:underline; cursor:pointer; margin-top:8px; display:inline-block; }

/* Abas (descrição completa / avaliações) */
.abas-produto{ margin-top:70px; }
.botoes-aba{ display:flex; gap:6px; border-bottom:1px solid var(--cinza-borda); margin-bottom:30px; }
.botao-aba{ padding:14px 26px; font-size:13px; letter-spacing:1px; text-transform:uppercase; color:var(--cinza-claro); border-bottom:2px solid transparent; }
.botao-aba.ativa{ color:var(--dourado); border-color:var(--dourado); }
.conteudo-aba{ display:none; color:var(--cinza-claro); font-size:14.5px; line-height:1.9; }
.conteudo-aba.ativa{ display:block; }

/* Modal genérico */
.modal-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.75); z-index:2000; display:none; align-items:center; justify-content:center; padding:20px; }
.modal-overlay.ativo{ display:flex; }
.modal-caixa{ background:var(--preto-card); border:1px solid var(--cinza-borda); border-radius:6px; max-width:480px; width:100%; padding:30px; position:relative; max-height:85vh; overflow-y:auto; }
.modal-fechar{ position:absolute; top:16px; right:16px; color:var(--cinza-claro); font-size:18px; }
.modal-fechar:hover{ color:var(--dourado); }

/* ------------------------------------------------------------------
   CARRINHO
------------------------------------------------------------------ */
.layout-carrinho{ display:grid; grid-template-columns:1fr 380px; gap:40px; align-items:flex-start; }
.tabela-carrinho{ width:100%; border-collapse:collapse; }
.tabela-carrinho th{ text-align:left; font-size:11.5px; letter-spacing:1px; text-transform:uppercase; color:var(--cinza-claro); padding-bottom:16px; border-bottom:1px solid var(--cinza-borda); }
.tabela-carrinho td{ padding:20px 10px; border-bottom:1px solid var(--cinza-borda); vertical-align:middle; }
.item-carrinho-info{ display:flex; gap:16px; align-items:center; }
.item-carrinho-info img{ width:80px; height:100px; object-fit:cover; border-radius:3px; }
.item-carrinho-info h4{ font-size:14.5px; font-weight:500; margin-bottom:6px; }
.item-carrinho-info span{ font-size:12.5px; color:var(--cinza-claro); display:block; }
.remover-item{ color:#888; font-size:16px; }
.remover-item:hover{ color:var(--vermelho); }
.preco-item-carrinho{ color:var(--dourado); font-family:var(--fonte-display); }

.caixa-resumo{ background:var(--preto-card); border:1px solid var(--cinza-borda); border-radius:4px; padding:28px; position:sticky; top:100px; }
.caixa-resumo h3{ font-size:18px; margin-bottom:22px; }
.linha-resumo{ display:flex; justify-content:space-between; margin-bottom:14px; font-size:14px; color:var(--cinza-claro); }
.linha-resumo strong{ color:var(--branco); }
.linha-resumo.total{ font-size:18px; padding-top:16px; border-top:1px solid var(--cinza-borda); margin-top:16px; }
.linha-resumo.total strong{ color:var(--dourado); font-family:var(--fonte-display); font-size:22px; }
.caixa-cupom{ display:flex; gap:8px; margin:20px 0; }
.caixa-cupom input{ flex:1; background:var(--preto-suave); border:1px solid var(--cinza-borda); padding:11px 14px; color:#fff; border-radius:3px; font-size:13px; }
.msg-cupom{ font-size:12.5px; margin-top:8px; }
.msg-cupom.sucesso{ color:var(--verde); }
.msg-cupom.erro{ color:var(--vermelho); }
.carrinho-vazio{ text-align:center; padding:100px 20px; }
.carrinho-vazio i{ font-size:60px; color:var(--cinza-borda); margin-bottom:20px; }
.carrinho-vazio h3{ margin-bottom:10px; }
.carrinho-vazio p{ color:var(--cinza-claro); margin-bottom:26px; }

/* ------------------------------------------------------------------
   CHECKOUT
------------------------------------------------------------------ */
.cartao-form{ background:var(--preto-card); border:1px solid var(--cinza-borda); border-radius:4px; padding:30px; }
.linha-campos{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.campo-form{ margin-bottom:18px; }
.campo-form label{ display:block; font-size:12.5px; letter-spacing:.5px; text-transform:uppercase; margin-bottom:8px; color:var(--cinza-claro); }
.campo-form input, .campo-form select, .campo-form textarea{
    width:100%; background:var(--preto-suave); border:1px solid var(--cinza-borda); padding:13px 16px;
    color:#fff; border-radius:3px; font-size:14px; transition:var(--transicao);
}
.campo-form input:focus, .campo-form select:focus, .campo-form textarea:focus{ border-color:var(--dourado); }
.campo-form .erro-campo{ color:var(--vermelho); font-size:12px; margin-top:6px; display:none; }

.resumo-pedido-checkout{ background:var(--preto-card); border:1px solid var(--cinza-borda); border-radius:4px; padding:28px; position:sticky; top:100px; }
.mini-item-pedido{ display:flex; gap:12px; margin-bottom:16px; align-items:center; }
.mini-item-pedido img{ width:54px; height:68px; object-fit:cover; border-radius:3px; }
.mini-item-pedido .info{ flex:1; }
.mini-item-pedido h5{ font-size:13px; font-weight:500; }
.mini-item-pedido span{ font-size:11.5px; color:var(--cinza-claro); }

.icone-whatsapp-flutuante{ position:fixed; bottom:26px; right:26px; width:58px; height:58px; background:#25D366; color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:26px; box-shadow:0 6px 20px rgba(0,0,0,.4); z-index:900; transition:var(--transicao); }
.icone-whatsapp-flutuante:hover{ transform:scale(1.08); }

/* ------------------------------------------------------------------
   PÁGINAS DE CONTEÚDO (login cliente, etc.)
------------------------------------------------------------------ */
.pagina-auth{ min-height:80vh; display:flex; align-items:center; justify-content:center; padding:60px 20px; }
.caixa-auth{ background:var(--preto-card); border:1px solid var(--cinza-borda); border-radius:6px; padding:46px; max-width:420px; width:100%; }
.caixa-auth h2{ text-align:center; margin-bottom:8px; }
.caixa-auth p.sub{ text-align:center; color:var(--cinza-claro); font-size:13.5px; margin-bottom:30px; }

/* ------------------------------------------------------------------
   ALERTAS
------------------------------------------------------------------ */
.alerta{ padding:14px 18px; border-radius:4px; font-size:13.5px; margin-bottom:20px; border-left:3px solid; }
.alerta-sucesso{ background:rgba(63,167,106,.1); border-color:var(--verde); color:#9fe3bb; }
.alerta-erro{ background:rgba(192,57,43,.1); border-color:var(--vermelho); color:#f3b3ad; }
.alerta-info{ background:rgba(201,162,39,.1); border-color:var(--dourado); color:var(--dourado-claro); }

/* ------------------------------------------------------------------
   ANIMAÇÕES
------------------------------------------------------------------ */
@keyframes fadeUp{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:translateY(0); } }
.fade-up{ animation:fadeUp .6s ease both; }
.toast{ position:fixed; bottom:26px; left:50%; transform:translateX(-50%) translateY(20px); background:var(--dourado); color:var(--preto); padding:14px 26px; border-radius:30px; font-size:13.5px; font-weight:600; z-index:3000; opacity:0; transition:.35s; pointer-events:none; box-shadow:0 8px 24px rgba(0,0,0,.4); }
.toast.mostrar{ opacity:1; transform:translateX(-50%) translateY(0); }

/* ==================================================================
   RESPONSIVO
   ================================================================== */
@media (max-width: 1100px){
    .grade-produtos{ grid-template-columns:repeat(3,1fr); }
    .grade-categorias{ grid-template-columns:repeat(3,1fr); }
    .rodape-grade{ grid-template-columns:1fr 1fr; gap:34px; }
    .grade-instagram{ grid-template-columns:repeat(4,1fr); }
    .menu-principal{ display:none; }
    .btn-menu-mobile{ display:block; }
    .busca-caixa{ display:none; }
}

@media (max-width: 980px){
    .layout-catalogo{ grid-template-columns:1fr; }
    .painel-filtros{ position:fixed; top:0; left:0; width:85%; max-width:340px; height:100%; z-index:1300; border-radius:0; overflow-y:auto; transform:translateX(-100%); transition:transform .35s ease; }
    .painel-filtros.aberto{ transform:translateX(0); }
    .fechar-painel-filtros{ display:block; }
    .btn-filtros-mobile{ display:inline-flex; }
    .layout-produto{ grid-template-columns:1fr; gap:34px; }
    .galeria-produto{ flex-direction:column-reverse; }
    .miniaturas-produto{ flex-direction:row; width:100%; overflow-x:auto; flex-shrink:0; }
    .miniaturas-produto img{ width:64px; flex-shrink:0; }
    .layout-carrinho{ grid-template-columns:1fr; }
    .faixa-beneficios{ grid-template-columns:repeat(2,1fr); }
    .item-beneficio:nth-child(2){ border-right:none; }
    .grade-avaliacoes{ grid-template-columns:1fr; }
}

@media (max-width: 768px){
    .grade-produtos{ grid-template-columns:repeat(2,1fr); gap:16px 12px; }
    .grade-categorias{ grid-template-columns:repeat(2,1fr); }
    .hero-conteudo{ padding-left:24px; }
    .hero-conteudo h1{ font-size:34px; }
    .hero-setas{ display:none; }
    .rodape-grade{ grid-template-columns:1fr; gap:30px; padding-bottom:30px; }
    .grade-instagram{ grid-template-columns:repeat(3,1fr); }
    .linha-campos{ grid-template-columns:1fr; }
    .secao{ padding:50px 0; }
    .titulo-secao{ font-size:26px; }
    .faixa-promo{ padding:34px 20px; }
    .faixa-promo .contador{ gap:10px; }
    .faixa-promo .contador div{ padding:10px 12px; min-width:56px; }
}

@media (max-width: 480px){
    .grade-produtos{ grid-template-columns:repeat(2,1fr); gap:12px 10px; }
    .info-produto{ padding:12px; }
    .preco-atual{ font-size:15px; }
    .container{ padding:0 16px; }
    .barra-nav{ padding:14px 16px; }
    .logo{ font-size:21px; }
    .grade-instagram{ grid-template-columns:repeat(3,1fr); }
}
