/* ------------------- */
/* 1. VARIÁVEIS E BASE */
/* ------------------- */
:root {
    --color-background: #121212;
    --color-surface: #1f1f1f;
    --color-primary-brown: #8a6c52;
    /* Extraído do book */
    --color-text-light: #f5f5f5;
    --color-text-muted: #a0a0a0;
    --color-accent-gold: #c7a475;

    --font-serif: 'Cormorant Garamond', serif;
    --font-sans: 'Montserrat', sans-serif;

    --spacing-xs: 0.5rem;
    --spacing-sm: 1rem;
    --spacing-md: 1.5rem;
    --spacing-lg: 3rem;
    --spacing-xl: 6rem;

    --transition-fast: 0.2s ease-in-out;
    --transition-smooth: 0.4s ease-in-out;
}

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

html {
    scroll-behavior: smooth;
}

body {
    background-color: var(--color-background);
    color: var(--color-text-light);
    font-family: var(--font-sans);
    -webkit-font-smoothing: antialiased;
}

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

img {
    max-width: 100%;
    display: block;
}

.section-title {
    font-family: var(--font-serif);
    font-size: clamp(2.2rem, 5vw, 3.5rem);
    color: var(--color-text-light);
    margin-bottom: var(--spacing-md);
    text-align: center;
}

.section-subtitle {
    font-size: 1.1rem;
    color: var(--color-text-muted);
    max-width: 70ch;
    margin: 0 auto var(--spacing-lg);
    text-align: center;
    line-height: 1.7;
}

.section-text {
    color: var(--color-text-muted);
    line-height: 1.8;
    font-size: 1rem;
}

.section-text:not(:last-child) {
    margin-bottom: var(--spacing-sm);
}

/* ------------------- */
/* 2. ESTILOS DAS SEÇÕES */
/* ------------------- */

/* --- HERO --- */
.hero {
    position: relative;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.hero__video-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.hero__video-wrapper::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
}

.hero__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero__content {
    position: relative;
    z-index: 2;
    max-width: 800px;
    padding: var(--spacing-md);
}

.hero__title {
    font-family: var(--font-serif);
    font-size: clamp(2.8rem, 7vw, 5rem);
    line-height: 1.1;
    margin-bottom: var(--spacing-md);
}

.hero__subtitle {
    font-size: clamp(1rem, 2.5vw, 1.2rem);
    color: var(--color-text-muted);
}

.hero__scroll-down {
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    width: 2px;
    height: 50px;
    background: var(--color-accent-gold);
}

.hero__scroll-down::before {
    content: '';
    position: absolute;
    top: 0;
    left: -4px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--color-accent-gold);
    animation: scroll-anim 2s infinite;
}

@keyframes scroll-anim {
    0% {
        top: 0;
        opacity: 1;
    }

    100% {
        top: 40px;
        opacity: 0;
    }
}

/* --- CURATORSHIP CAPÍTULO II --- */
.curatorship {
    padding: var(--spacing-xl) var(--spacing-md);
    display: grid;
    gap: var(--spacing-lg);
    align-items: center;
}

.curatorship__visual img {
    border-radius: 8px;
}

/* --- NOVO CAPÍTULO III: LIVING SHOWCASE --- */
.living-showcase {
    height: 80vh;
    min-height: 500px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--spacing-md);

    /* A Mágica do Parallax */
    background-image: url('../assets/img/belmonte/belmonte-foto2.webp');
    /* <<-- SUBSTITUIR PELA IMAGEM REAL */
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    background-attachment: fixed;
    /* Isso cria o efeito parallax! */
}

/* Overlay para garantir a legibilidade */
.living-showcase::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.4);
}

.living-showcase__content {
    position: relative;
    z-index: 2;
    max-width: 800px;
}

/* Ajusta as margens dos títulos nesta seção específica */
.living-showcase .section-title {
    margin-bottom: var(--spacing-sm);
    text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.7);
}

.living-showcase .section-subtitle {
    margin-bottom: 0;
    font-size: 1.2rem;
    text-shadow: 1px 1px 8px rgba(0, 0, 0, 0.7);
}

/* --- CAPÍTULO IV: A ARTE DA CHEGADA --- */
.arrival-art {
    padding: var(--spacing-xl) 0;
    /* Padding vertical, sem padding horizontal para o slider vazar */
    background-color: var(--color-surface);
}

