/* ============================================
   SEGORO TOPENG KALIWUNGU 2026
   STYLE.CSS — FULL REDESIGN
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Great+Vibes&family=Lato:wght@300;400;700&display=swap');

/* ---- VARIABLES ---- */
:root {
  --merah-tua:   #5C0000;
  --merah-gelap: #7A0000;
  --merah-mid:   #9B1A1A;
  --emas:        #C9A84C;
  --emas-muda:   #E8C97A;
  --emas-gelap:  #9C7A2C;
  --putih:       #FFFFFF;
  --teks-muda:   #F5E6CC;
  --card-bg:     rgba(255,255,255,0.07);
  --card-border: rgba(201,168,76,0.28);
  --shadow-emas: 0 4px 20px rgba(201,168,76,0.35);
  --radius:      14px;
  --radius-sm:   10px;
  --transition:  all 0.3s cubic-bezier(0.4,0,0.2,1);
}

/* ---- RESET ---- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:'Lato',sans-serif; background:#1A0000; color:var(--teks-muda); min-height:100vh; overflow-x:hidden; }
button { font-family:inherit; cursor:pointer; }
input,textarea,select { font-family:inherit; }

/* ============================================
   LOADING SCREEN
   ============================================ */
#loading-screen {
  position:fixed; inset:0; background:linear-gradient(180deg,#3D0000,#0A0000);
  z-index:9999; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:20px;
  transition:opacity 0.8s ease, visibility 0.8s ease;
}
#loading-screen.fade-out { opacity:0; visibility:hidden; pointer-events:none; }
.loading-title-img { width:220px; height:auto; mix-blend-mode:screen; animation:pulse-glow 1.5s ease-in-out infinite; }
@keyframes pulse-glow {
  0%,100% { filter:drop-shadow(0 0 10px rgba(201,168,76,0.4)); }
  50%      { filter:drop-shadow(0 0 28px rgba(201,168,76,0.9)); }
}
.loading-bar { width:200px; height:3px; background:rgba(201,168,76,0.2); border-radius:99px; overflow:hidden; margin-top:8px; }
.loading-bar-fill { height:100%; background:linear-gradient(90deg,var(--emas-gelap),var(--emas),var(--emas-muda)); border-radius:99px; animation:load-progress 2.5s ease forwards; }
@keyframes load-progress { from{width:0} to{width:100%} }
.loading-text { font-family:'Cinzel',serif; font-size:0.7rem; letter-spacing:3px; color:rgba(201,168,76,0.6); animation:blink 1.4s ease-in-out infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.4} }

/* ============================================
   APP WRAPPER
   ============================================ */
#app { max-width:430px; margin:0 auto; min-height:100vh; background:linear-gradient(180deg,var(--merah-gelap) 0%,#3D0000 40%,#1A0000 100%); position:relative; }

/* ============================================
   HEADER
   ============================================ */
.app-header {
  position:sticky; top:0; z-index:100;
  background:linear-gradient(135deg,#2D0000,var(--merah-gelap));
  border-bottom:1px solid rgba(201,168,76,0.35);
  padding:12px 18px;
  display:flex; align-items:center; justify-content:space-between;
  box-shadow:0 2px 16px rgba(0,0,0,0.5);
}
.header-left { display:flex; align-items:center; gap:10px; }
.hamburger { background:none; border:none; padding:4px; display:flex; flex-direction:column; gap:5px; }
.hamburger span { display:block; width:20px; height:2px; background:var(--emas); border-radius:2px; }
.header-title .main-title { font-family:'Cinzel',serif; font-size:0.82rem; font-weight:700; color:var(--emas); letter-spacing:1px; display:block; line-height:1.2; }
.header-title .sub-title  { font-family:'Great Vibes',cursive; font-size:1rem; color:var(--emas-muda); display:block; line-height:1; }
.vvip-badge { background:linear-gradient(135deg,var(--emas-gelap),var(--emas),var(--emas-muda)); color:var(--merah-tua); font-family:'Cinzel',serif; font-weight:900; font-size:0.72rem; letter-spacing:1px; padding:5px 14px; border-radius:99px; box-shadow:var(--shadow-emas); }

/* ============================================
   PAGES
   ============================================ */
.page { display:none; min-height:calc(100vh - 130px); padding-bottom:90px; animation:fadeIn 0.35s ease; }
.page.active { display:block; }
@keyframes fadeIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }

/* ============================================
   COVER / BERANDA
   ============================================ */
