/* public/css/style.css */

/* Configuração das fontes customizadas do Google Fonts */
.font-playfair {
    font-family: 'Playfair Display', serif;
}

.font-lora {
    font-family: 'Lora', serif;
}

/* Aplica a fonte Lora como padrão para o corpo */
body {
    font-family: 'Lora', serif;
    margin: 0;
    padding: 0;
    overflow-x: hidden; /* Evita rolagem horizontal indesejada */
}

/* Estilo para o contêiner da imagem de fundo com overlay */
.background-container {
    position: relative;
    width: 100%;
    min-height: 100vh; /* Garante que o fundo cubra toda a altura da viewport */
    background-image: url('/images/background.jpg'); /* Caminho para a imagem do casal */
    background-size: cover; /* Cobre toda a área, cortando se necessário */
    background-position: center; /* Centraliza a imagem */
    background-attachment: fixed; /* Mantém a imagem fixa ao rolar */
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start; /* Alinha o conteúdo ao topo */
}

/* Overlay para escurecer a imagem de fundo e melhorar a legibilidade */
.background-container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.55); /* Cor preta com 55% de opacidade, um pouco mais escuro */
    z-index: 0; /* Garante que o overlay fique abaixo do conteúdo */
}

/* Estilos para as fotos no feed (removendo gaps) */
#photosFeed {
    padding: 0; /* Remove padding do contêiner da grade */
}

#photosFeed .photo-card {
    background-color: rgba(255, 255, 255, 0.95); /* Fundo branco levemente transparente */
    border-radius: 0; /* Bordas retas para o efeito de grade sem gap */
    box-shadow: none; /* Remove sombra para o efeito de grade sem gap */
    overflow: hidden;
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    margin: 0; /* Garante que não há margem entre os cards */
    border: 1px solid rgba(255, 255, 255, 0.1); /* Borda sutil para separar visualmente */
}

#photosFeed .photo-card:hover {
    transform: scale(1.03); /* Efeito de zoom sutil no hover */
    box-shadow: 0 0 15px rgba(232, 62, 140, 0.4); /* Sombra rosa suave no hover */
    z-index: 1; /* Garante que a foto em hover fique acima das outras */
}

#photosFeed .photo-card img {
    width: 100%;
    height: 250px; /* Altura um pouco maior para as imagens */
    object-fit: cover; /* Garante que a imagem cubra o espaço sem distorcer */
    display: block; /* Remove espaço extra abaixo da imagem */
}

/* Ajustes para o input file, se necessário */
input[type="file"]::-webkit-file-upload-button {
    cursor: pointer;
}

input[type="file"]::file-selector-button {
    cursor: pointer;
}

/* --- Estilos para a legenda do SimpleLightbox (pop-up) --- */

/* Oculta o div da legenda no feed. Ele só será visível quando o SimpleLightbox o renderizar dentro do pop-up. */
/* Usamos 'visibility: hidden' e 'height: 0' para que ele ocupe espaço zero, mas ainda esteja no DOM para o SL. */
/* O 'opacity: 0' é uma camada extra de segurança visual. */
.sl-caption-content {
    visibility: hidden;
    height: 0;
    overflow: hidden;
    opacity: 0;
    /* Adicionamos position: absolute para que ele não afete o layout do <a> no feed */
    position: absolute;
    top: -9999px; /* Move para fora da tela */
    left: -9999px;
}

/* Estilos para o contêiner da legenda do SimpleLightbox (o elemento que o SL cria) */
/* Este é o elemento que o SimpleLightbox usa para exibir a legenda. */
.sl-caption {
    font-family: 'Lora', serif;
    font-size: 1rem;
    color: #fff;
    background-color: rgba(0, 0, 0, 0.7);
    padding: 10px 15px;
    text-align: center;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    box-sizing: border-box;
    line-height: 1.4;
    /* Garante que o .sl-caption esteja visível e acima de tudo */
    z-index: 1040 !important; /* Força a visibilidade e ordem de empilhamento */
    display: block !important; /* Garante que o contêiner da legenda seja exibido */
}

/* Estilo para o nome do convidado dentro da legenda (dentro do .sl-caption) */
/* O SimpleLightbox move o conteúdo do .sl-caption-content para dentro do .sl-caption */
/* Então, os seletores devem ser mais específicos para garantir que os estilos sejam aplicados */
.sl-caption strong {
    font-family: 'Playfair Display', serif;
    color: #e83e8c;
    font-weight: 700;
    display: block;
    margin-bottom: 5px;
}

/* Estilo para o timestamp dentro da legenda (dentro do .sl-caption) */
.sl-caption span {
    font-size: 0.85rem;
    color: #ccc;
    font-style: italic;
    display: block;
}


/* Media Queries para responsividade adicional */
@media (max-width: 640px) {
    .background-container {
        background-attachment: scroll;
    }
    #photosFeed .photo-card img {
        height: 180px;
    }
    #photosFeed {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .sl-caption {
        font-size: 0.9rem;
        padding: 8px 10px;
    }
    .sl-caption strong {
        font-size: 1rem;
    }
    .sl-caption span {
        font-size: 0.75rem;
    }
}

@media (min-width: 641px) and (max-width: 768px) {
    #photosFeed {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