.arrival-art video {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 8px;
    margin-bottom: var(--spacing-lg);
}

.arrival-art .container {
    margin-bottom: var(--spacing-lg);
}

.arrival-carousel {
    width: 100%;
    padding: 0 var(--spacing-sm);
    /* Padding para o "peek-a-boo" */
}

.arrival-card {
    position: relative;
    border-radius: 8px;
    overflow: hidden;
    height: 450px;
}

.arrival-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.arrival-card__caption {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: var(--spacing-sm);
    background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent);
    color: var(--color-text-light);
    font-size: 1rem;
}

.arrival-carousel .swiper-pagination {
    position: static;
    /* Coloca a paginação abaixo do slider */
    margin-top: var(--spacing-md);
}

.arrival-carousel .swiper-pagination-bullet {
    background: var(--color-text-muted);
}

.arrival-carousel .swiper-pagination-bullet-active {
    background: var(--color-accent-gold);
}

/* --- FLOORPLANS CAPÍTULO V --- */
.floorplans {
    padding: var(--spacing-xl) var(--spacing-md);
}

.floorplans__selectors {
    text-align: center;
    margin-bottom: var(--spacing-lg);
}

.tower-selector,
.plan-options {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.tower-button,
.plan-button {
    background: transparent;
    border: 1px solid var(--color-primary-brown);
    color: var(--color-primary-brown);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: 20px;
    cursor: pointer;
    transition: var(--transition-fast);
}

.tower-button.is-active,
.plan-button.is-active,
.tower-button:hover,
.plan-button:hover {
    background-color: var(--color-accent-gold);
    border-color: var(--color-accent-gold);
    color: var(--color-background);
}

.floorplans__display {
    display: grid;
    align-items: center;
    gap: var(--spacing-lg);
}

.floorplans__display-image {
    background: var(--color-surface);
    padding: var(--spacing-sm);
    border-radius: 8px;
}

#plan-highlights {
    list-style: none;
    padding-left: var(--spacing-sm);
    border-left: 2px solid var(--color-accent-gold);
}

#plan-highlights li {
    margin-bottom: var(--spacing-xs);
}

/* --- CAPÍTULO VI: GÊNESE DE UMA OBRA-PRIMA --- */
.genesis {
    position: relative;
    padding: var(--spacing-xl) 0 0 0;
    /* Padding apenas no topo, o resto vem da sub-seção */
    background-color: var(--color-background);
    /* Cor de fundo caso o vídeo não carregue */
}

.genesis__video-wrapper {
    position: absolute;
    /* top: 0;
    left: 0; */
    width: 100%;
    height: 60vh;
    /* Altura do vídeo */
    min-height: 400px;
    overflow: hidden;
}

.genesis__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.genesis__content-overlay {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 60vh;
    /* Mesma altura do vídeo */
    min-height: 400px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-color: rgba(18, 18, 18, 0.7);
    /* Overlay escuro */
    padding: var(--spacing-md);
}

.genesis__masters-section {
    position: relative;
    z-index: 2;
    /* Garante que fique acima do vídeo, caso haja sobreposição */
    padding: var(--spacing-xl) 0;
    background-color: var(--color-background);
    /* Fundo sólido para a área do grid */
}

.masters-grid {
    display: grid;
    gap: var(--spacing-md);
    /* Cria colunas responsivas, com no mínimo 250px de largura */
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.master-card-grid {
    background-color: var(--color-surface);
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--color-surface);
}

.master-card-grid img {
    width: 100%;
    height: 280px;
    object-fit: cover;
    filter: grayscale(1);
    /* Deixa as fotos em P&B, como na direção de arte */
    transition: filter var(--transition-smooth);
}

.master-card-grid:hover img {
    filter: grayscale(0);
    /* Revela a cor no hover */
}

.master-card-grid__content {
    padding: var(--spacing-md);
}

.master-card-grid h3 {
    font-family: var(--font-serif);
    font-size: 1.5rem;
    color: var(--color-text-light);
    margin-bottom: var(--spacing-xs);
}

.master-card-grid span {
    display: block;
    font-size: 0.8rem;
    color: var(--color-primary-brown);
    text-transform: uppercase;
    margin-bottom: var(--spacing-sm);
}

.master-card-grid p {
    font-style: italic;
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.6;
}


/* --- AMENITIES CAPÍTULO VII --- */
.amenities {
    padding: var(--spacing-xl) var(--spacing-md);
}

