/* =========================
   RESET
========================= */

*{
margin:0;
padding:0;
box-sizing:border-box;
scroll-behavior:smooth;
}

body{
font-family:'Poppins',sans-serif;
background:#130329;
color:white;
overflow-x:hidden;
}

/* =========================
   LOADER
========================= */

#loader{
position:fixed;
width:100%;
height:100vh;
background:#120028;
display:flex;
justify-content:center;
align-items:center;
z-index:9999;
transition:1s;
}

.loader-content{
text-align:center;
}

.loader-content h1{
font-size:4rem;
color:#FFD700;
font-family:'Cinzel',serif;
}

.loader-content p{
margin-top:10px;
}

/* =========================
   NAVBAR
========================= */

nav{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    padding:15px 5%;
    display:flex;
    justify-content:space-between;
    align-items:center;
    background:rgba(19,3,41,.85);
    backdrop-filter:blur(12px);
    border-bottom:1px solid rgba(255,215,0,.2);
    z-index:1000;
}

.logo{
    font-size:1.4rem;
    font-weight:700;
    color:var(--gold);
}

nav ul{
    display:flex;
    gap:20px;
    list-style:none;
    margin:0;
    padding:0;
}

nav a{
    color:white;
    text-decoration:none;
    transition:.3s;
}

nav a:hover{
    color:var(--gold);
}

/* =========================
   SPOTIFY
========================= */

.music-section{
    padding:100px 10%;
    text-align:center;
}

.music-section h2{
    color:#FFD36E;
    margin-bottom:30px;
    font-size:2rem;
}

.spotify-box{
    max-width:800px;
    margin:auto;
    border-radius:20px;
    overflow:hidden;
    box-shadow:0 0 20px rgba(255,211,110,.2);
}

/* =========================
   HERO
========================= */

/* IMPORT FONT */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&display=swap');

/* HERO SECTION */
.hero{
    min-height:100vh;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    text-align:center;
    padding:20px;
    background:
    linear-gradient(
        rgba(20,0,40,0.65),
        rgba(20,0,40,0.8)
    ),
    url('images/rapunzel-bg.jpg');
    background-size:cover;
    background-position:center;
}

/* JUDUL BESAR */
.hero h1{
    font-family:'Cinzel', serif;
    font-size:clamp(3rem,8vw,6rem);
    font-weight:700;
    color:#ffd86b;
    letter-spacing:4px;
    text-transform:uppercase;

    text-shadow:
    0 0 10px #ffd86b,
    0 0 20px #ffd86b,
    0 0 40px #ffcc33,
    0 0 80px #ffcc33,
    0 0 120px #ffcc33;

    animation: glow 2.5s ease-in-out infinite alternate;
}

/* SUBTITLE */
.hero p{
    margin-top:20px;
    font-size:1.3rem;
    color:#fff;
    max-width:800px;
    line-height:1.8;

    text-shadow:
    0 0 5px rgba(255,255,255,0.8),
    0 0 15px rgba(255,255,255,0.5);
}

/* BUTTON */
.hero button,
.hero .btn{
    margin-top:30px;
    padding:14px 32px;
    border:none;
    border-radius:50px;
    background:#ffd86b;
    color:#2d004d;
    font-weight:bold;
    cursor:pointer;
    transition:0.3s;
    box-shadow:
    0 0 15px #ffd86b,
    0 0 30px #ffd86b;
}

.hero button:hover,
.hero .btn:hover{
    transform:translateY(-5px) scale(1.05);
    box-shadow:
    0 0 25px #ffd86b,
    0 0 50px #ffd86b;
}

/* ANIMASI GLOW */
@keyframes glow{
    from{
        text-shadow:
        0 0 10px #ffd86b,
        0 0 20px #ffd86b,
        0 0 40px #ffcc33;
    }
    to{
        text-shadow:
        0 0 20px #ffd86b,
        0 0 40px #ffd86b,
        0 0 80px #ffcc33,
        0 0 120px #ffcc33;
    }
}

/* =========================
   ABOUT
========================= */

.about{
padding:120px 10%;
text-align:center;
}

.about h2{
font-size:3rem;
margin-bottom:40px;
color:#FFD700;
}

.about-box{
max-width:900px;
margin:auto;
padding:40px;
background:rgba(255,255,255,.08);
backdrop-filter:blur(15px);
border-radius:20px;
}

/* =========================
   TEAM
========================= */

.team-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:25px;
}

.flip-card{
    height:250px;
    perspective:1000px;
    cursor:pointer;
}

.flip-card-inner{
    position:relative;
    width:100%;
    height:100%;
    transition:transform .8s;
    transform-style:preserve-3d;
}

