*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{

    background:
    radial-gradient(circle at top,
    #2b2117 0%,
    #151515 45%);

    color:#fff;

    font-family:'Montserrat', sans-serif;

    overflow-x:hidden;

    -webkit-font-smoothing:antialiased;
}

/* HEADER */

header{

    width:100%;

    position:fixed;

    top:0;
    left:0;

    z-index:1000;

    display:flex;

    justify-content:space-between;
    align-items:center;

    padding:16px 40px;

    background:rgba(15,15,15,.82);

    backdrop-filter:blur(10px);
}

/* MENU */

nav{

    display:flex;

    gap:30px;

    overflow-y:auto;
}

nav a{

    text-decoration:none;

    color:#d8c3a5;

    font-size:11px;

    letter-spacing:2px;

    text-transform:uppercase;

    position:relative;

    transition:.3s;
}

nav a::after{

    content:'';

    width:0%;
    height:1px;

    background:#d8c3a5;

    position:absolute;

    left:0;
    bottom:-6px;

    transition:.4s;
}

nav a:hover::after{
    width:100%;
}

nav a:hover{
    color:#fff;
}

/* MENU MOBILE */

.menu-toggle{

    display:none;

    font-size:30px;

    color:#d8c3a5;

    cursor:pointer;
}

/* HERO */

.hero{

    position:relative;

    min-height:100vh;

    display:grid;

    grid-template-columns:1fr;

    overflow:hidden;
}

/* IMAGEM COM EFEITO */

.hero::before{

    content:'';

    position:absolute;

    inset:0;

    background:url('img/Tela.png') center center/cover no-repeat;

    animation:zoomHeroDesktop 18s ease-in-out infinite alternate;

    z-index:0;
}

/* OVERLAY */

.hero::after{

    content:'';

    position:absolute;

    inset:0;

    background:linear-gradient(
        to bottom,
        rgba(0,0,0,.12),
        rgba(0,0,0,.42)
    );

    z-index:1;
}

/* ANIMAÇÃO */

@keyframes zoomHeroDesktop{

    from{
        transform:scale(1);
    }

    to{
        transform:scale(1.08);
    }
}

/* TEXTO HERO */

.hero-text{

    position:absolute;

    top:6%;

    left:50%;

    transform:translateX(-50%);

    text-align:center;

    z-index:10;

    width:90%;

    padding:20px;
}

/* ARABESCO */

.ornamento{

    color:#e7c79d;

    font-size:16px;

    letter-spacing:10px;

    margin-bottom:2px;

    opacity:.95;

    text-shadow:
    0 0 15px rgba(231,199,157,.35),
    0 0 30px rgba(231,199,157,.18);
}

/* TITULO */

.hero-text h1{

    font-family:'Cormorant Garamond', serif;

    font-style:italic;

    font-size:96px;

    font-weight:500;

    color:#fff;

    letter-spacing:1px;

    line-height:.82;

    margin-bottom:5px;

    text-shadow:
    0 4px 25px rgba(0,0,0,.45),
    0 0 40px rgba(215,179,140,.15);
}

/* PRIMEIRA LETRA */

.hero-text h1::first-letter{

    font-size:118px;

    font-style:italic;

    color:#f1d3ab;
}

/* LINHA */

.linha-topo{

    width:120px;

    height:1px;

    background:#d7b38c;

    margin:0 auto 25px auto;

    opacity:.7;
}

/* SUB */

.hero-text p{

    font-size:15px;

    letter-spacing:4px;

    text-transform:uppercase;

    color:#e4c7a1;

    text-shadow:0 4px 20px rgba(0,0,0,.45);
}

/* CARDS HERO */

.hero-cards{

    position:absolute;

    bottom:40px;
    left:50%;

    transform:translateX(-50%);

    width:90%;
    max-width:1400px;

    display:grid;

    grid-template-columns:repeat(4,1fr);

    gap:20px;

    z-index:5;
}

.hero-card{

    background:rgba(255,255,255,0.10);

    backdrop-filter:blur(12px);

    border:1px solid rgba(255,255,255,0.15);

    border-radius:22px;

    padding:22px 18px;

    display:flex;

    align-items:center;

    gap:15px;

    transition:.4s;
}

.hero-card:hover{

    transform:translateY(-6px);

    background:rgba(255,255,255,0.16);
}

.hero-card i{

    font-size:24px;

    color:#d4b483;

    min-width:24px;
}

.hero-card span{

    color:#fff;

    font-size:15px;

    font-weight:600;

    line-height:1.5;
}

/* SOBRE */

.sobre{

    padding:140px 10%;

    text-align:center;
}

.sobre h2{

    font-family:'Cormorant Garamond', serif;

    font-size:55px;

    color:#d7b38c;

    margin-bottom:30px;
}

.linha{

    width:80px;
    height:1px;

    background:#c7a97b;

    margin:30px auto;
}

.sobre p{

    max-width:850px;

    margin:auto;

    line-height:2;

    color:#d3d3d3;
}

/* GALERIA */

.galeria{

    padding:80px 0;

    overflow:hidden;
}

.carousel{

    position:relative;

    width:100%;
    height:720px;

    display:flex;

    justify-content:center;
    align-items:center;

    overflow:hidden;
}

.slide{

    position:absolute;

    transition:
    transform .7s ease,
    opacity .7s ease;

    opacity:.25;

    transform:scale(.7);

    cursor:pointer;
}

.slide img{

    display:block;

    max-width:100%;
    max-height:100%;

    object-fit:contain;

    border-radius:8px;

    transition:
    transform .5s ease,
    box-shadow .5s ease;

    will-change:transform;

    box-shadow:0 10px 40px rgba(0,0,0,.35);
}

.slide.active{

    opacity:1;

    z-index:10;

    transform:translateX(0) scale(1);
}

.slide.active img{

    width:auto;

    max-width:620px;

    height:650px;

    object-fit:contain;
}

.slide.active img:hover{

    transform:scale(1.04);
}

.slide.left{

    transform:translateX(-420px) scale(.75);

    opacity:.4;

    z-index:2;
}

.slide.left img{

    width:auto;

    max-width:220px;

    height:340px;
}

.slide.right{

    transform:translateX(420px) scale(.75);

    opacity:.4;

    z-index:2;
}

.slide.right img{

    width:auto;

    max-width:220px;

    height:340px;
}

.slide.hidden{

    opacity:0;

    pointer-events:none;
}

.slide.zoomed{
    z-index:999;
}

.slide.zoomed img{

    transform:scale(1.15);
}

/* SETAS */

.arrow{

    position:absolute;

    top:50%;

    transform:translateY(-50%);

    font-size:70px;

    color:#fff;

    cursor:pointer;

    z-index:20;

    user-select:none;

    transition:.3s;
}

.arrow:hover{

    transform:
    translateY(-50%)
    scale(1.1);

    color:#d7b38c;
}

.prev{
    left:40px;
}

.next{
    right:40px;
}

/* DEPOIMENTOS */

.depoimentos{

    padding:140px 10%;

    text-align:center;
}

.depoimentos h2{

    font-family:'Cormorant Garamond', serif;

    font-size:50px;

    color:#d7b38c;

    margin-bottom:60px;
}

.cards{

    display:flex;

    gap:30px;

    justify-content:center;

    flex-wrap:wrap;
}

.card{

    background:#1d1d1d;

    border:1px solid rgba(255,255,255,.08);

    padding:40px;

    width:320px;

    text-align:left;

    transition:.4s;

    border-radius:10px;
}

.card:hover{

    transform:translateY(-10px);

    border-color:#b89b68;
}

.card p{

    line-height:1.8;

    color:#d5d5d5;
}

.card span{

    display:block;

    margin-top:25px;

    color:#b89b68;

    font-size:12px;

    letter-spacing:2px;
}

/* VIDEOS */

.videos{
    padding:120px 10%;
}

.videos h2{

    text-align:center;

    font-family:'Cormorant Garamond', serif;

    font-size:50px;

    color:#d7b38c;

    margin-bottom:60px;
}

.video-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:25px;
}

