*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:Arial, Helvetica, sans-serif;
}

body{
    background:#050505;
    color:white;
}

/* HEADER */

header{
    position:fixed;
    top:0;
    left:0;
    width:100%;

    display:flex;
    justify-content:space-between;
    align-items:center;

    padding:20px 70px;

    background:rgba(0,0,0,0.45);
    backdrop-filter:blur(6px);

    z-index:1000;
}

.logo img{
    width:80px;
    border-radius:12px;
}

nav{
    display:flex;
    gap:35px;
}

nav a{

    position: relative;
    color: white;
    text-decoration: none;
    font-size: 16px;
    font-weight: 600;
    padding: 10px 18px;
    border-radius: 12px;
    transition: 0.3s ease;
    overflow: hidden;

}
nav a::before{

    content:'';
    position:absolute;
    left:0;
    bottom:0;
    width:0%;
    height:2px;
    background:#b78cff;
    transition:0.3s ease;

}

nav a:hover{

    color:#b78cff;
    background:rgba(183,140,255,0.08);
    box-shadow:0 0 15px rgba(183,140,255,0.2);

}
nav a:hover::before{

    width:100%;

}

/* HERO */

.hero{
    position:relative;
    overflow:hidden;
    isolation:isolate;

    min-height:100vh;

    display:flex;
    align-items:center;
    justify-content:space-between;

    gap:80px;

    padding:140px 80px 80px;

    background:
    linear-gradient(
        rgba(0,0,0,0.70),
        rgba(0,0,0,0.85)
    ),

    url('assets/img/bannernovo.png');

    background-size:cover;
    background-position:center;
}

.hero-content{
    max-width:650px;
}

.hero h1{

    font-size:95px;

    line-height:92px;

    margin-bottom:25px;

    font-weight:900;

    letter-spacing:-3px;

    color:white;

    text-shadow:
    0 0 10px rgba(255,255,255,0.08),
    0 0 30px rgba(181,108,255,0.18);

    animation:fadeHero 1.5s ease;

}

.hero p{

    font-size:30px;

    color:#cfcfcf;

    margin-bottom:35px;

    line-height:42px;

    max-width:700px;

    animation:fadeHero 2s ease;

}

@keyframes fadeHero{

    from{

        opacity:0;
        transform:translateY(40px);

    }

    to{

        opacity:1;
        transform:translateY(0);

    }

}

.hero-button{
    display:inline-block;

position:relative;
overflow:hidden;

margin-top:10px;

padding:18px 40px;

background:linear-gradient(
135deg,
#7b2cff,
#b56cff
);

color:white;

text-decoration:none;

border-radius:16px;

font-size:18px;
font-weight:bold;

transition:0.4s ease;

box-shadow:
0 0 20px rgba(181,108,255,0.25);
}

.hero-button:hover{
    transform:translateY(-4px);

box-shadow:
0 0 35px rgba(181,108,255,0.45);
}

.hero-button::before{

    content:'';

    position:absolute;

    top:0;
    left:-100%;

    width:100%;
    height:100%;

    background:linear-gradient(
        90deg,
        transparent,
        rgba(255,255,255,0.2),
        transparent
    );

    transition:0.6s;

}

.hero-button:hover::before{

    left:100%;

}
/* HERO SIDE */

.hero-side{
    width:320px;

    display:flex;
    flex-direction:column;

    gap:20px;
}

.side-card{
    background:rgba(10,10,10,0.88);

    border:1px solid rgba(160,80,255,0.15);

    border-radius:18px;

    overflow:hidden;

    backdrop-filter:blur(10px);

    transition:0.45s ease;

    position:relative;
}

.side-card:hover{
    transform:translateY(-8px) scale(1.02);

    border-color:rgba(180,120,255,0.45);

    box-shadow:
    0 0 25px rgba(140,70,255,0.25),
    0 0 60px rgba(140,70,255,0.12);
}

.side-card img{
    width:100%;
    height:120px;

    object-fit:cover;
    transition:0.6s ease;
    display:block;
}

.side-card:hover img{
    transform:scale(1.06);

    filter:brightness(1.08);
}

