/* Reset Básico */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Estilo Global para Computadores */
body {
    margin: 0;
    padding: 0;
    width: 100%; /* Largura completa no computador */
    overflow-x: hidden; /* Permite rolagem horizontal */
    font-family: Arial, sans-serif; /* Fonte global */
}

/* Estilo para Telefones */
@media (max-width: 768px) {
    body {
        transform: translateX(10px) scale(0.25); /* Ajusta foco e zoom */
        transform-origin: left top; /* Define o ponto de referência */
        overflow-x: hidden; /* Impede rolagem horizontal */
        width: 1200px; /* Largura fixa lógica */
        max-height: 140vh; /* Limita a altura ao tamanho da viewport */
        margin-top: 0; /* Remove a margem superior */
    }
}

/* Estilo para o vídeo de introdução (mobile) */
#intro-video-mobile {
    display: none; /* Oculta por padrão */
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: black;
    z-index: 1000; /* Garante que fique acima de tudo */
}

#intro-video-mobile video {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Garante que o vídeo cubra toda a tela */
}

/* Exibir o vídeo apenas em dispositivos móveis */
@media (max-width: 768px) {
    #intro-video-mobile {
        display: block;
    }
}

/* Contêiner Principal */
#app {
    display: flex;
    justify-content: center; /* Centraliza horizontalmente */
    align-items: center; /* Centraliza verticalmente */
    height: 100vh; /* Ocupa toda a altura da viewport */
    overflow: hidden; /* Impede rolagem extra */
}

/* Contêiner de Conteúdo */
.content {
    width: 100%; /* Ajusta para preencher o layout */
    max-width: 1200px; /* Garante que não ultrapasse */
    text-align: center; /* Centraliza texto dentro */
    margin: 0 auto; /* Centraliza o contêiner */
}

/* Container Geral */
.container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0;
}

/* Menu e Logo */
header#menu {
    position: relative;
    width: 100%;
    height: auto; 
    /* Mantém esse header sem travar altura */
  }
  
/* Estilo Geral da Barra */
#barra {
    position: fixed; /* Contêiner pai */
    display: flex; /* Ativa Flexbox */
    justify-content: space-between; /* Espaçamento uniforme entre texto e botões */
    align-items: center; /* Centraliza verticalmente */
    width: 100%; /* Ocupa toda a largura */
    background: #ca9662; /* Fundo claro */
    padding: 20px; /* Espaçamento interno */
    height: 200px; /* Altura fixa */
    box-sizing: border-box; /* Inclui padding no cálculo da largura */
}

/* Contêiner Geral da Barra */
#barra {
    position: relative; /* Define o ponto de referência para os elementos absolutos */
    width: 100%; /* Ocupa toda a largura */
    height: 380px; /* Altura fixa */
    background: #a98963; /* Fundo */
    padding: 0px;
    box-sizing: border-box; /* Inclui padding no cálculo de largura */
}

/* Texto "Contactos" */
#barra p {
    font-family: 'Bree Serif', cursive;
    font-size: 3rem;
    font-weight: bold;
    color: #fbfafa;
    margin: 0;
    position: absolute; /* Agora o texto também pode ser posicionado livremente */
    top: 20px; /* Ajuste a posição vertical */
    left: 600px; /* Ajuste a posição horizontal */
}

/* Contêiner dos Botões */
#barra .contacts {
    position: relative; /* Pode ser mantido como referência interna (opcional) */
    width: 100%; /* Ocupa toda a largura */
    height: 100%; /* Ajusta à altura do contêiner */
}

/* Botão de Telefone */
#barra .contacts .phone-btn {
    position: absolute;
    top: 80px; /* Ajuste para cima/baixo */
    left: 47px; /* Ajuste para a direita/esquerda */
}

#barra .contacts .phone-btn img {
    width: 420px; /* Largura do botão */
    height: 120px;
}

/* Botão de Email */
#barra .contacts .email-btn {
    position: absolute;
    top: 270px; /* Ajuste vertical */
    left: 30px; /* Ajuste horizontal */
}

#barra .contacts .email-btn img {
    width: 850px;
    height: 90px;
}

/* Botão de Instagram */
#barra .contacts .instagram-btn {
    position: absolute;
    top: 180px; /* Ajuste vertical */
    left: 40px; /* Ajuste horizontal */
}

#barra .contacts .instagram-btn img {
    width: 610px;
    height: 100px;
}

/* Hover nos Botões */
#barra .contacts a img:hover {
    transform: scale(1.1); /* Efeito de zoom */
    transition: transform 0.3s ease; /* Suaviza o efeito */
}

/* Ajuste de scroll para a seção Contactos */
#barra {
    scroll-margin-top: 120px; /* Ajusta a margem superior para evitar que o menu fixe sobre a seção */
}

.logo {
    position: relative; 
    margin-left: 0px;
}

.logo img {
    width: 320px;
    height: 140px;
}

/* Nav Links */
.nav-links {
    position: absolute; 
    top: 110px;
    left: 70%;
    transform: translateX(-50%);
    display: flex;
    gap: 20px;
    width: auto;
    height: auto;
    overflow: visible; /* Garante que nada seja cortado */
}

.nav-links a {
    text-decoration: none;
    color: black;
    font-size: 2rem;
    transition: color 0.3s;
    font-weight: bold;
}

.nav-links a:hover {
    color: red;
}

/* Seção Hero */
#inicio {
    height: 900px; 
    background: url('images/hero.jpg') no-repeat center center/cover;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Frase de Impacto */
#impacto {
    margin: 0; /* Remove margens externas */
    padding: 0; /* Remove espaçamento interno */
    text-align: center;
    padding: 0px;
    background: #f5f5f5;
}