.flip-card:hover .flip-card-inner,
.flip-card.active .flip-card-inner{
    transform:rotateY(180deg);
}

.front,
.back{
    position:absolute;
    width:100%;
    height:100%;
    display:flex;
    justify-content:center;
    align-items:center;
    flex-direction:column;
    border-radius:20px;
    backface-visibility:hidden;
    padding:20px;
}

.front{
    background:#6a0dad;
    color:white;
}

.back{
    background:#FFD36E;
    color:#2b0a3d;
    transform:rotateY(180deg);
}

#musicBtn{
    position:fixed;
    right:20px;
    bottom:20px;
    width:60px;
    height:60px;
    border:none;
    border-radius:50%;
    background:#FFD36E;
    color:#2b0a3d;
    font-size:24px;
    cursor:pointer;
    z-index:9999;
}

/* =========================
   CANVA
========================= */

.canva{
padding:120px 8%;
text-align:center;
}

.canva h2{
font-size:3rem;
color:#FFD700;
margin-bottom:40px;
}

.canva-box{
border-radius:20px;
overflow:hidden;
box-shadow:0 0 30px rgba(255,215,0,.4);
}

.canva iframe{
width:100%;
height:700px;
border:none;
}

/* =========================
   JOURNEY
========================= */

.journey{
padding:120px 10%;
text-align:center;
}

.journey h2{
font-size:3rem;
color:#FFD700;
}

#mainLantern{
font-size:120px;
cursor:pointer;
margin-top:50px;
animation:float 3s infinite;
}

@keyframes float{

0%{
transform:translateY(0);
}

50%{
transform:translateY(-30px);
}

100%{
transform:translateY(0);
}

}

/* =========================
   MINI GAME
========================= */

.game{
padding:120px 10%;
text-align:center;
}

.game h2{
font-size:3rem;
color:#FFD700;
margin-bottom:20px;
}

#score{
font-size:2rem;
margin-bottom:30px;
}

#gameArea{
position:relative;
height:400px;
background:
rgba(255,255,255,.05);
border-radius:20px;
overflow:hidden;
}

.gameLantern{
position:absolute;
font-size:50px;
cursor:pointer;
transition:.3s;
}

.gameLantern:hover{
transform:scale(1.2);
}

/* =========================
   GALLERY
========================= */

.gallery{
padding:120px 8%;
text-align:center;
}

.gallery h2{
font-size:3rem;
color:#FFD700;
margin-bottom:40px;
}

.gallery-grid{
display:grid;
grid-template-columns:
repeat(auto-fit,minmax(250px,1fr));
gap:20px;
}

.gallery-grid img{
width:100%;
height:280px;
object-fit:cover;
border-radius:20px;
transition:.4s;
}

.gallery-grid img:hover{
transform:scale(1.05);
}

/* =========================
   FOOTER
========================= */

footer{
padding:50px;
text-align:center;
background:#0d021c;
}

/* =========================
   BUBBLES
========================= */

.bubble{
position:fixed;
bottom:-100px;
border-radius:50%;
background:
rgba(255,255,255,.2);
animation:rise linear infinite;
pointer-events:none;
}

@keyframes rise{

0%{
transform:translateY(0);
opacity:1;
}

100%{
transform:translateY(-120vh);
opacity:0;
}

}

/* =========================
   LANTERNS
========================= */

.floating-lantern{
position:fixed;
font-size:40px;
pointer-events:none;
animation:lanternFloat linear infinite;
opacity:.7;
}

@keyframes lanternFloat{

0%{
transform:translateY(100vh);
}

100%{
transform:translateY(-120vh);
}

}

/* =========================
   REVEAL SCROLL
========================= */

.reveal{
opacity:0;
transform:translateY(80px);
transition:1s;
}

.reveal.active{
opacity:1;
transform:translateY(0);
}

/* =========================
   MOBILE
========================= */

@media(max-width:768px){

.hero h1{
font-size:2.8rem;
}

nav{
flex-direction:column;
gap:15px;
}

nav{
    padding:15px 5%;
    flex-direction:column;
    gap:10px;
}

nav ul{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    gap:15px;
    list-style:none;
    padding:0;
    margin:0;
}

nav ul li{
    margin:0;
}

nav a{
    text-decoration:none;
    color:white;
}

}
nav ul{
flex-wrap:wrap;
justify-content:center;
}

.about h2,
.team h2,
.canva h2,
.gallery h2,
.game h2,
.journey h2{
font-size:2rem;
}

#mainLantern{
font-size:80px;
}

.canva iframe{
height:500px;
}

}