.amenities__grid {
    display: grid;
    gap: var(--spacing-lg);
}

.amenity-card {
    background-color: var(--color-surface);
}

.amenity-card__image-wrapper img {
    width: 100%;
    height: 300px;
    object-fit: cover;
    transition: transform var(--transition-smooth);
}

.amenity-card:hover .amenity-card__image-wrapper img {
    transform: scale(1.05);
}

.amenity-card__content {
    padding: var(--spacing-md);
}

.amenity-card h3 {
    font-family: var(--font-serif);
    color: var(--color-accent-gold);
    font-size: 1.5rem;
    margin-bottom: var(--spacing-sm);
}

/* --- CAPÍTULO VIIi: O ECOSSISTEMA PINHEIROS --- */
.ecosystem {
    padding: var(--spacing-xl) var(--spacing-md);
}

/* --- CAPÍTULO VIII: O ECOSSISTEMA PINHEIROS (MAPA) --- */
.interactive-map {
    width: 100%;
    height: 500px;
    /* Altura do mapa */
    border-radius: 8px;
    border: 1px solid var(--color-surface);
}

/* --- Estilo dos Marcadores Customizados --- */
.mapboxgl-marker.custom-marker {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background-color: var(--color-accent-gold);
    border: 2px solid var(--color-background);
    box-shadow: 0 0 10px var(--color-accent-gold);
    cursor: pointer;
    transition: transform var(--transition-fast);
}

.mapboxgl-marker.custom-marker:hover {
    transform: scale(1.2);
}

.mapboxgl-marker.home-marker {
    /* Marcador do Duni Terraza */
    width: 30px;
    height: 30px;
    background-color: var(--color-text-light);
    box-shadow: 0 0 15px var(--color-text-light);
}

/* --- Estilo do Popup (Tooltip) --- */
.mapboxgl-popup {
    font-family: var(--font-sans);
}

.mapboxgl-popup-content {
    background-color: var(--color-background);
    color: var(--color-text-light);
    padding: 10px 15px;
    border-radius: 4px;
    border: 1px solid var(--color-accent-gold);
    box-shadow: none;
}

.mapboxgl-popup-content h4 {
    margin: 0 0 5px 0;
    font-size: 1rem;
    color: var(--color-accent-gold);
}

.mapboxgl-popup-content p {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
}

.mapboxgl-popup-close-button {
    color: var(--color-text-muted);
}

/* Seta do popup */
.mapboxgl-popup-anchor-top .mapboxgl-popup-tip,
.mapboxgl-popup-anchor-bottom .mapboxgl-popup-tip {
    border-bottom-color: var(--color-accent-gold);
    border-top-color: var(--color-accent-gold);
}

/* --- QUALITY MANIFESTO CAPÍTULO IX --- */
.quality-manifesto {
    padding: var(--spacing-xl) var(--spacing-md);
}

.quality__grid {
    display: grid;
    gap: var(--spacing-md);
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.quality-item {
    background: var(--color-surface);
    padding: var(--spacing-md);
    border-radius: 8px;
    text-align: center;
}

.quality-item span {
    display: block;
    font-weight: 500;
    font-size: 1.1rem;
    margin-bottom: var(--spacing-xs);
}

.quality-item p {
    color: var(--color-text-muted);
    font-size: 0.9rem;
}

.quality-item img {
    /* Estilo para o placeholder [SVG] */
    display: block;
    margin: 0 auto ;
    font-style: normal;
    font-size: 2.5rem;
    color: var(--color-accent-gold);
    margin-bottom: var(--spacing-sm);
    height: 80px;
}

/* --- LEAD FORM --- */
.lead-form-section {
    padding: var(--spacing-xl) var(--spacing-md);
    background-color: var(--color-surface);
}

.lead-form__container {
    display: grid;
    gap: var(--spacing-lg);
    align-items: center;
}

.lead-form {
    display: grid;
    gap: var(--spacing-md);
}

.form-group label {
    display: block;
    font-size: 0.8rem;
    margin-bottom: var(--spacing-xs);
    color: var(--color-text-muted);
}

.form-group input {
    width: 100%;
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--color-text-muted);
    padding: 10px 0;
    color: var(--color-text-light);
    font-size: 1rem;
}

.form-group input:focus {
    outline: none;
    border-bottom-color: var(--color-accent-gold);
}