.barra-cinza {
    background: #f5f5f5; /* Cor da barra cinza */
    height: 120%; /* Altura total da seção */
    width: 100%; /* Largura total da seção */
    position: absolute; /* Posiciona a barra cinza atrás do texto */
    top: 0;
    left: 0;
    z-index: -1; /* Garante que a barra fique atrás do texto */
}

.impact-text {
    font-family:'Times New Roman', cursive;
    font-size: 3rem;
    color: #333;
    font-style: italic;
    margin: 0; /* Remove margens ao redor do texto */
}

/* Seção Sobre */
#sobre {
    position: relative;
    margin-top: 10px; /* Remove margens externas */
    min-height: 1000px;
    background: url('images/sobre-background.jpg') no-repeat center center/cover;
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: -50px; /* Ajuste o valor conforme necessário */
    padding: -50; /* Remove espaçamento interno */
    z-index: 0; /* Garante que fique atrás da barra cinza */
}

/* Animação de entrada */
@keyframes fadeInSlideRight {
    0% {
        opacity: 0; /* Inicia invisível */
        transform: translateX(-20px); /* Desliza 20px para a esquerda */
    }
    100% {
        opacity: 1; /* Torna-se visível */
        transform: translateX(0); /* Retorna à posição original */
    }
}

#portfolio {
    position: relative; /* Permite controle do layout interno */
    width: 120%; /* Garante que o contêiner ocupe toda a largura */
    padding: 90px; /* Adiciona um espaçamento interno */
    left: -170px; /* Move o portfólio 50px para a esquerda */
}

#portfolio h2 {
    font-family: 'Bree Serif', cursive;
    font-size: 3rem;
    text-align: center;
    position: relative; /* Permite ajustar com `left` */
    left: 120px; /* Move o título 20px para a direita */
    margin-bottom: 0px;
    color: rgb(144, 87, 41);
}

.portfolio-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* 2 colunas */
    gap: 20px;
    padding-left: 30px; /* Empurra as colunas para a direita */
    width: 120%; /* Ocupa toda a largura do contêiner */
    box-sizing: border-box; /* Inclui o padding no cálculo da largura */
    margin-bottom: 100px; /* Espaço extra abaixo do portfólio */ 
}

.portfolio-item {
    opacity: 0; /* Invisível inicialmente */
    transform: translateX(-20px); /* Desloca 50px para a esquerda */
    transition: transform 0.8s ease, opacity 0.8s ease; /* Animação suave */
    width: 130%;
    margin-left: 20px; /* Empurra cada caixa 50px para a direita */
    max-width: 590px;
    height: 400px;
    position: relative;
    background-color: #ddd;
    cursor: pointer;
    transition: background-color 0.5s ease;
}

/* Estado quando visível: na posição correta, opacidade total */
.portfolio-item.visible {
    opacity: 1; /* Torna visível */
    animation: fadeInSlideRight 0.8s ease-out forwards; /* Aplica a animação */
}

.portfolio-item span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-family: 'Pinyon Script', cursive;
    font-size: 3rem;
    color: rgb(16, 15, 15);
    z-index: 2;
    text-align: center;
}

.portfolio-item::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    opacity: 0;
    transition: opacity 0.5s ease;
    z-index: 1;
}

/* Exemplos de cores e imagens */
.portfolio-item.despensa { background-color: #a57474; }
.portfolio-item.despensa::before { background-image: url('images/despensa.jpg'); }

.portfolio-item.quarto { background-color: #6f8070; }
.portfolio-item.quarto::before { background-image: url('images/quarto.jpg'); }

.portfolio-item.banheiro { background-color: #a78686; }
.portfolio-item.banheiro::before { background-image: url('images/banheiro.jpg'); }

.portfolio-item.cozinha { background-color: #d6cda8; }
.portfolio-item.cozinha::before { background-image: url('images/cozinha.jpg'); }

.portfolio-item.sala { background-color: #81b8d5; }
.portfolio-item.sala::before { background-image: url('images/sala.jpg'); }

.portfolio-item.guarda-roupa { background-color: #bf90cb; }
.portfolio-item.guarda-roupa::before { background-image: url('images/guarda-roupa.jpg'); }

.portfolio-item:hover::before,
.portfolio-item:focus::before {
    opacity: 1;
}

/* Slider */
.slider {
    width: 100%;
    height: 1200px;
    overflow: hidden;
    position: relative;
    margin: 30px auto;
    margin-left: 150px; /* Move o slider para a direita */
    margin-bottom: -60px; /* Diminui a distância com a imagem abaixo */
}

.slider-content {
    display: flex;
    transition: transform 0.5s ease-in-out;
}

.slider-content img {
    width: 100%;
    height: auto;
    flex-shrink: 0;
    max-height: 600px;
}

.slider h3 {
    font-family: 'Bree Serif', cursive;
    font-size: 3.5rem;
    text-align: center;
    margin-bottom: 0px;
    color:rgb(144, 87, 41);
}

/* Seção Serviços */
#servicos {
    min-height: 900px;
    background: url('images/servicos-background.jpg') no-repeat center center/cover;
    background-size: 100% auto; 
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: -500px; /* Move a seção para cima */
}


/* Seção Investir */
#investir {
    min-height: 950px;
    background: url('images/investimento-agenda.jpg') no-repeat center center/cover;
    background-size: 100% auto; 
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 0px;
    text-align: center;
    color: white;
    margin-top: -10px; /* Remove a margem superior */
    margin-bottom: -50px; /* Remove a margem superior */
}