.side-card::before{
    content:"";

    position:absolute;

    inset:0;

    background:linear-gradient(
        120deg,
        transparent 20%,
        rgba(255,255,255,0.06) 50%,
        transparent 80%
    );

    transform:translateX(-120%);

    transition:0.8s;

    pointer-events:none;
}

.side-card:hover::before{
    transform:translateX(120%);
}

.side-card-content{
    padding:16px;
}

.side-card-content span{
    color:#b56cff;
    font-size:13px;
}

.side-card-content h3{
    font-size:24px;
    margin:8px 0 12px;
}

.side-card-content a{
    display:inline-block;

    padding:10px 18px;

    background:#7d3cff;
    color:white;

    text-decoration:none;

    border-radius:10px;

    transition:0.3s;

    font-size:14px;
}

.side-card-content a:hover{
    background:#9c66ff;
}

/* BANNER YOUTUBE */

.youtube-side-banner{
    background:rgba(10,10,10,0.88);

    border:1px solid rgba(160,80,255,0.15);

    border-radius:18px;

    overflow:hidden;

    backdrop-filter:blur(10px);

    transition:0.45s ease;

    position:relative;
}

.youtube-side-banner img{
    width:100%;
    border-radius:16px;

    display:block;

    transition:0.6s ease;
}

.youtube-side-banner:hover img{
    transform:scale(1.05);

    filter:brightness(1.08);
}

.youtube-side-banner::before{
    content:"";

    position:absolute;

    inset:0;

    background:linear-gradient(
        120deg,
        transparent 20%,
        rgba(255,255,255,0.06) 50%,
        transparent 80%
    );

    transform:translateX(-120%);

    transition:0.8s;

    pointer-events:none;

    z-index:2;
}

.youtube-side-banner:hover::before{
    transform:translateX(120%);
}

.youtube-side-banner:hover{
    transform:translateY(-8px) scale(1.02);

    border-color:rgba(180,120,255,0.45);

    box-shadow:
    0 0 25px rgba(140,70,255,0.25),
    0 0 60px rgba(140,70,255,0.12);
}

/* SEÇÕES */

section{
    padding:100px 80px;
}

.section-title{
    font-size:45px;
    margin-bottom:50px;
    text-align:center;
    color:#c58cff;

    position:relative;
}

.section-title::after{
    content:"";
    width:70px;
    height:3px;

    background:#b56cff;

    position:absolute;
    left:50%;
    bottom:-12px;

    transform:translateX(-50%);
}

/* CARDS DOS VIDEOS */

.cards{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
    gap:30px;
}

.card{

    position:relative;
    background:#0d0d0d;
    border-radius:24px;
    overflow:hidden;

    transition:0.4s ease;
    cursor:pointer;

    text-decoration:none;

    border:1px solid rgba(181,108,255,0.08);

}

.card:hover{
    transform:translateY(-10px);

    box-shadow:
     0 0 35px rgba(181,108,255,0.18);
}     

.card img{
    width:100%;
    height:340px;

    object-fit:contain;
    background:#000;

    display:block;

    transition:0.5s ease;
}

.card:hover img{
    transform:scale(1.08);

    filter:brightness(1.15);
}
.card::before{

    content:'';
    position:absolute;
    inset:0;

    background:linear-gradient(
        to top,
        rgba(0,0,0,0.88),
        rgba(0,0,0,0.15)
    );

    opacity:0;

    transition:0.4s ease;

    z-index:1;

}
.card:hover::before{

    opacity:1;

}

.card-content{
    padding:20px;
}

.card-content h3{
    margin-bottom:10px;
    color:#ffffff;
}

.card-content p{
    color:#bdbdbd;
    font-size:15px;
}

/* PAGE BANNER */

.page-banner{
    height:55vh;

    background:
    linear-gradient(
    rgba(0,0,0,0.65),
    rgba(0,0,0,0.88)
    ),

    url('assets/img/bannernovo.png');

    background-size:cover;
    background-position:center;

    display:flex;
    align-items:center;
    justify-content:center;

    position:relative;
}

.banner-content{
    text-align:center;
    z-index:2;
}

