/* === style.css === */

/* --- VARIABEL PUSAT --- */
:root {
    --primary-color: #8B4513; 
    --secondary-color: #800000; 
    --text-dark: #333333;
    --text-light: #FFFFFF;
}

/* --- DASAR --- */
body {
    margin: 0;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    color: var(--text-dark);
    background-color: var(--primary-color);
    background-image: url('img/brownlovel.jpg');
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
}

.text-secondary { color: var(--secondary-color); }
.text-maroon { color: var(--secondary-color); }
p, h1, h2, h3, span { text-shadow: 0px 0px 8px rgba(255, 255, 255, 0.9); }

/* --- BAGIAN LOGIN --- */
#login-section {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100vh;
}

.login-box {
    background: rgba(255, 255, 255, 0.15); 
    backdrop-filter: blur(8px); 
    -webkit-backdrop-filter: blur(8px);
    padding: 40px;
    border-radius: 15px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
    text-align: center;
    border: 2px solid var(--secondary-color); 
    width: 350px; 
    box-sizing: border-box;
}

.login-box input {
    display: block;
    width: 100%; 
    margin: 10px 0; 
    padding: 10px;
    border: 2px solid #ccccccad;
    border-radius: 5px;
    box-sizing: border-box; 
}

#pesan-error {
    color: var(--secondary-color);
    font-size: 14px;
    margin: 10px 0; 
    display: none; 
    text-align: center;
}

#btn-lanjut {
    display: inline-block; 
    visibility: visible; 
    opacity: 1; 
    background-color: #800000;
    color: var(--text-light);
    border: none;
    padding: 10px 20px;
    margin-top: 15px;
    border-radius: 5px;
    cursor: pointer;
    font-weight: bold;
    font-size: 16px;
    width: 100%; 
    box-sizing: border-box;
}

#btn-lanjut:hover { background-color: #cc0000; }

button {
    background-color: var(--secondary-color);
    color: var(--text-light);
    border: none;
    padding: 10px 20px;
    margin-top: 15px;
    border-radius: 5px;
    cursor: pointer;
    font-weight: bold;
    font-size: 16px;
}
button:hover { background-color: #cc0000; }

/* --- BAGIAN PROFIL --- */
#profile-section { display: none; }

header {
    background: rgba(128, 0, 0, 0.7);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding: 15px 40px; 
    box-shadow: 0 4px 6px rgba(0,0,0,0.2);
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
}

.logo-teks {
    font-size: 24px;
    font-weight: bold;
    color: var(--text-light); 
    letter-spacing: 1px;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
}

.dropdown-nav { position: relative; }

.menu-btn {
    background: transparent;
    color: var(--text-light);
    border: 2px solid var(--text-light);
    padding: 8px 16px;
    border-radius: 8px;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    transition: 0.3s;
    margin-top: 0;
}
.menu-btn:hover { background: rgba(255, 255, 255, 0.2); }

.nav-links {
    display: none; 
    position: absolute;
    top: 100%; 
    right: 0; 
    margin-top: 15px;
    background: rgba(128, 0, 0, 0.85); 
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 10px;
    padding: 10px;
    min-width: 150px;
    box-shadow: 0 8px 16px rgba(0,0,0,0.3);
    flex-direction: column; 
    gap: 5px;
    z-index: 100; 
}

.nav-links.show { display: flex; animation: fadeIn 0.3s; }

.nav-btn {
    background: none;
    color: var(--text-light);
    margin: 0;
    font-size: 16px;
    width: 100%;
    text-align: left;
    padding: 10px;
    border-radius: 5px;
}
.nav-btn:hover { background: rgba(255, 255, 255, 0.2); text-decoration: none; }

/* --- KOTAK KONTEN (EFEK KACA) --- */
.content-container {
    padding: 40px;
    max-width: 800px;
    margin: 40px auto; 
    background: rgba(255, 255, 255, 0.7); 
    backdrop-filter: blur(15px); 
    -webkit-backdrop-filter: blur(15px); 
    min-height: 60vh;
    border-radius: 20px; 
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2); 
    border: 1px solid rgba(255, 255, 255, 0.8); 
}

