:root{
  --bg: #0b0c10;
  --fg: #111827;
  --muted:#6b7280;
  --card:#ffffff;
  --card-muted:#f3f4f6;
  --line:#e5e7eb;
  --brand:#2563eb;      /* biru utama */
  --brand-2:#7c3aed;    /* ungu sekunder */
  --ok:#16a34a;
  --warn:#f59e0b;
  --danger:#ef4444;
  --shadow: 0 8px 24px rgba(0,0,0,.08);
  --radius: 14px;
}

@media (prefers-color-scheme: dark){
  :root{
    --fg:#e5e7eb; --muted:#9ca3af; --card:#111827; --card-muted:#0f172a; --line:#1f2937;
    --shadow: 0 10px 30px rgba(0,0,0,.35);
  }
  body{ background:#0b1220; }
}

[data-theme="light"] body{ background:#f6f7fb; }
[data-theme="dark"]  body{ background:#0b1220; }

*{ box-sizing: border-box }
html,body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  color:var(--fg);
}
a{ color:var(--brand); text-decoration: none }
a:hover{ text-decoration: underline }
img{ max-width:100%; display:block }
.wrap{ max-width:1200px; margin-inline:auto; padding: 18px 16px 40px; }

/* ------------------ header ------------------ */
.topbar{
  display:flex; align-items:center; gap:12px; justify-content:space-between; padding: 12px 0;
}
.brand{ display:flex; align-items:center; gap:10px; font-weight:700; letter-spacing:.2px; }
.logo{
  width:34px; height:34px; display:grid; place-items:center;
  background: linear-gradient(135deg,var(--brand),var(--brand-2));
  color:white; border-radius:10px; box-shadow: var(--shadow);
  font-size:18px; font-weight:800;
}
.brand-title{ font-size:16px; font-weight:800; }
.brand-sub{ font-size:12px; }
.plan{
  margin-left:6px; padding:6px 10px; border-radius:999px; font-size:12px; font-weight:800;
  border:1px solid var(--line); background:var(--card);
}
.plan.standard{ background:#eff6ff; color:#1e40af; border-color:#bfdbfe; }
.plan.pro{ background:#ecfdf5; color:#065f46; border-color:#a7f3d0; }
.plan.premium{ background:#f5f3ff; color:#4c1d95; border-color:#ddd6fe; }

.nav{ display:flex; gap:10px; flex-wrap:wrap; }
.chip{
  display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px;
  background:var(--card); border:1px solid var(--line); box-shadow: var(--shadow); color:var(--fg);
}
.chip.is-primary{ background: linear-gradient(135deg, rgba(37,99,235,.08), rgba(124,58,237,.08)); border-color: transparent; }
.tools{ display:flex; gap:8px; align-items:center; }

.btn{
  display:inline-flex; align-items:center; gap:10px; padding:12px 16px; border-radius:12px;
  background:var(--brand); color:#fff; border:0; cursor:pointer; box-shadow: var(--shadow);
  font-weight:600; letter-spacing:.2px;
}
.btn.secondary{ background: var(--card); color:var(--fg); border:1px solid var(--line); }
.btn.ghost{ background: transparent; color: var(--fg); border:1px solid var(--line); }
.btn.sm{ padding:9px 12px; border-radius:10px; font-size:14px }
.btn.link{ background:transparent; color:var(--brand); padding:0; border:none; box-shadow:none }
.btn:active{ transform: translateY(1px); }

/* ------------------ grid ------------------ */
.grid{
  display:grid; gap:18px; grid-template-columns: 1fr; margin-top:12px;
}
@media (min-width: 980px){
  .grid{ grid-template-columns: 1.65fr .95fr; }
}

/* ------------------ card ------------------ */
.card{
  background:var(--card); border:1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow);
}
.card-h{
  display:flex; align-items:center; justify-content:space-between; padding:16px 18px; border-bottom:1px solid var(--line);
}
.card-b{ padding:16px 18px; }
.muted{ color:var(--muted); font-size:14px; }
.title{ font-size:16px; font-weight:700; letter-spacing:.2px; }

/* ------------------ hero CTA ------------------ */
.hero{
  background: linear-gradient(135deg, rgba(37,99,235,.08), rgba(124,58,237,.08));
  border:1px dashed #93c5fd; border-radius: var(--radius); padding:18px; display:flex; gap:16px; align-items:center; justify-content:space-between;
}
.hero h2{ margin:0 0 6px; font-size:20px }
.hero p{ margin:0; color:var(--muted) }

/* ------------------ table ------------------ */
.table{ width:100%; border-collapse: collapse; }
.table th, .table td{ padding:12px 10px; text-align:left; border-bottom:1px solid var(--line); vertical-align: middle; }
.table th{ font-size:12px; text-transform:uppercase; letter-spacing:.4px; color:var(--muted); }
.table .col-actions{ text-align:right }
.table a.link{ color:var(--brand); text-decoration:none; font-weight:600 }
.table a.link:hover{ text-decoration:underline }

/* status badge/pill */
.pill{
  padding:6px 10px; border-radius:999px; font-size:12px; font-weight:700; display:inline-block;
  background:#eef2ff; color:#4338ca; border:1px solid #c7d2fe;
}
.pill.ok{ background:#ecfdf5; color:#065f46; border-color:#a7f3d0 }
.pill.warn{ background:#fffbeb; color:#92400e; border-color:#fde68a }
.pill.bad{ background:#fef2f2; color:#991b1b; border-color:#fecaca }

/* status khusus */
.status{ composes: pill; } /* (untuk konsisten) */
.status.draft{ background:#e0e7ff; color:#3730a3; border-color:#c7d2fe }
.status.hantar,.status.sent{ background:#dcfce7; color:#166534; border-color:#bbf7d0 }
.status.menunggu,.status.pending{ background:#fffbeb; color:#92400e; border-color:#fde68a }
.status.dibayar,.status.paid{ background:#dcfce7; color:#065f46; border-color:#a7f3d0 }
.status.belum{ background:#fef3c7; color:#92400e; border-color:#fde68a }
.status.overdue{ background:#fee2e2; color:#b91c1c; border-color:#fecaca }

/* ------------------ progress ------------------ */
.progress{ height:10px; background:var(--card-muted); border-radius:999px; overflow:hidden; border:1px solid var(--line) }
.progress > i{ display:block; height:100%; width:38%; background:linear-gradient(90deg,var(--brand),var(--brand-2)); }

/* ------------------ list ------------------ */
.list{ display:grid; gap:10px }
.li{ display:flex; align-items:flex-start; gap:12px }
.li i{ width:18px; height:18px; margin-top:2px; border-radius:4px; display:grid; place-items:center; background:#e0e7ff; color:#3730a3; font-size:12px; font-weight:800 }
.li.ok i{ background:#dcfce7; color:#065f46 }
.li.warn i{ background:#fef3c7; color:#92400e }

/* ------------------ empty state ------------------ */
.empty{
  display:grid; place-items:center; text-align:center; padding:28px 8px; color:var(--muted);
}
.empty b{ color:var(--fg); }

/* ------------------ footer ------------------ */
.foot{ padding:20px 4px; color:var(--muted); font-size:13px; }

/* ------------------ floating WhatsApp ------------------ */
.fab{
  position: fixed; right: 18px; bottom: 18px; z-index: 99;
  display:flex; align-items:center; gap:10px; padding:12px 14px; border-radius:999px;
  background:#22c55e; color:#fff; box-shadow: var(--shadow);
  font-weight:700;
}
.fab:hover{ filter: brightness(1.05) }

/* ------------------ utilities ------------------ */
.quicklinks{ display:grid; gap:10px }
.support-actions{ display:flex; gap:8px; flex-wrap:wrap }
.hidden{ display:none !important }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0 }

/* ------------------ skeleton / shimmer ------------------ */
.skeleton{
  border-radius:8px; background:
    linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(255,255,255,.45) 50%, rgba(0,0,0,0) 100%),
    var(--card-muted);
  background-size: 200% 100%, 100% 100%;
  animation: shimmer 1.3s infinite;
  border:1px solid var(--line);
}
.skeleton-row{
  height:44px; margin-bottom:10px; border-radius:10px;
  background:
    linear-gradient(90deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.35) 50%, rgba(255,255,255,.08) 100%),
    var(--card-muted);
  background-size:200% 100%, 100% 100%;
  animation: shimmer 1.2s infinite;
  border:1px solid var(--line);
}
@keyframes shimmer{
  0%{ background-position: -120% 0, 0 0; }
  100%{ background-position: 120% 0, 0 0; }
}

/* ------------------ badges kecil (tag nav) ------------------ */
.badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 10px; border-radius:999px; font-weight:700; font-size:12px;
  background:var(--card-muted); border:1px solid var(--line); color:var(--fg);
}
.badge.brand{ background:rgba(37,99,235,.12); border-color:rgba(37,99,235,.25); color:#1e40af }
.badge.ok{ background:rgba(22,163,74,.12); border-color:rgba(22,163,74,.25); color:#065f46 }
.badge.warn{ background:rgba(245,158,11,.12); border-color:rgba(245,158,11,.25); color:#92400e }

/* ------------------ small cards (Quick links) ------------------ */
.quick-card{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:12px 14px; border-radius:12px; background:var(--card); border:1px solid var(--line); box-shadow:var(--shadow);
}
.quick-card .label{ display:flex; align-items:center; gap:10px; font-weight:700 }
.quick-card .icon{
  width:30px; height:30px; display:grid; place-items:center; border-radius:10px;
  background:linear-gradient(135deg, rgba(37,99,235,.1), rgba(124,58,237,.1));
  color:#1e3a8a; font-weight:800
}

/* === Gating ikut plan/edition ============================== */
[data-plan="standard"] [data-only-plan]:not([data-only-plan~="standard"]) { display: none !important; }
[data-plan="pro"]      [data-only-plan]:not([data-only-plan~="pro"])      { display: none !important; }
[data-plan="premium"]  [data-only-plan]:not([data-only-plan~="premium"])  { display: none !important; }

/* edition khusus bila plan=standard */
[data-plan="standard"][data-edition="standard"]      [data-only-edition]:not([data-only-edition~="standard"])      { display:none !important; }
[data-plan="standard"][data-edition="standard-lite"] [data-only-edition]:not([data-only-edition~="standard-lite"]) { display:none !important; }
[data-plan="standard"][data-edition="standard-plus"] [data-only-edition]:not([data-only-edition~="standard-plus"]) { display:none !important; }
