/* Menggunakan font Inter */
html, body { height: 100%; }
body {
  font-family: Inter, sans-serif;
  height: 100dvh;
  overflow: hidden;
  background: #0f0f12;
  color: #e0e0e0;
  display: flex;
  flex-direction: column;
}
.gradient-bg { position: absolute; inset: 0; overflow: hidden; z-index: -1; filter: blur(100px); }
.blob { position: absolute; border-radius: 9999px; opacity: .5; }
@keyframes move1 {0%,100%{transform:translate(-20%,15%) scale(1.2);}50%{transform:translate(20%,-20%) scale(1.8);}}
@keyframes move2 {0%,100%{transform:translate(15%,-25%) scale(1);}50%{transform:translate(-25%,20%) scale(1.6);}}
@keyframes move3 {0%,100%{transform:translate(25%,20%) scale(.9);}50%{transform:translate(-15%,-20%) scale(1.5);}}
@keyframes move4 {0%,100%{transform:translate(-20%,-15%) scale(1);}50%{transform:translate(15%,20%) scale(1.7);}}
.blob1{animation:move1 25s infinite alternate;}
.blob2{animation:move2 30s infinite alternate;}
.blob3{animation:move3 28s infinite alternate;}
.blob4{animation:move4 32s infinite alternate;}

/* Video Container */
.video-container { 
  width: 90%; 
  max-width: 320px; 
  aspect-ratio: 9/19.5; 
  border-radius: 26px; 
  background: #111; 
  box-shadow: 0 8px 30px rgba(0,0,0,.35); 
  position: relative; 
  overflow: hidden; 
  margin: 0 auto; 
}
.video-container video { width: 100%; height: 100%; object-fit: cover; }

/* Slider Structure */
main.roll-container { flex: 1 1 auto; min-height: 0; position: relative; overflow: hidden; display: flex; justify-content: center; }
.roll-slider { position: relative; display: flex; flex-direction: column; width: 100%; will-change: transform; }

.roll-slide { 
  width: 100%; 
  flex-shrink: 0; 
  height: 100%;
  overflow-y: auto;
  padding: 2rem 0; 

  /* --- TAMBAHAN UNTUK CENTER V --- */
  display: flex;
  flex-direction: column;
  justify-content: center;
  /* --- AKHIR TAMBAHAN --- */
}
.roll-slide.active { 
  /* Tidak perlu apa-apa di sini */
}

.slide-content-wrapper {
  display: flex;
  flex-direction: column;
  width: 100%;
  transform: scale(0.9);
  opacity: 0.5;
  transition: opacity 0.4s, transform 0.4s;
}
.roll-slide.active .slide-content-wrapper {
  transform: scale(1);
  opacity: 1;
}
@media (min-width: 768px) { /* md: */
  .slide-content-wrapper {
    flex-direction: row;
  }
}

/* Text Animation Target */
.text-slide h2 span, .text-slide p span, .text-slide li span { display:inline-block; opacity:0; transform: translateY(10px); }

/* Custom List Item (Bullet) */
.text-slide ul{ list-style: none; padding-left: 0; }
.text-slide li{
  position: relative;
  padding-left: 1.25rem;
  --bScale: 0;
  --bAlpha: 0;
  --bY: 6px;
}
.text-slide li::before{
  content: "";
  position: absolute; left: 0; top: 0.6em;
  width: 0.5rem; height: 0.5rem; border-radius: 9999px; 
  background: #ffffff;
  transform: translateY(var(--bY)) scale(var(--bScale));
  opacity: var(--bAlpha);
  transition: none;
}

/* Marquee */
.marquee-container{ position:relative; height:4rem; overflow:hidden; display:flex; align-items:center; z-index:10; flex-shrink:0; }
.marquee-content{ display:inline-block; white-space:nowrap; animation:scrollLeft 30s linear infinite; font-size:.875rem; color:#6b7280; text-transform:uppercase; letter-spacing:.05em; }
.marquee-content span{ margin:0 .5rem; }
@keyframes scrollLeft{ from{transform:translateX(0%);} to{transform:translateX(-50%);} }