|
|
|
html, |
|
body { |
|
margin: 0; |
|
padding: 0; |
|
width: 100%; |
|
height: 100%; |
|
overflow-x: hidden; |
|
box-sizing: border-box; |
|
} |
|
|
|
body { |
|
|
|
background: linear-gradient(135deg, #175344, #1e604d); |
|
font-family: "Arial", sans-serif; |
|
font-size: 1rem; |
|
} |
|
|
|
|
|
.card { |
|
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); |
|
border: none; |
|
} |
|
|
|
|
|
@keyframes twinkle { |
|
0%, |
|
100% { |
|
opacity: 0.8; |
|
transform: scale(1); |
|
} |
|
50% { |
|
opacity: 1; |
|
transform: scale(1.2); |
|
} |
|
} |
|
|
|
|
|
.star { |
|
position: absolute; |
|
background: #fff; |
|
border-radius: 50%; |
|
width: 2px; |
|
height: 2px; |
|
animation: twinkle 2s infinite ease-in-out; |
|
} |
|
|
|
|
|
.eid-ketupat { |
|
position: absolute; |
|
z-index: 2; |
|
width: 80px; |
|
height: 80px; |
|
background: #32cd32; |
|
|
|
clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); |
|
border: 2px solid #006400; |
|
border-radius: 5px; |
|
animation: swing 3s ease-in-out infinite; |
|
} |
|
|
|
|
|
.eid-lantern { |
|
position: absolute; |
|
z-index: 2; |
|
width: 50px; |
|
height: 70px; |
|
background: #ffcc00; |
|
border: 2px solid #ff9900; |
|
border-radius: 10px; |
|
box-shadow: 0 0 10px rgba(255, 204, 0, 0.9); |
|
animation: swing 2.5s ease-in-out infinite, blink 1.5s ease-in-out infinite; |
|
} |
|
|
|
|
|
@keyframes swing { |
|
0% { |
|
transform: translateY(0) rotate(0deg); |
|
} |
|
25% { |
|
transform: translateY(-5px) rotate(5deg); |
|
} |
|
50% { |
|
transform: translateY(0) rotate(0deg); |
|
} |
|
75% { |
|
transform: translateY(5px) rotate(-5deg); |
|
} |
|
100% { |
|
transform: translateY(0) rotate(0deg); |
|
} |
|
} |
|
|
|
|
|
@keyframes blink { |
|
0%, |
|
100% { |
|
opacity: 1; |
|
} |
|
50% { |
|
opacity: 0.5; |
|
} |
|
} |
|
|
|
|
|
#threeCanvas, |
|
#tunnelCanvas { |
|
position: fixed; |
|
top: 0; |
|
left: 0; |
|
width: 100vw; |
|
height: 100vh; |
|
z-index: -1; |
|
display: block; |
|
} |
|
|
|
|
|
#background-video { |
|
position: fixed; |
|
right: 0; |
|
bottom: 0; |
|
min-width: 100%; |
|
min-height: 100%; |
|
width: auto; |
|
height: auto; |
|
z-index: -1; |
|
object-fit: cover; |
|
filter: opacity(0.99); |
|
} |
|
|
|
.child-container { |
|
text-align: center; |
|
margin: 0 auto; |
|
} |
|
|
|
.img-fluid { |
|
margin: 5px; |
|
width: 250px; |
|
height: auto; |
|
object-fit: cover; |
|
} |
|
|