* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
} /*Estilo básico para o corpo da página */

body {
    font-family: Arial, sans-serif;
    background-color: #f9f9f9;
    color: #333;
    line-height: 1.6;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
} /* Flexbox para layout de coluna e para que o footer fique no final da página */

main {
    flex-grow: 1;
} /* Faz o main crescer para ocupar o espaço disponível */


/* Header */
header {
    flex-wrap: wrap;
    background-color: #CD5B51;
} 

header .logo {
    width: 120px;
    margin-left: 0;
} /* Tamanho do logo */

header input.form-control {
    padding: 6px 10px;
    border: none;
    border-radius: 4px;

} /* Estilo do campo de busca */

header button.btn, .login {
    background-color: #F3A36B;
    color: #ffffff;
    border: none;
    padding: 6px 12px;
    border-radius: 4px;
    cursor: pointer;
    font-weight: bold;
} /* Estilo do botão de busca e cadastro */

header button.btn:hover, .login:hover {
    background-color: #f3a46ba2;
} /* Efeito hover no botão de busca e cadastro */

.navbar-nav .nav-link {
    color: #fff;
    font-weight: 500;
} /* Estilo dos links da navbar */

.navbar-nav .nav-link:hover {
    color: #F3A36B;
    text-decoration: underline;
} /* Efeito hover nos links da navbar */

.login {
  background-color: #F3A36B;
  color: white;
  border: none;
  border-radius: 10px; /* arredondado */
  padding: 8px 16px;
  font-weight: bold;
} /* Estilo do botão de login */

/* Carrossel */
.carousel-caption h5 {
    background-color: rgba(0, 0, 0, 0.418);
    display: inline-block;
    padding: 5px 10px;
    border-radius: 5px;
} /* Fundo semi-transparente para o título do carrossel */

.carousel-inner img {
    width: 100%;
    height: auto;
    max-height: 300px;
    object-fit: contain;
} /* Ajusta o tamanho das imagens do carrossel */

.carousel-inner p {
    color: white;
    background-color: rgba(0, 0, 0, 0.418);
    width: 300px;
    margin: auto;
    border-radius: 5px;
    font-weight: bolder;
} /* Estilo do texto descritivo do carrossel */

.carousel-control-prev-icon,
.carousel-control-next-icon {
    background-size: 100% 100%;
} /* Ajusta o tamanho dos ícones de controle do carrossel */

.carousel-control-prev-icon { 
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='lightslategrey' viewBox='0 0 10 10'%3E%3Cpath d='M3.5 0L4.5 1 1 5 4.5 9 3.5 10 0 5 3.5 0z'/%3E%3C/svg%3E"); 
} /* seta esquerda */ 

.carousel-control-next-icon { 
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='lightslategrey' viewBox='0 0 10 10'%3E%3Cpath d='M6.5 0L5.5 1 9 5 5.5 9 6.5 10 10 5 6.5 0z'/%3E%3C/svg%3E"); 
} /* seta direita */

    .carousel-caption {
    position: static;
    text-align: center;
    margin-top: 5px;
} /* Centraliza a legenda do carrossel */

/* Produtos */
.categoria {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 40px;
    padding: 15px;
    border: 1px solid #ccc;
    justify-content: flex-start;
} /* Flexbox para layout responsivo na seção de produtos*/

.categoria h2 {
    width: 100%;
    margin-bottom: 15px;
    color: #CD5B51;
} /* Estilo do título da categoria */

.categoria .produto {
    flex: 1 1 calc(50% - 20px); /* dois produtos por linha */
    max-width: calc(50% - 20px); 
    padding: 15px;
    border-radius: 10px;
    text-align: center;
    box-sizing: border-box;
    background-color: #fff;
} /* Estilo do container de produtos */

.produto img {
    width: 100%;
    max-width: 200px;
    margin-bottom: 10px;
} /* Tamanho da imagem do produto */

.produto h3 {
    color: #CD5B51;
    margin-bottom: 10px;
} /* Estilo do nome do produto */

.produto p {
    font-weight: bolder;
    margin: 10px 0;
} /* Estilo do preço do produto */

.produto button, .btnw-100 {
    background: #CD5B51;
    color: #ffffff;
    border: none;
    padding: 8px 10px;
    border-radius: 4px;
    cursor: pointer;
    font-weight: bold;
} /* Estilo do botão de compra */

.produto button:hover, .btnw-100:hover {
    background: #CD5B51a2;
} /* Efeito hover no botão de compra */

/* Serviços */