.banner-content h1{

    font-size:72px;

    font-weight:800;

    letter-spacing:1px;

    margin-bottom:28px;

    background:linear-gradient(
        to bottom,
        #ffffff,
        #d8b4ff 75%,
        #9b5cff
    );

    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;

    text-shadow:
    0 0 25px rgba(155,92,255,0.18),
    0 0 60px rgba(155,92,255,0.10);

    position:relative;

    display:inline-block;
}

.banner-content h1::after{

    content:"";

    width:120px;

    height:4px;

    border-radius:999px;

    background:linear-gradient(
        90deg,
        transparent,
        #9b5cff,
        transparent
    );

    position:absolute;

    left:50%;

    bottom:-18px;

    transform:translateX(-50%);

    box-shadow:0 0 18px rgba(155,92,255,0.55);
}

.banner-content p{

    font-size:24px;

    color:rgba(255,255,255,0.78);

    letter-spacing:0.5px;

    text-shadow:
    0 0 15px rgba(0,0,0,0.45);
}

/* PAGINA DE HISTORIA */

.story-banner{
    height:60vh;

    background-size:contain;
    background-repeat:no-repeat;
    background-position:right center;
    background-color:#000;

    display:flex;
    align-items:center;

    padding-left:120px;

    text-align:left;
}
/* ILHA DAS BONECAS */

.bonecas-banner{

    background:
    linear-gradient(
    rgba(0,0,0,0.70),
    rgba(0,0,0,0.88)
    ),

    url('assets/img/thumb3.jpg');

    background-size:contain;
    background-repeat:no-repeat;
    background-position:right center;
}

/* EASTERN */

.eastern-banner{

    background:
    linear-gradient(
    rgba(0,0,0,0.70),
    rgba(0,0,0,0.88)
    ),

    url('assets/img/thumb5.jpg');

    background-size:contain;
    background-repeat:no-repeat;
    background-position:right center;
}

/* Dama de Castanho */

.dama-banner{

    background:
    linear-gradient(
    rgba(0,0,0,0.70),
    rgba(0,0,0,0.88)
    ),

    url('assets/img/thumb7.png');

    background-size:contain;
    background-repeat:no-repeat;
    background-position:right center;
}
/* Paranapiacaba */

.paranapiacaba-banner{

    background:
    linear-gradient(
    rgba(0,0,0,0.70),
    rgba(0,0,0,0.88)
    ),

    url('assets/img/thumb2.png');

    background-size:contain;
    background-repeat:no-repeat;
    background-position:right center;
}
/* Povegliaa */

.poveglia-banner{

    background:
    linear-gradient(
    rgba(0,0,0,0.70),
    rgba(0,0,0,0.88)
    ),

    url('assets/img/thumb4.png');

    background-size:contain;
    background-repeat:no-repeat;
    background-position:right center;
}
/* Chernobyl */

.pripyat-banner{

    background:
    linear-gradient(
    rgba(0,0,0,0.70),
    rgba(0,0,0,0.88)
    ),

    url('assets/img/thumb6.png');

    background-size:contain;
    background-repeat:no-repeat;
    background-position:right center;
}
/* Waverly */

.waverly-banner{

    background:
    linear-gradient(
    rgba(0,0,0,0.70),
    rgba(0,0,0,0.88)
    ),

    url('assets/img/thumb1.png');

    background-size:contain;
    background-repeat:no-repeat;
    background-position:right center;
}

/* Corpo-seco */

.corpo-seco-banner{

    background:
    linear-gradient(
    rgba(0,0,0,0.70),
    rgba(0,0,0,0.88)
    ),

    url('assets/img/thumb8.png');

    background-size:contain;
    background-repeat:no-repeat;
    background-position:center center;

}

/* Pisadeira */

.pisadeira-banner{

    background:
    linear-gradient(
    rgba(0,0,0,0.70),
    rgba(0,0,0,0.88)
    ),

    url('assets/img/thumb9.png');

    background-size:contain;
    background-repeat:no-repeat;
    background-position:right center;
}

/* Samhein */

