:root{--dw-theme:#6c2bd9;--dw-progress:#22c55e;--dw-btn:#0f9f64;--dw-theme-soft:#eef2ff;--dw-theme-soft-strong:#f7f8ff;--dw-theme-border:#c5d3f3;--dw-theme-rgb:108,43,217;--dw-cta:#128c1c;--dw-cta-hover:#0f7a19;--dw-magenta:#e10061;--dw-blue:#0b67f5}
.dw-container{max-width:520px;width:100%;margin:0 auto;padding:0 12px}
.dw-single-v2{background:linear-gradient(180deg,#f7f9ff 0%,#eef2ff 50%,#f7f9ff 100%);padding:16px 0 20px;display:flex;justify-content:center;align-items:flex-start;min-height:100vh}
.dw-single-v2.dw-single-campaign{
  padding:0;
  background:#fff;
  overflow-x:hidden;
  width:100vw;
  max-width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
}

/* === Donate screen layout fix (no flex row) === */
body.donasiwp-donate-screen{margin:0;overflow-x:hidden;}
#donasiwp-donate-screen{min-height:100vh;overflow-x:hidden;}
.dw-single-v2.dw-donate-page{display:block!important;padding:0!important;background:#fff;overflow-x:hidden;width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.dw-single-v2.dw-donate-page .dw-container{
  /* breathing room below the sticky header */
  padding-top:14px;
  padding-bottom:140px; /* room for sticky CTA */
}

/* Desktop: make content sit closer to the header (match mobile feel) */
@media (min-width: 768px){
  .dw-single-v2.dw-donate-page .dw-container{
    padding-top:10px;
  }
}
.dw-single-campaign .dw-campaign-topbar{
  position:fixed;
  left:0; right:0;
  top:calc(env(safe-area-inset-top, 0px) + var(--donasiwp-adminbar-h, 0px));
  transform:none;
  width:100%;
  max-width:none;
  height:56px;
  z-index:12050;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  /* Before scroll: header transparan di atas cover (seperti contoh) */
  background:linear-gradient(180deg, rgba(15,23,42,.55) 0%, rgba(15,23,42,.22) 55%, rgba(15,23,42,0) 100%);
  transition:background .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.dw-single-campaign .dw-campaign-topbar.is-solid{
  background:#fff;
  box-shadow:0 10px 24px rgba(15,23,42,.16);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.dw-single-campaign .dw-campaign-topbar-inner{
  position:relative;
  width:100%;
  height:56px;
  padding:0 14px;
  display:flex;
  align-items:center;
  box-sizing:border-box;
}
.dw-single-campaign .dw-campaign-topbar{color:#fff}
.dw-single-campaign .dw-campaign-topbar.is-solid{color:#0f172a}
.dw-single-campaign .dw-campaign-back{
  width:56px;height:56px;
  border-radius:999px;
  border:0;
  background:transparent;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  color:inherit;
  flex:0 0 auto;
  position:absolute;
  left:6px;
  top:50%;
  transform:translateY(-50%);
}
.dw-single-campaign .dw-campaign-topbar.is-solid .dw-campaign-back{
  background:transparent;
}
.dw-single-campaign .dw-campaign-back svg{width:30px;height:30px;display:block}
.dw-single-campaign .dw-campaign-topbar-title{
  width:100%;
  text-align:center;
  padding:0 72px;
  box-sizing:border-box;
  min-width:0;
  font-weight:800;
  color:inherit;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  font-size:15px;
}
.dw-single-campaign .dw-campaign-topbar:not(.is-solid) .dw-campaign-topbar-title{display:none}
.dw-single-campaign .dw-campaign-topbar:not(.is-solid) .dw-campaign-topbar-title{
  color:#fff;
  text-shadow:0 2px 12px rgba(0,0,0,.55);
}
.dw-single-campaign .dw-campaign-topbar:not(.is-solid) .dw-campaign-back{color:#fff;filter:drop-shadow(0 2px 10px rgba(0,0,0,.6))}
.dw-single-campaign .dw-campaign-topbar.is-solid .dw-campaign-back{color:#111827;filter:none}
.dw-single-campaign .dw-campaign-back:focus,
.dw-single-campaign .dw-campaign-back:focus-visible,
.dw-single-campaign .dw-campaign-topbar-title:focus,
.dw-single-campaign .dw-campaign-topbar-title:focus-visible{
  outline:none !important;
  box-shadow:none !important;
}
/* Admin bar offset handled via --donasiwp-adminbar-h (set by JS) */
@media (min-width: 768px){
  /* Desktop: background pinggir (Kitabisa-like), konten 500px */
  .dw-single-v2.dw-single-campaign{
    padding:0 12px 24px;
    background:#f3f4f6;
  }

  /* Desktop: ikuti flow mobile (transparan -> putih saat scroll), lebar konten 500px */
  .dw-single-campaign .dw-container{max-width:500px !important}
  .dw-single-campaign .dw-campaign-topbar{
    left:50% !important;
    right:auto !important;
    transform:translateX(-50%) !important;
    width:calc(100% - 24px) !important;
    max-width:500px !important;
    background:linear-gradient(180deg, rgba(15,23,42,.55) 0%, rgba(15,23,42,.22) 55%, rgba(15,23,42,0) 100%) !important;
    box-shadow:none !important;
    border-bottom:0 !important;
    color:#fff !important;
  }
  .dw-single-campaign .dw-campaign-topbar.is-solid{
    background:transparent !important;
    box-shadow:none !important;
    border-bottom:0 !important;
    color:#0f172a !important;
  }
  .dw-single-campaign .dw-campaign-topbar-inner{
    max-width:500px !important;
    margin:0 auto !important;
    padding:0 14px !important;
  }
  .dw-single-campaign .dw-campaign-topbar.is-solid .dw-campaign-topbar-inner{
    background:#fff !important;
    box-shadow:0 10px 24px rgba(15,23,42,.16) !important;
    border-bottom:1px solid rgba(15,23,42,.06) !important;
  }
}
.dw-card2{background:#fff;border-radius:16px;box-shadow:0 10px 26px rgba(var(--dw-theme-rgb,108,43,217),.18);margin:12px 0;overflow:hidden}
.dw-single-campaign .dw-container{
  padding:0;
  /* Room for sticky CTA so last section (e.g. Kabar Terbaru) can be fully scrolled */
  padding-bottom:calc(110px + env(safe-area-inset-bottom, 0px));
  max-width:100%;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
}

/*
  Full width ala Kitabisa (mobile):
  Banyak theme/Elementor memberi wrapper max-width + padding.
  Trik 100vw ini membuat blok campaign bisa “bleed” kiri-kanan di layar kecil.
*/
@media (max-width: 640px){
  .dw-single-campaign{
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
  }
  .dw-single-campaign .dw-container{
    max-width:100vw;
    border-radius:0;
  }
}

/* Full-bleed cover seperti Kitabisa:
   Beberapa wrapper (Elementor/dialog/theme) sering memberi padding 16px kiri-kanan,
   sehingga cover terlihat tidak full. Trik ini membuat HERO "ngambil" padding itu
   tanpa harus tembus keluar wrapper (aman walau parent overflow hidden). */
/* Kitabisa-like: cover HERO full kiri-kanan (bleed keluar dari padding container),
   tapi hanya untuk area HERO saja (konten bawah tetap padded). */
.dw-single-campaign{ overflow-x:hidden; }

/* Full-bleed cover HERO:
   - Desktop: bleed sesuai padding wrapper (16px) supaya cover benar-benar full
   - Mobile: bleed adaptif untuk mengimbangi padding wrapper theme/Elementor yg bervariasi */
.dw-single-campaign{ --dw-hero-bleed:16px; }
@media (max-width: 767px){
  .dw-single-campaign{ --dw-hero-bleed:clamp(16px,5vw,32px); }
}
.dw-single-campaign .dw-card2.dw-hero{
  width:calc(100% + (var(--dw-hero-bleed) * 2)) !important;
  margin-left:calc(-1 * var(--dw-hero-bleed)) !important;
  margin-right:calc(-1 * var(--dw-hero-bleed)) !important;
  border-radius:0 !important;
  overflow:hidden !important;
}
.dw-single-campaign .dw-card2.dw-hero .cover{
  width:100% !important;
  max-width:none !important;
  border-radius:0 !important;
  height:260px !important;
  object-fit:cover !important;
  display:block !important;
}



.dw-single-campaign .dw-card2{
  border-radius:0;
  box-shadow:none;
  margin:0;
  border:0;
  overflow:visible;
}
.dw-single-campaign .dw-card2 + .dw-card2{
  border-top:10px solid #f1f5f9;
}
.dw-single-campaign .dw-section{padding:16px}
.dw-single-campaign .dw-hero .body{padding:16px}
.dw-single-campaign .dw-hero .cover{
  border-bottom:0;
  width:100% !important;
  max-width:none !important;
  margin:0 !important;
  /* Full cover seperti Kitabisa: fixed height + crop */
  height:260px !important;
  aspect-ratio:unset;
  object-fit:cover !important;
  object-position:center !important;
  display:block;
}
@media (max-width:420px){
  .dw-single-campaign .dw-hero .cover{height:230px !important;}
}
@media (min-width:768px){
  .dw-single-campaign .dw-hero .cover{height:300px !important;}
}
.dw-hero{display:block;padding:0;border-radius:0;box-shadow:none;margin:0}
.dw-hero .body{padding:18px 18px 16px;background:#fff}
.dw-hero .cover{width:100%;height:240px;object-fit:cover;display:block;border-bottom:4px solid #e5e7eb}
.dw-hero .title{font-weight:800;font-size:20px;margin:6px 0 10px;line-height:1.35;color:#0f172a}
.dw-hero .location{display:flex;align-items:center;gap:6px;color:#9aa3b2;font-size:12px;margin-bottom:8px}
.dw-hero .location .ic-pin{width:14px;height:14px;vertical-align:middle;color:var(--dw-theme,#6c2bd9)}
.dw-hero .progress{height:10px;border-radius:10px;background:var(--dw-theme-soft-strong,#eaf6ea);overflow:hidden;margin:8px 0;border:1px solid var(--dw-theme-soft-strong,#dcfce7)}
.dw-hero .progress>div{height:12px;background:var(--dw-progress,#22c55e);border-radius:10px}
.dw-hero .stats{display:flex;justify-content:space-between;color:#475569;font-size:12px;margin-top:8px;font-weight:700}
.dw-hero .cta{margin:14px 0 6px}
.dw-hero .cta .btn{display:inline-block;background:var(--dw-btn,#0f9f64);color:#fff;border-radius:10px;padding:14px 16px;text-decoration:none;width:100%;text-align:center;box-shadow:0 8px 20px rgba(var(--dw-theme-rgb,108,43,217),.28);font-weight:800;letter-spacing:.2px;border:none}
.dw-form-collapsed{display:none}
.dw-section{padding:18px}
.dw-section h3{margin:0 0 8px;font-weight:800}
.dw-fundraiser{display:flex;align-items:center;gap:12px}
.dw-fundraiser img{width:46px;height:46px;border-radius:999px;object-fit:cover}
.dw-fundraiser .dw-fundraiser-meta{display:flex;flex-direction:column;gap:4px}
.dw-fundraiser .dw-fundraiser-meta .name{font-weight:700;color:#0f172a}
.dw-fundraiser .dw-fundraiser-meta .line{display:flex;align-items:center;gap:8px;flex-wrap:wrap;align-items:center}
.dw-fundraiser .dw-fundraiser-meta .sub{color:var(--dw-theme,#0ea5e9);font-weight:700;font-size:12px;line-height:1}
.dw-fundraiser .dw-verified-pill{display:inline-flex;align-items:center;gap:6px;background:var(--dw-theme-soft,#e8f9ef);border:1px solid var(--dw-theme-border,#b2e2c1);color:var(--dw-theme,#166534);font-size:12px;font-weight:800;padding:6px 10px;border-radius:999px;box-shadow:0 0 0 1px rgba(0,0,0,.08)}
.dw-fundraiser .dw-verified-pill .ic{width:14px;height:14px}
.dw-single-tabs{margin:14px 0 6px;display:flex;gap:8px;border-bottom:1px solid #e5e7eb}
.dw-single-tabs a{padding:10px 14px;border-radius:10px 10px 0 0;text-decoration:none;color:#0f172a;font-weight:700;display:inline-block;border:1px solid transparent;border-bottom:0}
.dw-single-tabs a.active{background:var(--dw-theme,#6c2bd9);color:#fff;border-color:var(--dw-theme,#6c2bd9);box-shadow:0 8px 20px rgba(0,0,0,.08)}
.dw-single-campaign .dw-single-tabs{
  margin:0;
  display:block;
  gap:0;
  border-bottom:0;
}
.dw-single-campaign .dw-single-tabs a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  width:100%;
  padding:16px;
  border:0;
  border-bottom:1px solid #eef2f7;
  border-radius:0;
  background:#fff;
  box-shadow:none;
}
.dw-single-campaign .dw-single-tabs a::after{
  content:"›";
  font-size:22px;
  line-height:1;
  color:#9ca3af;
  margin-left:12px;
  flex:0 0 auto;
}
.dw-single-campaign .dw-single-tabs a.active{
  background:#fff;
  color:#0f172a;
  border:0;
  border-bottom:1px solid #eef2f7;
  box-shadow:none;
}
.dw-tab-panel{display:none}
.dw-tab-panel.active{display:block}
.dw-donor-box{display:flex;flex-direction:column;gap:12px}
.dw-donor-sort{display:flex;gap:10px;flex-wrap:wrap}
.dw-donor-sort-btn{border:1px solid var(--dw-theme,#6c2bd9);background:#fff;color:var(--dw-theme,#6c2bd9);border-radius:10px;padding:10px 16px;font-weight:700;cursor:pointer;transition:all .15s ease}
.dw-donor-sort-btn.active{background:var(--dw-theme,#6c2bd9);color:#fff;box-shadow:0 8px 16px rgba(0,0,0,.15)}
.dw-donor-list{display:none;flex-direction:column;gap:12px}
.dw-donor-list.active{display:flex}
.dw-donor-item{border:1px solid #e2e8f0;border-radius:12px;padding:12px 14px;background:#f8fbff;box-shadow:0 6px 14px rgba(15,23,42,.06)}
.dw-donor-item .top{display:flex;justify-content:space-between;align-items:center;font-weight:800;color:#0f172a}
.dw-donor-item .top .time{color:#94a3b8;font-weight:700;font-size:12px}
.dw-donor-item .amount{margin-top:6px;color:#0f172a;font-weight:600}
.dw-donor-item.hidden{display:none}
.dw-donor-load{text-align:center;margin-top:4px}
.dw-donor-load-btn{padding:10px 18px;border-radius:999px;border:1px solid var(--dw-theme,#6c2bd9);background:#fff;color:var(--dw-theme,#6c2bd9);font-weight:700;box-shadow:0 8px 20px rgba(0,0,0,.08);cursor:pointer}
.dw-empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px;text-align:center;color:#94a3b8}
.dw-empty-state img{width:100%;max-width:240px;height:auto;opacity:0.9;filter:drop-shadow(0 12px 24px rgba(0,0,0,.12))}
.dw-empty-state .txt{font-weight:700;color:#475569}
@media (max-width: 640px){
  .dw-empty-state img{max-width:200px}
}
.dw-single-v2 header,
.dw-single-v2 footer,
.site-header,
.main-header,
.site-footer,
footer.site-footer,
header#masthead,
.site-header-main,
.page-header,
.page-footer {
  display:none !important;
}
.dw-fp-page{
  position:relative;
  width:100%;
  min-height:100vh;
  --dw-fp-header-h: 68px;
  --dw-fp-maxw: 500px;
  padding-top:calc(var(--dw-fp-header-h) + env(safe-area-inset-top, 0px) + var(--donasiwp-adminbar-h, 0px));
  background:linear-gradient(180deg,#eef2ff 0%,#f8fafc 65%,#ffffff 100%);
}
.dw-fp-header{
  position:fixed;
  left:0;
  right:0;
  top:calc(env(safe-area-inset-top, 0px) + var(--donasiwp-adminbar-h, 0px));
  transform:none;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:center;
  height:var(--dw-fp-header-h,68px);
  padding:0 18px;
  width:100%;
  max-width:none;
  background:var(--dw-theme,#15803d);
  color:#fff;
  box-shadow:0 10px 24px rgba(15,23,42,.22);
  border-radius:0;
}
.dw-fp-header-title{
  font-size:16px;
  font-weight:700;
  letter-spacing:.01em;
  text-align:center;
  flex:1;
  margin:0;
}
.dw-fp-back{
  position:absolute;
  left:14px;
  border:0;
  background:transparent;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  padding:6px;
  box-shadow:none;
  outline:none;
  -webkit-tap-highlight-color: transparent;
}
.dw-fp-back:focus,
.dw-fp-back:focus-visible,
.dw-fp-back:active{
  background:transparent !important;
  box-shadow:none !important;
  outline:none !important;
}
.dw-fp-back svg{
  width:28px;
  height:28px;
}
.dw-fp-content{
  width:100%;
  max-width:var(--dw-fp-maxw,500px);
  margin:0 auto;
  padding:26px 16px 42px;
  display:flex;
  flex-direction:column;
  gap:18px;
  position:relative;
  z-index:1;
}
.dw-fp-profile-card{
  margin-top:-32px;
  background:#fff;
  border-radius:24px;
  padding:18px 22px;
  display:flex;
  gap:18px;
  align-items:flex-start;
  box-shadow:0 14px 30px rgba(15,23,42,.10);
  position:relative;
  z-index:10;
}
.dw-fp-avatar{
  width:74px;
  height:74px;
  border-radius:16px;
  object-fit:cover;
  border:2px solid #fff;
  box-shadow:0 10px 22px rgba(15,23,42,.14);
}
.dw-fp-profile-meta{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.dw-fp-profile-name{
  font-size:22px;
  font-weight:800;
  color:#0f172a;
  margin:0;
  display:flex;
  align-items:center;
  gap:8px;
}
.dw-fp-profile-line{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.dw-fp-profile-start{
  font-size:13px;
  font-weight:600;
  color:#475569;
}
.dw-fp-profile-location{
  font-size:12px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#64748b;
}
.dw-fp-type-badge{
  font-size:11px;
  font-weight:800;
  color:var(--dw-theme,#15803d);
  border:1.5px solid rgba(var(--dw-theme-rgb,21,128,61),.35);
  border-radius:999px;
  padding:4px 10px;
  background:#fff;
}
.dw-fp-verified-badge{
  margin-left:2px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.dw-fp-verified-badge img{
  width:18px;
  height:18px;
  display:block;
}
.dw-fp-section{
  background:#fff;
  border-radius:22px;
  padding:16px 18px 20px;
  box-shadow:0 10px 20px rgba(15,23,42,.08);
}
.dw-fp-section h2{
  margin:0;
}
.dw-fp-section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.dw-fp-section-head .title-strip{
  font-size:16px;
  font-weight:800;
}
.dw-fp-section-head h2{
  margin:0;
  font-size:18px;
  font-weight:800;
  color:#0f172a;
}
.dw-fp-section-body{
  color:#475569;
  line-height:1.7;
  font-size:14px;
}
.dw-fp-bio-empty{
  color:#94a3b8;
  margin:0;
}
.dw-fp-bio-cta{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:13px;
  font-weight:700;
  color:var(--dw-theme,#15803d);
  text-decoration:none;
}
.dw-fp-bio-cta span{
  font-size:16px;
  line-height:1;
}
.dw-fp-supported .dw-fp-section-head{
  border-bottom:0;
  padding-bottom:0;
  margin-bottom:14px;
}
.dw-fp-supported-count{
  font-size:12px;
  font-weight:700;
  color:#94a3b8;
}
.dw-fp-campaigns{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.dw-fp-campaigns .dw-sc-list{
  display:flex;
  flex-direction:column;
  gap:0;
  margin:0;
  padding:0;
  max-width:none;
}
.dw-fp-campaigns .dw-sc-item{
  display:flex;
  gap:14px;
  padding:16px 0;
  align-items:flex-start;
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  overflow:hidden;
  border-bottom:1px solid #e5e7eb;
}
.dw-fp-campaigns .dw-sc-item:last-child{
  border-bottom:0;
}
.dw-fp-campaigns .dw-sc-item .dw-thumb{
  display:block;
  flex:0 0 210px;
  width:210px;
  height:118px;
  border-radius:10px;
  background-size:cover;
  background-position:center;
  background-color:#f1f5f9;
}
.dw-fp-campaigns .dw-sc-content{
  padding:0;
}
.dw-fp-campaigns .dw-sc-title{
  font-size:15px;
}
.dw-fp-campaigns .dw-sc-progress{
  margin-top:8px;
  background:#eef2ff;
}
.dw-fp-campaigns .dw-sc-progress>div{
  background:var(--dw-progress,#22c55e);
}
.dw-fp-campaigns .dw-sc-meta .label{
  color:#94a3b8;
}
.dw-fp-campaigns .dw-sc-meta .val{
  font-weight:700;
  color:#0f172a;
}
.dw-fp-campaigns .dw-sc-meta{
  column-gap:12px;
}
.dw-fp-campaigns .dw-sc-meta .right{
  text-align:right;
}
@media (max-width: 640px){
  .dw-fp-page{
    --dw-fp-header-h: 56px;
  }
  .dw-fp-header{
    height:var(--dw-fp-header-h,56px);
  }
  .dw-fp-back{padding:4px}
  .dw-fp-profile-card{
    flex-direction:column;
    align-items:flex-start;
    margin-top:0;
  }
  .dw-fp-content{
    padding-top:16px;
  }
  /* Mobile: use shorter thumbnails */
  .dw-fp-campaigns .dw-sc-item{gap:12px;padding:14px 0}
  .dw-fp-campaigns .dw-sc-item .dw-thumb{flex-basis:160px;width:160px;height:94px}
}

@media (max-width: 420px){
  .dw-fp-campaigns .dw-sc-item{gap:10px}
  .dw-fp-campaigns .dw-sc-item .dw-thumb{flex-basis:140px;width:140px;height:84px}
}
@media (max-width: 360px){
  .dw-fp-campaigns .dw-sc-item{gap:10px}
  .dw-fp-campaigns .dw-sc-item .dw-thumb{flex-basis:128px;width:128px;height:76px}
}

@media (min-width: 768px){
  /* Desktop: background pinggir + kolom tengah 500px (seperti halaman campaign) */
  .dw-fp-page{
    background:#f3f4f6;
  }
  .dw-fp-page:before{
    content:"";
    position:fixed;
    top:0;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
    width:calc(100% - 24px);
    max-width:var(--dw-fp-maxw,500px);
    background:#fff;
    box-shadow:0 8px 18px rgba(15,23,42,.12);
    z-index:0;
    pointer-events:none;
  }
  .dw-fp-header{
    left:50%;
    right:auto;
    transform:translateX(-50%);
    width:calc(100% - 24px);
    max-width:var(--dw-fp-maxw,500px);
  }
}
.dw-tabs{display:flex;gap:8px;padding:10px 12px;background:#f8fafc;border-radius:12px;box-shadow:0 10px 24px rgba(var(--dw-theme-rgb,108,43,217),.1);margin:12px 0}
.dw-tabs a{padding:10px 12px;border-radius:10px;text-decoration:none;color:#0f172a;background:#fff;border:1px solid #e5e7eb;font-weight:700;flex:1;text-align:center}
.dw-tabs a.active{background:rgba(0,0,0,.03);border-color:var(--dw-theme,#6c2bd9);color:#0f172a;box-shadow:0 8px 20px rgba(0,0,0,.08)}
.dw-single-tabs a{display:flex;align-items:center;justify-content:center;gap:8px}
.dw-tab-label{display:flex;align-items:center;gap:10px;justify-content:space-between;flex:1;min-width:0}
.dw-tab-text{min-width:0}
.dw-count-pill{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 10px;border-radius:999px;background:rgba(var(--dw-theme-rgb,108,43,217),.16);border:1px solid rgba(var(--dw-theme-rgb,108,43,217),.22);color:var(--dw-theme,#6c2bd9);font-weight:900;font-size:13px;line-height:1}
.dw-desc{line-height:1.65;color:#334155}
.dw-desc.collapsed{max-height:300px;overflow:hidden;position:relative}
.dw-desc.collapsed:after{content:"";position:absolute;left:0;right:0;bottom:0;height:70px;background:linear-gradient(180deg,rgba(255,255,255,0),#fff)}
.dw-readmore{display:block;width:-moz-fit-content;width:fit-content;justify-content:center;align-items:center;margin:12px auto 14px;background:var(--dw-theme-soft,#e7fff0);border:1px solid var(--dw-theme-border,#34d399);color:var(--dw-theme,#6c2bd9);border-radius:999px;padding:10px 16px;text-decoration:none;box-shadow:0 4px 12px rgba(0,0,0,.12);text-align:center}
.dw-fund-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 18px;border-radius:10px;border:2px solid var(--dw-theme,#6c2bd9);background:linear-gradient(180deg,var(--dw-theme-soft,#f0fff7),var(--dw-theme-soft-strong,#d1fae5));color:var(--dw-theme,#6c2bd9);text-decoration:none;box-shadow:0 8px 24px rgba(var(--dw-theme-rgb,108,43,217),.25);transition:transform .15s ease}
.dw-fund-btn .ic{width:20px;height:20px;color:var(--dw-theme,#6c2bd9)}
.dw-fundraiser-block .dw-section{padding:16px}
.dw-fundraiser-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.dw-fundraiser-head-title{font-weight:600;font-size:18px;color:#0f172a;display:flex;align-items:center;gap:8px}
.dw-fundraiser-wrap{margin-top:10px}
.dw-fundraiser-list{display:flex;flex-direction:column;gap:10px}
.dw-fundraiser-item{border:1px solid #e2e8f0;background:#fff;border-radius:16px;padding:16px 18px;box-shadow:0 8px 20px rgba(15,23,42,.08);display:flex;flex-direction:column;gap:6px}
.dw-fundraiser-item.hidden{display:none}
.dw-fundraiser-name{font-weight:700;color:#0f172a;text-decoration:none}
.dw-fundraiser-name:hover{text-decoration:underline}
.dw-fundraiser-meta{font-size:14px;color:#475569}
.dw-fundraiser-amount{font-weight:700;font-size:18px;color:#0f172a}
.dw-fundraiser-load{text-align:center;margin-top:12px}
.dw-fundraiser-load-btn{padding:10px 20px;border-radius:999px;border:1px solid var(--dw-theme,#6c2bd9);background:#fff;color:var(--dw-theme,#6c2bd9);font-weight:700;box-shadow:0 8px 20px rgba(0,0,0,.08);cursor:pointer}
.dw-fundraiser-empty-state{margin:12px auto 0;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;padding:22px 12px}
.dw-fundraiser-empty-state img{max-width:240px;width:100%;height:auto}
@media (max-width: 640px){
  .dw-fundraiser-empty-state img{max-width:200px}
}
.dw-fundraiser-empty-title{font-weight:700;font-size:18px;color:#0f172a}
.dw-fundraiser-empty-desc{color:#64748b;font-size:14px;max-width:360px}
.dw-fundraiser-cta{margin-top:22px;margin-bottom:10px;text-align:center;display:flex;flex-direction:column;gap:12px}
.dw-fundraiser-cta p{margin:0;color:#64748b;font-size:15px;line-height:1.5}
.dw-fundraiser-cta .dw-fund-btn{margin:0 auto}
.dw-list{display:flex;flex-direction:column;gap:8px}
.dw-note{background:#fff;border:1px solid #eef2ff;border-radius:10px;padding:10px}
.dw-note .name{font-weight:600}
.dw-note .time{float:right;color:#94a3b8;font-size:12px}
.dw-footer{padding:16px;text-align:center;color:#94a3b8}
.dw-panel-green{background:linear-gradient(180deg,var(--dw-theme-soft,#ffffff),var(--dw-theme-soft-strong,#ecfdf3));border:1px solid var(--dw-theme-soft-strong,#d7f3ff);box-shadow:0 14px 30px rgba(var(--dw-theme-rgb,108,43,217),.18)}
.dw-panel-blue{background:linear-gradient(180deg,#f8fbff,#eef4ff)}
/* extra hero meta */
.dw-hero .subtitle{display:flex;align-items:center;gap:6px;color:#94a3b8;font-size:12px;margin-top:4px}
.dw-hero .amount{font-weight:700;margin-top:6px}
.dw-hero .stats{margin-top:6px}

/* Make "Doa-doa Orang Baik" panel background feel full on mobile */
@media (max-width: 640px){
  .dw-single-campaign .dw-card2.dw-panel-blue{
    border-top-color:#eef4ff;
    position:relative;
    background:transparent;
  }
  .dw-single-campaign .dw-card2.dw-panel-blue::before{
    content:"";
    position:absolute;
    top:0;
    bottom:0;
    left:50%;
    width:100vw;
    transform:translateX(-50%);
    background:linear-gradient(180deg,#f8fbff,#eef4ff);
    z-index:0;
  }
  .dw-single-campaign .dw-card2.dw-panel-blue .dw-section{
    padding-top:22px;
    padding-bottom:22px;
    padding-left:16px;
    padding-right:16px;
    position:relative;
    z-index:1;
  }
  .dw-single-campaign .dw-card2.dw-panel-blue .dw-prayers-head{
    margin-top:4px;
  }
  .dw-single-campaign .dw-card2.dw-panel-blue .dw-prayers-title{
    font-size:17px;
  }
}

/* ===== Doa-doa Orang Baik ===== */
.dw-prayers-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.dw-prayers-title{font-size:18px;font-weight:600;color:#0f172a;letter-spacing:0}
.dw-prayers-count{background:rgba(var(--dw-theme-rgb,14,165,233),.12);color:var(--dw-theme,#0ea5e9);font-weight:900;font-size:13px;border-radius:999px;padding:6px 10px;line-height:1}
.dw-prayers{display:flex;flex-direction:column;gap:14px}
.dw-prayer{background:#fff;border-radius:16px;border:1px solid rgba(15,23,42,.06);box-shadow:0 10px 22px rgba(15,23,42,.08);padding:14px 14px 0}
.dw-prayer-head{display:flex;align-items:flex-start;gap:12px}
.dw-prayer-avatar{width:38px;height:38px;border-radius:999px;background:#f1f5f9;color:#9ca3af;display:flex;align-items:center;justify-content:center;flex:0 0 auto;margin-top:2px}
.dw-prayer-meta{flex:1;min-width:0}
.dw-prayer-name{font-weight:800;color:#111827;font-size:15px;line-height:1.2}
.dw-prayer-time{margin-top:2px;color:#94a3b8;font-weight:700;font-size:12px;line-height:1.2}
.dw-prayer-more{border:0;background:transparent;color:#9ca3af;font-size:22px;line-height:1;padding:0 4px;cursor:default}
.dw-prayer-text{margin-top:10px;color:#334155;font-size:14px;line-height:1.7;white-space:pre-wrap;word-break:break-word}
.dw-prayer-aminline{margin-top:12px;color:#64748b;font-weight:700;font-size:13px}
.dw-prayer-aminline strong{color:#0f172a}
.dw-prayer-aminline{display:none}
.dw-prayer.has-aminline .dw-prayer-aminline{display:block;padding-bottom:12px;border-bottom:1px solid rgba(15,23,42,.06)}
.dw-prayer-actions{margin-top:12px;border-top:1px solid rgba(15,23,42,.06);display:flex;align-items:center;justify-content:center}
.dw-prayer.has-aminline .dw-prayer-actions{border-top:0;margin-top:0}
.dw-prayer-action{flex:1;border:0;background:transparent;color:#64748b;font-weight:800;padding:12px 8px;display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer}
.dw-prayer-action,
.dw-prayer-action:hover,
.dw-prayer-action:active,
.dw-prayer-action:focus,
.dw-prayer-action:focus-visible{
  background:transparent !important;
  background-color:transparent !important;
  box-shadow:none !important;
  outline:none !important;
  -webkit-tap-highlight-color: transparent;
  appearance:none;
  -webkit-appearance:none;
}
.dw-single-v2 .dw-prayer-actions button.dw-prayer-action,
.dw-single-v2 .dw-prayer-actions button.dw-prayer-action:hover,
.dw-single-v2 .dw-prayer-actions button.dw-prayer-action:active,
.dw-single-v2 .dw-prayer-actions button.dw-prayer-action:focus,
.dw-single-v2 .dw-prayer-actions button.dw-prayer-action:focus-visible{
  background:transparent !important;
  background-color:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  outline:none !important;
}
.dw-prayer-action .ic{display:inline-flex;align-items:center;justify-content:center;color:#9ca3af}
.dw-prayer-action .tx{font-size:14px}
.dw-prayer-action-sep{display:none}
.dw-prayer-amin.is-on{color:#0f172a}
.dw-prayer-amin.is-on .ic{color:#ef4444}
.dw-prayer-amin.is-on .ic svg path{fill:#ef4444;stroke:#ef4444}
.dw-prayer-amin .ic svg path{fill:none}

@media (max-width: 520px){
  .dw-prayer{box-shadow:0 8px 18px rgba(15,23,42,.07)}
}

/* Share sheet removed */

/* Donate page form chips */
.dw-donate .chips{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:18px;margin:12px 0 18px}
.dw-donate .chip{position:relative;border:1px solid #e5e7eb;border-radius:18px;padding:18px 16px;text-align:left;background:#fff;box-shadow:0 12px 26px rgba(15,23,42,.08);display:flex;flex-direction:column;gap:4px;font-size:16px;font-weight:800}
.dw-donate .chip .t{font-weight:700;font-size:16px}
.dw-donate .chip .sub{color:#9aa3b2;font-size:12px;margin-top:2px}
.dw-donate .chip input{position:absolute;opacity:0;width:1px;height:1px;clip:rect(0 0 0 0);clip-path:inset(50%)}
.dw-donate .chip.active{border-color:var(--dw-theme,#16a34a);box-shadow:0 16px 32px rgba(var(--dw-theme-rgb,108,43,217),.25);background:linear-gradient(180deg,var(--dw-theme-soft,#f7fff9),#fff)}
.dw-donate .chip.active::after{content:"";position:absolute;right:12px;top:12px;width:18px;height:18px;border-radius:999px;background:var(--dw-theme,#16a34a);box-shadow:0 0 0 3px var(--dw-theme-soft,#e0f2fe)}
.dw-list-cards{display:flex;flex-direction:column;gap:14px;margin:12px 0 18px}
.dw-list-card{position:relative;display:flex;align-items:center;gap:14px;border:1px solid #e5e7f0;border-radius:16px;padding:16px 16px;background:#fff;box-shadow:0 12px 30px rgba(15,23,42,.08);cursor:pointer}
.dw-list-card input{position:absolute;opacity:0;width:1px;height:1px;clip:rect(0 0 0 0);clip-path:inset(50%)}
.dw-list-card .emo{width:46px;height:46px;border-radius:14px;background:#f7f7fb;display:flex;align-items:center;justify-content:center;font-size:22px}
.dw-list-card .txt{flex:1}
.dw-list-card .txt .main{font-weight:700;font-size:16px}
.dw-list-card .txt .sub{color:#94a3b8;font-size:12px}
.dw-list-card .check{width:22px;height:22px;border-radius:999px;border:2px solid #e2e8f0;box-shadow:inset 0 0 0 2px #fff}
.dw-list-card:hover{border-color:var(--dw-theme,#6c2bd9);box-shadow:0 14px 28px rgba(108,43,217,.15)}
.dw-list-card input:checked ~ .emo{background:rgba(108,43,217,.08)}
.dw-list-card input:checked ~ .check{border-color:var(--dw-theme,#6c2bd9);background:var(--dw-theme,#6c2bd9)}
.dw-donate .section-title{font-weight:800;font-size:16px;margin:12px 0 8px}

/* Typing form */
.dw-typing-amount{display:flex;align-items:center;gap:10px;border:1px solid #e5e7eb;background:#f8fafc;border-radius:14px;padding:12px 14px;margin:10px 0 16px;box-shadow:0 8px 20px rgba(15,23,42,.06)}
.dw-typing-amount .prefix{font-weight:800;color:#0f172a}
.dw-typing-amount .dw-input-typing{flex:1;border:0;background:transparent;outline:none;font-size:24px;font-weight:800;color:#0f172a}
.dw-typing-amount .dw-input-typing::placeholder{color:#cbd5e1;font-weight:700}
.dw-donate .panel{background:#eaf3ff;border:1px solid #cddff7;border-radius:12px;padding:14px 16px;display:flex;justify-content:space-between;align-items:center;margin:14px 0 18px;gap:12px}
.dw-donate .panel.pay-panel{margin-bottom:16px}
.dw-donate .pay-panel .ic{width:36px;height:36px;border:2px solid #cfe3ff;border-radius:8px;background:linear-gradient(180deg,#fff,#f1f7ff);background-image:none!important}
.dw-donate .pay-panel .txt{flex:1;color:#1f2937;font-weight:600}
.dw-donate .pay-panel .ic img{width:100%;height:100%;object-fit:contain;display:block}
.dw-donate .btn-select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:8px 12px;display:inline-flex;align-items:center;gap:6px;font-weight:700;color:#0f172a}
.dw-donate .btn-select .caret{opacity:.6;font-size:0}
.dw-donate .btn-select .caret::before{content:"\25BE";font-size:14px}
.dw-donate .segmented{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;flex:1}
.dw-donate .segmented .seg{display:flex;align-items:center;justify-content:center;padding:10px 12px;min-height:42px;background:#fff;color:#111;border-right:1px solid #e5e7eb}
.dw-donate .segmented .seg:last-child{border-right:0}
.dw-donate .segmented .seg input{position:absolute;opacity:0;width:1px;height:1px;clip:rect(0 0 0 0);clip-path:inset(50%)}
.dw-donate .segmented .seg.active{background:var(--dw-theme,#6c2bd9);color:#fff;font-weight:600}
.dw-donate .segmented.two{grid-template-columns:repeat(2,1fr)}

/* Zakat form (donate page) */
.dw-donate .dw-zakat{margin:10px 0 16px}
.dw-donate .dw-zakat-label{color:#64748b;font-weight:800;margin:0 0 8px;font-size:13px}
.dw-donate .dw-zakat-input{display:flex;align-items:center;gap:10px}
.dw-donate .dw-zakat-input .prefix{background:#f1f5f9;border:1px solid #e5e7eb;border-radius:12px;padding:12px 12px;font-weight:900;color:#0f172a}
.dw-donate .dw-zakat-input input{flex:1}
.dw-donate .dw-zakat-period{margin:6px 0 14px}
.dw-donate .dw-zakat-summary{margin-top:12px;border:1px solid #dbeafe;background:linear-gradient(180deg,#eff6ff,#ffffff);border-radius:16px;box-shadow:0 14px 30px rgba(59,130,246,.12);overflow:hidden}
.dw-donate .dw-zakat-summary .row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid rgba(59,130,246,.12)}
.dw-donate .dw-zakat-summary .row:last-child{border-bottom:0}
.dw-donate .dw-zakat-summary .k{font-weight:800;color:#334155}
.dw-donate .dw-zakat-summary .v{font-weight:900;color:#0f172a}
.dw-donate .dw-zakat-summary .row.big{background:rgba(59,130,246,.08)}
.dw-donate .dw-zakat-summary .row.big .v{color:#1d4ed8;font-size:16px}
.dw-donate .dw-zakat-out-total,
.dw-donate .dw-zakat-out-nisab,
.dw-donate .dw-zakat-out-zakat{white-space:nowrap}
.dw-single-v2.dw-donate-page .dw-donate .dw-zakat-fitrah-title{font-weight:600;color:#0f172a;margin:6px 0 12px;font-size:18px!important;letter-spacing:.1px}
.dw-donate .dw-zf-items{display:flex;flex-direction:column;gap:12px}
.dw-donate .dw-zf-item{padding:12px;border-radius:16px;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 10px 24px rgba(15,23,42,.08)}
.dw-donate .dw-zf-top{display:flex;align-items:center;gap:14px}
.dw-single-v2.dw-donate-page .dw-donate .dw-zf-thumb{
  width:120px;
  height:68px; /* 16:9-ish to minimize letterboxing */
  border-radius:14px;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-weight:700;
  flex:0 0 auto;
  overflow:hidden;
  border:1px solid rgba(15,23,42,.08);
  padding:0;
  box-sizing:border-box
}
.dw-single-v2.dw-donate-page .dw-donate .dw-zf-thumb img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important; /* fill without blank top/bottom */
  object-position:center!important;
  display:block;
  background:#fff
}
.dw-donate .dw-zf-thumb span{font-size:16px;letter-spacing:.08em}
.dw-donate .dw-zf-main{flex:1;min-width:0}
.dw-single-v2.dw-donate-page .dw-donate .dw-zf-name{font-weight:700;color:#0f172a;line-height:1.2;font-size:16px!important}
.dw-single-v2.dw-donate-page .dw-donate .dw-zf-meta{color:#64748b;font-size:12px!important;margin-top:4px;line-height:1.25;font-weight:400}
.dw-single-v2.dw-donate-page .dw-donate .dw-zf-price{font-weight:700;color:#0f172a;margin-top:6px;font-size:14px!important}
.dw-single-v2.dw-donate-page .dw-donate .dw-zf-action{display:flex;align-items:center;justify-content:flex-end;min-width:132px;flex:0 0 auto}
.dw-single-v2.dw-donate-page .dw-donate .dw-zf-add{background:var(--dw-btn,#16a34a);border:0;color:#fff;font-weight:600;border-radius:12px;padding:10px 12px;cursor:pointer;min-width:104px;font-size:14px}
.dw-donate .dw-zf-add:active{transform:translateY(1px)}
.dw-donate .dw-zf-stepper{display:flex;align-items:center;gap:12px}
.dw-single-v2.dw-donate-page .dw-donate .dw-zf-minus,
.dw-single-v2.dw-donate-page .dw-donate .dw-zf-plus{
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid #e5e7eb;
  background:#f3f4f6;
  color:var(--dw-btn,#16a34a);
  font-weight:700;
  cursor:pointer;
  font-size:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  line-height:1;
}
.dw-single-v2.dw-donate-page .dw-donate .dw-zf-qty{min-width:18px;text-align:center;font-weight:700;color:#0f172a;font-size:18px!important}
.dw-donate .dw-zf-names{margin-top:12px;padding-top:12px;border-top:1px solid #eef2f7}
.dw-donate .dw-zf-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.dw-donate .dw-zf-chip{display:inline-flex;align-items:center;gap:6px;background:#e0f2fe;border:1px solid #bae6fd;color:#075985;border-radius:10px;padding:6px 10px;font-weight:600}
.dw-donate .dw-zf-chip .x{border:0;background:transparent;color:#075985;font-weight:900;cursor:pointer;line-height:1;padding:0 0 0 2px}
.dw-single-v2.dw-donate-page .dw-donate .dw-zf-name-input{width:100%;border:1px solid #e5e7eb;border-radius:12px;padding:12px 14px;font-weight:500;box-sizing:border-box;font-size:16px!important}
.dw-donate .dw-zf-name-input:disabled{background:#f1f5f9;color:#94a3b8}
.dw-donate .dw-zf-help{margin-top:8px;font-size:13px;color:#64748b;font-weight:500}
.dw-donate .dw-zf-item.is-name-error .dw-zf-name-input{border-color:#fb7185;box-shadow:0 0 0 3px rgba(251,113,133,.18)}
.dw-donate .dw-zf-item.is-name-error .dw-zf-help{color:#e11d48}
.dw-donate .dw-zf-extras{margin-top:14px;display:flex;flex-direction:column;gap:12px}
@media (min-width:768px){
  /* Desktop should be compact (not oversized) */
  .dw-single-v2.dw-donate-page .dw-donate .dw-zakat-fitrah-title{font-size:17px!important;font-weight:600;margin:4px 0 12px}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-item{padding:12px;border-radius:16px}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-top{gap:14px}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-thumb{width:132px;height:74px}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-name{font-size:16px!important}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-meta{font-size:12px!important}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-price{font-size:14px!important}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-action{min-width:124px}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-add{min-width:104px;padding:9px 11px;border-radius:12px;font-size:13px}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-minus,
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-plus{width:40px;height:40px;font-size:20px}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-qty{font-size:17px!important}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-name-input{font-size:15px!important}
}
@media (max-width:420px){
  .dw-single-v2.dw-donate-page .dw-donate .dw-zakat-fitrah-title{font-size:17px!important}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-thumb{width:98px;height:56px}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-name{font-size:15px!important}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-meta{font-size:11px!important}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-price{font-size:13px!important}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-action{min-width:118px}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-add{min-width:100px;padding:9px 11px;border-radius:12px;font-size:13px}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-minus,
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-plus{width:38px;height:38px;font-size:20px}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-qty{font-size:16px!important}
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-name-input{font-size:15px!important;padding:12px 14px}
}

/* Mobile layout (match compact card like mock) */
@media (max-width:640px){
  .dw-single-v2.dw-donate-page .dw-donate .dw-zakat-fitrah-title{
    font-size:16px!important;
    font-weight:600;
    margin:4px 0 10px;
  }
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-item{
    padding:12px;
    border-radius:16px;
  }
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-top{
    gap:12px;
  }
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-thumb{
    width:110px;
    height:62px;
    border-radius:14px;
  }
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-main{
    text-align:left;
    min-width:0;
  }
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-name{
    font-size:15px!important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-meta{
    font-size:11px!important;
  }
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-price{
    font-size:13px!important;
    margin-top:4px;
  }
  /* Qurban (mobile): keep currency + amount on one line (e.g. "Rp 2.000.000") */
  .dw-single-v2.dw-donate-page .dw-donate .dw-zakat[data-zakat-type="qurban"] .dw-zf-price{
    white-space:nowrap !important;
  }
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-action{
    min-width:116px;
  }
  .dw-single-v2.dw-donate-page .dw-donate .dw-zf-add{
    min-width:104px;
    padding:9px 11px;
    border-radius:12px;
    font-size:13px;
  }
}
.dw-donate .dw-row{display:flex;align-items:center;gap:12px;margin:8px 0}
.dw-donate .dw-row-label{color:#64748b;min-width:64px}
.dw-donate .dw-inline{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:8px 0}
.dw-donate .dw-inline-label{color:#64748b}
.dw-switch{position:relative;display:inline-block;width:44px;height:24px}
.dw-switch input{opacity:0;width:0;height:0}
.dw-switch .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#e5e7eb;border-radius:999px;transition:all .2s}
.dw-switch .slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:#fff;border-radius:50%;box-shadow:0 1px 2px rgba(0,0,0,.2);transition:all .2s}
.dw-switch input:checked + .slider{background:var(--dw-theme,#6c2bd9)}
.dw-switch input:checked + .slider:before{transform:translateX(20px)}
.dw-donate .cta-fixed{position:fixed;left:50%;transform:translateX(-50%);bottom:28px;z-index:999;display:block;width:calc(100% - 36px);max-width:500px;background:var(--dw-btn,#0f9f64);color:#fff;border-radius:12px;padding:16px 18px;text-align:center;box-shadow:0 12px 30px rgba(0,0,0,.15);border:none;font-size:16px;font-weight:800}
.dw-donate .cta-fixed .spinner{display:none;width:16px;height:16px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;margin-left:8px;vertical-align:middle;animation:vy-rot .8s linear infinite}
.dw-donate .cta-fixed.loading{opacity:.9;pointer-events:none}
.dw-donate .cta-fixed.loading .spinner{display:inline-block}
@keyframes vy-rot{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* Sticky CTA on single campaign */
.dw-sticky-cta{position:fixed;left:50%;transform:translateX(-50%);bottom:-140px;z-index:1200;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px;width:100%;max-width:500px;transition:all .22s ease;opacity:0;background:#fff;border-radius:12px;box-shadow:0 12px 26px rgba(var(--dw-theme-rgb,108,43,217),.1);border:1px solid var(--dw-theme-soft-strong,#f1f5ff)}
.dw-sticky-cta.visible{bottom:calc(8px + env(safe-area-inset-bottom, 0px));opacity:1}
.dw-sticky-cta .dw-sticky-share{border:2px solid var(--dw-theme,#6c2bd9);background:#fff;color:var(--dw-theme,#6c2bd9);border-radius:8px;padding:10px 12px;display:flex;align-items:center;justify-content:center;gap:10px;font-weight:800;cursor:pointer;box-shadow:none;min-height:44px;font-size:15px;transition:transform .2s ease,box-shadow .2s ease}
.dw-sticky-cta .dw-sticky-share:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(var(--dw-theme-rgb,108,43,217),.25)}
.dw-sticky-cta .dw-sticky-share .ic{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center}
.dw-sticky-cta .dw-sticky-share .ic svg{width:22px;height:22px;display:block}
.dw-sticky-cta .dw-sticky-share .txt{line-height:1}
.dw-sticky-cta .dw-sticky-share small{display:block;font-weight:500;color:var(--dw-theme,#6c2bd9)}
.dw-sticky-cta .dw-sticky-donate{background:var(--dw-btn,#0f9f64);color:#fff;border-radius:8px;padding:10px 12px;text-align:center;font-weight:800;text-decoration:none;display:flex;align-items:center;justify-content:center;box-shadow:none;border:2px solid var(--dw-btn,#0f9f64);min-height:44px;font-size:15px}

/* Packaged form */
.dw-packaged{margin:8px 0 18px}
.dw-packaged .pkg-title{color:#64748b;font-weight:700;margin-bottom:10px}
.dw-packaged .pkg-highlight{background:linear-gradient(180deg,#ecfdf3,#d1fae5);border:1px solid #bbf7d0;border-radius:16px;padding:18px 16px;box-shadow:0 14px 30px rgba(16,185,129,.15);display:flex;justify-content:space-between;align-items:center;gap:10px}
.dw-packaged .pkg-name{font-weight:800;color:#0f172a;line-height:1.35}
.dw-packaged .pkg-price{font-weight:800;color:#166534;font-size:15px}
.dw-packaged .pkg-select{margin-top:14px;position:relative}
.dw-packaged .pkg-select-trigger{width:100%;border:2px solid #16a34a;border-radius:14px;padding:16px 16px;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:800;font-size:15px;color:#0f172a;box-shadow:0 16px 36px rgba(22,163,74,.15);cursor:pointer;transition:box-shadow .15s ease,border-color .15s ease}
.dw-packaged .pkg-select-trigger .lbl{flex:1;text-align:center}
.dw-packaged .pkg-select-trigger .val{color:#1f2937;font-weight:700;white-space:nowrap}
.dw-packaged .pkg-select-trigger .chevron{width:20px;height:20px;border-radius:50%;border:1px solid #d1d5db;display:inline-flex;align-items:center;justify-content:center;position:relative}
.dw-packaged .pkg-select-trigger .chevron::before{content:"";border:5px solid transparent;border-top-color:#111827;transform:translateY(2px)}
.dw-packaged .pkg-select.open .pkg-select-trigger{border-color:var(--dw-theme,#0ea5e9);box-shadow:0 14px 30px rgba(var(--dw-theme-rgb,14,165,233),.18)}
.dw-packaged .pkg-options{position:absolute;left:0;right:0;top:calc(100% + 8px);background:#fff;border:1px solid #cbd5e1;border-radius:12px;box-shadow:0 18px 34px rgba(15,23,42,.2);overflow:hidden;z-index:30;max-height:320px;display:flex;flex-direction:column}
.dw-packaged .pkg-options[hidden]{display:none!important}
.dw-packaged .pkg-options-head{font-weight:700;color:#0f172a;padding:12px 14px;border-bottom:1px solid #e2e8f0;background:linear-gradient(180deg,#f8fafc,#eef2ff)}
.dw-packaged .pkg-option{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border:0;border-bottom:1px solid #f1f5f9;background:#fff;font-weight:700;color:#111827;text-align:left;cursor:pointer;gap:8px}
.dw-packaged .pkg-option:last-child{border-bottom:0}
.dw-packaged .pkg-option:hover,.dw-packaged .pkg-option.active{background:#f1f5f9}
.dw-packaged .pkg-option .opt-label{text-transform:none}
.dw-packaged .pkg-option .opt-sub{color:#16a34a;font-weight:700}

/* Full-screen loader while submitting */
.dw-loading-overlay{position:fixed;inset:0;background:rgba(255,255,255,.85);backdrop-filter:saturate(120%) blur(2px);z-index:10000;display:flex;align-items:center;justify-content:center}
.dw-loading-overlay .box{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:14px 16px;box-shadow:0 10px 30px rgba(2,6,23,.1);display:flex;align-items:center;gap:10px;color:#111827;font-weight:600}
.dw-loading-overlay .spinner{width:18px;height:18px;border:2px solid #94a3b8;border-top-color:#111827;border-radius:50%;animation:vy-rot .8s linear infinite}

/* Thin page progress bar */
.dw-page-progress{position:fixed;left:0;top:0;height:3px;width:100%;background:linear-gradient(90deg,var(--dw-theme-soft,#a7f3d0),var(--dw-theme,#6c2bd9),var(--dw-theme-soft-strong,#f7f8ff));background-size:200% 100%;animation:vy-progress 1.2s ease-in-out infinite;z-index:10001;display:none}
.dw-page-progress.active{display:block}
@keyframes vy-progress{0%{background-position:0 0}100%{background-position:100% 0}}

/* Helpers */
.dw-donate input[readonly]{background:#f8fafc;color:#111}
/* Inputs override (Hello Elementor compatibility) */
.dw-single-v2 .dw-donate .dw-field{margin:10px 0}
.dw-single-v2 .dw-donate .dw-field input,
.dw-single-v2 .dw-donate .dw-field textarea,
.dw-single-v2 .dw-donate .dw-field select{
  display:block; width:100%; background:#fff; color:#111;
  border:1px solid #e5e7eb; border-radius:12px; padding:14px 14px;
  box-shadow:none; outline:none; appearance:none; -webkit-appearance:none;
  font-weight:700; color:#334155;
}
.dw-single-v2 .dw-donate .dw-field textarea{min-height:96px; resize:vertical}
.dw-single-v2 .dw-donate .dw-inline{margin:12px 0}

/* Invoice page */
.dw-single-v2.dw-invoice-page{
  display:flex !important;
  justify-content:center !important;
  align-items:flex-start;
  padding:14px 0 30px;
  width:100%;
  overflow-x:hidden;
}

html, body{overflow-x:hidden;}


html, body{overflow-x:hidden;}

/* Force true centering on mobile (Elementor/theme sometimes adds left offsets) */
.dw-single-v2.dw-invoice-page .dw-container{
  width:100% !important;
  max-width:560px !important;
  margin:0 auto !important;
  padding:0 16px !important;
  box-sizing:border-box !important;
  display:flex !important;
  justify-content:center !important;
}


.dw-invoice-page{background:#eef2f7;padding:20px 0 40px}
.dw-invoice-card{background:#fff;border-radius:22px;box-shadow:0 18px 38px rgba(15,23,42,.09);overflow:hidden;max-width:780px;margin:0 auto;position:relative;width:min(540px,100%);margin-left:auto;margin-right:auto;border:1px solid #e5e7eb}
.dw-invoice-hero{padding:28px 22px 18px;position:relative;text-align:center;overflow:hidden;background:linear-gradient(180deg,#f8fbff,#fff)}
.dw-invoice-hero-bg{position:absolute;inset:0;background:radial-gradient(circle at 18% 20%,rgba(110,231,183,.25),transparent 38%),radial-gradient(circle at 78% 0,rgba(254,215,170,.3),transparent 45%),radial-gradient(circle at 72% 80%,rgba(147,197,253,.26),transparent 40%);z-index:0;width:160%;left:50%;transform:translateX(-50%);background-repeat:no-repeat;background-size:100% 100%}
.dw-invoice-logo-wrap{width:96px;height:96px;border-radius:20px;display:inline-flex;align-items:center;justify-content:center;background:#fff;border:1px solid #e5e7eb;box-shadow:0 16px 34px rgba(0,0,0,.08);position:relative;z-index:1;margin-bottom:12px}
.dw-invoice-logo{max-width:78px;max-height:78px;object-fit:contain}
.dw-invoice-thanks,.dw-invoice-sub,.dw-invoice-title{position:relative;z-index:1}
.dw-invoice-thanks{font-size:15px;color:#0f172a;margin-bottom:4px}
.dw-invoice-sub{color:#6b7280;font-size:13px;margin:0 0 6px}
.dw-invoice-title{font-weight:800;font-size:18px;color:#0f172a;line-height:1.35;margin-bottom:10px}
.dw-invoice-box{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px 16px;margin:14px 18px;box-shadow:0 10px 24px rgba(15,23,42,.04)}
.dw-invoice-box-head{display:flex;align-items:center;justify-content:space-between;font-weight:800;color:#0f172a;margin-bottom:6px}
.dw-invoice-bank .bank-number{font-weight:800;font-size:18px;letter-spacing:.4px;color:#0f172a}
.dw-invoice-bank .bank-method{color:#475569;font-weight:700;margin-top:4px}
.dw-invoice-bank .bank-holder{color:#94a3b8;font-weight:700;margin-top:2px}
.dw-invoice-qris .dw-invoice-box-head{margin-bottom:10px}
.dw-invoice-qris .dw-badge-qris{background:#eef2ff;border:1px solid #c7d2fe;color:#3730a3;border-radius:999px;padding:6px 10px;font-weight:800;font-size:12px}
.dw-qris-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;padding:10px 0 6px}
.dw-qris-label{font-size:14px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#0f172a}
.dw-qris-img{max-width:100%;width:auto;height:auto;border-radius:14px;border:1px solid #e5e7eb;box-shadow:0 14px 28px rgba(15,23,42,.08);display:block}
.dw-qris-missing{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:12px;padding:10px 12px;font-weight:700}
.dw-qris-instr{text-align:center;color:#475569;font-weight:700;margin:10px 0 6px} 
.dw-qris-steps-img{display:none;margin-top:8px} 
.dw-qris-steps-img img{max-width:100%;width:100%;height:auto;display:block;border-radius:12px;border:1px solid rgba(15,23,42,.10);background:#fff} 
.dw-qris-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:8px} 
.dw-qstep{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:10px 8px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center} 
.dw-qstep .ic{display:flex;align-items:center;justify-content:center;height:24px;color:#0f172a;line-height:1} 
.dw-qstep .ic svg{width:22px;height:22px;display:block} 
.dw-qstep .tx{font-size:12px;font-weight:800;color:#0f172a}
.dw-invoice-amount{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px}
.dw-invoice-amount .label{color:#475569;font-weight:700}
.dw-invoice-amount .amt{font-weight:900;font-size:20px;color:var(--dw-theme,#0ea5e9)}
.dw-invoice-copy{background:#f1f5f9;border:1px solid #e2e8f0;color:#0f172a;border-radius:10px;padding:6px 12px;font-weight:700;cursor:pointer;transition:all .12s ease}
.dw-invoice-copy:hover{box-shadow:0 10px 18px rgba(148,163,184,.28);transform:translateY(-1px)}
.dw-invoice-copy.ghost{background:#e7f3ff;border-color:#cfe3ff}
.dw-invoice-note{margin:6px 18px 4px;color:#6b7280;font-size:13px;line-height:1.5}
.dw-invoice-actions{display:flex;justify-content:center;margin:18px 18px 6px}
.dw-invoice-btn{background:var(--dw-theme,var(--dw-cta,#128c1c));color:#fff;border:none;border-radius:14px;padding:14px 18px;font-weight:800;width:100%;max-width:460px;box-shadow:0 16px 36px rgba(15,23,42,.2);cursor:pointer;font-size:16px;letter-spacing:.15px}
.dw-invoice-btn:hover{filter:brightness(.98)}
.dw-invoice-deadline{background:#fff7ed;border:1px solid #fed7aa;border-radius:12px;padding:14px 16px;margin:14px 18px;box-shadow:0 10px 22px rgba(249,115,22,.12);display:flex;align-items:center;gap:10px}
.dw-invoice-deadline .label{color:#b45309;font-weight:700}
.dw-invoice-deadline .time{color:#0f172a;font-weight:900}
.dw-invoice-instructions{margin:18px;border:1px solid #e2e8f0;border-radius:16px;background:#fff;box-shadow:0 12px 24px rgba(15,23,42,.06);overflow:hidden}
.dw-invoice-instructions .instr-title{font-weight:800;color:#0f172a;text-align:center;padding:14px 10px}
.dw-instr-item + .dw-instr-item{border-top:1px solid #eef2ff}
.dw-instr-head{width:100%;text-align:left;padding:12px 14px;background:#f1f5f9;border:0;display:flex;justify-content:space-between;align-items:center;font-weight:800;color:#0f172a;cursor:pointer}
.dw-instr-item.open .dw-instr-head{background:var(--dw-btn,#0f9f64);color:#fff}
.dw-instr-head .caret{width:20px;height:20px;border-radius:50%;border:1px solid currentColor;display:inline-flex;align-items:center;justify-content:center;font-size:12px}
.dw-instr-item.open .dw-instr-head .caret::before{content:"\2212"}
.dw-instr-head .caret::before{content:"+"}
.dw-instr-body{padding:12px 16px;display:none;background:#fff}
.dw-instr-item.open .dw-instr-body{display:block}
.dw-instr-body ol{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:8px}
.dw-instr-body li{color:#374151;font-weight:600;line-height:1.5}
.dw-invoice-card ol li strong{color:#0f172a}
.dw-invoice-card .bank-name{display:flex;align-items:center;gap:8px}
.dw-invoice-card .bank-name::before{content:"";width:22px;height:22px;border-radius:8px;background:#e0f2fe;border:1px solid #bfdbfe;display:inline-block}

.dw-proof-modal{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1500;display:flex;align-items:center;justify-content:center;padding:18px;backdrop-filter:blur(2px)}
.dw-proof-modal[hidden]{display:none!important}
.dw-proof-dialog{background:#fff;border-radius:20px;box-shadow:0 20px 44px rgba(0,0,0,.22);width:100%;max-width:500px;overflow:hidden;animation:vy-scale-in .2s ease-out forwards;max-height:90vh;display:flex;flex-direction:column}
.dw-proof-head{font-weight:800;font-size:17px;padding:16px 18px;border-bottom:1px solid #e5e7eb}
.dw-proof-body{padding:18px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}
.dw-proof-help{color:#475569;margin:0;line-height:1.5}
.dw-proof-drop{border:2px dashed #9cc7ff;border-radius:18px;padding:22px;text-align:center;background:#f7fbff;display:block;position:relative;min-height:220px;transition:border-color .15s ease,box-shadow .15s ease}
.dw-proof-drop input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;z-index:1}
.dw-proof-drop .dw-proof-invite,.dw-proof-drop .dw-proof-sub,.dw-proof-drop .dw-proof-choose,.dw-proof-drop .dw-proof-preview{position:relative;z-index:2}
.dw-proof-drop.has-preview{padding-bottom:18px}
.dw-proof-drop:hover{box-shadow:0 14px 32px rgba(59,130,246,.12);border-color:#7fb5ff}
.dw-proof-invite{display:block;font-weight:800;color:#0f172a;margin-bottom:8px;font-size:17px}
.dw-proof-sub{color:#64748b;font-size:13px;display:block;margin-bottom:12px}
.dw-proof-choose{background:var(--dw-blue,#0b67f5);border:1px solid var(--dw-blue,#0b67f5);color:#fff;padding:11px 16px;border-radius:12px;font-weight:800;cursor:pointer;position:relative;z-index:2;box-shadow:0 14px 26px rgba(11,103,245,.2)}
.dw-proof-preview{margin-top:12px;position:relative;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;border:1px dashed #bfdbfe;border-radius:14px;background:#fff}
.dw-proof-preview[hidden]{display:none!important}
.dw-proof-preview img{max-width:100%;max-height:280px;width:auto;height:auto;border-radius:10px;box-shadow:0 10px 20px rgba(0,0,0,.12);display:block;object-fit:contain}
.dw-proof-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:999px;border:none;background:#ef4444;color:#fff;font-weight:800;cursor:pointer;line-height:1;box-shadow:0 8px 16px rgba(239,68,68,.2)}
.dw-proof-actions{padding:0 18px 18px;display:flex;justify-content:flex-end;gap:10px}
.dw-proof-cancel{background:#e5e7eb;border:1px solid #cbd5e1;color:#0f172a;border-radius:12px;padding:11px 16px;font-weight:700;cursor:pointer}
.dw-proof-submit{background:var(--dw-theme,#6c2bd9);border:1px solid var(--dw-theme,#6c2bd9);color:#fff;border-radius:12px;padding:11px 18px;font-weight:800;cursor:pointer;min-width:140px;box-shadow:0 16px 28px rgba(var(--dw-theme-rgb,108,43,217),.28)} 
.dw-swal-soft{ 
  background:#fff!important; 
  color:#0f172a!important; 
  border-radius:22px!important; 
  padding:28px 26px!important; 
  box-shadow:0 26px 54px rgba(15,23,42,.22)!important; 
  width:min(560px,92vw)!important; 
  text-align:center!important; 
} 
.swal2-container.dw-swal-center,
.swal2-container.dw-swal-center.swal2-backdrop-show{
  position:fixed!important;
  inset:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  height:100vh!important;
  width:100vw!important;
  padding:0!important;
  background:transparent!important;
  grid-template-columns:unset!important;
  grid-template-rows:unset!important;
}
.swal2-container.dw-swal-center.swal2-noanimation{
  background:transparent!important;
  height:100vh!important;
  width:100vw!important;
}
.dw-swal-center .swal2-popup{margin:0!important;}
.dw-swal-soft .swal2-title{ 
  color:#0f172a!important; 
  font-weight:900!important; 
  font-size:30px!important; 
  margin-top:6px!important; 
  margin-bottom:8px!important; 
} 
.dw-swal-soft .swal2-html-container{ 
  color:#64748b!important; 
  font-weight:700!important; 
  font-size:16px!important; 
  padding:0 6px!important; 
} 
.dw-swal-soft .swal2-html-container{margin-left:auto!important;margin-right:auto!important;} 
.dw-swal-soft .swal2-confirm{min-width:90px!important;font-size:16px!important;} 
.dw-swal-soft-btn{background:var(--dw-theme,#6c2bd9)!important;color:#fff!important;border:0!important;border-radius:12px!important;padding:10px 18px!important;font-weight:800!important;box-shadow:0 14px 26px rgba(var(--dw-theme-rgb,108,43,217),.22)!important} 
.dw-swal-soft .swal2-actions{margin-top:18px!important;} 
.dw-swal-center{align-items:center!important;justify-content:center!important}

@media (min-width: 560px){
  .dw-donate .chips{grid-template-columns:repeat(3,1fr)}
}

@media (max-width: 500px){
  .dw-container{padding:0 10px;max-width:500px}
  .dw-hero .title{font-size:16px}
  .dw-hero .cta .btn{width:100%;text-align:center}
  .dw-sticky-cta{max-width:calc(100% - 20px);padding:10px 12px;grid-template-columns:1fr 1fr;gap:8px}
  .dw-sticky-cta .dw-sticky-share,.dw-sticky-cta .dw-sticky-donate{font-size:15px}
}
.dw-pay-modal{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000001!important;display:flex;align-items:center;justify-content:center;padding:env(safe-area-inset-top,24px) env(safe-area-inset-right,16px) env(safe-area-inset-bottom,32px) env(safe-area-inset-left,16px);overflow-x:hidden}
.dw-pay-modal[hidden]{display:none!important}
.dw-pay-modal .sheet{background:#fff;border-radius:20px;box-shadow:0 28px 48px rgba(15,23,42,.35);width:min(500px,calc(100% - 32px))!important;max-width:500px!important;overflow:hidden;transform:scale(.96);opacity:0;animation:vy-scale-in .2s ease-out forwards;max-height:calc(90vh - 48px);display:flex;flex-direction:column;box-sizing:border-box}
.dw-pay-modal .sheet-hd{background:#2f80ed;color:#fff;padding:14px 16px;font-weight:800;display:flex;justify-content:space-between;align-items:center;font-size:16px}
.dw-pay-modal .sheet-hd .dw-pay-close{background:transparent;border:0;color:#fff;line-height:1;font-size:0;width:28px;height:28px;cursor:pointer;border-radius:50%}
.dw-pay-modal .sheet-hd .dw-pay-close::before{content:"\00D7";font-size:22px;line-height:1}
.dw-pay-modal .sheet-sec{padding:0;border-top:1px solid #eef2ff;background:#fff;overflow-y:auto;overflow-x:hidden;flex:1;max-height:calc(90vh - 138px);-webkit-overflow-scrolling:touch}

body.dw-pay-open{overflow:hidden;}
.dw-pay-modal .dw-pay-section{padding:0;margin:0}
.dw-pay-modal .dw-pay-title{font-weight:700;color:#1f2937;background:#f5f7fb;border-bottom:1px solid #e5e7eb;padding:10px 14px;margin:0}
.dw-pay-modal .dw-pay-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border-bottom:1px solid #f1f5f9;cursor:pointer;justify-content:space-between;position:relative}
.dw-pay-modal .dw-pay-item:hover{background:#f8fafc}
.dw-pay-modal .dw-pay-item.bank{display:flex;align-items:center;gap:12px}
.dw-pay-modal .dw-pay-item.bank .bank-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.dw-pay-modal .dw-pay-item.bank .bank-logo{width:60px;height:22px;object-fit:contain;background:#fff;border-radius:4px;display:block}
.dw-pay-modal .dw-pay-item.bank .bank-logo-text{display:none!important}
.dw-pay-modal .dw-pay-item.bank .bank-logo.blank{width:60px;height:22px}
.dw-pay-modal .dw-pay-item .bank-name{font-weight:600;color:#1f2937}
.dw-pay-modal .dw-pay-item .bank-method{display:block;color:#64748b;font-size:12px;margin-top:2px}
.dw-pay-modal .dw-pay-item input{position:absolute;opacity:0;pointer-events:none}
.dw-pay-modal .dw-pay-item .check{width:18px;height:18px;border-radius:50%;border:2px solid #d1d5db;display:inline-flex;align-items:center;justify-content:center;box-shadow:inset 0 0 0 2px #fff;flex-shrink:0;transition:all .15s ease}
.dw-pay-modal .dw-pay-item .check::after{content:"";width:8px;height:4px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg);opacity:0}
.dw-pay-modal .dw-pay-item input:checked + .check{background:#2563eb;border-color:#2563eb;box-shadow:0 0 0 3px #e0f2fe}
.dw-pay-modal .dw-pay-item input:checked + .check::after{opacity:1}
.dw-pay-modal .btn-row{padding:12px 14px}
.dw-pay-modal .btn-row .button{background:#fff;border:1px solid #db2777;color:#db2777;border-radius:10px;padding:10px 16px;cursor:pointer;font-weight:700}
@keyframes vy-scale-in{0%{transform:scale(.96);opacity:0}100%{transform:scale(1);opacity:1}}

/* Desktop refinements (keep mobile as-is) */
@media (min-width: 768px){
  /* Match reference: narrower modal */
  .dw-pay-modal .sheet{width:400px!important;max-width:400px!important}

  /* Normalize payment logos size on desktop */
  .dw-pay-modal .dw-pay-item.bank .bank-logo{
    width:60px!important;
    height:22px!important;
    object-fit:contain!important;
    display:block!important;
  }
  .dw-pay-modal .dw-pay-item.bank .bank-logo.blank{width:60px!important;height:22px!important}

  /* Center header title & remove weird close button circle */
  .dw-pay-modal .sheet-hd{justify-content:center;position:relative}
  .dw-pay-modal .sheet-hd > div{flex:1;text-align:center;padding-right:32px}
  .dw-pay-modal .sheet-hd .dw-pay-close{
    position:absolute;right:14px;top:50%;transform:translateY(-50%);
    width:auto!important;height:auto!important;padding:0!important;
    font-size:26px!important;line-height:1!important;
    background:transparent!important;border:0!important;border-radius:0!important;
    box-shadow:none!important;outline:none!important;
    -webkit-appearance:none;appearance:none;
  }
  .dw-pay-modal .sheet-hd .dw-pay-close::before{content:none!important}
  .dw-pay-modal .sheet-hd .dw-pay-close:focus,
  .dw-pay-modal .sheet-hd .dw-pay-close:focus-visible{outline:none!important;box-shadow:none!important}

  /* Hide unselected radio "circles" on desktop; show only for selected item */
  .dw-pay-modal .dw-pay-item .check{opacity:0}
  .dw-pay-modal .dw-pay-item input:checked + .check{opacity:1}
}

.dw-powered-foot{margin:20px auto 8px;text-align:center;color:#94a3b8;font-size:12px;padding-top:12px;border-top:1px solid #e2e8f0;display:flex;flex-direction:column;align-items:center;gap:6px;max-width:320px}
.dw-powered-foot img{height:24px;width:auto;display:block}

.dw-brand-bar{display:flex;align-items:center;gap:12px;margin:0 0 12px}
.dw-brand-logo{width:48px;height:48px;border-radius:12px;object-fit:contain;box-shadow:0 8px 18px rgba(0,0,0,.08);background:#fff;padding:6px;border:1px solid #e5e7eb}
.dw-brand-logo.fallback{display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;color:#fff;background:var(--dw-theme,#6c2bd9)}
.dw-brand-name{font-weight:800;font-size:16px}
.dw-brand-tag{color:#94a3b8;font-size:12px;margin-top:2px}
.dw-packaged .pkg-highlight{background:linear-gradient(180deg,var(--dw-theme-soft) 0%,var(--dw-theme-soft-strong) 100%);border:1px solid var(--dw-theme);border-radius:16px;padding:18px 16px;box-shadow:0 14px 30px rgba(var(--dw-theme-rgb),.25);display:flex;justify-content:space-between;align-items:center;gap:10px}
.dw-packaged .pkg-name{font-weight:800;color:var(--dw-theme);line-height:1.35}
.dw-packaged .pkg-price{font-weight:800;color:var(--dw-theme);font-size:15px}
.dw-packaged .pkg-select{margin-top:14px;position:relative}
.dw-packaged .pkg-select-trigger{width:100%;border:2px solid var(--dw-theme);border-radius:14px;padding:16px 16px;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:800;font-size:15px;color:#0f172a;box-shadow:0 16px 36px rgba(0,0,0,.08);cursor:pointer;transition:box-shadow .15s ease,border-color .15s ease}
.dw-packaged .pkg-select-trigger .lbl{flex:1;text-align:center}
.dw-packaged .pkg-select-trigger .val{color:var(--dw-theme);font-weight:700;white-space:nowrap}
.dw-packaged .pkg-select-trigger .chevron{width:20px;height:20px;border-radius:50%;border:1px solid rgba(var(--dw-theme-rgb),.5);display:inline-flex;align-items:center;justify-content:center;position:relative}
.dw-packaged .pkg-select.open .pkg-select-trigger{border-color:var(--dw-theme);box-shadow:0 14px 30px rgba(var(--dw-theme-rgb),.3)}
.dw-packaged .pkg-options{position:absolute;left:0;right:0;top:calc(100% + 8px);background:#fff;border:1px solid rgba(var(--dw-theme-rgb),.4);border-radius:12px;box-shadow:0 18px 34px rgba(15,23,42,.2);overflow:hidden;z-index:30;max-height:320px;display:flex;flex-direction:column}
.dw-packaged .pkg-options[hidden]{display:none!important}
.dw-packaged .pkg-options-head{font-weight:700;color:#0f172a;padding:12px 14px;border-bottom:1px solid rgba(var(--dw-theme-rgb),.35);background:linear-gradient(180deg,var(--dw-theme-soft) 0%,var(--dw-theme-soft-strong) 100%)}
.dw-packaged .pkg-option{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border:0;border-bottom:1px solid rgba(var(--dw-theme-rgb),.1);background:#fff;font-weight:700;color:#111827;text-align:left;cursor:pointer;gap:8px}
.dw-packaged .pkg-option:last-child{border-bottom:0}
.dw-packaged .pkg-option:hover,.dw-packaged .pkg-option.active{background:rgba(var(--dw-theme-rgb),.08)}
.dw-packaged .pkg-option .opt-label{text-transform:none}
.dw-packaged .pkg-option .opt-sub{color:var(--dw-theme);font-weight:700}

/* Invoice bank header tweaks */
.dw-invoice-card .bank-name::before{display:none!important}
.dw-invoice-box-head{gap:12px}
.dw-bank-left{display:flex;align-items:center;gap:10px;min-width:0}
.dw-bank-logo{width:34px;height:34px;border-radius:10px;background:#fff;border:1px solid #e5e7eb;object-fit:contain;flex:0 0 auto;box-shadow:0 8px 16px rgba(15,23,42,.06)}
.dw-invoice-card .bank-name{font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px}
.dw-invoice-amount .dw-invoice-copy{grid-column:1 / -1;width:100%;margin-top:10px}
@media(max-width:420px){
  .dw-invoice-card{border-radius:18px}
  .dw-invoice-box{margin:12px 14px}
  .dw-invoice-amount .amt{font-size:18px}
  .dw-invoice-card .bank-name{max-width:180px}
}

/* Copy button states (avoid theme overrides causing white-on-light text) */
.dw-invoice-copy:focus,
.dw-invoice-copy:active,
.dw-invoice-copy:visited{color:#0f172a!important}
.dw-invoice-copy.copied{background:#dcfce7!important;border-color:#86efac!important;color:#065f46!important}

/* Tight, centered mobile layout (remove the "empty right space" feel) */
@media(max-width:520px){
  .dw-single-v2.dw-invoice-page{padding:10px 0 26px}
  .dw-single-v2.dw-invoice-page .dw-container{padding:0 12px;max-width:460px}
  .dw-invoice-card{width:100%!important;max-width:420px!important;margin-left:auto!important;margin-right:auto!important}
}

@media(max-width:380px){
  .dw-invoice-card{max-width:360px!important}
  .dw-invoice-hero{padding:22px 16px 14px}
  .dw-invoice-title{font-size:17px}
  .dw-bank-logo{width:30px;height:30px;border-radius:9px}
  .dw-invoice-box{margin:10px 12px;padding:12px 14px}
}


/* === DW FIX: center invoice card on mobile (Android/iPhone) + visible copy text === */
.dw-single-v2.dw-invoice-page .dw-container{
  width:100%!important;
  max-width:520px!important;
  margin-left:auto!important;
  margin-right:auto!important;
  box-sizing:border-box!important;
  padding-left:16px!important;
  padding-right:16px!important;
  display:flex!important;
  justify-content:center!important;
}
.dw-single-v2.dw-invoice-page .dw-invoice-card{
  width:100% !important;
  max-width:560px !important;
  margin:0 auto !important;
}


@media (max-width:520px){
  .dw-single-v2.dw-invoice-page .dw-container{
    max-width:520px!important;
    padding-left:14px!important;
    padding-right:14px!important;
  }
  .dw-single-v2.dw-invoice-page .dw-invoice-card{
    max-width:460px!important;
  }
}
@media (max-width:380px){
  .dw-single-v2.dw-invoice-page .dw-invoice-card{
    max-width:360px!important;
  }
}
/* copy button: keep text readable even when theme forces white on active/focus */
.dw-single-v2.dw-invoice-page .dw-invoice-copy,
.dw-single-v2.dw-invoice-page .dw-invoice-copy *{
  color:#0f172a!important;
}
.dw-single-v2.dw-invoice-page .dw-invoice-copy:focus,
.dw-single-v2.dw-invoice-page .dw-invoice-copy:active,
.dw-single-v2.dw-invoice-page .dw-invoice-copy:hover{
  color:#0f172a!important;
}
.dw-single-v2.dw-invoice-page .dw-invoice-copy.copied,
.dw-single-v2.dw-invoice-page .dw-invoice-copy.copied *{
  color:#065f46!important;
}


/* Strong override: keep Copy button text visible on iOS/Safari */
.dw-invoice-copy,
.dw-invoice-copy *{
  color:#0f172a !important;
  -webkit-text-fill-color:#0f172a !important;
}
.dw-invoice-copy:focus,
.dw-invoice-copy:hover,
.dw-invoice-copy:active,
.dw-invoice-copy.is-copied{
  color:#0f172a !important;
  -webkit-text-fill-color:#0f172a !important;
}


/* --- DonasiWP Lock UI: mobile centering + copy button visibility --- */
.dw-single-v2 .dw-container{
  width: 100%;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 16px;
  padding-right: 16px;
  box-sizing: border-box;
}
.dw-single-v2.dw-invoice-page,
.dw-single-v2 .dw-invoice-page{
  width: 100%;
}
.dw-single-v2 .dw-invoice-card{
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}
/* prevent any odd horizontal overflow that creates "ruang kosong kanan" */
.dw-single-v2,
.dw-single-v2 *{
  box-sizing: border-box;
}
.dw-single-v2{
  overflow-x: hidden;
}

/* Force Copy button style (avoid theme overriding text to white on light bg) */
.dw-single-v2 .dw-invoice-copy{
  background: #eaf3ff !important;
  border: 1px solid #cfe3ff !important;
  color: #0f172a !important;
  -webkit-text-fill-color: #0f172a !important;
}
.dw-single-v2 .dw-invoice-copy:hover{
  color: #0f172a !important;
  -webkit-text-fill-color: #0f172a !important;
}
/* when JS adds copied state (if used), make contrast clear */
.dw-single-v2 .dw-invoice-copy.is-copied,
.dw-single-v2 .dw-invoice-copy.dw-copied{
  background: #A02BAA !important;
  border-color: #A02BAA !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}

/* Kabar Terbaru (Updates timeline ala Kitabisa) */
.dw-single-v2 .dw-updates{display:flex;flex-direction:column;gap:14px}
.dw-single-v2 .dw-update{border:1px solid rgba(148,163,184,.35);border-radius:16px;padding:14px}
.dw-single-v2 .dw-update-head{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.dw-single-v2 .dw-update-date{font-size:12px;font-weight:700;color:#64748b}
.dw-single-v2 .dw-update-title{font-size:15px;font-weight:800;color:#0f172a}
.dw-single-v2 .dw-update-text{color:#334155}
.dw-single-v2 .dw-update-gallery{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.dw-single-v2 .dw-update-photo{display:block;width:96px;height:96px;border-radius:16px;overflow:hidden;border:1px solid rgba(148,163,184,.35)}
.dw-single-v2 .dw-update-photo img{width:100%;height:100%;object-fit:cover;display:block}


/* FIX9: Updates timeline (Kabar Terbaru) + gallery grid + lightbox + load more */
.dw-single-v2 .dw-updates-timeline{position:relative;display:flex;flex-direction:column;gap:14px;padding-left:18px;margin-top:6px}
/* Start the line below the first month heading so it doesn't "naik" sampai judul bulan */
.dw-single-v2 .dw-updates-timeline:before{content:'';position:absolute;left:8px;top:44px;bottom:16px;width:2px;background:rgba(148,163,184,.35);border-radius:999px}
.dw-single-v2 .dw-update-month{font-weight:900;color:#0f172a;margin:8px 0 6px;position:relative;left:0;padding-left:14px;font-size:18px;letter-spacing:-.2px}
.dw-single-v2 .dw-update-month::before{content:'';position:absolute;left:-16px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:999px;background:#fff;border:2px solid rgba(148,163,184,.55);box-shadow:0 0 0 3px rgba(148,163,184,.10)}
.dw-single-v2 .dw-update-month.hidden{display:none}
.dw-single-v2 .dw-update-item{position:relative}
.dw-single-v2 .dw-update-item.hidden{display:none}
.dw-single-v2 .dw-update-dot{position:absolute;left:-16px;top:18px;width:12px;height:12px;border-radius:999px;background:#fff;border:2px solid var(--dw-primary,#A02BAA);box-shadow:0 0 0 3px rgba(160,43,170,.10)}
.dw-single-v2 .dw-update-card{border:1px solid rgba(148,163,184,.28);border-radius:16px;padding:14px;background:#fff;box-shadow:0 10px 24px rgba(15,23,42,.06);transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease}
@media (hover:hover){.dw-single-v2 .dw-update-card:hover{transform:translateY(-1px);box-shadow:0 14px 30px rgba(15,23,42,.10);border-color:rgba(148,163,184,.42)}}
.dw-single-v2 .dw-update-head{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.dw-single-v2 .dw-update-date{font-size:12px;font-weight:800;color:#64748b;display:inline-flex;align-self:flex-start;gap:6px;background:#f8fafc;border:1px solid rgba(148,163,184,.30);padding:4px 10px;border-radius:999px}
.dw-single-v2 .dw-update-title{font-size:16px;font-weight:900;color:#0f172a;letter-spacing:-.2px}
.dw-single-v2 .dw-update-text{color:#334155}
.dw-single-v2 .dw-update-gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:10px}
@media (max-width: 720px){.dw-single-v2 .dw-update-gallery{grid-template-columns:repeat(2,minmax(0,1fr));}}
.dw-single-v2 .dw-update-photo{display:block;width:100%;aspect-ratio:1/1;border-radius:16px;overflow:hidden;border:1px solid rgba(148,163,184,.35)}
.dw-single-v2 .dw-update-photo img{width:100%;height:100%;object-fit:cover;display:block}
.dw-single-v2 .dw-updates-more-wrap{display:flex;justify-content:center;margin-top:12px}
.dw-single-v2 .dw-updates-more{border:1px solid rgba(148,163,184,.35);background:#fff;border-radius:999px;padding:10px 14px;font-weight:800;cursor:pointer}
.dw-lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(15,23,42,.82);z-index:999999;padding:18px}
.dw-lightbox.open{display:flex}
.dw-lightbox .inner{width:100%;max-width:980px;position:relative}
.dw-lightbox .img{width:100%;max-height:85vh;object-fit:contain;display:block;border-radius:16px;background:#000}
.dw-lightbox button{position:absolute;border:0;background:rgba(255,255,255,.12);color:#fff;border-radius:999px;width:44px;height:44px;cursor:pointer;font-size:28px;line-height:44px;text-align:center}
.dw-lightbox .close{top:-6px;right:-6px;background:rgba(255,255,255,.18);font-size:26px}
.dw-lightbox .prev{left:-10px;top:50%;transform:translateY(-50%)}
.dw-lightbox .next{right:-10px;top:50%;transform:translateY(-50%)}
.dw-lightbox .count{position:absolute;left:50%;transform:translateX(-50%);bottom:-8px;color:rgba(255,255,255,.85);font-weight:700;font-size:12px}
@media (max-width: 720px){.dw-lightbox .prev{left:6px}.dw-lightbox .next{right:6px}.dw-lightbox .close{top:6px;right:6px}}


/* ===== Rincian penggunaan dana (modal) ===== */
.dw-usage-link{
  width:100%;
  margin-top:12px;
  border:1px solid rgba(17,24,39,.10);
  /* Some themes force <button> backgrounds (e.g. red). Lock our neutral style. */
  background:#fff !important;
  background-color:#fff !important;
  border-radius:14px;
  padding:12px 14px;
  display:flex;
  align-items:center;
  gap:12px;
  cursor:pointer;
  transition:all .15s ease;
}
.dw-single-v2 .dw-usage-link{
  /* Extra specificity to beat theme-level button rules with !important. */
  background:#fff !important;
  background-color:#fff !important;
}
.dw-usage-link:hover{ box-shadow:0 8px 24px rgba(0,0,0,.08); transform:translateY(-1px); }
.dw-usage-ico{
  width:34px;height:34px;border-radius:10px;
  background:rgba(var(--dw-theme-rgb,14,165,233),.10);
  color:var(--dw-theme,#0ea5e9);
  display:flex;align-items:center;justify-content:center;
  flex:0 0 auto;
}
.dw-usage-text{ flex:1; text-align:left; font-weight:600; color:#111827; }
.dw-usage-arrow{ color:#9ca3af; font-size:22px; line-height:1; margin-left:6px; }

.dw-usage-modal{ position:fixed; inset:0; z-index:999999; display:none; }
.dw-usage-modal.is-open{ display:block; }
.dw-usage-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.45); }
.dw-usage-sheet{
  position:absolute;
  left:50%; top:50%;
  transform:translate(-50%,-50%);
  width:500px; max-width:92vw;
  max-height:86vh;
  background:#fff;
  border-radius:18px;
  overflow:hidden;
  display:flex; flex-direction:column;
  box-shadow:0 18px 60px rgba(0,0,0,.25);
}
@media(max-width:640px){
  .dw-usage-sheet{
    left:0; right:0; bottom:0; top:auto;
    transform:none;
    width:100%; max-width:100%;
    border-radius:18px 18px 0 0;
    max-height:88vh;
  }
}

.dw-usage-head{
  padding:16px 18px;
  border-bottom:1px solid rgba(17,24,39,.08);
  display:flex; align-items:center; justify-content:space-between;
  background:#fff;
}
.dw-usage-title{ font-size:18px; font-weight:700; color:#111827; }
.dw-usage-x{
  width:34px;height:34px;border-radius:10px;border:1px solid rgba(17,24,39,.10);
  background:#fff; cursor:pointer; font-size:22px; line-height:1;
  display:flex; align-items:center; justify-content:center;
}

.dw-usage-body{ padding:16px 18px; overflow:auto; }
.dw-usage-sec-title{ display:flex; gap:12px; align-items:flex-start; margin-bottom:14px; }
.dw-usage-sec-ico{
  width:34px;height:34px;border-radius:10px;
  background:rgba(var(--dw-theme-rgb,14,165,233),.10);
  color:var(--dw-theme,#0ea5e9);
  display:flex;align-items:center;justify-content:center;
  flex:0 0 auto;
}
.dw-usage-sec-h{ font-weight:700; color:#111827; }
.dw-usage-sec-sub{ color:rgba(17,24,39,.70); font-size:13px; margin-top:2px; }

.dw-usage-box{
  border-radius:14px;
  border:1px solid rgba(var(--dw-theme-rgb,14,165,233),.18);
  background:rgba(var(--dw-theme-rgb,14,165,233),.08);
  padding:12px 12px;
}
.dw-usage-row{
  display:grid;
  grid-template-columns:54px 1fr auto;
  gap:10px;
  align-items:center;
  padding:8px 6px;
}
.dw-usage-subrow{ padding:6px 6px; }
.dw-usage-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:4px 10px;
  font-size:12px;
  font-weight:700;
  color:#fff;
  background:var(--dw-theme,#0ea5e9);
  width:max-content;
}
.dw-usage-pill-gray{ background:rgba(17,24,39,.30); }
.dw-usage-lbl{ color:#111827; font-size:14px; }
.dw-usage-val{ color:#111827; font-weight:700; font-size:14px; }
.dw-usage-divider{ height:1px; background:rgba(var(--dw-theme-rgb,14,165,233),.20); margin:8px 6px; }
.dw-usage-row.dw-usage-total{
  /* Total row has only 2 columns (label + value). Prevent cramped layout. */
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:center;
}
.dw-usage-row.dw-usage-total .dw-usage-val{ justify-self:end; }
.dw-usage-total .dw-usage-lbl{ font-weight:800; }
.dw-usage-total .dw-usage-val{ font-weight:900; }

@media(max-width:420px){
  .dw-usage-row.dw-usage-total{ grid-template-columns:1fr; }
  .dw-usage-row.dw-usage-total .dw-usage-val{ justify-self:start; }
}

.dw-usage-acc{
  margin-top:14px;
  width:100%;
  border:1px solid rgba(17,24,39,.10);
  /* Themes may globally style <button> (e.g. red). Keep this neutral. */
  background:#fff !important;
  background-color:#fff !important;
  border-radius:14px;
  padding:12px 12px;
  display:grid;
  grid-template-columns:54px 1fr auto;
  gap:10px;
  align-items:center;
  cursor:pointer;
}
.dw-usage-sheet .dw-usage-acc{
  /* Extra specificity to beat theme-level button rules with !important. */
  background:#fff !important;
  background-color:#fff !important;
}
.dw-usage-chevron{ color:#6b7280; font-size:18px; line-height:1; }
.dw-usage-acc-panel{ margin-top:10px; }
.dw-usage-note{
  border:1px solid rgba(245,158,11,.25);
  background:rgba(245,158,11,.12);
  border-radius:14px;
  padding:14px;
  color:#111827;
  font-size:13px;
  line-height:1.5;
}

.dw-usage-updated{
  margin-top:14px;
  color:rgba(17,24,39,.70);
  font-size:12px;
  display:flex; align-items:center; gap:8px;
}
.dw-usage-foot{
  padding:14px 18px;
  border-top:1px solid rgba(17,24,39,.08);
  background:#fff;
}
.dw-usage-closebtn{
  width:100%;
  display:block !important;
  width:100% !important;
  min-width:100% !important;
  box-sizing:border-box !important;
  border:0 !important;
  background:var(--dw-theme,#0ea5e9) !important;
  background-color:var(--dw-theme,#0ea5e9) !important;
  color:#fff;
  font-weight:800;
  border-radius:12px;
  padding:12px 14px;
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
}
.dw-usage-closebtn:hover{ filter:brightness(.98); }
.dw-single-v2 .dw-usage-modal .dw-usage-closebtn{
  display:block !important;
  width:100% !important;
  min-width:100% !important;
  max-width:100% !important;
  border:0 !important;
  box-shadow:none !important;
  outline:none !important;
  text-align:center !important;
}
.dw-single-v2 .dw-usage-link,
.dw-single-v2 .dw-usage-acc,
.dw-single-v2 .dw-usage-x{
  border-color:rgba(17,24,39,.10) !important;
  box-shadow:none !important;
  outline:none !important;
}
.dw-single-v2 .dw-usage-link:focus,
.dw-single-v2 .dw-usage-link:focus-visible,
.dw-single-v2 .dw-usage-link:active,
.dw-single-v2 .dw-usage-acc:focus,
.dw-single-v2 .dw-usage-acc:focus-visible,
.dw-single-v2 .dw-usage-acc:active,
.dw-single-v2 .dw-usage-x:focus,
.dw-single-v2 .dw-usage-x:focus-visible,
.dw-single-v2 .dw-usage-x:active,
.dw-single-v2 .dw-usage-closebtn:focus,
.dw-single-v2 .dw-usage-closebtn:focus-visible,
.dw-single-v2 .dw-usage-closebtn:active{
  outline:none !important;
  box-shadow:none !important;
}
.dw-single-v2 .dw-usage-x{
  border:1px solid rgba(17,24,39,.10) !important;
  background:#fff !important;
  background-color:#fff !important;
}

html.dw-modal-open{ overflow:hidden; }

@media (max-width: 520px){ 
  .dw-qris-steps{grid-template-columns:repeat(2,1fr)} 
  .dw-qris-steps-img{display:block} 
  .dw-qris-steps-img + .dw-qris-steps{display:none} 
} 

/* Final guard: lock invoice layout to 500px max and avoid horizontal "side space" */
.dw-single-v2.dw-invoice-page{
  width:100% !important;
  overflow-x:hidden !important;
}
.dw-single-v2.dw-invoice-page .dw-container{
  width:100% !important;
  max-width:500px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:calc(14px + env(safe-area-inset-left)) !important;
  padding-right:calc(14px + env(safe-area-inset-right)) !important;
  box-sizing:border-box !important;
}
.dw-single-v2.dw-invoice-page .dw-invoice-card{
  width:100% !important;
  max-width:500px !important;
  margin-left:auto !important;
  margin-right:auto !important;
}
