/* ============================================================
   Ceklis Mobil Operasional — Yayasan Al-Fatihah
   Tema terang, aksen biru, layout sidebar.
   ============================================================ */
:root{
  --primary:#2563eb; --primary-d:#1d4ed8; --primary-l:#eff4ff;
  --bg:#f4f6fb; --side:#fff; --card:#fff;
  --ink:#1e2839; --muted:#697586; --faint:#9aa4b2;
  --line:#e8ecf3; --line-2:#dce2ec;
  --green:#16a34a; --green-bg:#e9f7ef;
  --red:#dc2626;   --red-bg:#fdeaea;
  --yellow:#d97706;--yellow-bg:#fef3e2;
  --blue:#2563eb;  --blue-bg:#e9f0fe;
  --gray:#64748b;  --gray-bg:#eef1f6;
  --coral:#f1644b; --coral-bg:#fdede9;
  --teal:#0d9488;  --teal-bg:#e6f5f3;
  --amber:#e0a106; --amber-bg:#fcf3da;
  --sidebar-w:248px; --radius:14px;
}
*{box-sizing:border-box}
body{margin:0;font-size:14px;line-height:1.55;color:var(--ink);background:var(--bg);
  font-family:'Inter','Segoe UI',Roboto,Helvetica,Arial,sans-serif}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-d)}
h1{font-size:25px;font-weight:700;letter-spacing:-.02em;margin:0 0 4px}
h2{font-size:17px;font-weight:600;margin:0 0 14px}

/* App shell */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--side);border-right:1px solid var(--line);
  padding:20px 14px;position:sticky;top:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column;gap:4px}
.sidebar .brand{display:flex;align-items:center;gap:11px;padding:8px 6px 4px}
.sidebar .brand-logo{max-width:170px;width:100%;height:auto;display:block}
.brand-sub{font-size:11px;color:var(--faint);font-weight:600;padding:0 8px 14px;border-bottom:1px solid var(--line);margin-bottom:6px}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--muted);
  font-weight:500;font-size:13.5px;transition:.13s}
.nav-item .ic{width:18px;text-align:center;font-size:15px;opacity:.9}
.nav-item:hover{background:var(--primary-l);color:var(--primary-d)}
.nav-item.active{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;box-shadow:0 6px 16px rgba(37,99,235,.28)}
.sidebar .spacer{flex:1}
.nav-grp{border:0}
.nav-grp summary{list-style:none;display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;
  color:var(--muted);font-weight:500;font-size:13.5px;cursor:pointer;user-select:none;transition:.13s}
.nav-grp summary::-webkit-details-marker{display:none}
.nav-grp summary:hover{background:var(--primary-l);color:var(--primary-d)}
.nav-grp .chev{margin-left:auto;font-size:10px;opacity:.55;transition:transform .15s}
.nav-grp[open] > summary .chev{transform:rotate(180deg)}
.nav-grp[open] > summary{color:var(--ink)}
.nav-sub{display:block;padding:8px 12px 8px 42px;border-radius:9px;color:var(--muted);font-weight:500;font-size:13px;transition:.13s}
.nav-sub:hover{background:var(--primary-l);color:var(--primary-d)}
.nav-sub.active{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;box-shadow:0 5px 14px rgba(37,99,235,.25)}