.samhein-banner{

    background:
    linear-gradient(
    rgba(0,0,0,0.70),
    rgba(0,0,0,0.88)
    ),

    url('assets/img/thumb11.png');

    background-size:contain;
    background-repeat:no-repeat;
    background-position:right center;
}

.story-banner-content h1{
    font-size:72px;
    margin-bottom:20px;
    max-width:700px;
}

.story-banner-content p{
    font-size:24px;
    color:#d2d2d2;

    max-width:500px;
}

.story-container{
    display:flex;
    justify-content:center;
}

.story-content{
    max-width:900px;
    font-size:22px;
    line-height:42px;
    color:#d8d8d8;
}

.story-content p{
    margin-bottom:35px;
}


/* FOOTER */

.footer{

    padding:40px 20px;
    text-align:center;
    background:#050505;
    border-top:1px solid #1a1a1a;

}

.footer-links{

    margin-bottom:15px;

}

.footer-links a{

    color:#b78cff;
    text-decoration:none;
    margin:0 12px;
    font-size:14px;
    transition:0.3s;

}

.footer-links a:hover{

    color:#ffffff;

}

.footer p{

    color:#777;
    font-size:13px;

}
@media(max-width:1100px){

    .hero{
        flex-direction:column;
        justify-content:center;

        padding:140px 30px 60px;

        text-align:center;
    }

    .hero-content{
        max-width:100%;
    }

    .hero h1{
        font-size:65px;
        line-height:70px;
    }

    .hero p{
        font-size:22px;
    }

    .hero-side{
        width:100%;

        flex-direction:row;
        justify-content:center;
        flex-wrap:wrap;

        margin-top:40px;
    }

    .side-card,
    .youtube-side-banner{
        width:280px;
    }

    header{
        padding:20px 25px;
    }

    nav{
        gap:18px;
    }

    nav a{
        font-size:15px;
    }

    section{
        padding:80px 25px;
    }

}
/* CONTATO */

.contact-section{
    display:grid;

    grid-template-columns:
    repeat(auto-fit,minmax(300px,1fr));

    gap:30px;
}

.contact-card{
    background:#0d0d0d;

    padding:40px;

    border-radius:20px;

    text-align:center;

    transition:0.4s;

    border:1px solid rgba(181,108,255,0.15);
}

.contact-card:hover{
    transform:translateY(-8px);

    box-shadow:
    0 0 30px rgba(181,108,255,0.20);
}

.contact-card h2{
    font-size:35px;

    margin-bottom:20px;

    color:#b56cff;
}

.contact-card p{
    color:#cfcfcf;

    line-height:30px;

    margin-bottom:30px;
}

.contact-card a{
    display:inline-block;

    padding:14px 25px;

    background:#7d3cff;
    color:white;

    text-decoration:none;

    border-radius:10px;

    transition:0.3s;
}

.contact-card a:hover{
    background:#9c66ff;

    transform:scale(1.05);
}
/* CONTATO */

.contact-section{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:40px;

    flex-wrap:wrap;

    padding:120px 80px;
}

.contact-card{
    width:300px;

    background:#0b0b0b;

    border:1px solid rgba(181,108,255,0.25);

    border-radius:20px;

    padding:50px 30px;

    text-align:center;

    transition:0.4s;
}

.contact-card:hover{
    transform:translateY(-8px);

    box-shadow:0 0 25px rgba(181,108,255,0.25);
}

.contact-card h2{
    font-size:28px;
    margin-bottom:25px;
    color:#b56cff;
}

.contact-card p{
    color:#d2d2d2;
    line-height:34px;
    margin-bottom:35px;
}

.contact-card a{
    display:inline-block;

    padding:14px 28px;

    background:#7d3cff;

    color:white;

    text-decoration:none;

    border-radius:10px;

    transition:0.3s;
}

.contact-card a:hover{
    background:#9d67ff;
    transform:scale(1.05);
}
.poveglia-thumb{
    height:340px !important;
    width:100% !important;

    object-fit:cover !important;
    object-position:center;

    display:block;
}
/* MOBILE */