#page-beranda { display:none; padding-bottom:0; }
#page-beranda.active { display:flex; flex-direction:column; }

.cover-wrap {
  min-height:100vh;
  background:linear-gradient(180deg,#4A0000 0%,#2D0000 50%,#1A0000 100%);
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
}

/* Background texture */
.cover-wrap::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 30%,rgba(201,168,76,0.07) 0%,transparent 60%);
  pointer-events:none;
}

/* --- SPONSOR BAR --- */
.sponsor-bar { position:relative; z-index:5; width:100%; flex-shrink:0; }
.sponsor-bar img { width:100%; display:block; max-height:64px; object-fit:cover; object-position:center; }

/* --- TOP ROW: logo + VVIP --- */
.cover-top-row {
  position:relative; z-index:4;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px 0;
}
.logo-bupati { display:flex; flex-direction:column; align-items:center; gap:4px; }
.logo-bupati img { width:52px; height:52px; object-fit:contain; filter:drop-shadow(0 2px 8px rgba(0,0,0,0.5)); }
.logo-bupati span { font-family:'Cinzel',serif; font-size:0.48rem; letter-spacing:1.5px; color:rgba(245,230,204,0.6); text-align:center; text-transform:uppercase; }
.cover-vvip { background:linear-gradient(135deg,var(--emas-gelap),var(--emas),var(--emas-muda)); color:var(--merah-tua); font-family:'Cinzel',serif; font-weight:900; font-size:0.9rem; letter-spacing:2px; padding:8px 20px; border-radius:99px; box-shadow:var(--shadow-emas); }

/* --- JUDUL AREA --- */
.cover-judul-area {
  position:relative; z-index:4;
  display:flex; flex-direction:column; align-items:flex-start;
  padding:12px 24px 0;
  align-items: center;
}
.cover-label-undangan { font-family:'Great Vibes',cursive; font-size:1.6rem; color:var(--emas-muda); line-height:1; margin-bottom:2px; }
.cover-teks-besar { font-family:'Cinzel',serif; font-weight:900; font-size:2.6rem; line-height:0.95; color:var(--putih); text-shadow:0 2px 16px rgba(0,0,0,0.6); letter-spacing:1px; }
.cover-script { font-family:'Great Vibes',cursive; font-size:3rem; color:var(--emas); text-shadow:0 2px 16px rgba(201,168,76,0.5); line-height:1; margin-top:-4px; }
.cover-tahun { font-family:'Cinzel',serif; font-size:1.4rem; font-weight:700; color:var(--putih); letter-spacing:4px; margin-top:2px; }

/* --- PENARI IMAGE --- */
.cover-penari-wrap {
  position:relative; z-index:3;
  width:100%; margin-top:-20px;
  display:flex; justify-content:center;
  /* Gambar penari menyatu dgn background */
}
.cover-penari-wrap img {
  width:100%; max-width:430px;
  height:auto; display:block;
  mix-blend-mode:screen;
  filter:brightness(1.05) contrast(1.05) drop-shadow(0 -8px 24px rgba(107,0,0,0.5));
  animation:penariFloat 5s ease-in-out infinite;
}
@keyframes penariFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

/* --- COVER BOTTOM --- */
.cover-bottom {
  position:relative; z-index:4;
  display:flex; flex-direction:column; align-items:center;
  padding:0 24px 28px; text-align:center;
  margin-top:-40px; /* overlap ke atas gambar penari */
}
.cover-kepada { font-size:0.82rem; color:rgba(245,230,204,0.7); line-height:1.6; margin-bottom:4px; }
.cover-nama { font-family:'Cinzel',serif; font-size:1.4rem; font-weight:700; color:var(--emas); letter-spacing:1px; margin:4px 0 10px; text-shadow:var(--shadow-emas); }
.cover-divider { display:flex; align-items:center; gap:8px; width:100%; margin-bottom:10px; }
.cover-divider .line { flex:1; height:1px; background:linear-gradient(90deg,transparent,var(--emas-gelap)); }
.cover-divider .line.r { background:linear-gradient(90deg,var(--emas-gelap),transparent); }
.cover-divider .dot { width:5px; height:5px; background:var(--emas); border-radius:50%; }
.cover-dengan-hormat { font-size:0.78rem; color:rgba(245,230,204,0.6); line-height:1.6; margin-bottom:4px; }
.cover-event-name { font-family:'Great Vibes',cursive; font-size:1.2rem; color:var(--emas); margin-bottom:2px; }
.cover-event-sub { font-size:0.75rem; color:rgba(245,230,204,0.55); margin-bottom:20px; }

