/* Corporate Seilana palette - mobile first */
:root{
  --bg:#f3f5f8;
  --surface:#ffffff;
  --surface2:#f8fafc;
  --ink:#111827;
  --muted:#667085;
  --line:#e4e7ec;
  --navy:#0b1f3a;
  --navy2:#102a4c;
  --navy3:#183b63;
  --gold:#b8872d;
  --gold2:#f3ead8;
  --red:#b42318;
  --red-soft:#fff4f2;
  --green:#067647;
  --green-soft:#ecfdf3;
  --shadow:0 18px 42px rgba(16,24,40,.09);
  --radius:22px;
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%;font-family:Inter,Arial,Helvetica,sans-serif;background:var(--bg);color:var(--ink)}
button,input{font:inherit}
.hidden{display:none!important}
.login-page{min-height:100vh;display:grid;place-items:center;padding:20px;background:linear-gradient(145deg,#f7f4ed 0,#f3f5f8 45%,#eef2f7 100%)}
.login-card{width:100%;max-width:390px;background:rgba(255,255,255,.92);border:1px solid rgba(229,231,235,.9);box-shadow:var(--shadow);border-radius:30px;padding:28px 22px;text-align:left}
.brand-mark{width:70px;height:70px;border-radius:24px;background:linear-gradient(145deg,var(--navy),var(--navy2));display:grid;place-items:center;color:var(--gold);font-weight:900;font-size:27px;margin:0 auto 16px;border:1px solid rgba(201,154,46,.3)}
.login-title{text-align:center;font-size:23px;font-weight:900;letter-spacing:-.4px}
.login-subtitle{text-align:center;color:var(--muted);font-size:13px;margin:5px 0 22px}
.field-label{font-size:13px;font-weight:800;margin:14px 0 7px;display:block;color:#334155}.input{width:100%;border:1px solid var(--line);border-radius:16px;background:#fff;padding:15px 14px;font-size:16px;outline:none}.input:focus{border-color:var(--gold);box-shadow:0 0 0 4px rgba(201,154,46,.15)}
.primary-btn{width:100%;border:0;border-radius:16px;padding:15px 16px;background:linear-gradient(145deg,var(--navy),var(--navy2));color:#fff;font-weight:900;margin-top:18px;box-shadow:0 14px 28px rgba(11,31,58,.22)}
.login-note{text-align:center;color:var(--muted);font-size:12px;margin:16px 0 0}.alert{padding:12px 13px;border-radius:14px;font-weight:800;font-size:13px;margin:12px 0}.alert.err{background:var(--red-soft);color:var(--red)}.alert.ok{background:var(--green-soft);color:var(--green)}
.app-shell{min-height:100vh;display:flex}.sidebar{position:fixed;inset:0 auto 0 0;width:310px;max-width:84vw;background:linear-gradient(180deg,#071a31 0%,#0b1f3a 48%,#081a2f 100%);color:#fff;z-index:30;transform:translateX(-105%);transition:.22s ease;display:flex;flex-direction:column;padding:18px;border-right:1px solid rgba(255,255,255,.08)}.sidebar.open{transform:translateX(0)}.overlay{position:fixed;inset:0;background:rgba(2,6,23,.45);z-index:25}.sidebar-head{display:flex;align-items:center;gap:12px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.1)}.mini-logo{width:48px;height:48px;border-radius:16px;background:rgba(201,154,46,.13);border:1px solid rgba(201,154,46,.35);color:var(--gold);display:grid;place-items:center;font-weight:900}.side-company{font-weight:900}.side-sub{color:#b6c2d1;font-size:12px;margin-top:2px}.side-nav{display:grid;gap:8px;margin-top:18px}.side-link{border:1px solid transparent;background:transparent;color:#d7dde8;text-align:left;padding:14px 14px;border-radius:16px;font-weight:850}.side-link.active{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.13);color:#fff}.sidebar-foot{margin-top:auto;border-top:1px solid rgba(255,255,255,.1);padding-top:14px}.side-user{font-size:13px;color:#cbd5e1;margin-bottom:10px}.ghost-btn{width:100%;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:#fff;border-radius:14px;padding:12px;font-weight:850}
.main-panel{width:100%;min-width:0}.mobile-topbar{position:sticky;top:0;z-index:15;background:rgba(243,245,248,.92);backdrop-filter:blur(14px);display:flex;align-items:center;gap:13px;padding:14px 16px;border-bottom:1px solid rgba(229,231,235,.9)}.icon-btn{width:44px;height:44px;border:1px solid var(--line);border-radius:15px;background:#fff;font-size:22px;color:var(--navy);font-weight:900}.top-title{font-weight:900;font-size:17px}.top-sub{font-size:12px;color:var(--muted);margin-top:2px}.content{padding:16px 14px 34px;max-width:980px;margin:0 auto}.hero-card{background:linear-gradient(145deg,#0b1f3a 0%,#102a4c 62%,#183b63 100%);color:#fff;border-radius:28px;padding:22px;box-shadow:var(--shadow);position:relative;overflow:hidden}.hero-card:after{content:"";position:absolute;width:160px;height:160px;border-radius:999px;background:rgba(184,135,45,.18);right:-55px;top:-60px}.eyebrow{font-size:12px;letter-spacing:.11em;text-transform:uppercase;color:#f3ead8;font-weight:900}.hero-title{font-size:25px;font-weight:950;line-height:1.08;margin-top:8px;letter-spacing:-.6px}.hero-sub{color:#cbd5e1;font-size:13px;line-height:1.55;margin-top:9px;max-width:580px}.money-xl{font-size:33px;font-weight:950;letter-spacing:-1px;margin-top:18px}.small-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.mini-stat{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:13px}.mini-label{font-size:11px;color:#cbd5e1;font-weight:850;text-transform:uppercase}.mini-value{font-size:18px;font-weight:950;margin-top:5px}.section{margin-top:16px}.section-head{display:flex;align-items:end;justify-content:space-between;gap:12px;margin-bottom:10px}.section-title{font-size:18px;font-weight:950;letter-spacing:-.3px}.section-note{font-size:12px;color:var(--muted);margin-top:3px}.card-list{display:grid;gap:10px}.menu-card,.data-card{background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:17px;box-shadow:0 10px 26px rgba(15,39,71,.06)}.menu-card{display:flex;align-items:center;gap:14px;text-align:left;width:100%;cursor:pointer}.menu-icon{width:45px;height:45px;border-radius:16px;display:grid;place-items:center;background:var(--gold2);color:var(--navy);font-weight:950}.menu-title{font-weight:950;font-size:16px}.menu-desc{color:var(--muted);font-size:12px;line-height:1.4;margin-top:3px}.chev{margin-left:auto;color:#94a3b8;font-weight:900}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stat-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:15px}.stat-label{font-size:11px;color:var(--muted);font-weight:900;text-transform:uppercase}.stat-value{font-size:20px;font-weight:950;margin-top:6px;letter-spacing:-.4px}.wide{grid-column:1/-1}.progress-wrap{height:10px;background:#e2e8f0;border-radius:99px;overflow:hidden;margin-top:10px}.progress-bar{height:100%;background:linear-gradient(90deg,#b8872d,#183b63);width:0}.person-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.person-name{font-size:18px;font-weight:950}.pill{display:inline-flex;border-radius:999px;padding:6px 9px;font-size:11px;font-weight:900;background:#f1f5f9;color:#334155}.pill.pending{background:var(--red-soft);color:var(--red)}.pill.ok{background:var(--green-soft);color:var(--green)}.kv{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.kv-item{border-top:1px solid #eef2f7;padding-top:10px}.kv-label{font-size:11px;color:var(--muted);font-weight:900;text-transform:uppercase}.kv-value{font-size:15px;font-weight:950;margin-top:3px}.empty{background:#fff;border:1px dashed #cbd5e1;border-radius:22px;padding:22px;text-align:center;color:var(--muted);font-weight:800}.admin-actions{display:grid;gap:10px}.action-btn{border:1px solid var(--line);background:#fff;border-radius:18px;padding:16px;text-align:left;font-weight:950;color:var(--ink)}.toast{position:fixed;left:14px;right:14px;bottom:16px;background:#0b1f3a;color:#fff;border-radius:16px;padding:13px 14px;font-weight:850;z-index:60;box-shadow:var(--shadow)}
@media(min-width:920px){.sidebar{position:sticky;transform:none;max-width:none;height:100vh;flex:0 0 292px}.mobile-topbar .icon-btn{display:none}.mobile-topbar{padding-left:24px}.content{padding:24px}.card-list.desktop-two{grid-template-columns:repeat(2,1fr)}.card-list.desktop-three{grid-template-columns:repeat(3,1fr)}.hero-title{font-size:31px}.money-xl{font-size:42px}.stat-grid{grid-template-columns:repeat(4,1fr)}.wide{grid-column:auto}.overlay{display:none!important}}


/* Corporate polish overrides */
.login-card,.menu-card,.data-card,.stat-card,.empty,.action-btn{
  border-color:#e4e7ec;
}
.menu-card:hover,.action-btn:hover{
  border-color:#c8d0dc;
  box-shadow:0 14px 30px rgba(16,24,40,.10);
}
.side-link.active{
  background:linear-gradient(90deg,rgba(184,135,45,.18),rgba(255,255,255,.07));
  border-color:rgba(184,135,45,.32);
}
.icon-btn{
  box-shadow:0 8px 18px rgba(16,24,40,.06);
}
.hero-card{
  border:1px solid rgba(255,255,255,.08);
}
.menu-icon{
  border:1px solid rgba(184,135,45,.18);
}
.pill{
  border:1px solid rgba(148,163,184,.18);
}

/* =========================================================
   Premium Corporate UI Pass - Seilana Group Internal Debt
   Focus: large-company look, mobile-first, clean status system
   ========================================================= */
:root{
  --bg:#f4f6f9;
  --surface:#ffffff;
  --ink:#101828;
  --muted:#667085;
  --line:#dfe5ee;
  --line-soft:#edf1f6;
  --navy:#071b33;
  --navy2:#0b2747;
  --navy3:#123a63;
  --gold:#b98a36;
  --gold-soft:#fbf5ea;
  --gold-line:#ead8b8;
  --red:#b42318;
  --red-soft:#fff5f3;
  --red-line:#f2b8b2;
  --green:#067647;
  --green-soft:#ecfdf3;
  --green-line:#abefc6;
  --blue-soft:#eff6ff;
  --shadow:0 18px 44px rgba(16,24,40,.08);
  --shadow-soft:0 8px 22px rgba(16,24,40,.055);
}
html,body{
  background:
    radial-gradient(circle at top right, rgba(184,135,45,.08), transparent 260px),
    linear-gradient(180deg,#f7f8fb 0%,#eef2f7 100%);
  color:var(--ink);
}
.login-card,.menu-card,.data-card,.stat-card,.empty,.action-btn{
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}
.mobile-topbar{
  background:rgba(247,248,251,.94);
  border-bottom:1px solid rgba(223,229,238,.9);
}
.icon-btn{
  border-color:#d8e0ea;
  box-shadow:0 10px 22px rgba(16,24,40,.07);
}
.top-title{color:#111827;letter-spacing:-.25px}.top-sub{color:#5b6778}
.sidebar{
  background:
    radial-gradient(circle at 90% 0%, rgba(184,135,45,.20), transparent 170px),
    linear-gradient(180deg,#06172d 0%,#081d36 48%,#051427 100%);
}
.side-link{
  letter-spacing:-.15px;
}
.side-link.active{
  background:linear-gradient(90deg,rgba(184,135,45,.22),rgba(255,255,255,.075));
  border-color:rgba(234,216,184,.30);
  box-shadow:inset 3px 0 0 var(--gold);
}
.hero-card{
  background:
    radial-gradient(circle at 105% -20%, rgba(184,135,45,.30), transparent 210px),
    linear-gradient(145deg,#071b33 0%,#0b2747 58%,#123a63 100%);
  border:1px solid rgba(255,255,255,.09);
  box-shadow:0 24px 52px rgba(7,27,51,.18);
}
.hero-card:after{background:rgba(255,255,255,.08)}
.eyebrow{color:#f4e7cf;letter-spacing:.13em}.hero-title{text-shadow:0 1px 0 rgba(0,0,0,.18)}
.money-xl{text-shadow:0 2px 0 rgba(0,0,0,.12)}
.stat-card{
  background:linear-gradient(180deg,#fff 0%,#fbfcfe 100%);
  position:relative;
  overflow:hidden;
}
.stat-card:before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--gold),#d9bf8a);opacity:.85;
}
.stat-label,.kv-label{
  color:#667085;
  letter-spacing:.035em;
}
.stat-value,.kv-value,.person-name,.menu-title{
  color:#0b1f3a;
}
.menu-card{
  background:linear-gradient(180deg,#ffffff 0%,#fbfcfe 100%);
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.menu-card:active{transform:scale(.992)}
.menu-icon{
  background:linear-gradient(145deg,#fff8ec,#f4ead8);
  border:1px solid var(--gold-line);
  color:#0b2747;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.chev{color:#98a2b3;font-size:22px}
.section-title{color:#050f1f}.section-note{color:#536174}

/* Premium employee/status cards */
.data-card.person-card{
  position:relative;
  overflow:hidden;
  padding:18px;
  border-radius:24px;
  background:linear-gradient(180deg,#ffffff 0%,#fbfcfe 100%);
}
.data-card.person-card:before{
  content:"";
  position:absolute;
  left:0;top:0;bottom:0;width:5px;
  background:#cbd5e1;
}
.data-card.person-card.safe{
  border-color:#dbe7df;
}
.data-card.person-card.safe:before{
  background:linear-gradient(180deg,#12b76a,#067647);
}
.data-card.person-card.safe:after{
  content:"";
  position:absolute;right:-50px;top:-52px;width:118px;height:118px;border-radius:999px;background:rgba(6,118,71,.065);
}
.data-card.person-card.pending{
  border-color:var(--red-line);
  background:linear-gradient(180deg,#fff 0%,#fffafa 100%);
}
.data-card.person-card.pending:before{
  background:linear-gradient(180deg,#f04438,#b42318);
}
.data-card.person-card.pending:after{
  content:"";
  position:absolute;right:-50px;top:-52px;width:118px;height:118px;border-radius:999px;background:rgba(180,35,24,.08);
}
.data-card.person-card.hold{
  border-color:var(--gold-line);
  background:linear-gradient(180deg,#fff 0%,#fffdf8 100%);
}
.data-card.person-card.hold:before{
  background:linear-gradient(180deg,#d6a74d,#9f6d19);
}
.data-card.person-card.hold:after{
  content:"";
  position:absolute;right:-50px;top:-52px;width:118px;height:118px;border-radius:999px;background:rgba(184,135,45,.10);
}
.person-head,.kv{position:relative;z-index:1}.person-name{font-size:19px;letter-spacing:-.35px}.pill{
  border:1px solid #d0d5dd;
  background:#f8fafc;
  color:#344054;
  box-shadow:0 1px 2px rgba(16,24,40,.04);
}
.pill.ok{background:var(--green-soft);color:var(--green);border-color:var(--green-line)}
.pill.pending{background:var(--red-soft);color:var(--red);border-color:var(--red-line)}
.pill.hold{background:var(--gold-soft);color:#8a5a12;border-color:var(--gold-line)}
.kv{gap:0 12px;margin-top:14px}.kv-item{
  border-top:1px solid var(--line-soft);
  padding:11px 0 10px;
}
.kv-value{font-size:16px;letter-spacing:-.25px}.kv-value.danger{color:var(--red)}.kv-value.success{color:var(--green)}
.progress-wrap{background:#e7edf5}.progress-bar{background:linear-gradient(90deg,#b98a36,#123a63)}
.empty{
  background:linear-gradient(180deg,#ffffff 0%,#fbfcfe 100%);
  border-style:solid;
  color:#536174;
}
.action-btn{
  background:linear-gradient(180deg,#ffffff 0%,#fbfcfe 100%);
  color:#0b1f3a;
}
.action-btn:before{content:"";display:inline-block;width:8px;height:8px;border-radius:999px;background:var(--gold);margin-right:10px;vertical-align:1px}
.toast{background:#071b33;border:1px solid rgba(234,216,184,.18)}
@media(max-width:520px){
  .content{padding:16px 13px 34px}.hero-card{border-radius:27px;padding:22px 22px 24px}.money-xl{font-size:34px}.data-card.person-card{padding:18px 17px}.kv-value{font-size:16px}.stat-value{font-size:21px}.menu-card{padding:16px 17px;border-radius:22px}
}



/* Patch: Back to Home button on detail pages */
.topbar-copy{
  min-width:0;
  flex:1;
}
.back-home-btn{
  margin-left:auto;
  border:1px solid rgba(184,138,54,.28);
  background:linear-gradient(180deg,#fffaf0 0%,#f7ecd9 100%);
  color:#0b2747;
  border-radius:999px;
  padding:10px 13px;
  font-size:12px;
  font-weight:950;
  letter-spacing:-.1px;
  box-shadow:0 8px 18px rgba(16,24,40,.07);
  white-space:nowrap;
}
.back-home-btn:active{
  transform:scale(.98);
}
@media(max-width:380px){
  .back-home-btn{
    padding:9px 11px;
    font-size:11px;
  }
}

/* =========================================================
   Patch Batch 2 - Admin Input Pembayaran Hari
   ========================================================= */
.primary-action{
  border-color:rgba(185,138,54,.35)!important;
  background:linear-gradient(135deg,#fff,#fbf5ea)!important;
}
.primary-action span{display:block;color:var(--navy);font-size:15px}
.primary-action small{display:block;color:var(--muted);font-size:12px;font-weight:750;margin-top:4px;line-height:1.35}
.form-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:24px;
  padding:18px;
  box-shadow:0 16px 36px rgba(16,24,40,.08);
}
.form-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding-bottom:12px;
  margin-bottom:4px;
  border-bottom:1px solid var(--line-soft);
}
.textarea{
  min-height:92px;
  resize:vertical;
  line-height:1.45;
}
.form-summary-note{
  margin-top:14px;
  border:1px solid var(--gold-line);
  background:var(--gold-soft);
  color:#5f481f;
  border-radius:16px;
  padding:12px 13px;
  font-size:12px;
  font-weight:750;
  line-height:1.45;
}
.form-save-btn{
  margin-top:14px;
}
.form-save-btn:disabled,
.primary-btn:disabled{
  opacity:.65;
  cursor:not-allowed;
}
select.input{
  appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,#667085 50%),linear-gradient(135deg,#667085 50%,transparent 50%);
  background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 13px) calc(50% - 3px);
  background-size:5px 5px,5px 5px;
  background-repeat:no-repeat;
}


/* =========================================================
   Patch Batch 3 - Status Transfer Tanggungan Hari
   ========================================================= */
.transfer-head{
  align-items:flex-start;
}
.filter-select{
  max-width:145px;
  margin-top:0;
}
.transfer-total-box{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:12px 0;
}
.transfer-mini-stat{
  background:linear-gradient(180deg,#fff 0%,#fbfcfe 100%);
  border:1px solid var(--line-soft);
  border-radius:16px;
  padding:12px;
}
.transfer-mini-stat span{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.transfer-mini-stat b{
  display:block;
  color:var(--navy);
  font-size:17px;
  margin-top:4px;
  letter-spacing:-.2px;
}
.transfer-toolbar{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:10px 0 14px;
}
.mini-action-btn,.mini-save-btn{
  border:1px solid var(--line);
  background:#fff;
  color:var(--navy);
  border-radius:14px;
  padding:11px 12px;
  font-weight:950;
  font-size:12px;
  box-shadow:0 8px 18px rgba(16,24,40,.045);
}
.mini-action-btn.strong,.mini-save-btn{
  border-color:rgba(185,138,54,.35);
  background:linear-gradient(180deg,#fffaf2 0%,#f7ecd9 100%);
}
.transfer-card{
  margin-bottom:0;
}
.transfer-amount-row{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
  margin-top:14px;
  position:relative;
  z-index:1;
}
.transfer-amount-row>div{
  border:1px solid var(--line-soft);
  background:#fff;
  border-radius:16px;
  padding:12px;
}
.transfer-amount-row span{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.transfer-amount-row b{
  display:block;
  color:var(--navy);
  font-size:17px;
  margin-top:4px;
}
.transfer-amount-row small{
  display:block;
  color:var(--muted);
  font-size:12px;
  margin-top:3px;
  line-height:1.35;
}
.transfer-edit-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:12px;
  position:relative;
  z-index:1;
}
.compact-input{
  padding:12px 12px;
  border-radius:14px;
  font-size:14px;
}
.compact-textarea{
  min-height:72px;
  font-size:14px;
}
.transfer-card-foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-top:12px;
  position:relative;
  z-index:1;
}
.proof-link{
  color:var(--navy3);
  font-size:12px;
  font-weight:900;
  text-decoration:none;
}
.muted-small{
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}
@media(min-width:720px){
  .transfer-amount-row{grid-template-columns:1fr 1fr;}
}
@media(max-width:390px){
  .transfer-toolbar,.transfer-edit-grid,.transfer-total-box{grid-template-columns:1fr;}
  .filter-select{max-width:none;width:100%;}
}

/* Batch 4 - Hari Payment History */
.history-toolbar{
  display:grid;
  grid-template-columns:1fr 150px auto;
  gap:10px;
  margin-bottom:12px;
}
.history-total-box{
  margin-bottom:12px;
}
.history-card{
  border-left:4px solid rgba(19,78,74,.62);
}
.history-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  position:relative;
  z-index:1;
}
.history-id{
  color:var(--navy);
  font-size:18px;
  font-weight:950;
  letter-spacing:-.02em;
}
.history-amount{
  color:var(--navy);
  font-size:18px;
  font-weight:950;
  white-space:nowrap;
  padding:8px 11px;
  border-radius:14px;
  background:linear-gradient(180deg,#fffaf2 0%,#f6ecd9 100%);
  border:1px solid rgba(185,138,54,.22);
}
.history-detail-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:14px;
  position:relative;
  z-index:1;
}
.history-detail-grid>div{
  border:1px solid var(--line-soft);
  background:#fff;
  border-radius:16px;
  padding:11px 12px;
}
.history-detail-grid>div.wide{
  grid-column:1 / -1;
}
.history-detail-grid span{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.history-detail-grid b{
  display:block;
  color:var(--navy);
  font-size:13px;
  line-height:1.45;
  margin-top:4px;
  word-break:break-word;
}
.history-proof-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin-top:12px;
  position:relative;
  z-index:1;
}
.proof-chip{
  display:inline-flex;
  align-items:center;
  max-width:100%;
  padding:8px 10px;
  border-radius:999px;
  background:#eef4ff;
  border:1px solid rgba(37,99,235,.15);
  color:#1e3a8a;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
@media(max-width:560px){
  .history-toolbar{
    grid-template-columns:1fr;
  }
  .history-detail-grid{
    grid-template-columns:1fr;
  }
  .history-head{
    flex-direction:column;
  }
  .history-amount{
    width:100%;
    text-align:center;
  }
}

/* Batch 5 - Riwayat Pembagian Uang Hari */
.distribution-toolbar{
  grid-template-columns:1fr 150px auto;
}
.distribution-history-list{
  gap:12px;
}
.distribution-group-card{
  position:relative;
  overflow:hidden;
  border-left:4px solid var(--green);
}
.distribution-group-card.pending{
  border-left-color:var(--red);
}
.distribution-group-head{
  padding-bottom:12px;
  border-bottom:1px solid var(--line-soft);
}
.distribution-summary-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-top:12px;
  position:relative;
  z-index:1;
}
.distribution-summary-row>div{
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:15px;
  padding:10px;
}
.distribution-summary-row span{
  display:block;
  color:var(--muted);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.distribution-summary-row b{
  display:block;
  color:var(--navy);
  font-size:14px;
  margin-top:4px;
  letter-spacing:-.15px;
}
.success-text{color:var(--green)!important;}
.danger-text{color:var(--red)!important;}
.distribution-diff-note{
  margin-top:10px;
  padding:10px 11px;
  border-radius:14px;
  background:var(--gold-soft);
  border:1px solid var(--gold-line);
  color:#6b4b17;
  font-size:12px;
  font-weight:800;
}
.distribution-recipient-list{
  display:grid;
  gap:8px;
  margin-top:12px;
  position:relative;
  z-index:1;
}
.distribution-recipient-row{
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:18px;
  padding:12px;
}
.distribution-recipient-main{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
}
.recipient-title{
  color:var(--navy);
  font-size:15px;
  font-weight:950;
  letter-spacing:-.15px;
}
.recipient-sub{
  color:var(--muted);
  font-size:11px;
  font-weight:750;
  margin-top:3px;
  line-height:1.35;
}
.recipient-amount{
  color:var(--navy);
  font-size:15px;
  font-weight:950;
  white-space:nowrap;
}
.distribution-recipient-meta{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  align-items:center;
  margin-top:9px;
}
.small-proof{
  padding:6px 8px;
  font-size:11px;
}
.distribution-note{
  margin-top:9px;
  padding:10px 11px;
  border-radius:14px;
  background:#f8fafc;
  border:1px solid var(--line-soft);
  color:#475467;
  font-size:12px;
  font-weight:750;
  line-height:1.45;
}
@media(max-width:560px){
  .distribution-toolbar,
  .distribution-summary-row{
    grid-template-columns:1fr;
  }
  .distribution-recipient-main{
    flex-direction:column;
  }
  .recipient-amount{
    width:100%;
    padding:8px 10px;
    border-radius:12px;
    background:linear-gradient(180deg,#fffaf2 0%,#f7ecd9 100%);
    border:1px solid rgba(185,138,54,.20);
    text-align:center;
  }
}

/* =========================================================
   Patch Batch 5.1 - Compact 4 Card Penerima Hak
   ========================================================= */
.compact-recipient-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:7px;
}
.recipient-mini-card{
  position:relative;
  min-height:92px;
  padding:9px 7px 8px;
  border:1px solid #dfe7f1;
  border-radius:16px;
  background:linear-gradient(180deg,#fff 0%,#fbfcfe 100%);
  box-shadow:0 8px 20px rgba(16,24,40,.045);
  overflow:hidden;
  text-align:left;
  color:var(--ink);
  cursor:pointer;
}
.recipient-mini-card:before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:3px;
  background:#12b76a;
}
.recipient-mini-card.pending{
  border-color:var(--red-line);
}
.recipient-mini-card.pending:before{
  background:#f04438;
}
.recipient-mini-card.hold{
  border-color:var(--gold-line);
}
.recipient-mini-card.hold:before{
  background:var(--gold);
}
.recipient-mini-card.active{
  border-color:#cda85d;
  background:linear-gradient(180deg,#fff 0%,#fffaf0 100%);
  box-shadow:0 12px 24px rgba(184,138,54,.16);
}
.recipient-mini-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:3px;
  padding-left:3px;
  min-height:25px;
}
.recipient-mini-name{
  min-width:0;
  font-size:12px;
  font-weight:950;
  line-height:1.05;
  letter-spacing:-.2px;
  color:#071b33;
  word-break:break-word;
}
.recipient-mini-status{
  display:inline-flex;
  flex-shrink:0;
  border-radius:999px;
  padding:3px 5px;
  font-size:8px;
  line-height:1;
  font-weight:950;
  border:1px solid #d0d5dd;
  background:#f8fafc;
  color:#344054;
}
.recipient-mini-status.ok{
  background:var(--green-soft);
  color:var(--green);
  border-color:var(--green-line);
}
.recipient-mini-status.pending{
  background:var(--red-soft);
  color:var(--red);
  border-color:var(--red-line);
}
.recipient-mini-status.hold{
  background:var(--gold-soft);
  color:#8a5a12;
  border-color:var(--gold-line);
}
.recipient-mini-label{
  margin:8px 0 0 3px;
  font-size:8.5px;
  color:#77849a;
  font-weight:950;
  line-height:1;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.recipient-mini-amount{
  margin:4px 0 0 3px;
  font-size:12px;
  line-height:1.05;
  color:#071b33;
  font-weight:950;
  letter-spacing:-.28px;
  white-space:nowrap;
}
.recipient-mini-pct{
  margin:7px 0 0 3px;
  font-size:9.5px;
  color:#607089;
  font-weight:850;
  line-height:1.1;
}
.compact-recipient-detail{
  margin-top:10px;
}
.recipient-detail-card{
  margin-top:0;
}
.compact-detail-head .person-name{
  font-size:17px;
}
.compact-kv{
  margin-top:10px;
}
.compact-kv .kv-item{
  padding:9px 0;
}
.compact-kv .kv-label{
  font-size:9.5px;
}
.compact-kv .kv-value{
  font-size:14px;
}
@media(max-width:390px){
  .content{padding-left:9px;padding-right:9px;}
  .compact-recipient-grid{gap:6px;}
  .recipient-mini-card{min-height:88px;padding:8px 5px;border-radius:15px;}
  .recipient-mini-name{font-size:11px;}
  .recipient-mini-status{font-size:7.5px;padding:3px 4px;}
  .recipient-mini-label{font-size:8px;}
  .recipient-mini-amount{font-size:10.8px;letter-spacing:-.35px;}
  .recipient-mini-pct{font-size:8.6px;}
}


/* Batch 5.2 - Compact Riwayat Pembagian Hari */
.distribution-history-list{
  display:block;
}
.distribution-compact-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:7px;
  margin-top:2px;
}
.distribution-mini-card{
  position:relative;
  min-height:92px;
  padding:9px 7px 8px;
  border-radius:16px;
  background:#fff;
  border:1px solid #dfe7f1;
  box-shadow:0 8px 20px rgba(15,23,42,.045);
  overflow:hidden;
  text-align:left;
  cursor:pointer;
}
.distribution-mini-card:before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:3px;
  background:#0f8a50;
}
.distribution-mini-card.pending:before{background:#b42318;}
.distribution-mini-card.active{
  border-color:#cda85d;
  box-shadow:0 12px 24px rgba(199,154,59,.16);
  background:linear-gradient(180deg,#fff,#fffaf0);
}
.distribution-mini-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:4px;
  padding-left:3px;
}
.distribution-mini-id{
  font-size:12px;
  font-weight:900;
  line-height:1.05;
  color:#071b33;
  letter-spacing:-.2px;
}
.distribution-mini-status{
  display:inline-flex;
  flex-shrink:0;
  border-radius:999px;
  padding:3px 5px;
  font-size:8.8px;
  font-weight:900;
  line-height:1;
  border:1px solid #d8e4f0;
}
.distribution-mini-status.ok{
  color:#087443;
  background:#e8f8ef;
  border-color:#bce9cf;
}
.distribution-mini-status.pending{
  color:#b42318;
  background:#fff0ee;
  border-color:#ffc7c1;
}
.distribution-mini-date{
  margin:8px 0 0 3px;
  font-size:9.5px;
  color:#607089;
  font-weight:800;
  line-height:1.15;
}
.distribution-mini-amount{
  margin:5px 0 0 3px;
  font-size:13px;
  line-height:1.05;
  color:#071b33;
  font-weight:900;
  letter-spacing:-.28px;
}
.distribution-mini-sub{
  margin:6px 0 0 3px;
  font-size:9.5px;
  color:#77849a;
  font-weight:900;
}
.distribution-selected-detail{
  margin-top:10px;
}
.distribution-selected-detail .distribution-group-card{
  margin-top:0;
}
.distribution-selected-detail .history-head{
  align-items:flex-start;
}
.distribution-selected-detail .history-amount{
  font-size:17px;
  padding:10px 13px;
}
.distribution-selected-detail .distribution-summary-row{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.distribution-selected-detail .distribution-recipient-row{
  padding:10px 11px;
}
.distribution-selected-detail .recipient-title{
  font-size:14px;
}
.distribution-selected-detail .recipient-amount{
  font-size:15px;
  padding:9px 12px;
}
@media(max-width:390px){
  .distribution-compact-grid{gap:6px;}
  .distribution-mini-card{padding:8px 6px;min-height:88px;}
  .distribution-mini-id{font-size:11px;}
  .distribution-mini-status{font-size:8px;padding:3px 4px;}
  .distribution-mini-date{font-size:9px;}
  .distribution-mini-amount{font-size:12px;}
  .distribution-selected-detail .distribution-summary-row{grid-template-columns:1fr;}
}

/* Batch 5.2 Fix - True compact Riwayat Pembagian Hari */
.distribution-selected-detail.hidden{
  display:none !important;
}
.distribution-detail-card{
  margin-top:10px;
  background:#fff;
  border:1px solid #dfe7f1;
  border-radius:20px;
  box-shadow:0 10px 26px rgba(15,23,42,.06);
  overflow:hidden;
  border-left:4px solid #0f8a50;
}
.distribution-detail-card.pending{
  border-left-color:#b42318;
}
.distribution-detail-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:8px;
  padding:12px 13px 8px;
  background:linear-gradient(135deg,#fff 0%,#f7fbff 100%);
}
.distribution-detail-id{
  font-size:16px;
  font-weight:900;
  color:#071b33;
  letter-spacing:-.35px;
}
.distribution-detail-sub{
  margin-top:3px;
  font-size:11px;
  color:#607089;
  font-weight:800;
  line-height:1.25;
}
.detail-close-btn{
  border:1px solid #e2c992;
  background:#fff8eb;
  color:#132238;
  border-radius:999px;
  padding:7px 10px;
  font-size:10px;
  font-weight:900;
  cursor:pointer;
  flex-shrink:0;
}
.distribution-detail-total{
  margin:0 13px 10px;
  padding:10px 12px;
  border-radius:14px;
  background:#fff6e6;
  border:1px solid #ecd19b;
  color:#071b33;
  font-size:18px;
  font-weight:900;
  text-align:center;
  letter-spacing:-.45px;
}
.distribution-mini-summary{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:7px;
  padding:0 13px 10px;
}
.distribution-mini-summary>div{
  border:1px solid #e5edf5;
  border-radius:13px;
  padding:8px 9px;
  background:#fff;
}
.distribution-mini-summary span{
  display:block;
  font-size:9px;
  color:#607089;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.distribution-mini-summary b{
  display:block;
  margin-top:4px;
  font-size:13px;
  color:#071b33;
  font-weight:900;
  letter-spacing:-.25px;
}
.distribution-diff-note.compact{
  margin:0 13px 10px;
  padding:8px 10px;
  border-radius:13px;
  background:#fff8eb;
  border:1px solid #ecd19b;
  color:#805000;
  font-size:11px;
  font-weight:900;
}
.distribution-compact-recipient-list{
  display:grid;
  gap:7px;
  padding:0 13px 13px;
}
.distribution-compact-recipient{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  border:1px solid #e5edf5;
  border-radius:14px;
  padding:9px 10px;
  background:#fff;
}
.distribution-compact-recipient.done{
  background:linear-gradient(90deg,#fff 0%,#f5fff9 100%);
}
.distribution-compact-recipient.pending{
  background:linear-gradient(90deg,#fff 0%,#fff5f4 100%);
}
.dist-rec-name{
  font-size:13px;
  font-weight:900;
  color:#071b33;
  line-height:1.1;
}
.dist-rec-sub{
  margin-top:3px;
  font-size:10px;
  color:#607089;
  font-weight:800;
  line-height:1.2;
}
.dist-rec-right{
  text-align:right;
  min-width:92px;
}
.dist-rec-amount{
  font-size:13px;
  font-weight:900;
  color:#071b33;
  letter-spacing:-.25px;
}
.dist-rec-meta{
  margin-top:4px;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:4px;
  flex-wrap:wrap;
  font-size:9px;
  color:#607089;
  font-weight:900;
}
.mini-status{
  display:inline-flex;
  border-radius:999px;
  padding:3px 5px;
  font-size:8.5px;
  line-height:1;
  font-weight:900;
  border:1px solid #d8e4f0;
}
.mini-status.ok{
  color:#087443;
  background:#e8f8ef;
  border-color:#bce9cf;
}
.mini-status.pending{
  color:#b42318;
  background:#fff0ee;
  border-color:#ffc7c1;
}
.mini-status.hold{
  color:#805000;
  background:#fff8eb;
  border-color:#ecd19b;
}
.mini-proof-link{
  color:#183b7a;
  background:#edf4ff;
  border:1px solid #c9daf7;
  text-decoration:none;
  border-radius:999px;
  padding:3px 5px;
  font-size:8.5px;
  font-weight:900;
}
.dist-rec-note{
  grid-column:1/-1;
  margin-top:1px;
  padding:7px 8px;
  border-radius:11px;
  background:#f8fafc;
  border:1px solid #e5edf5;
  color:#44546a;
  font-size:10.5px;
  font-weight:800;
  line-height:1.35;
}
@media(max-width:390px){
  .distribution-mini-summary{grid-template-columns:1fr;}
  .distribution-compact-recipient{grid-template-columns:1fr;}
  .dist-rec-right{text-align:left;min-width:0;}
  .dist-rec-meta{justify-content:flex-start;}
}

/* Batch 5.3 - Compact payment history + floating proof preview */
.payment-compact-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:7px;
  margin-top:2px;
}
.payment-mini-card{
  position:relative;
  min-height:88px;
  padding:9px 7px 8px;
  border-radius:16px;
  background:#fff;
  border:1px solid #dfe7f1;
  box-shadow:0 8px 20px rgba(15,23,42,.045);
  overflow:hidden;
  text-align:left;
  cursor:pointer;
}
.payment-mini-card:before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:3px;
  background:#c79a3b;
}
.payment-mini-card.no-proof:before{background:#94a3b8;}
.payment-mini-card.active{
  border-color:#cda85d;
  box-shadow:0 12px 24px rgba(199,154,59,.16);
  background:linear-gradient(180deg,#fff,#fffaf0);
}
.payment-mini-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:4px;
  padding-left:3px;
}
.payment-mini-id{
  font-size:12px;
  font-weight:900;
  line-height:1.05;
  color:#071b33;
  letter-spacing:-.2px;
}
.payment-mini-proof{
  display:inline-flex;
  flex-shrink:0;
  border-radius:999px;
  padding:3px 5px;
  font-size:8.5px;
  font-weight:900;
  line-height:1;
  border:1px solid #d8e4f0;
}
.payment-mini-proof.ok{
  color:#805000;
  background:#fff8eb;
  border-color:#ecd19b;
}
.payment-mini-proof.muted{
  color:#64748b;
  background:#f8fafc;
  border-color:#e2e8f0;
}
.payment-mini-date{
  margin:8px 0 0 3px;
  font-size:9.5px;
  color:#607089;
  font-weight:800;
  line-height:1.15;
}
.payment-mini-amount{
  margin:6px 0 0 3px;
  font-size:13px;
  line-height:1.05;
  color:#071b33;
  font-weight:900;
  letter-spacing:-.28px;
}
.payment-selected-detail.hidden{display:none !important;}
.payment-selected-detail{margin-top:10px;}
.payment-detail-card{
  margin-top:10px;
  background:#fff;
  border:1px solid #dfe7f1;
  border-radius:20px;
  box-shadow:0 10px 26px rgba(15,23,42,.06);
  overflow:hidden;
  border-left:4px solid #c79a3b;
}
.payment-detail-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:8px;
  padding:12px 13px 8px;
  background:linear-gradient(135deg,#fff 0%,#fffaf0 100%);
}
.payment-detail-id{
  font-size:16px;
  font-weight:900;
  color:#071b33;
  letter-spacing:-.35px;
}
.payment-detail-sub{
  margin-top:3px;
  font-size:11px;
  color:#607089;
  font-weight:800;
  line-height:1.25;
}
.payment-detail-total{
  margin:0 13px 10px;
  padding:10px 12px;
  border-radius:14px;
  background:#fff6e6;
  border:1px solid #ecd19b;
  color:#071b33;
  font-size:18px;
  font-weight:900;
  text-align:center;
  letter-spacing:-.45px;
}
.payment-detail-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:7px;
  padding:0 13px 10px;
}
.payment-detail-grid>div{
  border:1px solid #e5edf5;
  border-radius:13px;
  padding:8px 9px;
  background:#fff;
}
.payment-detail-grid span{
  display:block;
  font-size:9px;
  color:#607089;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.payment-detail-grid b{
  display:block;
  margin-top:4px;
  font-size:12px;
  color:#071b33;
  font-weight:900;
  line-height:1.35;
  word-break:break-word;
}
.proof-action-row{
  padding:0 13px 13px;
}
.proof-preview-btn{
  width:100%;
  border:1px solid #c9daf7;
  background:#edf4ff;
  color:#183b7a;
  border-radius:14px;
  padding:10px 12px;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
}
.mini-proof-link{
  appearance:none;
  border:1px solid #c9daf7;
  cursor:pointer;
}
.proof-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:flex-end;
  justify-content:center;
}
.proof-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(8,18,34,.58);
  backdrop-filter:blur(6px);
}
.proof-modal-card{
  position:relative;
  width:min(520px, calc(100vw - 18px));
  max-height:88vh;
  margin:0 auto 10px;
  background:#fff;
  border:1px solid rgba(255,255,255,.4);
  border-radius:24px;
  box-shadow:0 24px 70px rgba(0,0,0,.28);
  overflow:hidden;
}
.proof-modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  padding:14px 15px;
  background:linear-gradient(135deg,#0b2342 0%,#123760 100%);
  color:#fff;
}
.proof-modal-head h3{
  margin:0;
  font-size:16px;
  font-weight:900;
  letter-spacing:-.25px;
}
.proof-modal-head p{
  margin:3px 0 0;
  font-size:11px;
  color:#dbeafe;
  font-weight:800;
}
.proof-modal-close{
  width:34px;
  height:34px;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(255,255,255,.14);
  color:#fff;
  border-radius:999px;
  font-size:24px;
  line-height:1;
  font-weight:700;
  cursor:pointer;
}
.proof-modal-body{
  max-height:calc(88vh - 70px);
  overflow:auto;
  padding:12px;
  background:#f4f6fa;
}
.proof-figure{
  margin:0 0 12px;
  padding:10px;
  border:1px solid #dfe7f1;
  border-radius:18px;
  background:#fff;
}
.proof-figure:last-child{margin-bottom:0;}
.proof-figure img{
  display:block;
  width:100%;
  max-height:65vh;
  object-fit:contain;
  border-radius:14px;
  background:#f8fafc;
  border:1px solid #e5edf5;
}
.proof-figure figcaption{
  margin-top:8px;
  color:#44546a;
  font-size:11px;
  font-weight:900;
  word-break:break-word;
}
.proof-img-error{
  padding:16px;
  border-radius:14px;
  background:#fff8eb;
  border:1px solid #ecd19b;
  color:#805000;
  font-size:12px;
  font-weight:900;
  line-height:1.35;
}
@media(max-width:390px){
  .payment-compact-grid{gap:6px;}
  .payment-mini-card{padding:8px 6px;min-height:84px;}
  .payment-mini-id{font-size:11px;}
  .payment-mini-proof{font-size:8px;padding:3px 4px;}
  .payment-mini-date{font-size:9px;}
  .payment-mini-amount{font-size:12px;}
  .payment-detail-grid{grid-template-columns:1fr;}
  .proof-modal-card{width:calc(100vw - 12px);margin-bottom:6px;border-radius:22px;}
}

/* =========================================================
   Batch 6 - Riwayat Pengiriman Uang per Penerima
   ========================================================= */
.transfer-history-toolbar{
  grid-template-columns:1fr 130px 130px auto;
}
.transfer-history-list{gap:10px;}
.transfer-recipient-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:7px;
}
.transfer-recipient-mini-card{
  position:relative;
  min-height:94px;
  padding:9px 7px 8px;
  border:1px solid #dfe7f1;
  border-radius:16px;
  background:linear-gradient(180deg,#fff 0%,#fbfcfe 100%);
  box-shadow:0 8px 20px rgba(16,24,40,.045);
  overflow:hidden;
  text-align:left;
  color:var(--ink);
  cursor:pointer;
}
.transfer-recipient-mini-card:before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:3px;
  background:#12b76a;
}
.transfer-recipient-mini-card.pending{
  border-color:var(--red-line);
}
.transfer-recipient-mini-card.pending:before{
  background:#f04438;
}
.transfer-recipient-mini-card.active{
  border-color:#cda85d;
  background:linear-gradient(180deg,#fff 0%,#fffaf0 100%);
  box-shadow:0 12px 24px rgba(184,138,54,.16);
}
.transfer-recipient-mini-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:3px;
  padding-left:3px;
  min-height:25px;
}
.transfer-recipient-mini-name{
  min-width:0;
  font-size:12px;
  font-weight:950;
  line-height:1.05;
  letter-spacing:-.2px;
  color:#071b33;
  word-break:break-word;
}
.transfer-recipient-mini-status{
  display:inline-flex;
  flex-shrink:0;
  border-radius:999px;
  padding:3px 5px;
  font-size:8px;
  line-height:1;
  font-weight:950;
  border:1px solid #d0d5dd;
  background:#f8fafc;
  color:#344054;
}
.transfer-recipient-mini-status.ok{
  background:var(--green-soft);
  color:var(--green);
  border-color:var(--green-line);
}
.transfer-recipient-mini-status.pending{
  background:var(--red-soft);
  color:var(--red);
  border-color:var(--red-line);
}
.transfer-recipient-mini-label{
  margin:8px 0 0 3px;
  font-size:8.5px;
  color:#77849a;
  font-weight:950;
  line-height:1;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.transfer-recipient-mini-amount{
  margin:4px 0 0 3px;
  font-size:12px;
  line-height:1.05;
  color:#071b33;
  font-weight:950;
  letter-spacing:-.28px;
  white-space:nowrap;
}
.transfer-recipient-mini-sub{
  margin:7px 0 0 3px;
  font-size:9px;
  color:#607089;
  font-weight:800;
  line-height:1.15;
}
.transfer-recipient-selected-detail.hidden{display:none!important;}
.transfer-recipient-selected-detail{margin-top:10px;}
.transfer-recipient-detail-card{
  margin-top:10px;
  background:#fff;
  border:1px solid #dfe7f1;
  border-left:4px solid #12b76a;
  border-radius:20px;
  box-shadow:0 10px 26px rgba(15,23,42,.06);
  overflow:hidden;
}
.transfer-recipient-detail-card.pending{border-left-color:#f04438;}
.transfer-recipient-detail-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:8px;
  padding:12px 13px 8px;
  background:linear-gradient(135deg,#fff 0%,#f6fff9 100%);
}
.transfer-recipient-detail-card.pending .transfer-recipient-detail-head{
  background:linear-gradient(135deg,#fff 0%,#fff6f5 100%);
}
.transfer-recipient-detail-name{
  font-size:17px;
  font-weight:950;
  color:#071b33;
  letter-spacing:-.35px;
}
.transfer-recipient-detail-sub{
  margin-top:3px;
  color:#607089;
  font-size:11px;
  font-weight:800;
  line-height:1.25;
}
.transfer-recipient-summary{
  margin:0 12px 10px;
}
.transfer-history-row-list{
  display:grid;
  gap:7px;
  padding:0 12px 12px;
}
.transfer-history-row{
  border:1px solid #e5edf5;
  border-radius:15px;
  padding:9px 10px;
  background:#fff;
}
.transfer-history-row.done{background:linear-gradient(180deg,#fff 0%,#f8fffb 100%);}
.transfer-history-row.pending{background:linear-gradient(180deg,#fff 0%,#fff8f7 100%);}
.transfer-history-row.hold{background:linear-gradient(180deg,#fff 0%,#fffaf0 100%);}
.transfer-history-row-main{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
}
.transfer-history-pay{
  color:#071b33;
  font-size:13px;
  font-weight:950;
  letter-spacing:-.2px;
}
.transfer-history-sub{
  margin-top:3px;
  color:#607089;
  font-size:10px;
  font-weight:800;
  line-height:1.25;
}
.transfer-history-amount{
  color:#071b33;
  font-size:13px;
  font-weight:950;
  white-space:nowrap;
  letter-spacing:-.2px;
}
.transfer-history-meta{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:6px;
  margin-top:7px;
}
.transfer-history-note{
  margin-top:7px;
  padding:8px 9px;
  border-radius:12px;
  background:#f8fafc;
  border:1px solid #edf1f6;
  color:#475467;
  font-size:11px;
  font-weight:800;
  line-height:1.35;
}
@media(max-width:560px){
  .transfer-history-toolbar{
    grid-template-columns:1fr;
  }
}
@media(max-width:390px){
  .transfer-recipient-grid{gap:6px;}
  .transfer-recipient-mini-card{padding:8px 6px;min-height:90px;}
  .transfer-recipient-mini-name{font-size:11px;}
  .transfer-recipient-mini-status{font-size:7.8px;padding:3px 4px;}
  .transfer-recipient-mini-amount{font-size:11.5px;}
  .transfer-recipient-mini-sub{font-size:8.5px;}
}

/* Batch 6.1 - Tanggungan Hari section launcher */
.hari-launcher-section {
  margin-top: 14px;
}

.hari-section-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 9px;
}

.hari-section-card {
  width: 100%;
  border: 1px solid rgba(148, 163, 184, 0.26);
  background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
  border-radius: 20px;
  padding: 12px 12px;
  display: grid;
  grid-template-columns: 42px 1fr 24px;
  align-items: center;
  gap: 10px;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.055);
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.hari-section-card:active {
  transform: scale(.99);
}

.hari-section-card.active {
  border-color: rgba(199, 154, 59, 0.55);
  background: linear-gradient(135deg, #ffffff 0%, #fff8eb 100%);
  box-shadow: 0 14px 32px rgba(199, 154, 59, 0.16);
}

.hari-section-icon {
  width: 42px;
  height: 42px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: #eef3f8;
  border: 1px solid rgba(15, 35, 66, 0.08);
  font-size: 18px;
}

.hari-section-card.active .hari-section-icon {
  background: #fff2d6;
  border-color: rgba(199, 154, 59, .28);
}

.hari-section-copy {
  min-width: 0;
}

.hari-section-title {
  color: #0b2342;
  font-size: 14px;
  line-height: 1.12;
  font-weight: 900;
  letter-spacing: -.25px;
}

.hari-section-desc {
  margin-top: 3px;
  color: #66758b;
  font-size: 11px;
  line-height: 1.3;
  font-weight: 700;
}

.hari-section-meta {
  display: inline-flex;
  margin-top: 7px;
  padding: 4px 7px;
  border-radius: 999px;
  background: rgba(15, 35, 66, 0.06);
  color: #334155;
  font-size: 10px;
  font-weight: 900;
}

.hari-section-card.active .hari-section-meta {
  background: rgba(199, 154, 59, 0.16);
  color: #6d4b0f;
}

.hari-section-arrow {
  color: #94a3b8;
  font-size: 22px;
  font-weight: 900;
  line-height: 1;
  text-align: center;
}

.hari-section-card.active .hari-section-arrow {
  color: #9a6b16;
  font-size: 18px;
}

.active-data-section {
  border: 1px solid rgba(148, 163, 184, 0.22);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.055);
}

.compact-empty-guide {
  margin-top: 10px;
}

.empty-guide-card {
  border: 1px dashed rgba(148, 163, 184, 0.45);
  background: rgba(255, 255, 255, 0.64);
  border-radius: 18px;
  padding: 13px 14px;
  display: grid;
  gap: 4px;
}

.empty-guide-card b {
  color: #0b2342;
  font-size: 13px;
  font-weight: 900;
}

.empty-guide-card span {
  color: #66758b;
  font-size: 11px;
  line-height: 1.35;
  font-weight: 700;
}

.compact-section-head .mini-action-btn {
  flex-shrink: 0;
}

@media (min-width: 500px) {
  .hari-section-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Batch 7 - upload bukti dari web */
.file-input {
  padding: 10px 11px;
  cursor: pointer;
  background: #fff;
}
.file-input::file-selector-button {
  border: 0;
  border-radius: 12px;
  padding: 8px 10px;
  margin-right: 10px;
  background: #102a4c;
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  cursor: pointer;
}
.upload-help {
  margin: 6px 0 12px;
  font-size: 11px;
  line-height: 1.35;
  color: #64748b;
  font-weight: 700;
}
.compact-file-input {
  padding: 8px;
  font-size: 11px;
}
.compact-file-input::file-selector-button {
  padding: 7px 9px;
  font-size: 10px;
  border-radius: 10px;
}
.compact-upload-help {
  margin: 5px 0 9px;
  font-size: 10.5px;
}
.compact-proof-btn {
  padding: 7px 9px;
  font-size: 10.5px;
  border-radius: 999px;
}
.proof-figure img[src^="uploads/"] {
  background: #f8fafc;
}
@media (max-width: 420px) {
  .file-input::file-selector-button {
    display: block;
    width: 100%;
    margin: 0 0 8px 0;
  }
}

/* Batch 8 - Hutang Umum Dashboard */
.compact-section-box {
  animation: fadeInUp .18s ease-out;
}

.compact-4grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 7px;
}

.mini-entity-card {
  position: relative;
  min-height: 94px;
  width: 100%;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 16px;
  padding: 9px 7px 8px;
  text-align: left;
  box-shadow: 0 8px 20px rgba(15, 23, 42, .045);
  overflow: hidden;
  cursor: pointer;
}

.mini-entity-card:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--green);
}

.mini-entity-card.pending:before { background: var(--red); }
.mini-entity-card.hold:before { background: var(--gold); }

.mini-entity-card.active {
  border-color: rgba(199, 154, 59, .75);
  background: linear-gradient(180deg, #fff, #fffaf0);
  box-shadow: 0 12px 24px rgba(199, 154, 59, .16);
}

.mini-entity-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 4px;
  padding-left: 3px;
  min-height: 26px;
}

.mini-entity-top span {
  color: var(--navy);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -.2px;
  word-break: break-word;
}

.mini-entity-top em {
  flex-shrink: 0;
  border-radius: 999px;
  padding: 3px 5px;
  background: rgba(16, 185, 129, .10);
  border: 1px solid rgba(16, 185, 129, .22);
  color: #087443;
  font-size: 8px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
}

.mini-entity-card.pending .mini-entity-top em {
  background: rgba(239, 68, 68, .10);
  border-color: rgba(239, 68, 68, .20);
  color: #b42318;
}

.mini-entity-label {
  margin: 8px 0 0 3px;
  color: var(--muted);
  font-size: 8.5px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.mini-entity-amount {
  margin: 3px 0 0 3px;
  color: var(--navy);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: -.25px;
  line-height: 1.05;
}

.mini-entity-foot {
  margin: 7px 0 0 3px;
  color: #607089;
  font-size: 9.5px;
  font-weight: 800;
  line-height: 1.1;
}

.compact-empty-hint {
  margin-top: 10px;
  padding: 12px;
  border: 1px dashed rgba(100, 116, 139, .30);
  border-radius: 16px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  background: rgba(255,255,255,.72);
}

.general-detail-card {
  margin-top: 10px;
}

.selected-metric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 12px;
}

.selected-metric-grid > div {
  padding: 10px;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 14px;
  background: rgba(248, 250, 252, .86);
}

.selected-metric-grid span {
  display: block;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.selected-metric-grid b {
  display: block;
  margin-top: 5px;
  color: var(--navy);
  font-size: 14px;
  font-weight: 900;
  letter-spacing: -.25px;
}

.compact-row-list {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.compact-history-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 11px;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 15px;
  background: #fff;
}

.compact-history-row > div:first-child b,
.compact-history-row > div:last-child strong {
  display: block;
  color: var(--navy);
  font-size: 12px;
  font-weight: 900;
}

.compact-history-row > div:first-child span,
.compact-history-row > div:last-child em {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 10.5px;
  font-style: normal;
  font-weight: 800;
}

.compact-history-row > div:last-child {
  text-align: right;
  flex-shrink: 0;
}

.filter-compact-row {
  display: grid;
  grid-template-columns: 1fr 150px;
  gap: 8px;
  margin-bottom: 10px;
}

.detail-note-box {
  margin-top: 10px;
  padding: 10px 11px;
  border-radius: 14px;
  background: rgba(199, 154, 59, .10);
  border: 1px solid rgba(199, 154, 59, .22);
  color: #5d4512;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.4;
}

.slim-card {
  padding: 13px;
}

@media (max-width: 390px) {
  .compact-4grid { gap: 6px; }
  .mini-entity-card { min-height: 90px; padding: 8px 6px; }
  .mini-entity-top span { font-size: 11.2px; }
  .mini-entity-amount { font-size: 11px; }
  .mini-entity-top em { font-size: 7.5px; padding: 3px 4px; }
  .filter-compact-row { grid-template-columns: 1fr; }
}


/* =========================================================
   Patch Batch 9 - Tambah Hutang Umum
   ========================================================= */
.two-field-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.general-debt-form .form-head{
  border-bottom-color:rgba(199,154,59,.18);
}
.general-debt-form .input{
  margin-bottom:10px;
}
.general-debt-form .two-field-grid .input{
  margin-bottom:10px;
}
.general-note{
  background:linear-gradient(135deg,rgba(199,154,59,.12),rgba(11,35,66,.04));
}
@media(max-width:430px){
  .two-field-grid{grid-template-columns:1fr;gap:0;}
}


/* =========================================================
   Patch Batch 9.1 - Hutang Karyawan UI + catatan multiline
   ========================================================= */
.section-launcher-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:9px;
}
.section-launch-card{
  width:100%;
  border:1px solid rgba(148,163,184,.26);
  background:linear-gradient(135deg,#ffffff 0%,#f8fafc 100%);
  border-radius:20px;
  padding:12px 12px;
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:10px;
  text-align:left;
  cursor:pointer;
  box-shadow:0 10px 26px rgba(15,23,42,.055);
  color:var(--text);
  font-family:inherit;
  appearance:none;
  -webkit-appearance:none;
}
.section-launch-card.active{
  border-color:rgba(199,154,59,.55);
  background:linear-gradient(135deg,#ffffff 0%,#fff8eb 100%);
  box-shadow:0 14px 32px rgba(199,154,59,.16);
}
.launcher-title{
  color:var(--navy);
  font-size:14px;
  line-height:1.12;
  font-weight:900;
  letter-spacing:-.25px;
}
.launcher-note{
  margin-top:3px;
  color:#66758b;
  font-size:11px;
  line-height:1.3;
  font-weight:700;
}
.launcher-meta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:76px;
  padding:6px 8px;
  border-radius:999px;
  background:rgba(15,35,66,.06);
  color:#334155;
  font-size:10px;
  font-weight:900;
  white-space:nowrap;
}
.section-launch-card.active .launcher-meta{
  background:rgba(199,154,59,.16);
  color:#6d4b0f;
}
.note-rich{
  white-space:normal;
  line-height:1.45;
}
.detail-note-box.note-rich,
.dist-rec-note.note-rich,
.transfer-history-note.note-rich{
  white-space:normal;
}
.general-debt-form .section-note,
.general-note{
  line-height:1.45;
}

/* =========================================================
   Batch 10 - Cicilan Hutang Karyawan + Corporate Menu Polish
   ========================================================= */
.section-launcher-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.section-launch-card{
  min-height:112px;
  grid-template-columns:1fr;
  align-content:space-between;
  border-radius:22px;
  padding:13px 12px 12px;
  background:
    radial-gradient(circle at 100% 0%,rgba(184,135,45,.10),transparent 72px),
    linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
  border-color:rgba(209,216,228,.88);
  box-shadow:0 14px 34px rgba(16,24,40,.075);
}
.section-launch-card:before{
  content:"";
  width:34px;
  height:4px;
  border-radius:99px;
  background:linear-gradient(90deg,var(--gold),rgba(184,135,45,.20));
  display:block;
  margin-bottom:4px;
}
.section-launch-card:active{transform:scale(.992)}
.section-launch-card.active{
  border-color:rgba(184,135,45,.60);
  background:
    radial-gradient(circle at 100% 0%,rgba(184,135,45,.18),transparent 80px),
    linear-gradient(180deg,#ffffff 0%,#fff8ec 100%);
}
.launcher-title{
  font-size:13px;
  letter-spacing:-.18px;
}
.launcher-note{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:30px;
}
.launcher-meta{
  justify-self:start;
  min-width:auto;
  margin-top:8px;
  font-size:9.5px;
  padding:5px 8px;
}
.filter-compact-row.one-input{
  grid-template-columns:1fr;
}
.payment-grid .mini-entity-card:before{
  background:linear-gradient(180deg,#12b76a,#067647);
}
.general-proof-row{
  margin-top:12px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
}
.general-payment-form .input{
  margin-bottom:10px;
}
.general-payment-hint{
  margin:8px 0 12px;
  line-height:1.45;
}
.action-btn.primary-action span,
.action-btn span{
  display:block;
}
.action-btn small{
  display:block;
  margin-top:5px;
  color:#667085;
  font-size:11.5px;
  line-height:1.35;
  font-weight:800;
}
@media(max-width:360px){
  .section-launcher-grid{grid-template-columns:1fr;}
  .section-launch-card{min-height:auto;}
}


/* =========================================================
   Batch 10.1 - Admin Action Category Polish
   ========================================================= */
.admin-action-shell{
  display:grid;
  gap:14px;
}
.admin-intro-card{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(15,35,66,.08);
  border-radius:24px;
  padding:18px;
  background:
    radial-gradient(circle at 100% 0%,rgba(184,135,45,.16),transparent 92px),
    linear-gradient(135deg,#ffffff 0%,#f7f9fc 100%);
  box-shadow:0 16px 38px rgba(16,24,40,.075);
}
.admin-intro-card:before{
  content:"";
  position:absolute;
  left:0;
  top:18px;
  bottom:18px;
  width:4px;
  border-radius:0 99px 99px 0;
  background:linear-gradient(180deg,var(--gold),#7b5317);
}
.admin-intro-kicker{
  color:#8a5a12;
  font-size:10px;
  font-weight:950;
  letter-spacing:.14em;
}
.admin-intro-title{
  margin-top:5px;
  color:var(--navy);
  font-size:19px;
  font-weight:950;
  letter-spacing:-.35px;
}
.admin-intro-note{
  margin-top:5px;
  color:#667085;
  font-size:12px;
  line-height:1.45;
  font-weight:750;
}
.admin-action-group{
  border:1px solid rgba(209,216,228,.86);
  border-radius:26px;
  padding:14px;
  background:rgba(255,255,255,.70);
  box-shadow:0 14px 36px rgba(16,24,40,.06);
}
.admin-action-group + .admin-action-group{
  margin-top:2px;
}
.admin-group-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  padding:2px 2px 12px;
  margin-bottom:10px;
  border-bottom:1px solid rgba(226,232,240,.88);
}
.admin-group-title{
  color:var(--navy);
  font-size:16px;
  font-weight:950;
  letter-spacing:-.25px;
}
.admin-group-note{
  color:#667085;
  font-size:11.5px;
  line-height:1.38;
  font-weight:750;
  margin-top:3px;
}
.admin-group-badge{
  flex:0 0 auto;
  border-radius:999px;
  padding:6px 9px;
  background:linear-gradient(135deg,#0b2747,#123a63);
  color:#fff;
  font-size:9px;
  font-weight:950;
  letter-spacing:.05em;
  box-shadow:0 8px 18px rgba(11,39,71,.14);
}
.admin-group-badge.soft{
  background:linear-gradient(135deg,#fff6e5,#f3dfba);
  color:#7b5317;
  border:1px solid rgba(184,135,45,.26);
}
.admin-group-badge.disabled{
  background:#eef2f7;
  color:#667085;
  box-shadow:none;
}
.admin-actions-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.admin-actions-grid.single-action{
  grid-template-columns:1fr;
}
.admin-action-shell .action-btn{
  position:relative;
  min-height:104px;
  border-radius:22px;
  padding:15px 14px 14px;
  background:
    radial-gradient(circle at 100% 0%,rgba(15,35,66,.06),transparent 78px),
    linear-gradient(180deg,#ffffff 0%,#fbfcfe 100%);
  border-color:rgba(209,216,228,.94);
  box-shadow:0 12px 28px rgba(16,24,40,.065);
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.admin-action-shell .action-btn:before{
  display:block;
  width:34px;
  height:4px;
  margin:0 0 12px;
  background:linear-gradient(90deg,var(--gold),rgba(184,135,45,.18));
}
.admin-action-shell .action-btn span{
  color:#0b2747;
  font-size:14px;
  line-height:1.15;
  letter-spacing:-.18px;
}
.admin-action-shell .action-btn small{
  color:#667085;
  font-size:11px;
  line-height:1.35;
  margin-top:7px;
  font-weight:750;
}
.admin-action-shell .action-btn:active{
  transform:scale(.992);
}
.admin-action-shell .primary-action{
  border-color:rgba(184,135,45,.42)!important;
  background:
    radial-gradient(circle at 100% 0%,rgba(184,135,45,.14),transparent 82px),
    linear-gradient(180deg,#ffffff 0%,#fff8eb 100%)!important;
}
.admin-action-shell .action-card-debt:before{
  background:linear-gradient(90deg,#0b2747,rgba(11,39,71,.18));
}
.admin-action-shell .action-card-payment:before{
  background:linear-gradient(90deg,#12b76a,rgba(18,183,106,.18));
}
.disabled-action{
  opacity:.78;
}
.muted-group{
  background:rgba(248,250,252,.74);
}
@media(min-width:760px){
  .admin-action-shell .action-btn:hover{
    transform:translateY(-1px);
    box-shadow:0 18px 38px rgba(16,24,40,.09);
    border-color:rgba(184,135,45,.34);
  }
}
@media(max-width:480px){
  .admin-action-group{padding:12px;border-radius:24px;}
  .admin-actions-grid{grid-template-columns:1fr;gap:9px;}
  .admin-action-shell .action-btn{min-height:auto;padding:14px;}
  .admin-group-head{margin-bottom:9px;padding-bottom:10px;}
  .admin-intro-card{border-radius:23px;padding:17px 17px 17px 18px;}
}

/* =========================================================
   Batch 10.2 - Admin Action Floating Modal
   ========================================================= */
body.admin-modal-lock{
  overflow:hidden;
  touch-action:none;
}
.admin-modal{
  position:fixed;
  inset:0;
  z-index:120;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:18px 12px calc(18px + env(safe-area-inset-bottom));
  background:rgba(8,22,41,.54);
  backdrop-filter:blur(12px);
  overflow:auto;
  -webkit-overflow-scrolling:touch;
}
.admin-modal-dialog{
  position:relative;
  width:min(100%,620px);
  margin:auto 0;
  animation:adminModalIn .18s ease-out;
}
.admin-modal-dialog-wide{
  width:min(100%,860px);
}
.admin-modal .form-card{
  border-radius:28px;
  border:1px solid rgba(255,255,255,.72);
  box-shadow:0 28px 80px rgba(5,18,34,.28);
  max-height:calc(100vh - 36px - env(safe-area-inset-bottom));
  overflow:auto;
  padding:19px;
}
.admin-modal .form-head{
  padding-right:44px;
}
.admin-modal-close{
  position:absolute;
  z-index:3;
  top:14px;
  right:14px;
  width:38px;
  height:38px;
  border:1px solid rgba(203,213,225,.9);
  border-radius:14px;
  background:rgba(255,255,255,.94);
  color:#0b2747;
  font-size:24px;
  line-height:1;
  font-weight:900;
  box-shadow:0 10px 24px rgba(16,24,40,.12);
}
.admin-modal-close:active{
  transform:scale(.96);
}
.admin-modal .form-save-btn{
  position:sticky;
  bottom:0;
  z-index:2;
  box-shadow:0 -10px 24px rgba(255,255,255,.88),0 12px 28px rgba(16,24,40,.14);
}
@keyframes adminModalIn{
  from{opacity:0;transform:translateY(14px) scale(.985)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@media(max-width:480px){
  .admin-modal{
    padding:10px 8px calc(10px + env(safe-area-inset-bottom));
    align-items:stretch;
  }
  .admin-modal-dialog{
    width:100%;
    margin:0;
  }
  .admin-modal .form-card{
    border-radius:24px;
    max-height:calc(100vh - 20px - env(safe-area-inset-bottom));
    padding:16px;
  }
  .admin-modal .form-head{
    padding-right:42px;
  }
  .admin-modal-close{
    top:11px;
    right:11px;
  }
}


/* Batch 10.7: Rekap Hutang Karyawan styles moved to assets/modules/rekap-hutang-karyawan.css */

/* Batch 13.2 — Paste Image Proof Upload */
.proof-paste-tools {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 8px;
}
.proof-paste-btn,
.proof-clear-btn {
  border: 1px solid rgba(15, 23, 42, .14);
  border-radius: 12px;
  padding: 9px 12px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .01em;
  background: rgba(255,255,255,.92);
  color: #0f172a;
  box-shadow: 0 8px 20px rgba(15,23,42,.06);
  cursor: pointer;
}
.proof-paste-btn {
  background: linear-gradient(135deg, rgba(14,165,233,.13), rgba(34,197,94,.13));
  border-color: rgba(14,165,233,.22);
}
.proof-clear-btn {
  background: rgba(248,250,252,.94);
  color: #64748b;
}
.proof-paste-btn:active,
.proof-clear-btn:active { transform: translateY(1px); }
.proof-input-preview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
  gap: 8px;
  margin-top: 10px;
}
.proof-preview-chip {
  border: 1px solid rgba(15,23,42,.1);
  border-radius: 14px;
  background: rgba(255,255,255,.88);
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(15,23,42,.06);
}
.proof-preview-chip img {
  width: 100%;
  height: 76px;
  object-fit: cover;
  display: block;
  background: #f8fafc;
}
.proof-preview-chip span {
  display: block;
  padding: 7px 8px;
  font-size: 11px;
  color: #475569;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.paste-capture-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: 18px;
}
.paste-capture-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15,23,42,.68);
  backdrop-filter: blur(6px);
}
.paste-capture-card {
  position: relative;
  width: min(420px, 100%);
  border-radius: 24px;
  padding: 18px;
  background: #ffffff;
  box-shadow: 0 28px 70px rgba(15,23,42,.28);
  border: 1px solid rgba(255,255,255,.62);
}
.paste-capture-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 12px;
  background: #f1f5f9;
  color: #0f172a;
  font-size: 22px;
  cursor: pointer;
}
.paste-capture-title {
  font-size: 16px;
  font-weight: 900;
  color: #0f172a;
  padding-right: 36px;
}
.paste-capture-note {
  margin-top: 6px;
  font-size: 12px;
  color: #64748b;
  line-height: 1.45;
}
.paste-capture-zone {
  margin-top: 14px;
  min-height: 116px;
  border: 2px dashed rgba(14,165,233,.34);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(14,165,233,.08), rgba(34,197,94,.08));
  display: grid;
  place-items: center;
  text-align: center;
  color: #0369a1;
  font-weight: 900;
  outline: none;
}
.paste-capture-zone:focus {
  border-color: rgba(14,165,233,.72);
  box-shadow: 0 0 0 4px rgba(14,165,233,.12);
}

/* Batch 13.3 - Sidebar wrapped Hutang Karyawan label */
.side-link-subline{
  display:block;
  font-size:.92em;
  line-height:1.05;
  opacity:.92;
  margin-top:2px;
}
.side-link span:first-child{
  display:block;
}

/* Batch 13.4 - Hari transfer proof edit modal */
.edit-proof-link{
  border-color: rgba(212, 162, 74, .45) !important;
  background: rgba(255, 246, 224, .9) !important;
  color: #7a4a00 !important;
  font-weight: 900;
}
.hari-proof-edit-overlay{
  z-index: 9995;
  align-items: center;
  justify-content: center;
  padding: 18px;
}
.hari-proof-edit-card{
  max-width: 560px;
  width: min(560px, calc(100vw - 26px));
  max-height: calc(100vh - 34px);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
.proof-edit-head{
  border-bottom: 1px solid rgba(15, 23, 42, .09);
  margin-bottom: 14px;
  padding-bottom: 12px;
}
.proof-edit-summary{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 10px 0 16px;
}
.proof-edit-summary > div,
.existing-proof-box{
  border:1px solid rgba(148, 163, 184, .35);
  background: linear-gradient(135deg, #ffffff, #f8fafc);
  border-radius: 16px;
  padding: 12px;
}
.proof-edit-summary span{
  display:block;
  font-size: 11px;
  font-weight: 900;
  color:#64748b;
  text-transform: uppercase;
  letter-spacing:.04em;
}
.proof-edit-summary b{
  display:block;
  margin-top:4px;
  color:#071f3e;
  font-size:15px;
}
.existing-proof-box{ margin: 12px 0; }
@media (max-width: 640px){
  .proof-edit-summary{ grid-template-columns: 1fr; }
  .hari-proof-edit-overlay{ padding: 8px; align-items:flex-start; }
  .hari-proof-edit-card{ width: calc(100vw - 16px); max-height: calc(100vh - 16px); }
}