@media(max-width:768px){

    header{
        padding:15px 15px;

        flex-direction:row;
        align-items:center;
    }

    .logo img{
        width:60px;
    }

    nav{
        gap:12px;
        flex-wrap:wrap;
        justify-content:center;
    }

    nav a{
        font-size:14px;
    }

    /* HERO */

    .hero{
        padding:130px 20px 60px;

        gap:40px;

        text-align:center;
    }

    .hero h1{
        font-size:58px;
        line-height:58px;
    }

    .hero p{
        font-size:18px;
        line-height:30px;
    }

    .hero-button{
        width:100%;
        max-width:320px;

        padding:18px;
        font-size:18px;
    }

    /* SIDE */

    .hero-side{
        width:100%;
    }

    .side-card,
    .youtube-side-banner{
        width:100%;
    }

    /* SECTIONS */

    section{
        padding:70px 20px;
    }

    .section-title{
        font-size:34px;
    }

    /* CARDS */

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

    .card img{
        height:260px;
        object-fit:cover;
    }

    /* BANNER PAGES */

    .page-banner{
        height:45vh;
        padding:20px;
    }

    .banner-content h1{
        font-size:42px;
    }

    .banner-content p{
        font-size:18px;
    }

    /* STORY BANNER */

    .story-banner{
        height:auto;

        padding:
        140px 20px 70px;

        justify-content:center;

        text-align:center;

        background-position:center top;
        background-size:cover;
    }

    .story-banner-content h1{
        font-size:48px;
        line-height:52px;
    }

    .story-banner-content p{
        font-size:18px;
        line-height:30px;
    }

    /* STORY CONTENT */

    .story-content{
        font-size:19px;
        line-height:36px;
    }

    /* CONTATO */

    .contact-section{
        padding:80px 20px;
    }

    .contact-card{
        width:100%;
    }

}


.story-buttons{

    display:flex;

    gap:20px;

    margin-top:40px;

    flex-wrap:wrap;

}

.story-buttons{

    display:flex;

    justify-content:center;

    align-items:center;

    gap:20px;

    margin-top:40px;

    flex-wrap:wrap;

}

.youtube-button,
.next-story-button{

    display:flex;

    align-items:center;

    justify-content:center;

    min-width:320px;

    padding:18px 35px;

    background:#7d3cff;

    color:white;

    text-decoration:none;

    border-radius:12px;

    font-weight:bold;

    font-size:18px;

    text-align:center;

    transition:0.3s;

    box-shadow:
    0 0 20px rgba(125,60,255,0.25);

}

.youtube-button:hover,
.next-story-button:hover{

    background:#9c66ff;

    transform:
    translateY(-3px)
    scale(1.03);

    box-shadow:
    0 0 30px rgba(125,60,255,0.45);

}
.video-container{

    width:100%;
    max-width:900px;

    margin:40px auto;

    height:500px;
}

.video-container iframe{

    width:100%;
    height:100%;

    border:none;

    border-radius:18px;

    box-shadow:
    0 0 30px rgba(128,0,255,0.25);
}
.view-counter{

    margin-top:20px;

    text-align:center;

    color:#b98cff;

    font-size:16px;

    font-weight:500;

    opacity:0.9;

}
/* CONTAINER */

.container {

    max-width: 900px;
    margin: 120px auto 60px auto;
    padding: 40px 20px;
    line-height: 1.8;

}

/* Neblina */

.hero-content,
.hero-side{
    position:relative;
    z-index:2;
}

/* NEBLINA REAL */

.fog{
    position:absolute;

    top:-20%;
    left:-20%;

    width:140%;
    height:140%;

    background:
    radial-gradient(circle at 20% 50%, rgba(255,255,255,0.05), transparent 25%),
    radial-gradient(circle at 70% 30%, rgba(255,255,255,0.04), transparent 30%),
    radial-gradient(circle at 50% 80%, rgba(180,120,255,0.05), transparent 35%);

    filter:blur(80px);

    opacity:0.7;

    animation:fogMove 18s ease-in-out infinite alternate;

    pointer-events:none;

    z-index:1;
}

@keyframes fogMove{

    from{
        transform:translateX(-20px) translateY(0px);
    }

    to{
        transform:translateX(20px) translateY(-10px);
    }
}