/* Kas Rusun 2 — antarmuka bendahara
   Palet: hijau tua (arsip/dinas), kuning kuningan (aksen), kertas gading.
   Tipografi: Plus Jakarta Sans (khas Jakarta) untuk seluruh antarmuka. */
@font-face{font-family:"Plus Jakarta Sans";src:url("fonts/pjs-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Plus Jakarta Sans";src:url("fonts/pjs-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Plus Jakarta Sans";src:url("fonts/pjs-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Plus Jakarta Sans";src:url("fonts/pjs-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Plus Jakarta Sans";src:url("fonts/pjs-800.woff2") format("woff2");font-weight:800;font-style:normal;font-display:swap}

:root{
  --paper:#f4f1e8;
  --paper-2:#efeadd;
  --surface:#ffffff;
  --ink:#22271f;
  --ink-soft:#5f6459;
  --line:#e5e0d1;
  --line-soft:#eee9dc;
  --green:#234d34;         /* primary */
  --green-700:#173625;
  --green-900:#0f2418;
  --green-050:#e9f0e9;
  --brass:#b0872f;
  --brass-bright:#d9b458;
  --brass-050:#f5ecd7;
  --ok:#2e7d46;
  --ok-bg:#e5f2e8;
  --bad:#c0392b;
  --bad-bg:#fbe9e7;
  --gray:#b9b6ab;
  --gray-bg:#eeece4;
  --radius:14px;
  --radius-sm:9px;
  --shadow:0 1px 2px rgba(24,30,20,.05),0 10px 26px -20px rgba(24,30,20,.4);
  --shadow-md:0 2px 6px rgba(24,30,20,.06),0 18px 40px -24px rgba(24,30,20,.5);
  --shadow-lg:0 30px 70px -28px rgba(15,36,24,.55);
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --sans:"Plus Jakarta Sans",ui-sans-serif,system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background:var(--paper);
  background-image:radial-gradient(1200px 480px at 100% -8%,rgba(176,135,47,.06),transparent 60%),
                   radial-gradient(1000px 420px at -10% 0%,rgba(35,77,52,.05),transparent 55%);
  background-attachment:fixed;
  font-size:15px;line-height:1.55;letter-spacing:-.003em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:var(--green);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:1.55rem;margin:0 0 .15em;letter-spacing:-.02em;font-weight:800}
h2{font-size:1.06rem;margin:0;font-weight:700;letter-spacing:-.01em}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}
.muted{color:var(--ink-soft)}
.nowrap{white-space:nowrap}
.ta-right{text-align:right}
.small{font-size:.8rem}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
.pos{color:var(--ok)}
.neg{color:var(--bad)}

/* ---------- Topbar (masthead) ---------- */
.topbar{position:sticky;top:0;z-index:40;color:#f3efe2;
  background:linear-gradient(180deg,#25543a,var(--green-700));
  border-bottom:1px solid rgba(0,0,0,.25);
  box-shadow:0 1px 0 rgba(217,180,88,.55),0 10px 30px -18px rgba(0,0,0,.7)}
.topbar-inner{max-width:1180px;margin:0 auto;display:flex;align-items:center;gap:20px;
  padding:11px 20px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px;color:#fff}
.brand:hover{text-decoration:none}
.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.35),inset 0 0 0 1px rgba(217,180,88,.35);flex:0 0 auto}
.brand-mark img,.brand-mark svg{width:100%;height:100%;display:block}
.brand-mark-lg{width:72px;height:72px;border-radius:18px}
.brand-text strong{display:block;font-size:1.05rem;line-height:1.12;font-weight:800;letter-spacing:-.01em}
.brand-text small{color:#c7d7c4;font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;font-weight:600}
.mainnav{display:flex;gap:3px;margin-left:auto}
.nav-link{color:#d3e0d1;padding:8px 13px;border-radius:9px;font-size:.9rem;font-weight:600;
  letter-spacing:-.005em;transition:background .14s,color .14s}
.nav-link:hover{background:rgba(255,255,255,.1);color:#fff;text-decoration:none}
.nav-link.is-active{background:var(--brass);color:#241a05;font-weight:700;
  box-shadow:0 2px 10px -4px rgba(176,135,47,.8)}
.userbox{display:flex;align-items:center;gap:8px}
.userbox-name{font-size:.85rem;color:#e7eee5}
.mobilenav{display:none}

/* ---------- Layout ---------- */
.page{max-width:1180px;margin:0 auto;padding:22px 20px 40px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
  margin-bottom:18px;flex-wrap:wrap}
.head-actions{display:flex;gap:8px;align-items:center}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-side{display:grid;grid-template-columns:1.7fr 1fr;gap:18px;align-items:start}
.stack{display:flex;flex-direction:column;gap:18px}
@media(max-width:860px){.grid-2,.grid-side{grid-template-columns:1fr}}

/* ---------- Panels & cards ---------- */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow)}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px;
  padding-bottom:12px;border-bottom:1px solid var(--line-soft)}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.cards-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:860px){.cards,.cards-3{grid-template-columns:repeat(2,1fr)}}
.card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:17px 18px;display:flex;flex-direction:column;gap:5px;box-shadow:var(--shadow);
  transition:transform .16s ease,box-shadow .16s ease}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.card-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:700}