#servicos .servico {
    background-color: #fff;
    border-radius: 10px;
    padding: 20px;
    margin: 10px;
    box-shadow: 0 8px 12px rgba(0, 0, 0, 0.116);
    transition: transform 0.5s, box-shadow 0.3s;
} /* Estilo do container de serviços */

#servicos .servico:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 12px rgba(0,0,0,0.2); 
} /* Efeito hover nos serviços */

#servicos .servico h3 {
    color: #CD5B51;
    margin-bottom: 10px;
} /* Estilo do título do serviço */

#servicos .servico p {
    color: #333;
    font-size: 14px;
    margin-bottom: 5px;
} /* Estilo do texto do serviço */

.btn-custom {
    background-color: #CD5B51;
    color: #fff;
} /* Botão de confirmação do agendamento de serviço */

.btn-custom:hover {
  background-color: #b94a42;
} /* Efeito hover no botão de confirmação do agendamento de serviço */

/* Footer */

footer {
    background-color: black;
    display: flex;
    flex-wrap: wrap;
    padding: 20px;
    justify-content: center;
    gap: 30px;
    color: white;
} /* Flexbox para layout responsivo no footer */

footer a {
    color: darkgrey;
    text-decoration: none;
} /* Estilo dos links do footer */

footer a:hover {
    text-decoration: underline;
    color: #CD5B51;
} /* Efeito hover nos links do footer */

footer h3 {
    color: #CD5B51;
} /* Estilo dos títulos do footer */

.footer-author, .contact-info, .footer-links, .social-media {
    text-align: center;
} /* Centraliza o texto nas seções do footer */

.footer-author {
    width: 100%;
    margin-top: 20px;
} /* Estilo da seção de autoria no footer (para ficar em uma linha sozinho) */

/* Responsividade */

/* tela pequena (celulares) */
@media (max-width: 575px) {
     .carousel-caption h5 {
        font-size: 14px;
        padding: 3px 5px;
    } /* Ajusta o tamanho do título do carrossel em telas pequenas */

    .carousel-caption p {
        font-size: 12px;
        width: 90%;
    } /* Ajusta o tamanho do texto do carrossel em telas pequenas */
    .categoria {
        justify-content: center;
    } /* centraliza se houver 1 produto por linha */

    .categoria .produto {
        flex: 1 1 100%;
        max-width: 100%;
        margin-bottom: 20px;
    } /* um produto por linha */
}

/* Seção de agendamento / Serviços */

main h1 {
    color: #CD5B51;
    text-align: center;
    margin: 30px 0;
    font-size: 32px;
} /* Estilo do título principal */

main form {
    max-width: 500px;
    margin: auto;
    background-color: #fff;
    padding: 30px;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
} /* Estilo do formulário */

main form p {
    font-weight: bold;
    display: block;
    margin-bottom: 5px;
    color: #333;
} /* Estilo dos textos do formulário */

form label {
    display: flex;
    align-items: center;
    margin-right: 15px;
    cursor: pointer;
} /* Estilo dos labels dos radio buttons */

form #retirada + #ret {
    display: inline-flex;
} /* Coloca os radio buttons em linha (retirada) */

form #entrega + #ent {
    display: inline-flex;
} /* Coloca os radio buttons em linha (entrega) */

main form input[type="date"],
main form input[type="time"] {
    width: 100%;
    padding: 8px 10px;
    margin-bottom: 20px;
    border-radius: 5px;
    border: 1px solid #ccc;
    box-sizing: border-box;
} /* Estilo dos campos de data e hora */

main form button {
    background-color: #CD5B51;
    color: #fff;
    border: none;
    padding: 10px 15px;
    border-radius: 5px;
    cursor: pointer;
    font-weight: bold;
    width: 100%;
    transition: background 0.3s;
} /* Estilo do botão de envio */

main form button:hover {
    background-color: #CD5B51a2;
} /* Efeito hover no botão de envio */

/* Responsividade */
@media(max-width: 767px) {
    main form {
        padding: 20px;
    }
}

/* Seção de cadastro de usuários */


main form input.form-control {
  border-radius: 8px;
  border: 1px solid #ccc;
  padding: 8px 10px;
  margin-bottom: 15px;
} /* Estilo para inputs do cadastro */

/* Botão do cadastro */
main form button {
  background-color: #CD5B51;
  color: #fff;
  border: none;
  padding: 10px 15px;
  border-radius: 8px;
  cursor: pointer;
  font-weight: bold;
  transition: background 0.3s;
} /* Estilo do botão do formulário */

main form button:hover {
  background-color: #CD5B51a2;
} /* Efeito hover no botão do formulário */