/* ═══════════════════════════════════════════════════════════════
   EXTRAS — komponen tambahan untuk Karind MVP
   (calendar, time picker, beranda ry-cards, package info-mode,
    transaction filter, invoice stamp, back button, currency input)
   ═══════════════════════════════════════════════════════════════ */

/* ──────────────────────────────────────────────
   BERANDA — Royalty type cards (Mechanical / Performance)
   ────────────────────────────────────────────── */
.ry-head{
  font-size:14px;font-weight:800;color:var(--tx);font-family:'Poppins',sans-serif;
  padding:16px 16px 8px;letter-spacing:.2px;
}
.ry-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 14px;
}
.ry-card{
  position:relative;overflow:hidden;cursor:pointer;
  background:var(--card);border:.5px solid var(--border);border-radius:16px;
  padding:14px 12px 12px;transition:transform .15s ease;
}
.ry-card:active{transform:scale(.97);}
.ry-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--c1,#e50914),var(--c2,#8f0609));
}
.ry-card-mech{--c1:#1db954;--c2:#1a9a5f;}
.ry-card-perf{--c1:#ff3c5c;--c2:#e50914;}
.ry-ic{
  width:42px;height:42px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin-bottom:10px;
  background:linear-gradient(135deg,var(--c1),var(--c2));
  box-shadow:0 4px 12px rgba(0,0,0,.28);
}
.ry-t{
  font-size:14px;font-weight:800;color:var(--tx);
  font-family:'Poppins',sans-serif;margin-bottom:4px;
}
.ry-s{
  font-size:10.5px;color:var(--muted);line-height:1.45;
  margin-bottom:10px;min-height:30px;
}
.ry-go{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:700;color:var(--c1);
  font-family:'Inter',sans-serif;
}

/* ──────────────────────────────────────────────
   CALENDAR POPUP (.cal-ov overlay + .cal-pop card)
   ────────────────────────────────────────────── */
.cal-ov{
  display:none;position:fixed;inset:0;z-index:2000;
  background:rgba(0,0,0,.68);backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  align-items:center;justify-content:center;padding:20px;
}
.cal-ov.on{display:flex;animation:fadeIn .2s ease;}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

.cal-pop{
  width:100%;max-width:340px;
  background:var(--card);border:.5px solid var(--border);
  border-radius:20px;padding:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  animation:popUp .22s cubic-bezier(.25,1.4,.5,1);
}
@keyframes popUp{from{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:none}}

.cal-hd{
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;padding:2px 4px 14px;
}
.cal-title{
  font-size:15px;font-weight:800;color:var(--tx);
  font-family:'Poppins',sans-serif;flex:1;text-align:center;
  letter-spacing:.2px;
}
.cal-nav{
  width:34px;height:34px;border-radius:10px;border:none;
  background:var(--card2,rgba(255,255,255,.06));
  color:var(--tx);font-size:18px;font-weight:700;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .12s;
}
.cal-nav:hover{background:rgba(229,9,20,.12);color:var(--red);}
.cal-nav:active{transform:scale(.92);}

.cal-wd{
  display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px;
}
.cal-wd>div{
  text-align:center;font-size:10px;color:var(--muted);
  font-weight:700;letter-spacing:.6px;text-transform:uppercase;padding:6px 0;
}

.cal-days{
  display:grid;grid-template-columns:repeat(7,1fr);gap:4px;
}
.cal-day{
  aspect-ratio:1;border-radius:10px;border:.5px solid transparent;
  background:transparent;color:var(--tx);
  font-size:13px;font-weight:600;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-family:'Inter',sans-serif;position:relative;
  transition:background .12s,border .12s,color .12s;
}
.cal-day:hover:not(.dis){background:var(--card2,rgba(255,255,255,.05));}
.cal-day.dis{color:var(--muted);opacity:.28;cursor:not-allowed;}
.cal-day.today{border-color:rgba(229,9,20,.45);}
.cal-day.today::after{
  content:'';position:absolute;bottom:5px;left:50%;transform:translateX(-50%);
  width:4px;height:4px;border-radius:50%;background:var(--red);
}
.cal-day.sel{
  background:linear-gradient(135deg,#e50914,#8f0609);
  color:#fff;border-color:transparent;
  box-shadow:0 4px 12px rgba(229,9,20,.38);
}
.cal-day.sel.today::after{background:#fff;}

.cal-foot{
  display:flex;gap:8px;margin-top:14px;padding-top:14px;
  border-top:.5px solid var(--border);
}
.cal-btn{
  flex:1;padding:10px 8px;border-radius:11px;
  font-size:12px;font-weight:700;cursor:pointer;
  font-family:'Inter',sans-serif;transition:.12s;
}
.cal-btn:active{transform:scale(.96);}
.cal-btn-s{
  background:var(--card2,rgba(255,255,255,.05));
  color:var(--muted);border:.5px solid var(--border);
}
.cal-btn-s:hover{color:var(--tx);}
.cal-btn-p{
  flex:1.3;border:none;color:#fff;font-weight:800;
  background:linear-gradient(135deg,#e50914,#8f0609);
  box-shadow:0 4px 12px rgba(229,9,20,.32);
}

/* ──────────────────────────────────────────────
   TIME PICKER POPUP (.tp-ov overlay + .tp-pop card)
   ────────────────────────────────────────────── */
.tp-ov{
  display:none;position:fixed;inset:0;z-index:2000;
  background:rgba(0,0,0,.68);backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  align-items:center;justify-content:center;padding:20px;
}
.tp-ov.on{display:flex;animation:fadeIn .2s ease;}

.tp-pop{
  width:100%;max-width:320px;
  background:var(--card);border:.5px solid var(--border);
  border-radius:20px;padding:18px;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  animation:popUp .22s cubic-bezier(.25,1.4,.5,1);
}

.tp-title{
  font-size:13px;font-weight:700;color:var(--muted);
  text-align:center;letter-spacing:1.5px;text-transform:uppercase;
  font-family:'Poppins',sans-serif;margin-bottom:6px;
}
.tp-disp{
  font-size:44px;font-weight:900;color:var(--red);
  text-align:center;letter-spacing:4px;
  font-family:'Poppins',sans-serif;margin-bottom:14px;
  text-shadow:0 2px 14px rgba(229,9,20,.28);
}
.tp-split{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  margin-bottom:4px;
}
.tp-col-lbl{
  font-size:9px;color:var(--muted);letter-spacing:1.3px;
  text-transform:uppercase;font-weight:700;text-align:center;
  padding:6px 0 4px;
}
.tp-items{
  background:var(--card2,rgba(255,255,255,.03));
  border:.5px solid var(--border);border-radius:12px;
  max-height:170px;overflow-y:auto;padding:4px;
  scroll-behavior:smooth;scrollbar-width:thin;
}
.tp-items::-webkit-scrollbar{width:3px;}
.tp-items::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}

.tp-item{
  display:block;width:100%;padding:8px 0;
  background:transparent;border:.5px solid transparent;
  color:var(--tx);font-size:13px;font-weight:600;
  cursor:pointer;border-radius:8px;margin-bottom:2px;
  font-family:'Inter',sans-serif;text-align:center;
  transition:.12s;
}
.tp-item:hover{background:rgba(255,255,255,.05);}
.tp-item.on{
  background:linear-gradient(135deg,#e50914,#8f0609);
  color:#fff;font-weight:800;
  box-shadow:0 3px 10px rgba(229,9,20,.28);
}

/* ──────────────────────────────────────────────
   CUSTOM DATE/TIME DISPLAY BUTTON (pengganti native input)
   ────────────────────────────────────────────── */
.dt-input,.tm-input{
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;width:100%;padding:12px 14px;
  background:var(--card);border:.5px solid var(--border);
  border-radius:12px;cursor:pointer;
  font-size:13px;color:var(--tx);
  font-family:'Inter',sans-serif;transition:.15s;
}
.dt-input:hover,.tm-input:hover{border-color:rgba(229,9,20,.42);}
.dt-input .ph,.tm-input .ph{color:var(--muted);}
.dt-input::after{content:'📅';flex-shrink:0;opacity:.65;font-size:14px;}
.tm-input::after{content:'🕐';flex-shrink:0;opacity:.65;font-size:14px;}

/* ──────────────────────────────────────────────
   CURRENCY INPUT — visual polish
   ────────────────────────────────────────────── */
input.currency-inp{
  font-family:'Inter',sans-serif;font-weight:600;letter-spacing:.3px;
}
input.currency-inp::placeholder{
  color:var(--muted);font-weight:400;letter-spacing:0;
}

/* ──────────────────────────────────────────────
   PACKAGE CARD — info-mode (lihat harga saja, tanpa transaksi)
   ────────────────────────────────────────────── */
.pkg-card.info-mode{cursor:default;}
.pkg-card.info-mode .pkg-check{display:none!important;}
.pkg-card.info-mode:active{transform:none;}

.pkg-info-cta{
  margin-top:16px;padding:14px 16px;border-radius:14px;
  background:linear-gradient(135deg,#e50914,#8f0609);
  color:#fff;border:none;cursor:pointer;width:100%;
  display:flex;flex-direction:column;align-items:center;gap:3px;
  box-shadow:0 6px 18px rgba(229,9,20,.32);
  transition:transform .12s;
}
.pkg-info-cta:active{transform:scale(.98);}
.pkg-info-cta-t{
  font-size:13px;font-weight:800;letter-spacing:.3px;
  font-family:'Poppins',sans-serif;
}
.pkg-info-cta-s{
  font-size:10px;opacity:.85;font-family:'Inter',sans-serif;
}

/* ──────────────────────────────────────────────
   TRANSACTION PAGE — filter bar + chips + status badges
   ────────────────────────────────────────────── */
.tx-filter-bar{
  position:sticky;top:0;z-index:5;
  display:flex;justify-content:space-between;align-items:center;
  gap:10px;padding:10px 14px 10px;
  background:var(--bg);border-bottom:.5px solid var(--border);
  flex-wrap:wrap;
}
.tx-chips{display:flex;gap:6px;flex:1;min-width:0;flex-wrap:wrap;}
.tx-chip{
  padding:6px 11px;background:var(--card);color:var(--tx);
  border:.5px solid var(--border);border-radius:20px;
  font-size:11px;font-weight:700;cursor:pointer;
  display:inline-flex;align-items:center;gap:5px;
  font-family:'Inter',sans-serif;transition:.12s;
}
.tx-chip:active{transform:scale(.95);}
.tx-chip.on{
  background:var(--red);color:#fff;border-color:var(--red);
  box-shadow:0 3px 10px rgba(229,9,20,.3);
}
.tx-chip-count{
  font-size:9px;padding:1.5px 5px;
  background:rgba(255,255,255,.17);border-radius:8px;
  font-weight:800;min-width:16px;text-align:center;
}
.tx-chip:not(.on) .tx-chip-count{
  background:rgba(255,255,255,.06);color:var(--muted);
}
.tx-sort-btn{
  padding:6px 11px;background:var(--card);color:var(--tx);
  border:.5px solid var(--border);border-radius:20px;
  font-size:11px;font-weight:700;cursor:pointer;
  display:inline-flex;align-items:center;gap:5px;flex-shrink:0;
  font-family:'Inter',sans-serif;
}
.tx-sort-btn:active{transform:scale(.95);}

/* Transaction list items + status badges */
.tx-item{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-bottom:.5px solid var(--border);
  cursor:pointer;transition:background .12s;
}
.tx-item:hover{background:rgba(255,255,255,.02);}
.tx-item:active{background:rgba(229,9,20,.05);}
.tx-avatar{
  width:40px;height:40px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:18px;
}
.tx-avatar-perf{background:linear-gradient(135deg,#ff3c5c,#e50914);}
.tx-avatar-mech{background:linear-gradient(135deg,#1db954,#1a9a5f);}
.tx-body{flex:1;min-width:0;}
.tx-label-row{display:flex;align-items:center;gap:6px;margin-bottom:3px;}
.tx-label{
  font-size:10px;color:var(--muted);font-weight:700;
  text-transform:uppercase;letter-spacing:.5px;
}
.tx-stat{
  font-size:9px;font-weight:800;padding:2px 7px;border-radius:6px;
  letter-spacing:.4px;
}
.tx-stat-sukses{
  background:rgba(29,185,84,.18);color:#5dd9a0;
  border:.5px solid rgba(29,185,84,.32);
}
.tx-stat-pending{
  background:rgba(245,197,24,.18);color:#f5c518;
  border:.5px solid rgba(245,197,24,.32);
  animation:pendingPulse 1.8s ease-in-out infinite;
}
@keyframes pendingPulse{
  0%,100%{opacity:1;}
  50%{opacity:.6;}
}
.tx-name{
  font-size:13px;color:var(--tx);font-weight:700;
  font-family:'Poppins',sans-serif;margin-bottom:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.tx-inv{
  font-size:10px;color:var(--muted);
  font-family:'Courier New',monospace;letter-spacing:.2px;
}
.tx-amt{
  font-size:13px;font-weight:800;color:var(--red);
  font-family:'Poppins',sans-serif;flex-shrink:0;
}

.tx-empty{text-align:center;padding:60px 24px;}
.tx-empty-ic{font-size:48px;margin-bottom:14px;opacity:.5;}
.tx-empty-t{
  font-size:15px;font-weight:800;color:var(--tx);
  font-family:'Poppins',sans-serif;margin-bottom:6px;
}
.tx-empty-s{font-size:11px;color:var(--muted);line-height:1.55;}

/* ──────────────────────────────────────────────
   BACK BUTTON (untuk page riwayat)
   ────────────────────────────────────────────── */
.back-btn{
  width:36px;height:36px;border-radius:10px;
  background:var(--card);border:.5px solid var(--border);
  color:var(--tx);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:700;transition:.12s;
}
.back-btn:hover{background:rgba(229,9,20,.1);color:var(--red);}
.back-btn:active{transform:scale(.92);}

/* ──────────────────────────────────────────────
   INVOICE — stamp LUNAS / MENUNGGU + layout
   ────────────────────────────────────────────── */
.inv-stamp{
  transform:rotate(-8deg);padding:5px 12px;border:2px solid;
  border-radius:6px;font-size:13px;font-weight:900;
  letter-spacing:2px;font-family:'Poppins',sans-serif;flex-shrink:0;
}
.inv-stamp-lunas{border-color:#5dd9a0;color:#5dd9a0;}
.inv-stamp-pending{
  border-color:#f5c518;color:#f5c518;
  animation:stampPulse 1.8s ease-in-out infinite;
}
@keyframes stampPulse{
  0%,100%{opacity:1;transform:rotate(-8deg) scale(1);}
  50%{opacity:.72;transform:rotate(-8deg) scale(.97);}
}

.inv-head{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:12px;padding:14px;background:linear-gradient(135deg,#18181b,#0f0f12);
  border-radius:14px;margin-bottom:14px;
}
.inv-logo{
  font-size:18px;font-weight:900;color:#fff;
  font-family:'Poppins',sans-serif;letter-spacing:.5px;
}
.inv-logo small{
  display:block;font-size:9px;color:#999;font-weight:500;
  letter-spacing:1px;margin-top:2px;
}
.inv-meta{
  display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;
  padding:12px 14px;background:var(--card);
  border:.5px solid var(--border);border-radius:12px;margin-bottom:12px;
}
.inv-meta-lbl{
  font-size:9px;color:var(--muted);letter-spacing:.5px;
  text-transform:uppercase;font-weight:700;margin-bottom:2px;
}
.inv-meta-val{
  font-size:12px;color:var(--tx);font-weight:700;
  font-family:'Inter',sans-serif;
}
.inv-meta-val.inv-no{font-family:'Courier New',monospace;}

.inv-section{
  padding:12px 14px;background:var(--card);
  border:.5px solid var(--border);border-radius:12px;margin-bottom:12px;
}
.inv-sec-title{
  font-size:10px;color:var(--muted);letter-spacing:.8px;
  text-transform:uppercase;font-weight:800;margin-bottom:10px;
}
.inv-artist-box{
  padding:10px 12px;background:rgba(255,255,255,.02);
  border:.5px dashed var(--border);border-radius:10px;margin-bottom:8px;
}
.inv-artist-box:last-child{margin-bottom:0;}
.inv-artist-name{
  font-size:12.5px;font-weight:800;color:var(--tx);
  font-family:'Poppins',sans-serif;margin-bottom:6px;
}
.inv-artist-row{
  display:flex;justify-content:space-between;font-size:11px;
  padding:4px 0;color:var(--muted);
}
.inv-artist-row strong{color:var(--tx);font-weight:700;}
.inv-song-list{
  margin-top:8px;padding-top:8px;border-top:.5px solid var(--border);
  font-size:11px;color:var(--muted);line-height:1.6;
}
.inv-song-list div{padding:2px 0;}
.inv-total{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px;background:linear-gradient(135deg,rgba(229,9,20,.08),rgba(229,9,20,.04));
  border:.5px solid rgba(229,9,20,.25);border-radius:14px;
  margin-bottom:14px;
}
.inv-total-lbl{
  font-size:12px;font-weight:700;color:var(--tx);
  font-family:'Poppins',sans-serif;
}
.inv-total-val{
  font-size:19px;font-weight:900;color:var(--red);
  font-family:'Poppins',sans-serif;letter-spacing:.5px;
}
.inv-footer{
  text-align:center;font-size:10px;color:var(--muted);
  line-height:1.6;padding:10px 4px;
}
.inv-actions{display:flex;gap:8px;margin-top:14px;}
.inv-btn{
  flex:1;padding:12px;border-radius:12px;
  font-size:12px;font-weight:800;cursor:pointer;
  font-family:'Inter',sans-serif;transition:.12s;
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.inv-btn:active{transform:scale(.97);}
.inv-btn-p{
  border:none;color:#fff;
  background:linear-gradient(135deg,#e50914,#8f0609);
  box-shadow:0 4px 14px rgba(229,9,20,.35);
}
.inv-btn-s{
  background:var(--card);color:var(--tx);
  border:.5px solid var(--border);
}

/* ══════════════════════════════════════════════════════════════
   DESKTOP TOP NAVBAR (.dt-nav) — hidden by default on mobile
   ══════════════════════════════════════════════════════════════ */
.dt-nav{display:none;}
.dt-nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;max-width:1200px;margin:0 auto;padding:12px 24px;height:64px;
}
.dt-brand{display:flex;align-items:center;gap:10px;cursor:pointer;}
.dt-logo{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,#e50914,#8f0609);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 12px rgba(229,9,20,.3);flex-shrink:0;
}
.dt-bname{
  font-size:16px;font-weight:900;color:var(--tx);
  font-family:'Poppins',sans-serif;letter-spacing:.3px;line-height:1.1;
}
.dt-bsub{
  font-size:9px;color:var(--muted);letter-spacing:1.5px;
  text-transform:uppercase;font-weight:700;margin-top:2px;
}
.dt-menu{display:flex;align-items:center;gap:4px;flex:1;justify-content:center;}
.dt-link{
  padding:8px 16px;background:transparent;border:none;
  color:var(--muted);font-size:13px;font-weight:600;
  cursor:pointer;border-radius:10px;font-family:'Inter',sans-serif;
  transition:color .15s,background .15s;
}
.dt-link:hover{color:var(--tx);background:rgba(255,255,255,.04);}
.dt-link-on{color:var(--red)!important;font-weight:800;background:rgba(229,9,20,.08);}
.dt-auth{display:flex;align-items:center;gap:8px;}

/* ══════════════════════════════════════════════════════════════
   RY-MINI — kompak icon row (ganti ry-grid lama)
   ══════════════════════════════════════════════════════════════ */
.ry-mini-wrap{
  display:flex;gap:8px;padding:12px 14px 4px;
  overflow-x:auto;scrollbar-width:none;
}
.ry-mini-wrap::-webkit-scrollbar{display:none;}
.ry-mini{
  flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;
  gap:5px;padding:10px 6px;background:var(--card);
  border:.5px solid var(--border);border-radius:14px;cursor:pointer;
  transition:transform .12s,border-color .12s;
}
.ry-mini:active{transform:scale(.96);}
.ry-mini-mech:hover{border-color:rgba(29,185,84,.4);}
.ry-mini-perf:hover{border-color:rgba(229,9,20,.4);}
.ry-mini-info:hover{border-color:rgba(245,197,24,.4);}
.ry-mini-ic{
  width:36px;height:36px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;font-size:19px;
}
.ry-mini-mech .ry-mini-ic{background:linear-gradient(135deg,rgba(29,185,84,.22),rgba(29,185,84,.08));}
.ry-mini-perf .ry-mini-ic{background:linear-gradient(135deg,rgba(229,9,20,.22),rgba(229,9,20,.08));}
.ry-mini-info .ry-mini-ic{background:linear-gradient(135deg,rgba(245,197,24,.22),rgba(245,197,24,.08));}
.ry-mini-lbl{
  font-size:10.5px;font-weight:700;color:var(--tx);
  font-family:'Inter',sans-serif;letter-spacing:.2px;text-align:center;
  white-space:nowrap;
}

/* ══════════════════════════════════════════════════════════════
   LI-PREVIEW-BTN — tombol play 15s di setiap item lagu
   ══════════════════════════════════════════════════════════════ */
.li-preview-btn{
  width:32px;height:32px;border-radius:50%;border:none;flex-shrink:0;
  background:linear-gradient(135deg,#e50914,#8f0609);color:#fff;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 3px 10px rgba(229,9,20,.35);
  transition:transform .12s;margin-left:6px;
}
.li-preview-btn:hover{transform:scale(1.08);}
.li-preview-btn:active{transform:scale(.92);}
.li-preview-btn.playing{
  background:linear-gradient(135deg,#f5c518,#d4a817);
  box-shadow:0 3px 10px rgba(245,197,24,.4);
  animation:btnPulse 1.2s ease-in-out infinite;
}
@keyframes btnPulse{
  0%,100%{box-shadow:0 3px 10px rgba(245,197,24,.4);}
  50%{box-shadow:0 3px 18px rgba(245,197,24,.7);}
}

/* ══════════════════════════════════════════════════════════════
   DESKTOP LAYOUT — >= 900px
   ══════════════════════════════════════════════════════════════ */
@media (min-width:900px){
  /* Fix scroll & klik di desktop — override mobile overflow:hidden */
  html{height:auto;overflow-y:auto;}
  body{background:var(--bg);min-height:100vh;height:auto;overflow-y:auto;}

  /* Tampilkan top navbar desktop, sembunyikan mobile topbar + bottom nav */
  .dt-nav{
    display:block;position:sticky;top:0;z-index:100;
    background:rgba(10,10,10,.92);backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    border-bottom:.5px solid var(--border2);
  }
  .bnav{display:none!important;}
  .topbar{display:none!important;}

  /* Screen jadi full-width, content area max 1200px */
  .screen{
    width:100%!important;max-width:100%!important;
    height:auto;min-height:calc(100vh - 64px);
    overflow:visible;display:block;
  }
  .page{display:none;overflow:visible!important;}
  .page.active{display:block!important;}
  .scroll{
    overflow:visible;padding:28px 24px 60px;
    max-width:1100px;margin:0 auto;width:100%;
    box-sizing:border-box;
  }

  /* Greet + search header di beranda (non-topbar) */
  .greet{padding:8px 0 14px;}
  .g-label{font-size:13px;}
  .g-name{font-size:26px;}
  .srow{margin-bottom:12px;}
  .srch{max-width:560px;}

  /* Banner lebih tinggi di desktop */
  .bwrap{margin-bottom:28px;}
  .bcard{height:320px;}
  .btit{font-size:32px;}
  .bsub{font-size:14px;}

  /* Ry-mini: kasih lebih banyak breathing room, tetap kompak */
  .ry-mini-wrap{max-width:600px;margin:0 auto;padding:0 0 20px;}
  .ry-mini{padding:14px 10px;}
  .ry-mini-ic{width:42px;height:42px;font-size:22px;}
  .ry-mini-lbl{font-size:12px;}

  /* Kategori lagu (beranda + musik) jadi grid multi-column di desktop */
  .hs{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
    gap:14px;overflow:visible;padding:0 0 8px;
  }
  .sc-card{width:auto!important;min-width:0;}

  /* Section header lebih besar */
  .sec-t{font-size:17px;}

  /* Venue sections di page musik */
  .venue-hd{padding:16px 0 10px;}
  .venue-title{font-size:15px;}

  /* List item (page musik list-all) pake grid 2 kolom */
  #list-all{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));
    gap:10px;
  }
  .li{border-radius:12px;}

  /* Sheet bottom → modal centered di desktop */
  .sh-sheet{
    left:50%!important;right:auto!important;bottom:auto!important;
    top:50%!important;transform:translate(-50%,-50%) scale(.96)!important;
    width:92%;max-width:520px;
    max-height:86vh;border-radius:20px;
    opacity:0;transition:opacity .22s,transform .22s cubic-bezier(.25,1.4,.5,1);
  }
  .sh-sheet.on{
    transform:translate(-50%,-50%) scale(1)!important;opacity:1;
  }
  .sh-handle{display:none;}

  /* Invoice sheet lebar sedikit lebih besar */
  #invSheet{max-width:640px;}

  /* Topbar mobile hidden, tapi greet masih ditampilkan inline di beranda */
  #page-beranda .topbar{
    display:block!important;background:transparent;
    padding:24px 24px 0;max-width:1100px;margin:0 auto;
    box-sizing:border-box;width:100%;
  }
  #page-beranda .topbar .tb-top{display:none;} /* brand + auth di desktop nav */
  #page-beranda .topbar.sc{border-bottom:none;}
  #page-beranda .greet{padding:0 0 10px;}
  #page-beranda .srow{padding:0;}

  /* Topbar non-beranda (header page) — hide di desktop karena dt-nav sudah ada */
  .page:not(#page-beranda) .topbar{display:none!important;}

  /* Mini player (playlist) → pin atas di desktop (bukan bottom) */
  .mp{
    position:fixed!important;top:auto;bottom:20px;
    left:50%;transform:translateX(-50%);
    width:520px;max-width:calc(100vw - 40px);
    border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,.5);
  }
}

/* ══════════════════════════════════════════════════════════════
   TABLET — 600px to 899px
   ══════════════════════════════════════════════════════════════ */
@media (min-width:600px) and (max-width:899px){
  .hs{
    display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
    overflow:visible;padding:0 14px;
  }
  .sc-card{width:auto!important;min-width:0;}
}

/* ══════════════════════════════════════════════════════════════
   PRINT (invoice → print to PDF)
   ══════════════════════════════════════════════════════════════ */
@media print{
  .dt-nav,.bnav,.topbar,.inv-actions,.sh-close,.sh-handle{display:none!important;}
  body{background:#fff;color:#000;}
  .inv-stamp-pending{animation:none;}
  .sh-sheet{
    position:static!important;transform:none!important;
    width:100%!important;max-width:100%!important;
    max-height:none!important;opacity:1!important;
  }
}

/* ═══════════════════════════════════════════════
   PACKAGE LOCK — paket di bawah kategori terkunci
   ═══════════════════════════════════════════════ */
.pkg-card.pkg-locked{
  opacity:.55;cursor:not-allowed;position:relative;
  filter:grayscale(.4);
}
.pkg-card.pkg-locked:active{transform:none;}
.pkg-card.pkg-locked .pkg-check{display:none;}
.pkg-lock-ov{
  position:absolute;top:8px;right:8px;
  display:flex;align-items:center;gap:5px;
  padding:4px 9px;border-radius:16px;
  background:rgba(0,0,0,.58);backdrop-filter:blur(6px);
  border:.5px solid rgba(255,255,255,.12);
  pointer-events:none;
}
.pkg-lock-ic{font-size:12px;}
.pkg-lock-msg{
  font-size:9.5px;color:#fff;font-weight:700;
  letter-spacing:.2px;font-family:'Inter',sans-serif;
}

/* ═══════════════════════════════════════════════
   CHECKOUT SHEET
   ═══════════════════════════════════════════════ */
.co-hero{
  display:flex;align-items:center;gap:12px;
  padding:14px;background:linear-gradient(135deg,rgba(229,9,20,.1),rgba(229,9,20,.03));
  border:.5px solid rgba(229,9,20,.22);border-radius:14px;margin-bottom:14px;
}
.co-hero-ic{
  width:50px;height:50px;border-radius:13px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:25px;
  border:.5px solid var(--border);
}
.co-hero-bd{flex:1;min-width:0;}
.co-hero-t{
  font-size:16px;font-weight:800;color:var(--tx);
  font-family:'Poppins',sans-serif;margin-bottom:2px;
}
.co-hero-s{font-size:11px;color:var(--muted);line-height:1.45;}

.co-section{
  margin-bottom:12px;padding:12px 14px;
  background:var(--card);border:.5px solid var(--border);
  border-radius:12px;
}
.co-section-t{
  font-size:10px;color:var(--muted);letter-spacing:.8px;
  text-transform:uppercase;font-weight:800;margin-bottom:8px;
}
.co-row{
  display:flex;justify-content:space-between;gap:10px;
  font-size:12px;padding:4px 0;
}
.co-row-l{color:var(--muted);}
.co-row-r{color:var(--tx);text-align:right;font-weight:600;}

.co-notice{
  padding:14px;background:rgba(245,197,24,.08);
  border:.5px solid rgba(245,197,24,.3);border-radius:14px;
  margin-bottom:14px;
}
.co-notice-hd{
  font-size:12px;font-weight:800;color:#f5c518;
  font-family:'Poppins',sans-serif;margin-bottom:8px;
}
.co-notice-ul{
  margin:0;padding:0 0 0 18px;
  font-size:11px;color:var(--tx);line-height:1.7;
}
.co-notice-ul li{margin-bottom:4px;}
.co-notice-ul li:last-child{margin-bottom:0;}
.co-notice-ul b{color:#f5c518;font-weight:800;}

.co-topup{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;
  background:linear-gradient(135deg,rgba(124,111,255,.12),rgba(124,111,255,.04));
  border:.5px solid rgba(124,111,255,.3);border-radius:14px;margin-bottom:14px;
  cursor:pointer;transition:transform .12s;
}
.co-topup:active{transform:scale(.98);}
.co-topup-ic{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:19px;
  background:rgba(124,111,255,.2);
}
.co-topup-bd{flex:1;min-width:0;}
.co-topup-t{
  font-size:12.5px;font-weight:800;color:#a29dff;
  font-family:'Poppins',sans-serif;margin-bottom:2px;
}
.co-topup-s{font-size:10.5px;color:var(--muted);line-height:1.45;}

.co-total{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 16px;
  background:linear-gradient(135deg,rgba(229,9,20,.1),rgba(229,9,20,.04));
  border:.5px solid rgba(229,9,20,.3);border-radius:14px;margin-bottom:12px;
}
.co-total-l{
  font-size:13px;font-weight:700;color:var(--tx);
  font-family:'Poppins',sans-serif;
}
.co-total-r{
  font-size:22px;font-weight:900;color:var(--red);
  font-family:'Poppins',sans-serif;letter-spacing:.5px;
}
.co-pay-btn{
  width:100%;padding:14px;font-size:14px!important;
  letter-spacing:.4px;margin-top:4px;
}
.co-footer{
  text-align:center;font-size:10px;color:var(--muted);
  margin-top:10px;line-height:1.5;
}

/* ═══════════════════════════════════════════════
   PROFILE EDIT SHEET — note styling
   ═══════════════════════════════════════════════ */
.pe-note{
  font-size:11px;color:var(--muted);line-height:1.55;
  padding:10px 12px;background:rgba(127,119,221,.05);
  border:.5px dashed rgba(127,119,221,.2);border-radius:10px;
  margin-top:4px;
}

/* ═══════════════════════════════════════════════
   PROFILE CARD — center avatar & info (mobile & desktop)
   ═══════════════════════════════════════════════ */
.profile-card{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
}
.profile-av{
  width:68px!important;height:68px!important;
  font-size:28px!important;
  margin:0 0 12px!important;
  box-shadow:0 6px 20px rgba(229,9,20,.35);
}
.profile-name{margin-bottom:4px!important;}
.profile-email{margin-bottom:12px!important;}
.role-badge{display:inline-flex;}

/* ═══════════════════════════════════════════════
   PREVIEW BTN di "Tambah ke Playlist" sheet items
   ═══════════════════════════════════════════════ */
.add-preview-btn{
  width:30px;height:30px;border-radius:50%;border:none;flex-shrink:0;
  background:linear-gradient(135deg,#f5c518,#d4a817);color:#fff;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 3px 8px rgba(245,197,24,.35);
  transition:transform .12s;margin-right:4px;
}
.add-preview-btn:hover{transform:scale(1.08);}
.add-preview-btn:active{transform:scale(.92);}
.add-preview-btn.playing{
  background:linear-gradient(135deg,#ff3c5c,#e50914);
  box-shadow:0 3px 10px rgba(229,9,20,.45);
  animation:btnPulse 1.2s ease-in-out infinite;
}

/* ═══════════════════════════════════════════════
   DEMO ACCOUNT CARD — di login sheet untuk quick-fill
   ═══════════════════════════════════════════════ */
.demo-acc-card{
  margin:0 0 14px;padding:11px 13px;
  background:linear-gradient(135deg,rgba(124,111,255,.12),rgba(124,111,255,.04));
  border:.5px dashed rgba(124,111,255,.32);border-radius:12px;
  cursor:pointer;transition:transform .12s,border-color .12s;
}
.demo-acc-card:hover{border-color:rgba(124,111,255,.5);}
.demo-acc-card:active{transform:scale(.98);}
.demo-acc-hd{
  display:flex;align-items:center;gap:6px;margin-bottom:6px;
  font-size:10.5px;font-weight:800;color:#a29dff;
  font-family:'Poppins',sans-serif;letter-spacing:.5px;text-transform:uppercase;
}
.demo-acc-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;color:var(--tx);font-family:'Inter',sans-serif;padding:2px 0;
}
.demo-acc-row-l{color:var(--muted);}
.demo-acc-row-r{font-weight:700;font-family:'Courier New',monospace;}
.demo-acc-hint{
  font-size:9.5px;color:var(--muted);margin-top:6px;line-height:1.5;
}

/* ══════════════════════════════════════════════════════════════
   MAP PICKER MODAL
   ══════════════════════════════════════════════════════════════ */
#mapPickerOv { display: none; }
#mapLeaflet .leaflet-container { background: var(--card2); }
/* Override Leaflet tile attribution for dark mode */
.leaflet-control-attribution { background: rgba(0,0,0,.5) !important; color: rgba(255,255,255,.4) !important; }
.leaflet-control-attribution a { color: rgba(255,255,255,.5) !important; }
/* Map search results scrollbar */
#mapSearchResults::-webkit-scrollbar { display: none; }
/* Desktop — map picker becomes a centered modal */
@media (min-width:900px){
  #mapPickerOv { align-items: center !important; }
  #mapPickerBox {
    border-radius: 20px !important;
    max-width: 600px !important;
    max-height: 80vh !important;
  }
  #mapLeaflet { min-height: 300px !important; }
}

/* ══════════════════════════════════════════════════════════════
   CONTRACT UPLOAD
   ══════════════════════════════════════════════════════════════ */
#aa-contract-preview { display: none; }

/* ══════════════════════════════════════════════════════════════
   DISCLAIMER MODAL
   ══════════════════════════════════════════════════════════════ */
#disclaimerOv { display: none; }
@media (min-width:900px){
  #disclaimerOv > div { max-width: 500px !important; }
}

/* ══════════════════════════════════════════════════════════════
   CERTIFICATE SHEET
   ══════════════════════════════════════════════════════════════ */
#certSheet .sh-body { padding-bottom: 32px; }
@media (min-width:900px){
  #certSheet { max-width: 580px !important; }
}

/* ══════════════════════════════════════════════════════════════
   ARTIST TYPE BADGE in form
   ══════════════════════════════════════════════════════════════ */
#aa-type-solo, #aa-type-duet { transition: background .15s, color .15s; }

/* ══════════════════════════════════════════════════════════════
   SOLO COUNTER HINT — colored urgency
   ══════════════════════════════════════════════════════════════ */
#aa-solo-hint { font-size: 10px; line-height: 1.5; }