/* --- TOMBOL BUKA UNDANGAN --- */
.btn-buka {
  display:flex; align-items:center; justify-content:space-between;
  background:linear-gradient(135deg,var(--emas-gelap),var(--emas),var(--emas-muda));
  color:var(--merah-tua); border:none; border-radius:99px;
  padding:15px 24px; width:100%;
  font-family:'Cinzel',serif; font-weight:700; font-size:0.88rem; letter-spacing:2px;
  box-shadow:var(--shadow-emas); transition:var(--transition); position:relative; overflow:hidden;
}
.btn-buka:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(201,168,76,0.5); }
.btn-buka .arrow { width:34px; height:34px; background:var(--merah-tua); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--emas); font-size:1.1rem; }

/* --- ORNAMENT BAWAH COVER --- */
.cover-ornament-bottom { position:relative; z-index:4; text-align:center; padding:0 24px 16px; }
.cover-ornament-bottom img { width:55%; max-width:200px; mix-blend-mode:screen; opacity:0.9; }

/* ============================================
   PAGE HEADER (semua halaman dalam)
   ============================================ */
.page-header { text-align:center; padding:28px 20px 20px; }
.page-title { font-family:'Cinzel',serif; font-size:1rem; font-weight:700; color:var(--emas); letter-spacing:3px; text-transform:uppercase; }
.ornament-line { display:flex; align-items:center; gap:8px; margin:8px auto 0; width:fit-content; }
.ornament-line .line { width:50px; height:1px; background:linear-gradient(90deg,transparent,var(--emas)); }
.ornament-line .line.r { background:linear-gradient(90deg,var(--emas),transparent); }
.ornament-line .diamond { width:5px; height:5px; background:var(--emas); transform:rotate(45deg); }

/* ============================================
   INFO CARDS
   ============================================ */
.info-cards { padding:0 18px; display:flex; flex-direction:column; gap:12px; }
.info-card {
  background:var(--card-bg); border:1px solid var(--card-border);
  border-radius:var(--radius); padding:16px 18px;
  display:flex; align-items:center; gap:14px;
  transition:var(--transition);
}
.info-card:hover { border-color:rgba(201,168,76,0.55); transform:translateX(3px); }
.info-icon { width:46px; height:46px; background:linear-gradient(135deg,var(--merah-gelap),var(--merah-tua)); border:1px solid var(--card-border); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; flex-shrink:0; }
.info-detail .label { font-family:'Cinzel',serif; font-size:0.62rem; letter-spacing:2px; color:var(--emas); text-transform:uppercase; margin-bottom:4px; }
.info-detail .value { font-size:0.92rem; font-weight:600; color:var(--putih); line-height:1.4; }

/* Tentang */
.tentang-section { margin:22px 18px 0; }
.section-title { font-family:'Cinzel',serif; font-size:0.92rem; font-weight:700; color:var(--emas); letter-spacing:2px; text-align:center; margin-bottom:6px; text-transform:uppercase; }
.tentang-text { background:var(--card-bg); border:1px solid var(--card-border); border-radius:var(--radius); padding:18px; font-size:0.86rem; line-height:1.8; color:rgba(245,230,204,0.85); text-align:center; }

/* Event image */
.event-image-section { margin:20px 0 0; overflow:hidden; }
.event-image-section img { width:100%; height:auto; display:block; }

/* ============================================
   RUNDOWN
   ============================================ */
.rundown-list { padding:0 22px; display:flex; flex-direction:column; position:relative; }
.rundown-list::before { content:''; position:absolute; left:34px; top:16px; bottom:16px; width:2px; background:linear-gradient(180deg,transparent,var(--emas),var(--emas),transparent); opacity:0.3; }
.rundown-item { display:flex; align-items:flex-start; gap:14px; padding:12px 0; animation:slideIn 0.4s ease both; }
@keyframes slideIn { from{opacity:0;transform:translateX(-16px)} to{opacity:1;transform:translateX(0)} }
.rundown-dot { width:12px; height:12px; background:linear-gradient(135deg,var(--emas-gelap),var(--emas)); border-radius:50%; flex-shrink:0; margin-top:4px; box-shadow:0 0 6px rgba(201,168,76,0.5); z-index:1; }
.rundown-detail { display:flex; flex-direction:column; gap:2px; }
.rundown-tanggal { font-size:0.68rem; color:var(--emas-muda); letter-spacing:0.5px; opacity:0.8; }
.rundown-jam { font-family:'Cinzel',serif; font-size:0.85rem; font-weight:700; color:var(--emas); }
.rundown-kegiatan { font-size:0.88rem; color:var(--teks-muda); line-height:1.4; }