/* Main / topbar */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:16px;padding:14px 28px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.topbar .crumb{color:var(--faint);font-size:13px}
.topbar .right{margin-left:auto;display:flex;align-items:center;gap:16px}
.bell{position:relative;font-size:18px;color:var(--muted)}
.bell .dot-n{position:absolute;top:-5px;right:-6px;background:var(--red);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:9px;display:grid;place-items:center;padding:0 3px}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#6366f1);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}
.who{font-size:13px;text-align:right;line-height:1.2}
.who b{font-weight:600}.who small{color:var(--faint)}
.content{padding:26px 28px;max-width:1240px;width:100%}
.menu-btn{display:none;background:#fff;border:1px solid var(--line-2);border-radius:9px;width:38px;height:38px;font-size:17px;cursor:pointer;color:var(--ink)}
@media(max-width:900px){
  .sidebar{position:fixed;left:0;top:0;z-index:60;transform:translateX(-100%);transition:.25s;box-shadow:0 0 40px rgba(0,0,0,.2);width:80%;max-width:300px}
  .sidebar.open{transform:none}
  .menu-btn{display:block}
  .scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:55}
  .scrim.show{display:block}
}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:12px;margin-bottom:22px}
.page-head p{margin:4px 0 0;color:var(--muted)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:20px;box-shadow:0 1px 3px rgba(16,24,40,.04)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:7px;cursor:pointer;border:0;font-family:inherit;background:var(--primary);color:#fff;padding:10px 17px;border-radius:10px;font-size:13.5px;font-weight:600;transition:.15s;box-shadow:0 3px 10px rgba(37,99,235,.22)}
.btn:hover{background:var(--primary-d);color:#fff}
.btn-sm{padding:6px 11px;font-size:12.5px;border-radius:8px;box-shadow:none}
.btn-light{background:#fff;color:var(--ink);border:1px solid var(--line-2);box-shadow:none}
.btn-light:hover{background:#f6f8fc}
.btn-danger{background:var(--red);box-shadow:0 3px 10px rgba(220,38,38,.2)}
.btn-danger:hover{background:#b91c1c;color:#fff}
.btn-blue{background:var(--primary)}
.btn-green{background:var(--green);box-shadow:0 3px 10px rgba(22,163,74,.2)}
.btn-green:hover{background:#15803d;color:#fff}

/* Tables */
table{width:100%;border-collapse:collapse}
.tbl{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.tbl th,.tbl td{padding:11px 14px;text-align:left;vertical-align:middle;border-bottom:1px solid var(--line)}
.tbl th{background:#f7f9fc;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);font-weight:700}
.tbl tr:last-child td{border-bottom:0}
.tbl tr:hover td{background:#f9fbfe}
.tbl .center{text-align:center}
.tbl td small{color:var(--faint)}
.infotbl{width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.infotbl th{background:#f7f9fc;text-align:left;font-weight:600;color:var(--muted);font-size:12.5px;padding:9px 12px;border:1px solid var(--line);vertical-align:top}
.infotbl td{padding:9px 12px;border:1px solid var(--line);font-size:13.5px}

/* Forms */
label{display:block;font-weight:600;margin:12px 0 5px;font-size:12.5px;color:var(--ink)}
input[type=text],input[type=number],input[type=date],input[type=month],input[type=email],input[type=password],select,textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line-2);border-radius:10px;font-size:14px;font-family:inherit;background:#fff;color:var(--ink);transition:.15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.14)}
input::placeholder,textarea::placeholder{color:var(--faint)}
textarea{min-height:80px;resize:vertical}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr 1fr}.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:760px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.hint{font-size:11.5px;color:var(--faint);font-weight:400}

/* Badges / flash */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:999px;font-size:12px;font-weight:600}
.b-green{background:var(--green-bg);color:var(--green)}
.b-red{background:var(--red-bg);color:var(--red)}
.b-yellow{background:var(--yellow-bg);color:var(--yellow)}
.b-gray{background:var(--gray-bg);color:var(--gray)}
.b-blue{background:var(--blue-bg);color:var(--blue)}
.flash{padding:12px 18px;border-radius:11px;margin-bottom:18px;font-weight:500;border:1px solid}
.flash-success{background:var(--green-bg);color:#15803d;border-color:#b7e4c7}
.flash-error{background:var(--red-bg);color:#b91c1c;border-color:#f3c0c0}

/* Stat cards */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:22px}
.stat{border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:15px;border:1px solid rgba(255,255,255,.6);box-shadow:0 6px 16px rgba(2,6,23,.08),0 1px 0 rgba(255,255,255,.7) inset;transition:transform .15s,box-shadow .15s}
.stat:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(2,6,23,.13)}
.stat .ico{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:22px;color:#fff;flex-shrink:0;background-image:linear-gradient(145deg,rgba(255,255,255,.30),rgba(0,0,0,.18));box-shadow:inset 0 2px 3px rgba(255,255,255,.45),inset 0 -4px 5px rgba(0,0,0,.22),0 5px 10px rgba(2,6,23,.22);text-shadow:0 1px 2px rgba(0,0,0,.25)}
.stat .lbl{font-size:13px;color:var(--muted);font-weight:500}
.stat .num{font-size:25px;font-weight:800;letter-spacing:-.02em;margin-top:1px}
.stat .sub{font-size:11.5px;font-weight:600;margin-top:2px}
.stat.coral{background:var(--coral-bg)} .stat.coral .ico{background:var(--coral)} .stat.coral .sub{color:var(--coral)}
.stat.teal{background:var(--teal-bg)} .stat.teal .ico{background:var(--teal)} .stat.teal .sub{color:var(--teal)}
.stat.blue{background:var(--blue-bg)} .stat.blue .ico{background:var(--blue)} .stat.blue .sub{color:var(--blue)}
.stat.amber{background:var(--amber-bg)} .stat.amber .ico{background:var(--amber)} .stat.amber .sub{color:var(--amber)}
.stat.green{background:var(--green-bg)} .stat.green .ico{background:var(--green)} .stat.green .sub{color:var(--green)}

/* Metric cards + sparkline */
.metrics{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.metric{display:flex;align-items:stretch;justify-content:space-between;gap:16px}
.metric .mleft{min-width:0;display:flex;flex-direction:column;justify-content:center}
.metric .mlbl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-weight:700}
.metric .mnum{font-size:34px;font-weight:800;letter-spacing:-.02em;line-height:1.05;margin:6px 0 2px}
.metric .msub{font-size:12px;color:var(--faint);margin-top:6px}
.metric .mspark{width:48%;min-width:120px;height:88px;align-self:center}
.delta{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:700;padding:2px 9px;border-radius:999px;width:max-content}
.delta.up{background:var(--green-bg);color:var(--green)}
.delta.down{background:var(--red-bg);color:var(--red)}
.delta.flat{background:var(--gray-bg);color:var(--gray)}
.compo-row{margin:14px 0}
.compo-row .top{display:flex;justify-content:space-between;align-items:baseline;font-size:13.5px;margin-bottom:6px}
.compo-row .top .pct{color:var(--muted);font-size:12px}
.bar{height:9px;border-radius:999px;background:#eef1f6;overflow:hidden}
.bar > i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#2563eb,#60a5fa)}
.segs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.seg{border-radius:12px;padding:18px 12px;text-align:center}
.seg .n{font-size:27px;font-weight:800;line-height:1}
.seg .t{font-size:12px;margin-top:4px;font-weight:600}
.seg.ok{background:var(--green-bg)} .seg.ok .n,.seg.ok .t{color:var(--green)}
.seg.warn{background:var(--yellow-bg)} .seg.warn .n,.seg.warn .t{color:var(--yellow)}
.seg.bad{background:var(--red-bg)} .seg.bad .n,.seg.bad .t{color:var(--red)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:760px){.grid2{grid-template-columns:1fr}.metrics{grid-template-columns:1fr}}

/* Filter bar */
.filter-bar{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}
.filter-bar > div{min-width:150px}
.filter-bar label{margin-top:0}

/* Form ceklis modern */
.ck-summary{display:flex;align-items:center;gap:9px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 16px;margin-bottom:16px;box-shadow:0 1px 3px rgba(16,24,40,.04)}
.ck-chip{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;padding:5px 12px;border-radius:999px}
.ck-chip b{font-weight:800;font-size:13px}
.ck-chip.baik{background:var(--green-bg);color:var(--green)}
.ck-chip.warn{background:var(--yellow-bg);color:var(--yellow)}
.ck-chip.bad{background:var(--red-bg);color:var(--red)}
.ck-chip.na{background:var(--gray-bg);color:var(--gray)}
.ck-summary .ck-hint{margin-left:auto;font-size:11.5px;color:var(--faint);max-width:340px;text-align:right}
.ck-cat{display:flex;align-items:center;gap:10px;margin:22px 0 12px;font-weight:700;color:var(--primary-d);text-transform:uppercase;letter-spacing:.04em;font-size:12.5px}
.ck-cat::before{content:"";width:4px;height:18px;border-radius:4px;background:var(--primary)}
.ck-cat .count{margin-left:auto;font-size:11px;color:var(--primary-d);font-weight:700;background:var(--primary-l);padding:3px 10px;border-radius:999px;text-transform:none;letter-spacing:0}
.ck-item{display:grid;grid-template-columns:1fr auto;gap:10px 16px;align-items:center;background:#fff;border:1px solid var(--line);border-left:3px solid var(--line-2);border-radius:12px;padding:13px 16px;margin-bottom:10px;transition:.15s}
.ck-item:hover{box-shadow:0 3px 12px rgba(16,24,40,.07)}
.ck-item.is-warn{border-left-color:var(--yellow);background:#fffdf6}
.ck-item.is-bad{border-left-color:var(--red);background:#fff8f8}
.ck-item.is-na{border-left-color:var(--gray)}
.ck-item.checked{border-left-color:var(--green);background:#f6fdf9}
.ck-item-name{font-weight:600;font-size:14.5px}
.ck-item-spec{font-size:12px;color:var(--muted);margin-top:2px}
.ck-seg{display:inline-flex;border:1px solid var(--line-2);border-radius:10px;overflow:hidden;background:#fff;flex-shrink:0}
.ck-seg label{margin:0;cursor:pointer;display:block}
.ck-seg input{position:absolute;opacity:0;width:0;height:0}
.ck-seg .seg{display:block;padding:9px 15px;font-size:12.5px;font-weight:600;color:var(--muted);border-right:1px solid var(--line);transition:.12s;white-space:nowrap}
.ck-seg label:last-child .seg{border-right:0}
.ck-seg label:hover .seg{background:#f6f8fc}
.ck-seg input:checked + .seg.baik{background:var(--green);color:#fff}
.ck-seg input:checked + .seg.warn{background:var(--yellow);color:#fff}
.ck-seg input:checked + .seg.bad{background:var(--red);color:#fff}
.ck-seg input:checked + .seg.na{background:var(--gray);color:#fff}
.ck-ket{grid-column:1/-1;max-height:0;overflow:hidden;opacity:0;transition:max-height .2s,opacity .2s,margin .2s}
.ck-item.show-ket .ck-ket{max-height:64px;opacity:1;margin-top:4px}
.ck-savebar{position:sticky;bottom:0;z-index:25;display:flex;align-items:center;gap:10px;justify-content:flex-end;background:rgba(255,255,255,.96);backdrop-filter:blur(6px);border-top:1px solid var(--line);padding:13px 0;margin:16px 0 0}
.ck-savebar-info{margin-right:auto;font-size:13px;color:var(--muted)}
/* kontrol ekspedisi */
.eks-ctrl{display:flex;align-items:center;gap:10px;flex-shrink:0}
.eks-qty{width:92px;padding:8px 10px;text-align:center}
.eks-toggle{margin:0;cursor:pointer}
.eks-toggle input{position:absolute;opacity:0;width:0;height:0}
.eks-toggle span{display:inline-block;padding:9px 16px;border:1.5px solid var(--line-2);border-radius:10px;font-size:12.5px;font-weight:600;color:var(--muted);background:#fff;transition:.12s;white-space:nowrap}
.eks-toggle:hover span{border-color:var(--faint)}
.eks-toggle input:checked + span{background:var(--green);border-color:var(--green);color:#fff}

/* Foto */
.foto-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.foto-grid img{width:100%;height:130px;object-fit:cover;border-radius:11px;border:1px solid var(--line-2);transition:.15s}
.foto-grid img:hover{border-color:var(--primary);transform:scale(1.02)}

/* Auth (login & logout) */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(1000px 520px at 50% -10%,#e7edff,transparent 60%),var(--bg)}
.auth-card{width:100%;max-width:900px;display:grid;grid-template-columns:1fr 1fr;background:#fff;border-radius:22px;overflow:hidden;box-shadow:0 30px 70px rgba(16,24,40,.18)}
.auth-left{background:linear-gradient(160deg,#2f44d6,#1e3a8a);color:#fff;padding:36px 32px;display:flex;flex-direction:column}
.auth-logo{background:#fff;border-radius:13px;padding:12px 16px;width:max-content;margin-bottom:22px;box-shadow:0 8px 22px rgba(0,0,0,.18)}
.auth-logo img{height:36px;width:auto;display:block}
.auth-welcome{font-size:14.5px;line-height:1.75;opacity:.96;margin:0}
.auth-welcome b{font-weight:700}
.auth-doa{margin-top:auto;border-top:1px solid rgba(255,255,255,.22);padding-top:18px}
.auth-doa .ar{font-size:19px;text-align:right;direction:rtl;margin-bottom:8px;font-weight:600}
.auth-doa .ar2{font-size:13.5px;text-align:right;direction:rtl;opacity:.9;line-height:2;margin-bottom:12px}
.auth-doa p{font-size:12px;opacity:.82;font-style:italic;margin:0;line-height:1.6}
.auth-right{padding:38px 36px;display:flex;flex-direction:column}
.auth-right h1{font-size:25px;margin:0 0 4px}
.auth-right .sub{color:var(--muted);font-size:13.5px;margin:0 0 22px}
.auth-right label{font-size:13px;margin-top:14px}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:46px}
.pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:0;cursor:pointer;font-size:17px;padding:8px;line-height:1;border-radius:8px}
.pw-toggle:hover{background:#f0f3f8}
.auth-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:16px 0 20px;font-size:13px;flex-wrap:wrap}
.auth-row .remember{display:flex;align-items:center;gap:8px;margin:0;font-weight:500;color:var(--ink);cursor:pointer}
.auth-row .remember input{width:auto}
.forgot{color:var(--primary);font-weight:600}
.auth-btn{width:100%;justify-content:center;font-size:15px;padding:13px}
.auth-foot{margin-top:24px;padding-top:18px;border-top:1px solid var(--line);text-align:center}
.auth-foot .quote{font-weight:700;color:var(--primary-d);font-size:14px;margin:0 0 6px;line-height:1.5}
.auth-foot .muted{color:var(--muted);font-size:12.5px;margin:0}
.logout-card{width:100%;max-width:420px;background:#fff;border-radius:22px;padding:42px 34px;text-align:center;box-shadow:0 30px 70px rgba(16,24,40,.16)}
.logout-ic{width:74px;height:74px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;font-size:36px;background:var(--primary-l)}
.logout-card h1{font-size:23px;margin:0 0 6px}
.logout-card .sub{color:var(--muted);font-size:14px;margin:0 0 14px}
.logout-card .doa{color:var(--primary-d);font-size:13.5px;margin:0 0 22px;font-weight:600}
.logout-card .muted{color:var(--faint);font-size:12px;margin:16px 0 0}

.footer{text-align:center;color:var(--faint);padding:24px;font-size:12.5px}

/* Print */
.print-only{display:none}
@media print{.no-print{display:none!important}.content{padding:0;max-width:100%}.print-only{display:block}}

/* ============================================================
   MOBILE (HP)
   ============================================================ */
@media(max-width:900px){
  .topbar{padding:11px 15px;gap:10px}
  .topbar .crumb{font-weight:600;color:var(--ink)}
  .content{padding:18px 16px}
}
@media(max-width:760px){
  .auth-card{grid-template-columns:1fr;max-width:440px}
  .auth-left{padding:26px 24px}
  .auth-doa{display:none}
  .auth-right{padding:28px 24px}
}
@media(max-width:640px){
  h1{font-size:20px} h2{font-size:15.5px}
  .content{padding:14px 12px}
  .page-head{align-items:stretch;margin-bottom:16px}
  .page-head > .btn,.page-head a.btn{width:100%;justify-content:center}
  .who{display:none}
  .stats{grid-template-columns:1fr;gap:11px}
  .stat{padding:14px;gap:13px}.stat .num{font-size:21px}

  /* Tabel jadi tumpukan kartu (tanpa geser samping) */
  .tbl{display:block;border:0;border-radius:0;overflow:visible}
  .tbl thead{display:none}
  .tbl tr{display:block;background:#fff;border:1px solid var(--line);border-radius:11px;margin-bottom:10px;padding:4px 2px;box-shadow:0 1px 3px rgba(16,24,40,.04)}
  .tbl tr:first-child{display:none}
  .tbl td{display:flex;justify-content:space-between;align-items:center;gap:12px;text-align:right;border:0;border-bottom:1px solid var(--line);padding:9px 12px}
  .tbl tr td:last-child{border-bottom:0}
  .tbl td::before{content:attr(data-label);font-weight:700;color:var(--faint);text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.03em;flex:0 0 42%}
  .tbl td.center{justify-content:flex-end}
  .tbl td[colspan]{justify-content:center;text-align:center;font-weight:700;background:var(--primary-l);border-radius:8px}
  .tbl td[colspan]::before{content:""}

  /* info table jadi label-nilai bertumpuk */
  .infotbl,.infotbl tbody,.infotbl tr,.infotbl th,.infotbl td{display:block;width:100%!important;border:0}
  .infotbl tr{border:1px solid var(--line);border-radius:10px;margin-bottom:8px;background:#fff;padding:4px 2px}
  .infotbl th{background:transparent;padding:8px 12px 0;font-size:10.5px;text-transform:uppercase;letter-spacing:.03em}
  .infotbl td{padding:1px 12px 9px;font-weight:500}

  /* filter & form */
  .filter-bar{flex-direction:column;align-items:stretch}
  .filter-bar > div{min-width:0;width:100%}
  .filter-bar .btn{width:100%;justify-content:center}
  .ck-summary .ck-hint{display:none}
  .ck-item{grid-template-columns:1fr}
  .ck-seg{width:100%}
  .ck-seg label{flex:1}
  .ck-seg .seg{text-align:center;padding:11px 4px}
  .ck-savebar-info{display:none}
  .ck-savebar .btn{flex:1;justify-content:center}
  .eks-ctrl{width:100%}.eks-qty{flex:1}.eks-toggle{flex:1}.eks-toggle span{display:block;text-align:center}
  .foto-grid{grid-template-columns:repeat(auto-fill,minmax(46%,1fr));gap:9px}
  .foto-grid img{height:110px}
}

/* popup edit (form jadi modal saat action=edit) */
.editmodal-ov{position:fixed;inset:0;background:rgba(16,24,40,.45);z-index:80;display:flex;
  align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto;backdrop-filter:blur(2px)}
.editmodal-box{max-width:680px;width:100%;margin:0!important;box-shadow:0 30px 70px rgba(0,0,0,.3);
  animation:popin .18s ease}
@keyframes popin{from{transform:translateY(-12px);opacity:.4}to{transform:none;opacity:1}}
@media(max-width:640px){.editmodal-ov{padding:16px 10px}}

/* perbaikan sel Aksi (tombol) di tampilan HP agar tidak keluar kartu */
@media(max-width:640px){
  .tbl td{white-space:normal!important}
  .tbl td:has(.btn){flex-wrap:wrap;justify-content:flex-end;gap:6px;padding:10px 12px}
  .tbl td:has(.btn)::before{display:none}
  .tbl td:has(.btn) .btn{flex:1 1 auto;min-width:84px;justify-content:center}
}

/* ===== Perbaikan tampilan HP: page-head aksi banyak tombol + tile setting ===== */
@media(max-width:640px){
  .page-head{flex-direction:column}
  .page-head > div{width:100%}
  .page-head > div:last-child{display:flex;flex-wrap:wrap;gap:8px}
  .page-head > div:last-child .btn{flex:1 1 auto;justify-content:center}
  .set-grid{gap:12px}
  .chk-grid{gap:9px 14px}
  /* matriks hak akses & tabel lebar tetap terbaca sebagai kartu */
  .tbl td input[type=checkbox]{width:20px;height:20px}
}

/* ===== Premium hero cards + donut (dashboard) ===== */
.herorow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:20px}
.hcard{position:relative;background:#fff;border-radius:18px;padding:18px 18px 20px;box-shadow:0 10px 28px rgba(2,6,23,.08);overflow:hidden;min-height:142px;text-decoration:none;color:inherit;display:block;border:1px solid #eef2f7;transition:transform .15s,box-shadow .15s}
.hcard:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(2,6,23,.13)}
.hcard .hlbl{font-weight:700;font-size:14px;color:var(--ink)}
.hcard .hnum{font-size:38px;font-weight:800;letter-spacing:-.02em;line-height:1.05;margin-top:6px}
.hcard .hsub{font-size:12px;color:var(--muted);margin-top:5px}
.hcard .hd{font-size:12px;font-weight:700;margin-top:8px}
.hcard .hd.up{color:#16a34a}.hcard .hd.down{color:#dc2626}.hcard .hd.flat{color:#94a3b8}
.horb{position:absolute;right:10px;top:24px;width:82px;height:82px;border-radius:50%;display:grid;place-items:center;font-size:36px;
  background:radial-gradient(circle at 32% 28%,rgba(255,255,255,.85),var(--c) 44%,var(--cd) 100%);
  box-shadow:0 16px 22px -8px var(--cd),inset 0 -6px 10px rgba(0,0,0,.28),inset 0 5px 9px rgba(255,255,255,.45);
  text-shadow:0 2px 3px rgba(0,0,0,.3)}
.hped{position:absolute;right:22px;top:116px;width:58px;height:13px;border-radius:50%;background:radial-gradient(ellipse at center,rgba(2,6,23,.24),transparent 72%);filter:blur(1px)}
@media(max-width:900px){.herorow{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.herorow{grid-template-columns:1fr}}
.donut-c{position:absolute;inset:0;display:grid;place-items:center;text-align:center;pointer-events:none}
.donut-c .dn{font-size:30px;font-weight:800;line-height:1}
.donut-c small{color:var(--muted);font-size:12px}
.lgd{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid #eef2f7;font-weight:500}
.lgd:last-child{border-bottom:0}
.lgd .dot{width:13px;height:13px;border-radius:4px;flex-shrink:0;box-shadow:0 2px 4px rgba(0,0,0,.15)}
.lgd b{margin-left:auto;font-size:19px;font-weight:800}