.video-item{

    transition:.4s;
}

.video-item iframe{

    width:100%;

    height:240px;

    border:none;

    border-radius:8px;

    box-shadow:0 10px 30px rgba(0,0,0,.35);
}

.video-item:hover{

    transform:translateY(-5px);
}

.hidden-video{

    display:none;
}

/* BOTÃO */

.load-more-container{

    text-align:center;

    margin-top:50px;
}

.btn-load{

    display:inline-block;

    padding:16px 40px;

    border:1px solid #b89b68;

    background:transparent;

    color:#d7b38c;

    text-decoration:none;

    letter-spacing:2px;

    text-transform:uppercase;

    font-size:12px;

    cursor:pointer;

    transition:.4s;

    border-radius:4px;
}

.btn-load:hover{

    background:#b89b68;

    color:#111;

    transform:translateY(-3px);
}

/* CONTATO */

.contato{

    padding:140px 10%;

    text-align:center;
}

.contato h2{

    font-family:'Cormorant Garamond', serif;

    font-size:50px;

    color:#d7b38c;
}

.contato p{

    margin:25px 0 40px;

    color:#d4d4d4;
}

.btn{

    display:inline-block;

    padding:16px 40px;

    border:1px solid #b89b68;

    color:#d7b38c;

    text-decoration:none;

    letter-spacing:2px;

    text-transform:uppercase;

    font-size:12px;

    transition:.4s;

    border-radius:4px;
}