/* Peta */
.peta-section { margin:20px 18px 0; }
.map-container { border-radius:var(--radius); overflow:hidden; border:1px solid var(--card-border); height:190px; background:#1a2a1a; display:flex; align-items:center; justify-content:center; flex-direction:column; gap:8px; color:rgba(201,168,76,0.6); font-size:0.8rem; }
.btn-maps { display:flex; align-items:center; justify-content:center; gap:10px; background:linear-gradient(135deg,var(--emas-gelap),var(--emas)); color:var(--merah-tua); border:none; border-radius:12px; padding:15px; font-family:'Cinzel',serif; font-weight:700; font-size:0.82rem; letter-spacing:1.5px; width:100%; margin-top:12px; transition:var(--transition); }
.btn-maps:hover { transform:translateY(-2px); box-shadow:var(--shadow-emas); }

/* ============================================
   RSVP / KONFIRMASI
   ============================================ */
.rsvp-section { padding:0 18px; }
.rsvp-desc { font-size:0.83rem; color:rgba(245,230,204,0.65); text-align:center; margin-bottom:22px; line-height:1.7; }
.rsvp-form { display:flex; flex-direction:column; gap:12px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group label { font-size:0.8rem; color:rgba(245,230,204,0.7); display:flex; align-items:center; gap:6px; }
.form-input { background:rgba(255,255,255,0.06); border:1px solid var(--card-border); border-radius:var(--radius-sm); padding:13px 15px; color:var(--putih); font-size:0.9rem; outline:none; transition:var(--transition); width:100%; }
.form-input::placeholder { color:rgba(245,230,204,0.25); }
.form-input:focus { border-color:var(--emas); background:rgba(255,255,255,0.1); }
.btn-hadir { display:flex; align-items:center; justify-content:center; gap:10px; background:linear-gradient(135deg,var(--emas-gelap),var(--emas)); color:var(--merah-tua); border:none; border-radius:99px; padding:15px; font-family:'Cinzel',serif; font-weight:700; font-size:0.88rem; letter-spacing:1.5px; width:100%; margin-top:6px; transition:var(--transition); }
.btn-hadir:hover { transform:translateY(-2px); box-shadow:var(--shadow-emas); }
.btn-tidak-hadir { display:flex; align-items:center; justify-content:center; gap:10px; background:transparent; color:var(--emas-muda); border:1px solid var(--card-border); border-radius:99px; padding:15px; font-family:'Cinzel',serif; font-weight:700; font-size:0.88rem; letter-spacing:1.5px; width:100%; transition:var(--transition); }
.btn-tidak-hadir:hover { border-color:var(--emas); background:rgba(201,168,76,0.08); }
.privacy-note { font-size:0.73rem; color:rgba(245,230,204,0.45); text-align:center; margin-top:10px; display:flex; align-items:center; justify-content:center; gap:6px; }

/* Buku Tamu */
.buku-tamu-section { padding:0 18px; }
.buku-intro { font-size:0.83rem; color:rgba(245,230,204,0.65); text-align:center; margin-bottom:18px; line-height:1.7; }
.pesan-list { display:flex; flex-direction:column; gap:12px; max-height:360px; overflow-y:auto; padding-right:2px; }
.pesan-list::-webkit-scrollbar { width:3px; }
.pesan-list::-webkit-scrollbar-thumb { background:var(--emas-gelap); border-radius:3px; }
.pesan-card { background:var(--card-bg); border:1px solid var(--card-border); border-radius:var(--radius); padding:14px; }
.pesan-header { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.avatar { width:38px; height:38px; background:linear-gradient(135deg,var(--merah-gelap),var(--merah-mid)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Cinzel',serif; font-weight:700; font-size:0.9rem; color:var(--emas-muda); flex-shrink:0; border:1px solid var(--card-border); }
.pesan-info .nama { font-weight:700; font-size:0.88rem; color:var(--putih); }
.pesan-info .jabatan { font-size:0.73rem; color:var(--emas-muda); }
.pesan-teks { font-size:0.83rem; line-height:1.65; color:rgba(245,230,204,0.82); font-style:italic; margin-bottom:6px; }
.pesan-waktu { font-size:0.7rem; color:rgba(245,230,204,0.38); }
.btn-tulis { display:flex; align-items:center; justify-content:center; gap:8px; background:linear-gradient(135deg,var(--emas-gelap),var(--emas)); color:var(--merah-tua); border:none; border-radius:12px; padding:15px; font-family:'Cinzel',serif; font-weight:700; font-size:0.82rem; letter-spacing:1.5px; width:100%; margin-top:14px; transition:var(--transition); }
.btn-tulis:hover { transform:translateY(-2px); box-shadow:var(--shadow-emas); }

/* QR */
.qr-section { padding:0 18px; }
.qr-intro { font-size:0.83rem; color:rgba(245,230,204,0.65); text-align:center; margin-bottom:20px; line-height:1.7; }
.qr-card { background:var(--putih); border-radius:var(--radius); padding:24px 20px; text-align:center; box-shadow:var(--shadow-emas); margin-bottom:16px; }
.qr-card .kat-label { font-family:'Cinzel',serif; font-size:1.5rem; font-weight:900; color:var(--merah-tua); letter-spacing:4px; margin-bottom:14px; }
.qr-code-box { width:170px; height:170px; margin:0 auto 14px; border:3px solid var(--merah-tua); border-radius:10px; overflow:hidden; display:flex; align-items:center; justify-content:center; background:#fff; }
.qr-kode { font-family:'Cinzel',serif; font-size:0.78rem; font-weight:700; color:var(--merah-tua); letter-spacing:1px; margin-bottom:3px; }
.qr-berlaku { font-size:0.76rem; color:rgba(107,0,0,0.65); }
.qr-nama-box { background:var(--card-bg); border:1px solid var(--card-border); border-radius:var(--radius); padding:18px; text-align:center; margin-bottom:14px; }
.qr-nama-box .lbl { font-family:'Cinzel',serif; font-size:0.65rem; letter-spacing:2px; color:var(--emas-muda); margin-bottom:6px; }
.qr-nama-box .nama { font-family:'Cinzel',serif; font-size:1.1rem; font-weight:700; color:var(--emas); }
.btn-dl-qr { display:flex; align-items:center; justify-content:center; gap:8px; background:linear-gradient(135deg,var(--emas-gelap),var(--emas)); color:var(--merah-tua); border:none; border-radius:12px; padding:15px; font-family:'Cinzel',serif; font-weight:700; font-size:0.82rem; letter-spacing:1.5px; width:100%; transition:var(--transition); }
.btn-dl-qr:hover { transform:translateY(-2px); box-shadow:var(--shadow-emas); }
.qr-deco { margin-top:18px; border-radius:var(--radius); overflow:hidden; height:110px; background:linear-gradient(135deg,var(--merah-gelap),var(--merah-tua)); display:flex; align-items:center; justify-content:center; }
.qr-deco img { height:100%; width:100%; object-fit:cover; mix-blend-mode:screen; opacity:0.7; }

/* ============================================
   BOTTOM NAV
   ============================================ */
.bottom-nav {
  position:fixed; bottom:0; left:50%; transform:translateX(-50%);
  width:100%; max-width:430px;
  background:linear-gradient(135deg,#1A0000,#0A0000);
  border-top:1px solid rgba(201,168,76,0.28);
  display:flex; z-index:200;
  padding:6px 0 max(6px,env(safe-area-inset-bottom));
}
.nav-item { flex:1; display:flex; flex-direction:column; align-items:center; gap:3px; padding:8px 4px; background:none; border:none; color:rgba(245,230,204,0.38); transition:var(--transition); position:relative; }
.nav-item.active { color:var(--emas); }
.nav-item.active::before { content:''; position:absolute; top:-1px; left:50%; transform:translateX(-50%); width:28px; height:2px; background:var(--emas); border-radius:0 0 4px 4px; }
.nav-icon { font-size:1.15rem; transition:var(--transition); }
.nav-item.active .nav-icon { transform:translateY(-2px); }
.nav-label { font-family:'Cinzel',serif; font-size:0.56rem; letter-spacing:0.5px; }

/* ============================================
   MODAL
   ============================================ */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.7); z-index:500; display:none; align-items:flex-end; justify-content:center; backdrop-filter:blur(4px); }
.modal-overlay.active { display:flex; }
.modal-sheet { background:linear-gradient(180deg,#3D0000,#1A0000); border:1px solid var(--card-border); border-bottom:none; border-radius:22px 22px 0 0; padding:24px 22px 36px; width:100%; max-width:430px; animation:slideUp 0.3s ease; }
@keyframes slideUp { from{transform:translateY(100%)} to{transform:translateY(0)} }
.modal-handle { width:38px; height:4px; background:rgba(201,168,76,0.35); border-radius:99px; margin:0 auto 18px; }
.modal-title { font-family:'Cinzel',serif; font-size:0.95rem; font-weight:700; color:var(--emas); letter-spacing:2px; text-align:center; margin-bottom:18px; }
.modal-form { display:flex; flex-direction:column; gap:12px; }
.btn-submit { display:flex; align-items:center; justify-content:center; gap:8px; background:linear-gradient(135deg,var(--emas-gelap),var(--emas)); color:var(--merah-tua); border:none; border-radius:12px; padding:14px; font-family:'Cinzel',serif; font-weight:700; font-size:0.82rem; letter-spacing:1.5px; width:100%; margin-top:6px; transition:var(--transition); }
.btn-submit:hover { transform:translateY(-2px); box-shadow:var(--shadow-emas); }
.btn-cancel { background:transparent; border:1px solid rgba(201,168,76,0.25); border-radius:10px; padding:12px; color:rgba(245,230,204,0.5); font-size:0.83rem; width:100%; transition:var(--transition); }
.btn-cancel:hover { border-color:var(--emas); color:var(--emas-muda); }

/* ============================================
   DIVIDER
   ============================================ */
.section-divider { height:1px; background:linear-gradient(90deg,transparent,var(--card-border),transparent); margin:22px 0; }

/* ============================================
   TOAST
   ============================================ */
.toast { position:fixed; top:76px; left:50%; transform:translateX(-50%) translateY(-16px); background:linear-gradient(135deg,var(--emas-gelap),var(--emas)); color:var(--merah-tua); padding:10px 22px; border-radius:99px; font-family:'Cinzel',serif; font-size:0.76rem; font-weight:700; letter-spacing:1px; z-index:999; opacity:0; transition:all 0.3s ease; pointer-events:none; white-space:nowrap; box-shadow:var(--shadow-emas); }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ============================================
   PARTICLES
   ============================================ */
.particles { position:fixed; inset:0; max-width:430px; margin:0 auto; pointer-events:none; z-index:0; overflow:hidden; }
.particle { position:absolute; width:3px; height:3px; background:var(--emas); border-radius:50%; opacity:0; animation:pFloat linear infinite; }
@keyframes pFloat { 0%{opacity:0;transform:translateY(100vh)} 10%{opacity:0.5} 90%{opacity:0.2} 100%{opacity:0;transform:translateY(-20px)} }

/* ============================================
   MUSIK BUTTON
   ============================================ */
.musik-btn { position:fixed; bottom:80px; right:16px; z-index:300; width:40px; height:40px; background:linear-gradient(135deg,var(--emas-gelap),var(--emas)); border:none; border-radius:50%; display:none; align-items:center; justify-content:center; font-size:1.1rem; box-shadow:var(--shadow-emas); transition:var(--transition); cursor:pointer; }
.musik-btn.visible { display:flex; }
.musik-btn:hover { transform:scale(1.1); }
.musik-btn.playing { animation:musikPulse 1.5s ease-in-out infinite; }
@keyframes musikPulse { 0%,100%{box-shadow:0 0 0 0 rgba(201,168,76,0.5)} 50%{box-shadow:0 0 0 10px rgba(201,168,76,0)} }

/* ============================================
   RESPONSIVE
   ============================================ */
@media (min-width:430px) { body{background:#0A0000} #app{box-shadow:0 0 60px rgba(107,0,0,0.5)} }
@media (max-width:360px) { .cover-teks-besar{font-size:2.1rem} .cover-script{font-size:2.4rem} }


.cover-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.06; /* transparansi — naikkan kalau mau lebih kelihatan */
  background-image: 
    radial-gradient(circle at 25px 25px, var(--emas) 2px, transparent 2px),
    radial-gradient(circle at 75px 75px, var(--emas) 2px, transparent 2px);
  background-size: 100px 100px;
}

.cover-bottom {
  margin-top: 2px; /* naikkan angka ini sesuai selera */
}

#page-beranda .cover-wrap {
  padding-bottom: 120px; /* ruang untuk nav bar + tombol */
}

.cover-bottom {
  margin-top: 16px !important;
  padding-bottom: 0;
}

.cover-ornament-bottom {
  padding-bottom: 16px;
}