.button--form {
    background-color: var(--color-accent-gold);
    color: var(--color-background);
    border: none;
    padding: var(--spacing-md);
    font-family: var(--font-sans);
    font-size: 1rem;
    cursor: pointer;
    transition: var(--transition-fast);
}

.button--form:hover {
    filter: brightness(1.1);
}

.form-feedback {
    margin-top: var(--spacing-sm);
}


/* FOOTER DE CONFORMIDADE */
/* ------------------- */
.site-footer {
    padding: var(--spacing-lg) var(--spacing-md);
    border-top: 1px solid var(--color-surface);
    color: var(--color-text-muted);
    font-size: 0.8rem;
    line-height: 1.6;
    text-align: center;
}

.footer__section {
    margin-bottom: var(--spacing-lg);
}

.footer__section:last-child {
    margin-bottom: 0;
}

.footer__title {
    font-family: var(--font-sans);
    font-weight: 500;
    font-size: 0.9rem;
    color: var(--color-text-light);
    margin-bottom: var(--spacing-md);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* --- Seção de Parceiros --- */
.footer__partners-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: var(--spacing-lg);
}

.partner-logo {
    max-width: 120px;
}

.partner-logo img {
    width: 100%;
    height: auto;
    /* Para logos escuros em fundo escuro, podemos clareá-los */
    /* filter: grayscale(1) brightness(5); */
    opacity: 0.7;
    transition: opacity var(--transition-fast);
}

.partner-logo img:hover {
    opacity: 1;
}

/* --- Seção Legal e Copyright --- */
.footer__legal p {
    max-width: 80ch;
    margin: 0 auto;
}

.footer__copyright p {
    margin-bottom: var(--spacing-xs);
    font-size: 0.75rem;
}

.footer__copyright img {
    max-width: 150px;
    margin-bottom: var(--spacing-sm);
}


@media(min-width: 992px) {

    .curatorship {
        grid-template-columns: 1fr 1.2fr;
    }

    .floorplans__display {
        grid-template-columns: 2fr 1fr;
    }

    .amenities__grid {
        grid-template-columns: 1fr 1fr;
    }

    .amenity-card {
        display: grid;
        grid-template-columns: 1fr 1fr;
        align-items: center;
    }

    .amenities__grid .amenity-card:nth-child(even) .amenity-card__image-wrapper {
        order: 2;
    }

    .amenity-card__image-wrapper img {
        height: 100%;
        min-height: 350px;
    }

    .lead-form__container {
        grid-template-columns: 1fr 1fr;
    }

    .site-footer {
        display: grid;
        grid-template-areas:
            "partners legal"
            "copyright copyright";
        gap: var(--spacing-lg);
        text-align: left;
    }

    .footer__partners {
        grid-area: partners;
    }

    .footer__legal {
        grid-area: legal;
    }

    .footer__copyright {
        grid-area: copyright;
        text-align: center;
    }

    .footer__partners-grid {
        justify-content: flex-start;
    }

    .footer__legal p {
        margin: 0;
    }
}

/* --- CAPÍTULO X: O CONVITE (FORMULÁRIO E WHATSAPP) --- */
.lead-invitation-section {
    padding: var(--spacing-xl) var(--spacing-md);
    background-color: var(--color-surface);
}

.lead-invitation__grid {
    display: grid;
    gap: var(--spacing-lg);
}

.lead-option__title {
    font-family: var(--font-serif);
    font-size: 1.8rem;
    color: var(--color-text-light);
    margin-bottom: var(--spacing-sm);
}

.lead-option__description {
    color: var(--color-text-muted);
    line-height: 1.7;
    margin-bottom: var(--spacing-lg);
    min-height: 80px; /* Garante alinhamento em desktop */
}

/* --- Botão WhatsApp --- */
.button--whatsapp {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    width: 100%;
    background-color: var(--color-accent-gold);
    color: var(--color-background);
    border: none;
    padding: var(--spacing-md);
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    border-radius: 4px;
    transition: var(--transition-fast);
}
.button--whatsapp:hover {
    filter: brightness(1.1);
}
.button--whatsapp svg {
    width: 24px;
    height: 24px;
}

@media(min-width: 992px) {
    .lead-invitation__grid {
        grid-template-columns: 1fr 1fr;
        align-items: flex-start;
        gap: var(--spacing-xl);
    }
    .lead-option--whatsapp {
        padding-left: var(--spacing-xl);
        border-left: 1px solid var(--color-background);
    }
}