/* ==========================
   CONTEÚDO DO PAINEL
========================== */
.painel-conteudo{
    width:90%;
    max-width:1100px;
    max-height:90vh;

    background:#fff;

    border-radius:25px;

    display:flex;
    align-items:flex-start; /* ALTERADO */
    gap:30px;

    padding:30px;

    position:relative;

    overflow-y:auto;

    transform:translateY(50px);
    transition:0.4s ease;
}

/* ==========================
   INFORMAÇÕES
========================== */
.info-produto{
    flex:1;

    display:flex;
    flex-direction:column;

    justify-content:flex-start; /* ALTERADO */
    align-items:flex-start;

    text-align:left;

    gap:8px;
	  
}

/* ==========================
   TÍTULO
========================== */
.info-produto h2{
    font-size:34px;
    margin:0 0 8px 0;

    color:#111827;

    line-height:1.1;

    text-align:left;

    position:relative;
    top:-40px;
}

/* ==========================
   SUBTÍTULO
========================== */
.info-produto h3{
    margin:10px 0 5px 0;

    font-size:20px;

    color:#111827;
}

/* ==========================
   PREÇO
========================== */
.preco{
    font-size:30px;
    color:#dc2626;

    font-weight:bold;

    margin:0 0 15px 0;
}

/* ==========================
   DESCRIÇÃO
========================== */
.descricao{
    color:#555;

    line-height:1.5;

    margin-top:-40px;
    margin-bottom:0;

    padding:0;

    text-align:justify;
}
/* ==========================
   LISTA
========================== */
.info-produto ul{
    list-style:none;

    padding:0;

    margin:10px 0 15px 0;

    width:100%;
}

.info-produto ul li{
    padding:0;

    margin-bottom:4px;

    color:#222;

    text-align:left;
}











/* BOTÃO */
.btn-comprar{
   
    
	padding:15px 35px;

    border:none;

    border-radius:50px;

    background:linear-gradient(135deg,#fff,#fff);

    color:#fff;

    font-size:17px;
    font-weight:bold;

    cursor:pointer;

    transition:0.3s;

    width:auto; /* NÃO ESTICAR */
}







/* PAINEL */
.painel-produto{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:100vh;
    background:rgba(0,0,0,0.7);

    display:flex;
    justify-content:center;
    align-items:center;

    opacity:0;
    visibility:hidden;

    transition:0.4s ease;
    z-index:9999;
}

/* ABRIR PAINEL */
.painel-produto.ativo{
    opacity:1;
    visibility:visible;
}

/* CONTEÚDO */
.painel-conteudo{
    width:90%;
    max-width:1100px;
    background:#fff;
    border-radius:25px;
    overflow:hidden;

    display:flex;
    gap:30px;

    padding:30px;
    position:relative;

    transform:translateY(50px);
    transition:0.4s ease;
}

/* ANIMAÇÃO */
.painel-produto.ativo .painel-conteudo{
    transform:translateY(0);
}

/* FECHAR */

.fecharPainel{
    position:absolute !important;
    top:15px;
    right:15px;

    width:40px !important;
    height:40px !important;

    min-width:40px !important;
    max-width:40px !important;

    border:none;
    border-radius:50% !important;

    background:#333 !important;
    color:#fff !important;

    font-size:26px;
    font-weight:bold;
    line-height:40px;

    cursor:pointer;

    padding:0 !important;
    margin:0 !important;

    z-index:99999;
}

.painel-conteudo{
    position:relative;
}






/* GALERIA */
.galeria-produto{
    flex:1;

    display:flex;
    align-items:flex-start;
    gap:20px;
}

/* ÁREA IMAGEM */
.area-imagem{
    flex:1;

    display:flex;
    justify-content:center;
    align-items:center;

    position:relative;
}

/* IMAGEM PRINCIPAL */
.imagem-principal{
    width:100% !important;
    max-width:450px;

    height:420px !important;

    object-fit:cover;

    border-radius:20px;
}

/* MINIATURAS */
.miniaturas{
    display:flex;
    flex-direction:column;

    gap:12px;
}

/* MINIATURAS IMG */
.miniaturas img{
    width:85px;
    height:85px;

    object-fit:cover;

    border-radius:12px;

    cursor:pointer;

    transition:0.3s;
}

.miniaturas img:hover{
    transform:scale(1.05);
}

/* FECHAR */
.fechar-painel{
    position:absolute;

    top:-10px;
    right:10px;

    font-size:35px;

    cursor:pointer;

    z-index:10;
}


/* ====================================
   TABLET
==================================== */
@media(max-width:991px){

    .galeria-produto{
        flex-direction:column;
        align-items:center;

        width:100%;
    }

    /* garante área da imagem visível */
    .area-imagem{
        width:100%;

        display:flex;
        justify-content:center;
        align-items:center;
    }

    /* imagem principal não pode “sumir” nem ficar sem largura */
    .imagem-principal{
        display:block;

        width:100% !important;
        max-width:100% !important;

        height:320px !important;

        object-fit:cover;

        border-radius:15px;
    }

    /* miniaturas na horizontal */
    .miniaturas{
        flex-direction:row;
        justify-content:center;
        flex-wrap:wrap;

        width:100%;
        margin-top:15px;
    }
}




/* ====================================
   MOBILE
==================================== */
@media(max-width:600px){

    .galeria-produto{
        width:100%;

        display:flex;
        flex-direction:column;

        align-items:center;
    }

    /* ÁREA IMAGEM */
    .area-imagem{
        width:100%;

        display:flex;
        justify-content:center;
    }

    /* IMAGEM PRINCIPAL */
    .imagem-principal{
        display:block;

        width:100% !important;
        max-width:100% !important;

        height:240px !important;

        object-fit:cover;

        border-radius:15px;
    }

    /* MINIATURAS */
    .miniaturas{
        display:flex;

        flex-direction:row;

        justify-content:center;

        flex-wrap:wrap;

        gap:10px;

        width:100%;
    }

    .miniaturas img{
        width:70px;
        height:70px;
    }

    /* CONTEÚDO */
    .painel-conteudo{
        width:95%;
        padding:15px;

        overflow-y:auto;
    }

    /* INFO */
    .info-produto{
        width:100%;
    }

    /* BOTÃO */
    .btn-comprar{
        width:100%;
        max-width:100%;

        box-sizing:border-box;
    }

}







.area-imagem{
    position:relative;
}

.btn-ampliar{
    position:absolute;
    bottom:20px;
    right:20px;

    background:rgba(0,0,0,.8);
    color:#fff;
    border:none;
    padding:10px 18px;
    border-radius:30px;
    cursor:pointer;
    z-index:10;
}

.imagem-principal{
    cursor:zoom-in;
}





.modal-imagem{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:100vh;

    background:rgba(0,0,0,.95);

    display:flex;
    justify-content:center;
    align-items:center;

    opacity:0;
    visibility:hidden;

    transition:.3s;

    z-index:999999;
}

.modal-imagem.ativo{
    opacity:1;
    visibility:visible;
}

#imagemModal{
    max-width:90%;
    max-height:90vh;
    border-radius:15px;
}

.fechar-modal{
    position:absolute;
    top:20px;
    right:30px;

    font-size:50px;
    color:#fff;
    cursor:pointer;
}