.content-container p, 
.content-container h1, 
.content-container h2, 
.content-container h3, 
.content-container span {
    color: #333333; 
    text-shadow: none; 
}

.content-container .text-secondary, 
.content-container .text-maroon {
    color: #800000;
    text-shadow: none;
}

.tab-content { display: none; }
.tab-content.active { display: block; animation: fadeIn 0.5s; }
.bg-gambar { background-image: url('img/brownlovel.jpg') !important; }

/* --- GALERI & TOMBOL --- */
.upload-area { text-align: center; margin-bottom: 20px; }

.btn-upload {
    background-color: var(--secondary-color);
    color: var(--text-light);
    border: none;
    padding: 10px 20px;
    margin: 0;
    border-radius: 8px;
    cursor: pointer;
    font-weight: bold;
    box-shadow: 0 4px 6px rgba(0,0,0,0.2);
}

.gallery-grid {
    column-count: 3; 
    column-gap: 15px;
    margin-top: 20px;
}

.gallery-item {
    position: relative;
    background-color: rgba(255,255,255,0.1);
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.3);
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
    display: inline-block; 
    width: 100%;
    margin-bottom: 15px; 
    break-inside: avoid;
}

.gallery-img {
    width: 100%;
    height: auto; 
    display: block;
    cursor: pointer; 
    transition: transform 0.3s ease;
}

.gallery-item:hover .gallery-img { transform: scale(1.05); }

.btn-hapus {
    position: absolute;
    top: 8px; right: 8px; 
    background: rgba(230, 0, 0, 0.8);
    color: white; border: none; border-radius: 50%; 
    width: 30px; height: 30px; cursor: pointer;
    display: none; 
    font-size: 18px; 
    line-height: 30px; 
    text-align: center; 
    padding: 0; 
    box-sizing: border-box; 
    z-index: 10;
}
.gallery-item:hover .btn-hapus { display: block; }

/* --- MODAL GAMBAR --- */
.modal { 
    display: none; position: fixed; z-index: 99999; padding-top: 50px; left: 0; top: 0; 
    width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.85); backdrop-filter: blur(8px); 
}
.modal-content { 
    margin: auto; display: block; max-width: 90%; max-height: 80vh; object-fit: contain; 
    border-radius: 10px; box-shadow: 0 0 20px rgba(255, 255, 255, 0.2); animation: zoomIn 0.3s ease; 
}
.close-modal { 
    position: absolute; top: 20px; right: 40px; color: #ffffff; font-size: 50px; font-weight: bold; cursor: pointer; 
}
.close-modal:hover { color: var(--secondary-color); }