.btn:hover{

    background:#b89b68;

    color:#111;
}

/* FOOTER */

footer{

    padding:40px;

    text-align:center;

    border-top:1px solid rgba(255,255,255,.06);

    color:#777;

    font-size:12px;
}

/* RESPONSIVO */

@media(max-width:980px){

    .hero-cards{
        grid-template-columns:repeat(2,1fr);
    }

}

@media(max-width:764px){

    /* HERO MOBILE */

    .hero{

        min-height:100svh;
    }

    .hero::before{

        background:url('img/tela2.png') center center/cover no-repeat;

        animation:zoomHeroMobile 14s ease-in-out infinite alternate;
    }

    @keyframes zoomHeroMobile{

        from{
            transform:scale(1);
        }

        to{
            transform:scale(1.12);
        }
    }

    .hero-text{

        top:10%;

        width:100%;

        padding:0 20px;
    }

    .ornamento{

        font-size:12px;

        letter-spacing:6px;

        margin-bottom:14px;
    }

    .hero-text h1{

        font-size:54px;

        line-height:.9;
    }

    .hero-text h1::first-letter{

        font-size:72px;
    }

    .linha-topo{

        width:80px;

        margin:0 auto 18px auto;
    }

    .hero-text p{

        font-size:11px;

        letter-spacing:2px;

        line-height:1.8;
    }

    /* HEADER */

    header{

        width:100%;

        padding:15px 20px;
    }

    .menu-toggle{
        display:block;
        z-index:2000;
    }

    nav{

        position:fixed;

        top:0;
        right:-100%;

        width:75%;
        height:100vh;

        background:rgba(12,12,12,.98);

        backdrop-filter:blur(12px);

        flex-direction:column;

        align-items:center;

        padding-top:120px;

        transition:.5s;

        z-index:1500;
    }

    nav.active{

        right:0;

        box-shadow:-10px 0 30px rgba(0,0,0,.5);
    }

    nav a{
        margin:10px 0;
    }

    /* CARDS HERO */

     .hero-cards{

        grid-template-columns:1fr;

        gap:10px;

        bottom:12px;

        width:92%;
    }

    .hero-card{

        padding:12px 14px;

        border-radius:16px;

        gap:10px;
    }

    .hero-card i{

        font-size:18px;

        min-width:18px;
    }

    .hero-card span{

        font-size:12px;

        line-height:1.4;
    }

    /* SOBRE */

    .sobre{
        padding:90px 25px;
    }

    .sobre h2{
        font-size:40px;
    }

    /* GALERIA */

    .carousel{

        height:500px;
    }

    .slide.left,
    .slide.right{
        display:none;
    }

    .slide.active{

        width:100%;

        display:flex;

        justify-content:center;
        align-items:center;
    }

    .slide.active img{

        width:auto;

        max-width:94vw;

        height:420px;

        object-fit:contain;
    }

    .slide.active img:hover{
        transform:none;
    }

    .arrow{
        font-size:42px;
    }

    .prev{
        left:10px;
    }

    .next{
        right:10px;
    }

    /* CARDS */

    .cards{
        flex-direction:column;
    }

    .card{
        width:100%;
    }

    /* VIDEOS */

    .video-grid{
        grid-template-columns:1fr;
    }

}