.card-value{font-size:1.6rem;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.03em;line-height:1.1}
.card-value small{font-size:1rem;color:var(--ink-soft);font-weight:600}
.card-foot{font-size:.78rem;color:var(--ink-soft)}
.card-saldo{background:
    radial-gradient(120px 120px at 92% 12%,rgba(217,180,88,.16),transparent 70%),
    linear-gradient(155deg,#2a5a3d,var(--green-900));
  color:#fff;border:none;overflow:hidden}
.card-saldo::after{content:"";position:absolute;right:-26px;bottom:-26px;width:104px;height:104px;
  border-radius:50%;border:2px solid rgba(217,180,88,.35);
  box-shadow:inset 0 0 0 6px rgba(217,180,88,.1)}
.card-saldo .card-label{color:#cfe0cd}
.card-saldo .card-foot{color:#b9ccb6}
.card-saldo .card-value{color:#fff}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid transparent;
  border-radius:10px;padding:9px 16px;font-size:.9rem;font-weight:700;cursor:pointer;font-family:inherit;
  letter-spacing:-.005em;background:#eae7da;color:var(--ink);
  transition:transform .1s ease,filter .12s,background .12s,box-shadow .12s}
.btn:hover{text-decoration:none;filter:brightness(.98)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(180deg,#2b5b3e,var(--green));color:#fff;
  box-shadow:0 2px 10px -3px rgba(35,77,52,.6),inset 0 1px 0 rgba(255,255,255,.12)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-outline{background:var(--surface);border-color:var(--green);color:var(--green)}
.btn-outline:hover{background:var(--green-050)}
.btn-ghost{background:transparent;color:inherit;border-color:transparent}
.topbar .btn-ghost{color:#e7eee5;border-color:rgba(255,255,255,.25)}
.topbar .btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-danger{background:transparent;color:var(--bad);border-color:#e8c6c1}
.btn-danger:hover{background:var(--bad-bg)}
.btn-block{width:100%;justify-content:center}
.btn-sm{padding:6px 11px;font-size:.82rem}
.btn-xs{padding:4px 9px;font-size:.76rem;border-radius:7px}
.row-actions{display:inline-flex;gap:6px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.inline{display:inline}

/* ---------- Tables ---------- */
.tablewrap{overflow:auto;border-radius:var(--radius-sm);border:1px solid var(--line-soft)}
.table{width:100%;border-collapse:collapse;font-size:.9rem;background:var(--surface)}
.table th{text-align:left;font-size:.68rem;text-transform:uppercase;letter-spacing:.09em;font-weight:700;
  color:var(--ink-soft);padding:10px 11px;background:var(--paper-2);
  border-bottom:1px solid var(--line);white-space:nowrap}
.table td{padding:10px 11px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
.table td.ta-right,.table th.ta-right,.table td.num,.table th.num{text-align:right}
.table td.ta-center,.table th.ta-center{text-align:center}
.table tbody tr:last-child td{border-bottom:none}
.table tbody tr:hover{background:#faf8f0}
/* area yang dapat digulir (daftar panjang) */
.scroll-y{max-height:440px;overflow-y:auto;overflow-x:hidden;
  border-radius:var(--radius-sm);scrollbar-width:thin;scrollbar-color:var(--brass) transparent}
.scroll-y::-webkit-scrollbar{width:9px}
.scroll-y::-webkit-scrollbar-thumb{background:#d8cba6;border-radius:6px;border:2px solid var(--surface)}
.scroll-y::-webkit-scrollbar-thumb:hover{background:var(--brass)}
.sticky-head thead th{position:sticky;top:0;z-index:2}
.table-compact td,.table-compact th{padding:6px 8px}
.table tfoot td{font-weight:700;border-top:2px solid var(--line);border-bottom:none;background:#faf9f2}
.ledger td:nth-child(1){white-space:nowrap}
.ledger-open td{background:#faf7ec;color:var(--ink-soft)}

/* ---------- Ledger matrix ---------- */
.tablewrap-scroll{max-height:70vh}
.matrix{font-size:.85rem}
.matrix th,.matrix td{text-align:center;padding:7px 6px}
.matrix thead th{background:var(--paper-2);position:sticky;top:0}
.matrix .col-nama{text-align:left;min-width:200px}
.nm-name{display:block;font-weight:600;line-height:1.2}
.nm-meta{display:block;font-size:.72rem;color:var(--ink-soft);margin-top:1px;letter-spacing:.01em}
.matrix tbody tr:nth-child(even) .sticky-col,
.matrix tbody tr:nth-child(even) .sticky-col2{background:#faf8f1}
.matrix .col-m{width:44px}
.matrix .sticky-col,.matrix .sticky-col2{position:sticky;background:var(--surface);text-align:left;z-index:2}
.matrix thead .sticky-col,.matrix thead .sticky-col2{z-index:3}
.matrix .sticky-col{left:0;min-width:52px}
.matrix .sticky-col2{left:52px}
.matrix tbody tr:hover .sticky-col,.matrix tbody tr:hover .sticky-col2{background:#faf9f4}
.cell{padding:0!important}
.cell-link{display:block;width:100%;height:100%;padding:8px 0;font-weight:700;color:inherit}
.cell-link:hover{text-decoration:none;outline:2px solid var(--brass);outline-offset:-2px}
.cell-green{background:var(--ok-bg);color:var(--ok)}
.cell-red{background:var(--bad-bg);color:var(--bad)}
.cell-gray{background:var(--gray-bg)}
.row-dinas{color:var(--ink-soft)}

/* dot & pill status */
.dot{display:inline-block;width:10px;height:10px;border-radius:50%;vertical-align:baseline;margin-right:2px}
.dot-green{background:var(--ok)}.dot-red{background:var(--bad)}.dot-gray{background:var(--gray)}
.pill{font-size:.74rem;font-weight:600;padding:2px 9px;border-radius:999px;white-space:nowrap}
.pill-aktif{background:var(--ok-bg);color:var(--ok)}
.pill-dinas{background:var(--brass-050);color:var(--brass)}
.pill-kosong{background:var(--gray-bg);color:var(--ink-soft)}
.tag{display:inline-block;background:var(--green-050);color:var(--green-700);border-radius:6px;
  padding:1px 7px;font-size:.78rem;font-weight:600}
.tag-mini{background:var(--gray-bg);color:var(--ink-soft);font-size:.68rem;padding:1px 6px;font-weight:600}
.badge{font-size:.8rem;font-weight:700;padding:2px 10px;border-radius:999px}
.badge-red{background:var(--bad-bg);color:var(--bad)}

/* ---------- Forms ---------- */
label{display:block;font-size:.85rem;font-weight:600;color:var(--ink)}
input,select,textarea{width:100%;font-family:inherit;font-size:.92rem;margin-top:5px;
  padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--green);outline-offset:0;border-color:var(--green)}
input[type=file]{padding:7px 9px;background:#fbfaf5}
input:disabled{background:#f0eee6;color:var(--ink-soft)}
.inline-form{display:inline-flex;gap:8px;margin:0}
.inline-form select{margin-top:0;width:auto}
.stackform{display:flex;flex-direction:column;gap:12px}
.form-actions{display:flex;gap:8px;margin-top:4px}
.picker{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.picker label{min-width:220px;flex:1}

/* payment form */
.pay-person{display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:12px 14px;background:var(--green-050);border-radius:10px;margin-bottom:16px}
.pay-person strong{margin:0 8px}
.months{border:1px solid var(--line);border-radius:12px;padding:14px;margin:0 0 16px}
.months legend{font-weight:700;font-size:.85rem;padding:0 6px}
.month-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
@media(max-width:680px){.month-grid{grid-template-columns:repeat(3,1fr)}}
.month-chip{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;
  border:1px solid var(--line);border-radius:10px;padding:9px 4px;font-weight:600;position:relative;
  background:#fff;transition:border-color .12s,background .12s}
.month-chip input{width:auto;margin:0;position:absolute;top:6px;left:6px}
.month-chip .m-name{font-size:.9rem}
.month-chip .m-state{font-size:.68rem;color:var(--ink-soft);font-weight:600}
.month-chip.is-lunas{background:var(--ok-bg);border-color:#bfe0c8;color:var(--ok);cursor:not-allowed}
.month-chip.is-lunas .m-state{color:var(--ok)}
.month-chip.selected{border-color:var(--green);background:var(--green-050)}
.month-tools{display:flex;align-items:center;gap:10px;margin-top:12px;flex-wrap:wrap}
.pick-count{margin-left:auto;font-size:.82rem}
.pay-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:760px){.pay-grid{grid-template-columns:1fr 1fr}}
.pay-foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px;flex-wrap:wrap;gap:10px}
.pay-total{font-size:1.05rem}
.pay-total strong{font-size:1.25rem}

/* add box */
.addbox{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:8px 16px;margin-bottom:18px;box-shadow:var(--shadow)}
.addbox summary{cursor:pointer;font-weight:600;padding:8px 0;color:var(--green)}
.addform{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;padding:8px 0 14px}
.addform label{flex:1;min-width:130px}
.addform .grow{flex:2;min-width:220px}

/* ---------- Feed ---------- */
.feed{list-style:none;margin:0;padding:0}
.feed-item{display:grid;grid-template-columns:88px 1fr auto;gap:10px;align-items:baseline;
  padding:9px 2px;border-bottom:1px solid var(--line)}
.feed-item:last-child{border-bottom:none}
.feed-date{font-size:.76rem;color:var(--ink-soft)}
.feed-desc{font-size:.88rem}
.feed-amt{font-variant-numeric:tabular-nums;font-weight:700;font-size:.88rem;white-space:nowrap}

.quick-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.empty{color:var(--ink-soft);padding:14px 4px;text-align:center}
.note{font-size:.82rem;margin-top:12px}
.link{color:var(--green);font-weight:600;font-size:.85rem}

/* ---------- Flash ---------- */
.flash{padding:11px 15px;border-radius:10px;margin-bottom:14px;font-size:.9rem;font-weight:500;
  border:1px solid transparent}
.flash-ok{background:var(--ok-bg);color:#1e5c33;border-color:#bfe0c8}
.flash-error{background:var(--bad-bg);color:#a3271b;border-color:#eec6c0}

/* ---------- Login ---------- */
.login-body{display:grid;place-items:center;min-height:100vh;padding:24px;
  background:
    radial-gradient(700px 340px at 50% -6%,rgba(217,180,88,.22),transparent 62%),
    radial-gradient(900px 500px at 100% 110%,rgba(217,180,88,.08),transparent 60%),
    linear-gradient(160deg,#2a5a3d,var(--green-900))}
.login-card{position:relative;background:var(--surface);border-radius:22px;padding:38px 34px 30px;
  width:min(400px,94vw);box-shadow:var(--shadow-lg);border:1px solid rgba(217,180,88,.25)}
.login-card::before{content:"";position:absolute;left:26px;right:26px;top:0;height:4px;border-radius:0 0 4px 4px;
  background:linear-gradient(90deg,var(--brass),var(--brass-bright),var(--brass))}
.login-head{text-align:center;margin-bottom:20px}
.login-head .brand-mark{margin:0 auto 14px;box-shadow:0 10px 24px -10px rgba(15,36,24,.6),inset 0 0 0 1px rgba(217,180,88,.4)}
.login-head h1{font-size:1.4rem;margin:0;letter-spacing:-.02em}
.login-head p{color:var(--ink-soft);font-size:.82rem;margin:.3em 0 0;text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.login-form{display:flex;flex-direction:column;gap:14px;margin-top:6px}
.login-hint{text-align:center;font-size:.78rem;color:var(--ink-soft);margin:18px 0 0;line-height:1.7}
.login-hint code{background:var(--gray-bg);padding:2px 7px;border-radius:6px;font-family:var(--mono);font-size:.9em}

/* ---------- Footer ---------- */
.sitefoot{max-width:1180px;margin:0 auto;padding:20px;display:flex;justify-content:space-between;
  color:var(--ink-soft);font-size:.8rem;border-top:1px solid var(--line);flex-wrap:wrap;gap:8px}

/* ---------- Tampilan responsif (HP) ---------- */
/* Helper: sembunyikan/tampilkan sesuai perangkat */
.only-mobile{display:none}
.only-desktop{display:block}

@media(max-width:720px){
  /* Navigasi bawah tetap (bottom bar) ala aplikasi */
  .mainnav{display:none}
  .userbox{margin-left:auto}
  .userbox-name{display:none}

  .mobilenav{
    display:flex;position:fixed;left:0;right:0;bottom:0;z-index:50;
    gap:0;padding:0;background:var(--green-700);
    box-shadow:0 -2px 12px rgba(0,0,0,.18);
    padding-bottom:env(safe-area-inset-bottom,0);
  }
  .mobilenav .nav-link{
    position:relative;
    flex:1 1 0;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:2px;padding:9px 2px 8px;font-size:.7rem;font-weight:600;
    color:#cdd9cb;white-space:nowrap;border-radius:0;text-align:center;line-height:1.1;
  }
  .mobilenav .nav-link::before{
    content:attr(data-ikon);font-size:1.15rem;line-height:1;font-weight:400;
  }
  .mobilenav .nav-link:hover{text-decoration:none}
  .mobilenav .nav-link.is-active{background:transparent;color:#fff}
  .mobilenav .nav-link.is-active::after{
    content:"";position:absolute;top:0;width:34px;height:3px;border-radius:0 0 4px 4px;background:var(--brass);
  }

  /* beri ruang di bawah agar konten tak tertutup bottom bar */
  body{padding-bottom:64px}

  /* Header sedikit dirapatkan */
  .topbar{flex-wrap:wrap}
  .page{padding-left:14px;padding-right:14px}
  h1{font-size:1.3rem}

  /* Kartu ringkasan: 1 kolom penuh biar angka besar & jelas */
  .cards,.cards-3{grid-template-columns:1fr!important;gap:10px}
  .card{padding:14px 16px}

  /* Tombol & kolom form lebih besar untuk disentuh */
  .btn{min-height:42px;padding:10px 16px}
  .btn-sm{min-height:38px}
  .btn-xs{min-height:34px;padding:7px 12px;font-size:.8rem}
  input,select,textarea{font-size:16px;min-height:44px} /* 16px cegah zoom iOS */
  .pay-grid{grid-template-columns:1fr!important}
  .picker{grid-template-columns:1fr!important}

  /* ====== TABEL -> KARTU ======
     Tabel dengan kelas .table-cards berubah jadi daftar kartu di HP. */
  .table-cards thead{display:none}
  .table-cards, .table-cards tbody, .table-cards tr, .table-cards td{display:block;width:100%}
  .table-cards tfoot,.table-cards tfoot tr,.table-cards tfoot td{display:block;width:100%}
  .table-cards tr{
    background:var(--surface);border:1px solid var(--line);border-radius:12px;
    padding:10px 14px;margin-bottom:10px;box-shadow:var(--shadow);
  }
  .table-cards tr:hover{background:var(--surface)}
  .table-cards td{
    border:none;padding:5px 0;display:flex;justify-content:space-between;
    align-items:center;gap:14px;text-align:right;
  }
  .table-cards td::before{
    content:attr(data-label);font-size:.72rem;font-weight:700;text-transform:uppercase;
    letter-spacing:.03em;color:var(--ink-soft);text-align:left;flex:0 0 auto;
  }
  /* baris tanpa isi (mis. kolom kosong) disembunyikan di HP */
  .table-cards td:empty,
  .table-cards td.cell-bukti:empty,
  .table-cards td.cell-aksi:empty{display:none}
  /* keterangan/nama dibuat menonjol di atas kartu */
  .table-cards td[data-label="Keterangan"],
  .table-cards td[data-label="Nama"]{
    font-size:1rem;font-weight:600;border-bottom:1px dashed var(--line);
    padding-bottom:8px;margin-bottom:4px;
  }
  .table-cards td[data-label="Keterangan"]::before,
  .table-cards td[data-label="Nama"]::before{align-self:center}
  .table-cards .cell-aksi{justify-content:flex-end;padding-top:8px}
  .table-cards tfoot tr{background:var(--green-050);border-color:#cfe0d1}
  .table-cards tfoot td{display:flex;font-weight:700}
  .table-cards tfoot td[colspan]::before{content:""}
  /* varian rapat (daftar belum-bayar di dasbor) */
  .table-cards-tight tr{padding:8px 12px}

  /* ====== KARTU LAPORAN TAHUNAN ====== */
  .only-desktop{display:none}
  .only-mobile{display:block}
  .matrix-cards{display:flex;flex-direction:column;gap:10px}
  .mc{background:var(--surface);border:1px solid var(--line);border-radius:12px;
    padding:12px 14px;box-shadow:var(--shadow)}
  .mc-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}
  .mc-unit{font-weight:700;background:var(--gray-bg);border-radius:6px;padding:2px 8px;font-size:.85rem}
  .mc-nama{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}
  .mc-nama-n{font-weight:700;font-size:.95rem;line-height:1.15}
  .mc-nama-m{font-size:.72rem;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mc-count{font-size:.82rem;color:var(--ink-soft);font-weight:700}
  .mc-months{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
  .mc-m{display:flex;flex-direction:column;align-items:center;gap:2px;
    border-radius:8px;padding:6px 0 5px;font-weight:700;text-decoration:none}
  .mc-m:hover{text-decoration:none;outline:2px solid var(--brass);outline-offset:-2px}
  .mc-m-name{font-size:.64rem;letter-spacing:.02em;font-weight:600}
  .mc-m-mark{font-size:.95rem;line-height:1}
  .mc-m.is-lunas{background:var(--ok-bg);color:var(--ok)}
  .mc-m.is-belum{background:var(--bad-bg);color:var(--bad)}
  .mc-m.is-kosong{background:var(--gray-bg);color:var(--ink-soft)}
  .mc-dinas{opacity:.85}
  .mc-note{font-size:.85rem}

  /* Feed transaksi: rapat & tetap terbaca */
  .feed-item{grid-template-columns:74px 1fr auto;gap:8px}
  .sitefoot{justify-content:center;text-align:center}
}

/* Layar sangat kecil */
@media(max-width:380px){
  .mc-months{grid-template-columns:repeat(4,1fr)}
  .mobilenav .nav-link{font-size:.64rem}
}