/* --- ANIMASI DASAR --- */
@keyframes zoomIn { from { transform: scale(0.7); opacity: 0; } to { transform: scale(1); opacity: 1; } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

/* =========================================================
   ANIMASI BUNGA MAGIS (TIDAK ADA YANG DIUBAH)
   ========================================================= */
.night-garden { position: relative; display: flex; align-items: flex-end; justify-content: center; height: 60vh; min-height: 400px; background-color: #000; overflow: hidden; perspective: 1000px; border-radius: 15px; box-shadow: 0 10px 30px rgba(0,0,0,0.5); }
.night-garden .night { position: absolute; left: 50%; top: 0; transform: translateX(-50%); width: 100%; height: 100%; filter: blur(0.1vmin); background-image: radial-gradient(ellipse at top, transparent 0%, #000), radial-gradient(ellipse at bottom, #000, rgba(145, 233, 255, 0.2)), repeating-linear-gradient(220deg, rgb(0, 0, 0) 0px, rgb(0, 0, 0) 19px, transparent 19px, transparent 22px), repeating-linear-gradient(189deg, rgb(0, 0, 0) 0px, rgb(0, 0, 0) 19px, transparent 19px, transparent 22px), repeating-linear-gradient(148deg, rgb(0, 0, 0) 0px, rgb(0, 0, 0) 19px, transparent 19px, transparent 22px), linear-gradient(90deg, rgb(0, 255, 250), rgb(240, 240, 240)); }
.night-garden .flowers { position: relative; transform: scale(0.45) !important; transform-origin: bottom center !important; bottom: 12vmin !important; }
.night-garden .flower { position: absolute; bottom: 10vmin; transform-origin: bottom center; z-index: 10; --fl-speed: 0.8s; }
.night-garden .flower--1 { animation: moving-flower-1 4s linear infinite; }
.night-garden .flower--1 .flower__line { height: 70vmin; animation-delay: 0.3s; }
.night-garden .flower--1 .flower__line__leaf--1 { animation: blooming-leaf-right var(--fl-speed) 1.6s backwards; }
.night-garden .flower--1 .flower__line__leaf--2 { animation: blooming-leaf-right var(--fl-speed) 1.4s backwards; }
.night-garden .flower--1 .flower__line__leaf--3 { animation: blooming-leaf-left var(--fl-speed) 1.2s backwards; }
.night-garden .flower--1 .flower__line__leaf--4 { animation: blooming-leaf-left var(--fl-speed) 1s backwards; }
.night-garden .flower--1 .flower__line__leaf--5 { animation: blooming-leaf-right var(--fl-speed) 1.8s backwards; }
.night-garden .flower--1 .flower__line__leaf--6 { animation: blooming-leaf-left var(--fl-speed) 2s backwards; }
.night-garden .flower--2 { left: 50%; transform: rotate(20deg); animation: moving-flower-2 4s linear infinite; }
.night-garden .flower--2 .flower__line { height: 60vmin; animation-delay: 0.6s; }
.night-garden .flower--2 .flower__line__leaf--1 { animation: blooming-leaf-right var(--fl-speed) 1.9s backwards; }
.night-garden .flower--2 .flower__line__leaf--2 { animation: blooming-leaf-right var(--fl-speed) 1.7s backwards; }
.night-garden .flower--2 .flower__line__leaf--3 { animation: blooming-leaf-left var(--fl-speed) 1.5s backwards; }
.night-garden .flower--2 .flower__line__leaf--4 { animation: blooming-leaf-left var(--fl-speed) 1.3s backwards; }
.night-garden .flower--3 { left: 50%; transform: rotate(-15deg); animation: moving-flower-3 4s linear infinite; }
.night-garden .flower--3 .flower__line { animation-delay: 0.9s; }
.night-garden .flower--3 .flower__line__leaf--1 { animation: blooming-leaf-right var(--fl-speed) 2.5s backwards; }
.night-garden .flower--3 .flower__line__leaf--2 { animation: blooming-leaf-right var(--fl-speed) 2.3s backwards; }
.night-garden .flower--3 .flower__line__leaf--3 { animation: blooming-leaf-left var(--fl-speed) 2.1s backwards; }
.night-garden .flower--3 .flower__line__leaf--4 { animation: blooming-leaf-left var(--fl-speed) 1.9s backwards; }
.night-garden .flower__leafs { position: relative; animation: blooming-flower 2s backwards; }
.night-garden .flower__leafs--1 { animation-delay: 1.1s; }
.night-garden .flower__leafs--2 { animation-delay: 1.4s; }
.night-garden .flower__leafs--3 { animation-delay: 1.7s; }
.night-garden .flower__leafs::after { content: ""; position: absolute; left: 0; top: 0; transform: translate(-50%, -100%); width: 8vmin; height: 8vmin; background-color: #6bf0ff; filter: blur(10vmin); }
.night-garden .flower__leaf { position: absolute; bottom: 0; left: 50%; width: 8vmin; height: 11vmin; border-radius: 51% 49% 47% 53% / 44% 45% 55% 69%; background-color: #800000; background-image: linear-gradient(to top, #4a0000, #b30000); transform-origin: bottom center; opacity: 0.9; box-shadow: inset 0 0 2vmin rgba(255, 255, 255, 0.5); }
.night-garden .flower__leaf--1 { transform: translate(-10%, 1%) rotateY(40deg) rotateX(-50deg); }
.night-garden .flower__leaf--2 { transform: translate(-50%, -4%) rotateX(40deg); }
.night-garden .flower__leaf--3 { transform: translate(-90%, 0%) rotateY(45deg) rotateX(50deg); }
.night-garden .flower__leaf--4 { width: 8vmin; height: 8vmin; transform-origin: bottom left; border-radius: 4vmin 10vmin 4vmin 4vmin; transform: translate(0%, 18%) rotateX(70deg) rotate(-43deg); background-image: linear-gradient(to top, #660000, #b30000); z-index: 1; opacity: 0.8; }
.night-garden .flower__white-circle { position: absolute; left: -3.5vmin; top: -3vmin; width: 9vmin; height: 4vmin; border-radius: 50%; background-color: #fff; }
.night-garden .flower__white-circle::after { content: ""; position: absolute; left: 50%; top: 45%; transform: translate(-50%, -50%); width: 60%; height: 60%; border-radius: inherit; background-image: repeating-linear-gradient(135deg, rgba(0,0,0,0.03) 0px, rgba(0,0,0,0.03) 1px, transparent 1px, transparent 12px), linear-gradient(90deg, rgb(255, 235, 18), rgb(255, 206, 0)); }
.night-garden .flower__line { height: 55vmin; width: 1.5vmin; background-image: linear-gradient(to left, rgba(0,0,0,0.2), transparent, rgba(255,255,255,0.2)), linear-gradient(to top, transparent 10%, #5C4033, #8B4513); box-shadow: inset 0 0 2px rgba(0,0,0,0.5); animation: grow-flower-tree 4s backwards; }
.night-garden .flower__line__leaf { --w: 7vmin; --h: calc(var(--w) + 2vmin); position: absolute; top: 20%; left: 90%; width: var(--w); height: var(--h); border-top-right-radius: var(--h); border-bottom-left-radius: var(--h); background-image: linear-gradient(to top, rgba(92,64,51,0.4), #8B4513); }
.night-garden .flower__line__leaf--1 { transform: rotate(70deg) rotateY(30deg); }
.night-garden .flower__line__leaf--2 { top: 45%; transform: rotate(70deg) rotateY(30deg); }
.night-garden .flower__line__leaf--3, .night-garden .flower__line__leaf--4, .night-garden .flower__line__leaf--6 { border-top-right-radius: 0; border-bottom-left-radius: 0; border-top-left-radius: var(--h); border-bottom-right-radius: var(--h); left: -460%; top: 12%; transform: rotate(-70deg) rotateY(30deg); }
.night-garden .flower__line__leaf--4 { top: 40%; }
.night-garden .flower__line__leaf--5 { top: 0; transform-origin: left; transform: rotate(70deg) rotateY(30deg) scale(0.6); }
.night-garden .flower__line__leaf--6 { top: -2%; left: -450%; transform-origin: right; transform: rotate(-70deg) rotateY(30deg) scale(0.6); }
.night-garden .flower__light { position: absolute; bottom: 0vmin; width: 1vmin; height: 1vmin; background-color: rgb(255, 251, 0); border-radius: 50%; filter: blur(0.2vmin); animation: light-ans 4s linear infinite backwards; }
.night-garden .flower__light:nth-child(odd) { background-color: #23f0ff; }
.night-garden .flower__light--1 { left: -2vmin; animation-delay: 1s; }
.night-garden .flower__light--2 { left: 3vmin; animation-delay: 0.5s; }
.night-garden .flower__light--3 { left: -6vmin; animation-delay: 0.3s; }
.night-garden .flower__light--4 { left: 6vmin; animation-delay: 0.9s; }
.night-garden .flower__light--5 { left: -1vmin; animation-delay: 1.5s; }
.night-garden .flower__light--6 { left: -4vmin; animation-delay: 3s; }
.night-garden .flower__light--7 { left: 3vmin; animation-delay: 2s; }
.night-garden .flower__light--8 { left: -6vmin; animation-delay: 3.5s; }
.night-garden .grow-ans { animation: grow-ans 2s var(--d) backwards; }
.night-garden .not-loaded * { animation-play-state: paused !important; }
.night-garden .growing-grass { animation: growing-grass-ans 1s 2s backwards; }
.night-garden .flower__grass { --c: #8B4513; --line-w: 1.5vmin; position: absolute; bottom: 12vmin; left: -7vmin; display: flex; flex-direction: column; align-items: flex-end; z-index: 20; transform-origin: bottom center; transform: rotate(-48deg) rotateY(40deg); }
.night-garden .flower__grass--1 { animation: moving-grass 2s linear infinite; }
.night-garden .flower__grass--2 { left: 2vmin; bottom: 10vmin; transform: scale(0.5) rotate(75deg) rotateX(10deg) rotateY(-200deg); opacity: 0.8; z-index: 0; animation: moving-grass--2 1.5s linear infinite; }
.night-garden .flower__grass--top { width: 7vmin; height: 10vmin; border-top-right-radius: 100%; border-right: var(--line-w) solid var(--c); transform-origin: bottom center; transform: rotate(-2deg); }
.night-garden .flower__grass--bottom { margin-top: -2px; width: var(--line-w); height: 25vmin; background-image: linear-gradient(to top, transparent, var(--c)); }
.night-garden .flower__grass__leaf { --size: 10vmin; position: absolute; width: calc(var(--size) * 2.1); height: var(--size); border-top-left-radius: var(--size); border-top-right-radius: var(--size); background-image: linear-gradient(to top, transparent, transparent 30%, var(--c)); z-index: 100; }
.night-garden .flower__grass__leaf--1 { top: -6%; left: 30%; --size: 6vmin; transform: rotate(-20deg); animation: growing-grass-ans--1 2s 2.6s backwards; }
.night-garden .flower__grass__leaf--2 { top: -5%; left: -110%; --size: 6vmin; transform: rotate(10deg); animation: growing-grass-ans--2 2s 2.4s linear backwards; }
.night-garden .flower__grass__leaf--3 { top: 5%; left: 60%; --size: 8vmin; transform: rotate(-18deg) rotateX(-20deg); animation: growing-grass-ans--3 2s 2.2s linear backwards; }
.night-garden .flower__grass__leaf--4 { top: 6%; left: -135%; --size: 8vmin; transform: rotate(2deg); animation: growing-grass-ans--4 2s 2s linear backwards; }
.night-garden .flower__grass__leaf--5 { top: 20%; left: 60%; --size: 10vmin; transform: rotate(-24deg) rotateX(-20deg); animation: growing-grass-ans--5 2s 1.8s linear backwards; }
.night-garden .flower__grass__leaf--6 { top: 22%; left: -180%; --size: 10vmin; transform: rotate(10deg); animation: growing-grass-ans--6 2s 1.6s linear backwards; }
.night-garden .flower__grass__leaf--7 { top: 39%; left: 70%; --size: 10vmin; transform: rotate(-10deg); animation: growing-grass-ans--7 2s 1.4s linear backwards; }
.night-garden .flower__grass__leaf--8 { top: 40%; left: -215%; --size: 11vmin; transform: rotate(10deg); animation: growing-grass-ans--8 2s 1.2s linear backwards; }
.night-garden .flower__grass__overlay { position: absolute; top: -10%; right: 0%; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.6); filter: blur(1.5vmin); z-index: 100; }
.night-garden .long-g { position: absolute; bottom: 25vmin; left: -42vmin; transform-origin: bottom left; }
.night-garden .long-g--1 { bottom: 0vmin; transform: scale(0.8) rotate(-5deg); }
.night-garden .long-g--1 .leaf, .night-garden .long-g--2 .leaf, .night-garden .long-g--3 .leaf, .night-garden .long-g--4 .leaf { -webkit-mask-image: linear-gradient(to top, transparent 40%, #5C4033 80%) !important; }
.night-garden .long-g--1 .leaf--1 { --w: 5vmin; --h: 60vmin; left: -2vmin; transform: rotate(3deg) rotateY(-180deg); }
.night-garden .long-g--2, .night-garden .long-g--3 { bottom: -3vmin; left: -35vmin; transform-origin: center; transform: scale(0.6) rotateX(60deg); }
.night-garden .long-g--2 .leaf--1, .night-garden .long-g--3 .leaf--1 { left: -1vmin; transform: rotateY(-180deg); }
.night-garden .long-g--3 { left: -17vmin; bottom: 0vmin; }
.night-garden .long-g--4 { left: 25vmin; bottom: -3vmin; transform-origin: center; transform: scale(0.6) rotateX(60deg); }
.night-garden .long-g--5 { left: 42vmin; bottom: 0vmin; transform: scale(0.8) rotate(2deg); }
.night-garden .long-g--6 { left: 0vmin; bottom: -20vmin; z-index: 100; filter: blur(0.3vmin); transform: scale(0.8) rotate(2deg); }
.night-garden .long-g--7 { left: 35vmin; bottom: 20vmin; z-index: -1; filter: blur(0.3vmin); transform: scale(0.6) rotate(2deg); opacity: 0.7; }
.night-garden .long-g .leaf { --w: 15vmin; --h: 40vmin; --c: #5C4033; position: absolute; bottom: 0; width: var(--w); height: var(--h); border-top-left-radius: 100%; border-left: 2vmin solid var(--c); -webkit-mask-image: linear-gradient(to top, transparent 20%, #000); transform-origin: bottom center; }
.night-garden .long-g .leaf--0 { left: 2vmin; animation: leaf-ans-1 4s linear infinite; }
.night-garden .long-g .leaf--1 { --w: 5vmin; --h: 60vmin; animation: leaf-ans-1 4s linear infinite; }
.night-garden .long-g .leaf--2 { --w: 10vmin; --h: 40vmin; left: -0.5vmin; bottom: 5vmin; transform-origin: bottom left; transform: rotateY(-180deg); animation: leaf-ans-2 3s linear infinite; }
.night-garden .long-g .leaf--3 { --w: 5vmin; --h: 30vmin; left: -1vmin; bottom: 3.2vmin; transform-origin: bottom left; transform: rotate(-10deg) rotateY(-180deg); animation: leaf-ans-3 3s linear infinite; }

@keyframes moving-flower-1 { 0%, 100% { transform: rotate(2deg); } 50% { transform: rotate(-2deg); } }
@keyframes moving-flower-2 { 0%, 100% { transform: rotate(18deg); } 50% { transform: rotate(14deg); } }
@keyframes moving-flower-3 { 0%, 100% { transform: rotate(-18deg); } 50% { transform: rotate(-20deg) rotateY(-10deg); } }
@keyframes blooming-leaf-right { 0% { transform-origin: left; transform: rotate(70deg) rotateY(30deg) scale(0); } }
@keyframes blooming-leaf-left { 0% { transform-origin: right; transform: rotate(-70deg) rotateY(30deg) scale(0); } }
@keyframes grow-flower-tree { 0% { height: 0; border-radius: 1vmin; } }
@keyframes blooming-flower { 0% { transform: scale(0); } }
@keyframes grow-ans { 0% { transform: scale(0); opacity: 0; } }
@keyframes light-ans { 0% { opacity: 0; transform: translateY(0vmin); } 25% { opacity: 1; transform: translateY(-5vmin) translateX(-2vmin); } 50% { opacity: 1; transform: translateY(-15vmin) translateX(2vmin); filter: blur(0.2vmin); } 75% { transform: translateY(-20vmin) translateX(-2vmin); filter: blur(0.2vmin); } 100% { transform: translateY(-30vmin); opacity: 0; filter: blur(1vmin); } }
@keyframes growing-grass-ans--1 { 0% { transform-origin: bottom left; transform: rotate(-20deg) scale(0); } }
@keyframes growing-grass-ans--2 { 0% { transform-origin: bottom right; transform: rotate(10deg) scale(0); } }
@keyframes growing-grass-ans--3 { 0% { transform-origin: bottom left; transform: rotate(-18deg) rotateX(-20deg) scale(0); } }
@keyframes growing-grass-ans--4 { 0% { transform-origin: bottom right; transform: rotate(2deg) scale(0); } }
@keyframes growing-grass-ans--5 { 0% { transform-origin: bottom left; transform: rotate(-24deg) rotateX(-20deg) scale(0); } }
@keyframes growing-grass-ans--6 { 0% { transform-origin: bottom right; transform: rotate(10deg) scale(0); } }
@keyframes growing-grass-ans--7 { 0% { transform-origin: bottom left; transform: rotate(-10deg) scale(0); } }
@keyframes growing-grass-ans--8 { 0% { transform-origin: bottom right; transform: rotate(10deg) scale(0); } }
@keyframes moving-grass { 0%, 100% { transform: rotate(-48deg) rotateY(40deg); } 50% { transform: rotate(-50deg) rotateY(40deg); } }
@keyframes moving-grass--2 { 0%, 100% { transform: scale(0.5) rotate(75deg) rotateX(10deg) rotateY(-200deg); } 50% { transform: scale(0.5) rotate(79deg) rotateX(10deg) rotateY(-200deg); } }
@keyframes growing-grass-ans { 0% { transform: scale(0); } }
@keyframes leaf-ans-1 { 0%, 100% { transform: rotate(-5deg) scale(1); } 50% { transform: rotate(5deg) scale(1.1); } }
@keyframes leaf-ans-2 { 0%, 100% { transform: rotateY(-180deg) rotate(5deg); } 50% { transform: rotateY(-180deg) rotate(0deg) scale(1.1); } }
@keyframes leaf-ans-3 { 0%, 100% { transform: rotate(-10deg) rotateY(-180deg); } 50% { transform: rotate(-20deg) rotateY(-180deg); } }

/* --- FITUR LIHAT KATA SANDI --- */
.password-wrapper { position: relative; width: 100%; margin: 10px 0; }
.password-wrapper input { margin: 0; padding-right: 40px; }
#toggle-sandi { position: absolute; right: 15px; top: 50%; transform: translateY(-50%); cursor: pointer; color: var(--text-dark); transition: 0.3s ease; }
#toggle-sandi:hover { color: var(--secondary-color); }

/* --- YOUTUBE MUSIC STYLE PLAYER --- */
#yt-music-player {
    position: fixed; bottom: 20px; right: 20px;
    background: rgba(20, 20, 20, 0.9); 
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 12px;
    padding: 10px 15px; display: none; z-index: 99999;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5); width: 280px; transition: all 0.3s ease;
}

.player-content { display: flex; align-items: center; gap: 12px; }

#track-cover {
    width: 45px; height: 45px; border-radius: 50%; object-fit: cover;
    border: 2px solid var(--secondary-color);
    animation: spinCover 5s linear infinite; animation-play-state: paused; 
}

.track-info { flex: 1; overflow: hidden; white-space: nowrap; }
.track-title { color: #ffffff; font-size: 14px; font-weight: bold; text-overflow: ellipsis; overflow: hidden; text-shadow: none; }
.track-artist { color: #aaaaaa; font-size: 12px; text-overflow: ellipsis; overflow: hidden; text-shadow: none; }

.player-controls { display: flex; gap: 12px; align-items: center; }
.player-controls button {
    background: none; border: none; color: #ffffff; font-size: 16px;
    cursor: pointer; padding: 0; margin: 0; transition: color 0.2s; box-shadow: none;
}
.player-controls button:hover { color: var(--secondary-color); background: none; }
#play-pause-btn { font-size: 22px; }

@keyframes spinCover { 100% { transform: rotate(360deg); } }

/* --- RESPONSIVE MOBILE --- */
nav, header, .nav-menu, .menu, ul { position: relative !important; z-index: 9999 !important; }
.container, .tab-content { position: relative; z-index: 1 !important; }

@media screen and (max-width: 768px) {
    .container { width: 90%; margin-top: 20px; padding: 15px; }
    /* 2. Menyesuaikan Galeri Foto (Jadi 2 baris agar muat di HP) */
    .gallery-grid {
        column-count: 2;
        column-gap: 10px;
        display: block;
    }
    #yt-music-player { width: 90%; right: 5%; bottom: 15px; z-index: 9998; }
    #puzzle-modal > div { width: 90% !important; padding: 20px !important; }
    #puzzle-modal span { font-size: 13px; word-break: break-all; display: block; }
}

@media screen and (max-width: 768px) {
    .gallery-grid { grid-template-columns: 1fr; }
}