:root{--bg:#f4f7fb;--panel:#fff;--ink:#0f172a;--muted:#475569;--line:#e2e8f0;--primary:#2563eb;--green:#10b981;--red:#ef4444;--dark:#0f172a;--cyan:#06b6d4;--soft:#eef6ff}
*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px}a{text-decoration:none;color:inherit}.layout{display:grid;grid-template-columns:250px 1fr;min-height:100vh}.sidebar{background:#0f172a;color:#fff;padding:18px 18px;position:sticky;top:0;height:100vh}.brand{display:flex;gap:12px;align-items:center;margin-bottom:28px}.badge{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#2563eb,#10b981);display:grid;place-items:center;font-weight:800}.brand h1{font-size:16px;margin:0}.brand p{margin:4px 0 0;color:#bfdbfe;font-size:12px}.nav a{display:block;padding:13px 14px;border-radius:12px;font-weight:700;margin:6px 0;color:#f8fafc}.nav a.active,.nav a:hover{background:#273244}.sidebar-foot{position:absolute;bottom:18px;font-size:12px;color:#bfdbfe}.topbar{height:70px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:20}.topbar h2{font-size:20px;margin:0}.top-actions{display:flex;gap:10px;align-items:center}.user-pill{display:flex;gap:9px;align-items:center;background:#f8fafc;border:1px solid var(--line);padding:8px 13px;border-radius:24px}.avatar{width:28px;height:28px;border-radius:50%;background:#0ea5e9;color:#fff;display:grid;place-items:center;font-weight:800}.main{padding:24px}.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:0 10px 30px rgba(15,23,42,.06);margin-bottom:16px;overflow:hidden}.card-head{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:12px}.card-head h3{margin:0;font-size:16px}.card-body{padding:18px}.grid{display:grid;gap:16px}.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.kpi{padding:18px;background:#fff;border:1px solid var(--line);border-radius:16px;position:relative;overflow:hidden}.kpi:after{content:"";position:absolute;right:-20px;top:-20px;width:80px;height:80px;border-radius:50%;background:#dff3fb}.kpi small{font-weight:800;color:#64748b;text-transform:uppercase}.kpi b{display:block;font-size:24px;margin:8px 0}.hero{background:linear-gradient(135deg,#172554,#0f766e);color:#fff;border-radius:20px;padding:26px;margin-bottom:22px;display:flex;justify-content:space-between;align-items:center}.hero h1{margin:0;font-size:28px}.hero p{margin:8px 0 0}.btn{border:0;border-radius:10px;padding:10px 14px;font-weight:800;cursor:pointer;background:#f8fafc;border:1px solid var(--line);display:inline-flex;align-items:center;gap:6px}.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn.green{background:var(--green);color:#fff;border-color:var(--green)}.btn.red{background:#fee2e2;color:#b91c1c;border-color:#fecaca}.btn.small{padding:7px 10px;font-size:12px}.btn:disabled{opacity:.6;cursor:not-allowed}label{font-size:12px;font-weight:800;color:#0f172a;display:block;margin-bottom:7px}.input,select,textarea{width:100%;border:1px solid #cbd5e1;border-radius:11px;padding:10px 12px;font-size:14px;background:#fff}textarea{min-height:80px}.form-row{display:grid;gap:14px;grid-template-columns:repeat(2,1fr);margin-bottom:14px}.form-row.three{grid-template-columns:repeat(3,1fr)}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px}table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:11px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{font-size:11px;text-transform:uppercase;color:#334155;background:#f8fafc;letter-spacing:.03em}.status{display:inline-block;padding:6px 9px;border-radius:99px;font-weight:800;font-size:12px}.status.green{background:#dcfce7;color:#166534}.status.red{background:#fee2e2;color:#991b1b}.status.yellow{background:#fef3c7;color:#92400e}.notice{padding:12px 14px;border-radius:12px;background:#eff6ff;border:1px dashed #93c5fd;color:#1e3a8a;margin:12px 0}.login-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#eef7ff,#f8fafc)}.login-card{width:min(430px,92vw);background:#fff;border-radius:26px;padding:36px;box-shadow:0 24px 60px rgba(15,23,42,.12)}.login-title{display:flex;gap:14px;align-items:center;margin-bottom:24px}.invoice-box{background:#fff;color:#001b44;font-family:Arial,sans-serif}.invoice-print{max-width:900px;margin:0 auto;background:#fff;padding:28px}.invoice-head{text-align:center;border-bottom:3px solid #394a5a;padding-bottom:12px;margin-bottom:14px}.invoice-head img{max-width:92px;max-height:92px;object-fit:contain;display:block;margin:0 auto 6px}.invoice-head h1{font-size:20px;color:#e11d1d;margin:5px 0 2px}.invoice-head p{font-size:12px;margin:2px 0;color:#01457c;font-weight:700}.invoice-title{text-align:center;color:#dc2626;font-weight:900;text-decoration:underline;margin:14px 0;font-size:16px}.invoice-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid #3f4f63;margin-bottom:0}.invoice-grid>div{padding:8px;border-right:1px solid #3f4f63;font-size:12px}.invoice-grid>div:last-child{border-right:0}.invoice-table th,.invoice-table td{border:1px solid #3f4f63;padding:7px;font-size:12px}.invoice-table th{background:#e0f2f1;text-align:center}.pay-total{display:grid;grid-template-columns:1fr 1fr;border-left:1px solid #3f4f63;border-right:1px solid #3f4f63;border-bottom:1px solid #3f4f63}.pay-total>div{padding:8px;font-size:12px}.total-line{display:flex;justify-content:space-between;border-bottom:1px solid #3f4f63;padding:6px 8px;font-weight:800}.balance{color:#dc2626}.print-only{display:none}.logo-preview{max-width:96px;max-height:96px;object-fit:contain}.row-actions{display:flex;gap:7px;flex-wrap:wrap}.item-row{display:grid;grid-template-columns:1.4fr .8fr .5fr 40px;gap:10px;margin-bottom:10px;align-items:end}.mobile-only{display:none}
@media(max-width:900px){.layout{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.sidebar-foot{position:static;margin-top:20px}.grid-4,.grid-3,.grid-2,.form-row,.form-row.three{grid-template-columns:1fr}.item-row{grid-template-columns:1fr}.topbar{position:relative}.main{padding:14px}}
@media print{.sidebar,.topbar,.no-print,.btn{display:none!important}.layout{display:block}.main{padding:0}.card{box-shadow:none;border:0}.print-only{display:block}.invoice-print{padding:0}.invoice-table th,.invoice-table td,.invoice-grid>div,.pay-total>div{font-size:12px}body{background:#fff}.landscape{page:landscape}@page landscape{size:A4 landscape;margin:10mm}@page{size:A4 portrait;margin:10mm}}

/* Invoice A4 portrait template - website version */
.invoice-a4{width:210mm;min-height:297mm;max-width:210mm;margin:0 auto;background:#fff;padding:10mm 10mm 8mm;color:#0b2142;font-family:Arial,sans-serif;font-size:12px;line-height:1.25;box-shadow:0 10px 30px rgba(15,23,42,.08)}
.invoice-head-clean{text-align:center;border-bottom:3px solid #5f6368;padding-bottom:8px;margin-bottom:8px}
.invoice-head-clean img{max-width:72px;max-height:72px;object-fit:contain;display:block;margin:0 auto 4px}
.invoice-head-clean h1{font-size:20px;line-height:1.1;color:#e11d1d;margin:4px 0 3px;text-transform:uppercase;font-weight:900}
.invoice-head-clean p{font-size:12px;line-height:1.15;margin:2px 0;color:#08706d;font-weight:700}
.invoice-title{text-align:center;color:#dc2626;font-weight:900;text-decoration:underline;margin:10px 0 8px;font-size:14px;letter-spacing:.02em}
.invoice-info-table{width:100%;border-collapse:collapse;table-layout:fixed;margin:0 0 -1px 0}
.invoice-info-table td{border:1.4px solid #26364a;padding:5px 7px;font-size:12px;vertical-align:top;color:#0b2142}
.invoice-info-table .bill-to{width:55%}.invoice-info-table .invoice-meta{width:45%}
.invoice-table{width:100%;border-collapse:collapse;table-layout:fixed;margin:0}
.invoice-table th,.invoice-table td{border:1.4px solid #26364a;padding:5px 7px;font-size:12px;vertical-align:top;color:#0b2142}
.invoice-table th{background:#dbeeed;text-align:center;text-transform:none;font-size:12px;font-weight:800;letter-spacing:0}
.invoice-table small{font-size:11px;color:#334155}
.invoice-bottom-table{width:100%;border-collapse:collapse;table-layout:fixed;margin:-1px 0 0 0}
.invoice-bottom-table td{border:1.4px solid #26364a;padding:5px 7px;font-size:12px;vertical-align:top;color:#0b2142}
.invoice-bottom-table .payment-cell{width:55%;font-size:12px;line-height:1.35}
.invoice-bottom-table .label-cell{width:23%;font-weight:800;color:#08706d;text-align:left}
.invoice-bottom-table .value-cell{width:22%;font-weight:800;text-align:right;color:#08706d}
.invoice-bottom-table .balance{color:#dc2626!important}
.signature-cell{text-align:center;height:52mm;vertical-align:middle!important}
.invoice-bottom-logo img{max-width:95px!important;max-height:55px!important;object-fit:contain!important;display:block!important;margin:4px auto 5px!important}
.invoice-bottom-logo .badge{margin:5px auto!important;transform:scale(.8)}
.invoice-footer-text{font-size:11px;margin:8px 0 0;color:#0b2142;text-align:left;line-height:1.45}.invoice-footer-text div{margin:2px 0;display:block}
@media print{body{background:#fff!important}.invoice-a4{width:190mm;min-height:auto;max-width:190mm;padding:0;box-shadow:none;margin:0 auto;font-size:12px}.invoice-head-clean img{max-width:70px;max-height:70px}.invoice-bottom-logo img{max-width:90px!important;max-height:52px!important}@page{size:A4 portrait;margin:10mm}}

/* Update invoice logo, signature, and stamp */
.profile-image-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:14px 0;padding:12px;border:1px dashed #cbd5e1;border-radius:12px;background:#f8fafc;text-align:center}
.profile-image-preview img{max-width:110px;max-height:80px;object-fit:contain;margin:8px auto 0;display:block}
.small-text{font-size:12px;color:#64748b;display:inline-block;margin-top:10px}.invoice-sign-preview{text-align:center;border:1px dashed #cbd5e1;border-radius:12px;padding:12px;margin:14px 0;background:#f8fafc}
.invoice-head-clean img{max-width:118px!important;max-height:118px!important;margin:0 auto 6px!important;object-fit:contain!important}
.invoice-head-clean h1{font-size:24px!important;line-height:1.05!important;margin:4px 0 2px!important}
.invoice-head-clean p{font-size:13px!important;line-height:1.2!important}
.stamp-sign-wrap{position:relative;min-height:72px;display:flex;justify-content:center;align-items:center;gap:8px;margin:5px auto 8px}.stamp-img{max-width:92px!important;max-height:72px!important;object-fit:contain!important;display:inline-block!important}.signature-img{max-width:150px!important;max-height:72px!important;object-fit:contain!important;display:inline-block!important}.invoice-approval{text-align:center;min-height:85px;display:flex;flex-direction:column;justify-content:center;align-items:center}.invoice-approval b{font-size:12px}.signature-cell{height:56mm!important;vertical-align:middle!important}.signature-cell .stamp-sign-wrap{min-height:85px}.signature-cell .stamp-img{max-width:110px!important;max-height:82px!important}.signature-cell .signature-img{max-width:175px!important;max-height:82px!important}
@media print{.invoice-head-clean img{max-width:112px!important;max-height:112px!important}.invoice-head-clean h1{font-size:23px!important}.invoice-head-clean p{font-size:12.5px!important}.signature-cell .stamp-img{max-width:105px!important;max-height:78px!important}.signature-cell .signature-img{max-width:165px!important;max-height:78px!important}}
@media(max-width:900px){.profile-image-preview{grid-template-columns:1fr}}

/* Update Karyawan / Penggajian separate menu and A4 slip gaji */
.slip-a4{width:210mm;min-height:297mm;max-width:210mm;margin:0 auto;background:#fff;color:#000;font-family:Arial,sans-serif;font-size:12px;line-height:1.35;padding:14mm 16mm;box-shadow:0 12px 35px rgba(15,23,42,.12)}
.slip-logo{text-align:center;margin-bottom:4px}.slip-logo img{max-width:86px;max-height:86px;object-fit:contain;display:block;margin:0 auto 6px}.slip-logo .badge{margin:0 auto 6px}
.slip-title{text-align:center;border:2px solid #000;border-bottom:0;padding:10px 8px 8px}.slip-title h2{font-size:18px;margin:0 0 14px;text-transform:uppercase;font-weight:900}.slip-title h3{font-size:16px;margin:0 0 10px;text-decoration:underline;font-weight:900}.slip-title h4{font-size:14px;margin:0;font-weight:900}
.slip-section{border:2px solid #000;padding:12px 0}.slip-info{display:grid;grid-template-columns:1.2fr 1fr;gap:8px 30px;border-top:2px solid #000;border-bottom:0}.slip-info>div{display:grid;grid-template-columns:95px 14px 1fr;padding:0 0;font-size:12px}.slip-info b,.slip-info strong{font-size:12px}
.slip-table{width:100%;border-collapse:collapse;border:2px solid #000}.slip-table th,.slip-table td{border:0;border-bottom:0;padding:7px 0;font-size:12px;color:#000;background:#fff}.slip-table th.yellow{background:#ffff00!important;color:#000;text-align:left;border-top:2px solid #000;border-bottom:2px solid #000;padding:5px 6px;font-weight:900}.slip-table td:first-child{width:105px;padding-left:0}.slip-table td:nth-child(2){width:14px}.slip-table .takehome th{background:#00b050!important;color:#000;text-align:left;border-top:2px solid #000;border-bottom:2px solid #000;padding:8px 6px;font-weight:900}.slip-table .takehome td{border-top:2px solid #000;border-bottom:2px solid #000;font-weight:900;padding:8px 0}.slip-actions{max-width:210mm;margin:12px auto;display:flex;gap:10px;justify-content:center}.print-section{break-inside:avoid}
@media print{body{background:#fff!important;font-size:12px!important}.slip-a4{width:178mm;min-height:auto;max-width:178mm;margin:0 auto;box-shadow:none;padding:0;font-size:12px}.slip-logo img{max-width:82px;max-height:82px}.slip-title h2{font-size:18px}.slip-title h3{font-size:16px}.slip-title h4{font-size:14px}.slip-info b,.slip-info strong,.slip-table th,.slip-table td{font-size:12px!important}@page{size:A4 portrait;margin:16mm}}

/* Update Sales/Customer + Stock collapsible forms and edit actions */
.toggle-card{padding:0;overflow:hidden}.toggle-card summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 18px;border-bottom:1px solid var(--line);background:linear-gradient(135deg,#fff,#f8fbff)}.toggle-card summary::-webkit-details-marker{display:none}.toggle-card summary h3{margin:0 0 4px}.toggle-card summary p{margin:0;color:#475569;font-size:12px}.toggle-card:not([open]) summary{border-bottom:0}.form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:16px}.row-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.btn.green{background:#10b981;color:#fff;border-color:#10b981}.btn.primary{background:#2563eb;color:#fff;border-color:#2563eb}.btn.small{padding:7px 10px;font-size:12px;border-radius:9px}.card-head p{margin:3px 0 0;color:#64748b;font-size:12px}small{color:#64748b;font-size:11px}.item-row{display:grid;grid-template-columns:1.2fr 1fr 130px auto;gap:10px;align-items:end;margin-top:10px;padding:10px;border:1px solid #dbeafe;border-radius:12px;background:#f8fbff}
@media(max-width:900px){.item-row{grid-template-columns:1fr}.grid.grid-2{grid-template-columns:1fr!important}.row-actions{flex-direction:column;align-items:flex-start}}

/* Update Input Penjualan collapse, export penjualan, invoice print buttons */
.export-filter{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr auto;gap:12px;align-items:end}
.export-actions{display:flex;gap:8px;align-items:end}.report-landscape{background:#fff;color:#0f172a;padding:16px;max-width:1120px;margin:0 auto;font-size:12px}.report-head{display:grid;grid-template-columns:90px 1fr auto;gap:14px;align-items:center;border-bottom:2px solid #0f172a;padding-bottom:10px;margin-bottom:12px}.report-head img{max-width:82px;max-height:82px;object-fit:contain}.report-head h1{margin:0;font-size:22px;color:#0f172a;text-transform:uppercase}.report-head p{margin:3px 0 0;font-size:12px;color:#334155}.report-head span{font-size:11px;white-space:nowrap}.report-landscape h2{font-size:20px;margin:8px 0 4px}.report-total{border:1px solid #cbd5e1;background:#f8fafc;border-radius:10px;padding:10px 12px;margin-top:10px}
/* make stamp and signature closer/touching on invoice */
.stamp-sign-wrap{gap:0!important}.stamp-img{margin-right:-10px!important;z-index:2;position:relative}.signature-img{margin-left:-10px!important;z-index:1;position:relative}.signature-cell .stamp-img{margin-right:-14px!important}.signature-cell .signature-img{margin-left:-14px!important}
@media(max-width:1000px){.export-filter{grid-template-columns:1fr 1fr}.export-actions{grid-column:1/-1}.report-head{grid-template-columns:70px 1fr}.report-head span{grid-column:1/-1}}
@media print{.report-landscape{page:landscape;max-width:none;padding:0;font-size:12px}.report-landscape .table-wrap{overflow:visible}.report-landscape th,.report-landscape td{font-size:10px;padding:5px 6px}.report-head{grid-template-columns:82px 1fr auto}.report-head img{max-width:76px;max-height:76px}@page landscape{size:A4 landscape;margin:10mm}}

/* Compact one-row sales export toolbar */
.compact-export-card .card-head{padding:14px 18px}.compact-export-card .card-body{padding:14px 18px}.export-filter-compact{display:grid!important;grid-template-columns:180px 190px 1fr auto!important;gap:12px!important;align-items:end!important}.export-filter-compact label{margin-bottom:5px}.export-filter-compact .input{height:38px;padding:8px 11px}.export-period-badge{min-height:38px;display:flex;align-items:center;padding:8px 12px;border-radius:11px;background:#eff6ff;border:1px dashed #93c5fd;color:#1e3a8a;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.export-filter-compact .export-actions{display:flex;align-items:end;justify-content:flex-end}.export-filter-compact .btn{height:38px;white-space:nowrap}
@media(max-width:900px){.export-filter-compact{grid-template-columns:1fr 1fr!important}.export-period-badge,.export-filter-compact .export-actions{grid-column:1/-1}.export-filter-compact .export-actions{justify-content:flex-start}}

/* Update Invoice Penjualan: logo lebih besar dan tabel komisi sales/mitra */
.report-sales-detail .report-head,
.report-head-big-logo{
  grid-template-columns:120px 1fr auto;
  gap:18px;
  align-items:center;
}
.report-sales-detail .report-head img,
.report-head-big-logo img{
  max-width:112px!important;
  max-height:112px!important;
  object-fit:contain!important;
}
.report-sales-detail .report-head h1,
.report-head-big-logo h1{
  font-size:24px!important;
  line-height:1.1;
}
.report-sales-detail .report-head p,
.report-head-big-logo p{
  font-size:13px!important;
  line-height:1.35;
}
.report-sales-detail th,
.report-sales-detail td{
  font-size:11.5px;
}
@media print{
  .report-sales-detail .report-head,
  .report-head-big-logo{grid-template-columns:110px 1fr auto;gap:16px;}
  .report-sales-detail .report-head img,
  .report-head-big-logo img{max-width:104px!important;max-height:104px!important;}
  .report-sales-detail .report-head h1,
  .report-head-big-logo h1{font-size:23px!important;}
  .report-sales-detail .report-head p,
  .report-head-big-logo p{font-size:12.5px!important;}
}

/* Update Karyawan + Penggajian collapse cards */
.collapsible-card summary.card-head{cursor:pointer;list-style:none;user-select:none}
.collapsible-card summary.card-head::-webkit-details-marker{display:none}
.collapsible-card .when-open{display:none}
.collapsible-card[open] .when-open{display:inline}
.collapsible-card[open] .when-closed{display:none}
.collapsible-card .form-actions{margin-top:16px;display:flex;justify-content:flex-end;gap:10px}
.collapsible-card:not([open]){box-shadow:0 6px 18px rgba(15,23,42,.04)}
.collapsible-card:not([open]) summary.card-head{border-bottom:0}

/* Update 2026-05: default collapsed input forms, professional Laba/Rugi export, larger slip logo inside border */
#invoiceFormWrap:not([open]) .card-body,
#expenseFormWrap:not([open]) .card-body{display:none}
.profit-report{font-size:12px;line-height:1.35}.profit-report .report-head{margin-bottom:14px}.profit-report .report-subtitle{margin:0 0 12px;color:#475569}.profit-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:12px 0}.profit-kpis>div{border:1px solid #cbd5e1;border-radius:10px;padding:10px 12px;background:#f8fafc}.profit-kpis small{display:block;text-transform:uppercase;font-weight:900;color:#64748b;font-size:10px;margin-bottom:5px}.profit-kpis b{font-size:16px}.profit-columns{display:grid;grid-template-columns:1.1fr .9fr;gap:14px;margin-top:10px}.profit-columns h3{font-size:14px;margin:0 0 8px}.report-table{width:100%;border-collapse:collapse}.report-table th,.report-table td{border:1px solid #cbd5e1;padding:7px 8px;font-size:11px;vertical-align:top}.report-table th{background:#e2e8f0;text-transform:uppercase;font-size:9.5px}.report-table .money{text-align:right;font-weight:800}.report-table .center{text-align:center}.profit-report .report-total{font-size:12px;margin-top:12px}.slip-title .slip-logo{margin:0 auto 8px;text-align:center}.slip-title .slip-logo img{max-width:172px!important;max-height:172px!important;object-fit:contain;display:block;margin:0 auto 8px}.slip-title{padding-top:12px}.slip-title h2{margin-top:0!important}
@media print{.profit-report{page:landscape;max-width:none;padding:0}.profit-kpis{gap:8px}.profit-columns{grid-template-columns:1.1fr .9fr;gap:10px}.profit-report .report-table th,.profit-report .report-table td{font-size:10.5px;padding:6px}.slip-title .slip-logo img{max-width:164px!important;max-height:164px!important}.slip-title{padding-top:10px!important}@page landscape{size:A4 landscape;margin:10mm}}
@media(max-width:900px){.profit-kpis,.profit-columns{grid-template-columns:1fr}.profit-report .report-head{grid-template-columns:80px 1fr}}

/* Update user password access: account dropdown and forgot password */
.login-links{margin-top:14px;text-align:center;font-weight:800;font-size:13px}
.login-links a{color:#2563eb;text-decoration:none}
.login-links a:hover{text-decoration:underline}
.account-menu{position:relative;display:inline-block}
.account-menu summary{list-style:none;cursor:pointer}
.account-menu summary::-webkit-details-marker{display:none}
.account-dropdown{position:absolute;right:0;top:48px;width:330px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 24px 60px rgba(15,23,42,.18);padding:14px;z-index:100;color:#0f172a}
.account-dropdown:before{content:"";position:absolute;right:24px;top:-8px;width:14px;height:14px;background:#fff;border-left:1px solid var(--line);border-top:1px solid var(--line);transform:rotate(45deg)}
.account-title{padding:2px 2px 10px;border-bottom:1px solid var(--line);margin-bottom:12px}
.account-title b{display:block;font-size:15px}
.account-title small{display:block;color:#64748b;margin-top:3px;font-size:12px}
.account-dropdown label{margin-top:9px}
.account-dropdown .input{height:38px;padding:8px 10px;margin-bottom:8px}
.account-dropdown hr{border:0;border-top:1px solid var(--line);margin:14px 0}
@media(max-width:900px){.account-dropdown{right:-90px;width:300px}.top-actions{gap:6px}.user-pill span{display:none}}
@media print{.account-menu{display:none!important}}

.money-input{text-align:left;font-weight:700}

/* DKK FLOOR premium login - patch only, all app features preserved */
.dkk-login-page{min-height:100vh;display:grid;grid-template-columns:minmax(0,1.06fr) minmax(430px,.94fr);overflow:hidden;background:#f8fafc;color:#0f172a;position:relative;font-family:Inter,Arial,sans-serif}
.dkk-brand-panel{position:relative;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:clamp(28px,4vw,60px);background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(255,255,255,.80)),radial-gradient(circle at 20% 80%,rgba(14,165,233,.10),transparent 32%),linear-gradient(180deg,#fff,#eef4f8);overflow:hidden}
.dkk-brand-panel:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.7),rgba(255,255,255,.3)),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='900' height='620'%3E%3Crect width='900' height='620' fill='white'/%3E%3Cg opacity='.14' stroke='%2394a3b8' stroke-width='2' fill='none'%3E%3Cpath d='M80 520V160h650v360M120 520V210h570M160 520V250h480M210 520V120M300 520V100M390 520V130M480 520V105M570 520V150M660 520V180'/%3E%3C/g%3E%3C/svg%3E") center/cover no-repeat;opacity:.62}
.dkk-swoosh{position:absolute;border-radius:50%;pointer-events:none;filter:drop-shadow(0 20px 40px rgba(15,23,42,.10))}
.dkk-red{width:520px;height:520px;left:-350px;top:-340px;border:58px solid #e7362e;border-bottom-color:transparent;border-right-color:transparent;transform:rotate(-18deg)}
.dkk-yellow{width:610px;height:610px;left:-410px;top:-395px;border:54px solid #f8c51f;border-bottom-color:transparent;border-right-color:transparent;transform:rotate(-18deg)}
.dkk-green{width:1080px;height:880px;left:-425px;bottom:-430px;border:68px solid #20994a;border-top-color:transparent;border-right-color:transparent;transform:rotate(-8deg)}
.dkk-blue{width:820px;height:660px;left:-310px;bottom:-470px;border:72px solid #0759bd;border-top-color:transparent;border-right-color:transparent;transform:rotate(-8deg)}
.dkk-brand-content{position:relative;z-index:2;text-align:center;max-width:620px;width:100%;margin-top:2vh}.dkk-main-logo{width:min(430px,76%);height:auto;object-fit:contain;margin:0 auto 34px;display:block;filter:drop-shadow(0 8px 16px rgba(15,23,42,.10))}.dkk-brand-content h1{font-size:clamp(28px,3.1vw,44px);line-height:1.05;margin:0 0 18px;font-weight:900;letter-spacing:.02em;color:#111827}.dkk-brand-content p{font-size:clamp(14px,1.15vw,18px);line-height:1.65;color:#64748b;max-width:570px;margin:0 auto 42px}.dkk-features{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:600px;margin:0 auto}.dkk-features div{background:rgba(255,255,255,.82);border:1px solid rgba(226,232,240,.88);box-shadow:0 18px 40px rgba(15,23,42,.08);border-radius:18px;padding:18px 10px;backdrop-filter:blur(10px)}.dkk-features span{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;margin:0 auto 10px;font-weight:900;font-size:24px;background:#fff}.dkk-features div:nth-child(1) span{color:#169b4a}.dkk-features div:nth-child(2) span{color:#f7bf13}.dkk-features div:nth-child(3) span{color:#ef3b2d}.dkk-features div:nth-child(4) span{color:#0d63d5}.dkk-features b{display:block;font-size:12px;color:#334155;line-height:1.25}.dkk-login-panel{position:relative;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:clamp(22px,3.2vw,56px);background:radial-gradient(circle at 20% 0%,rgba(34,197,94,.18),transparent 34%),linear-gradient(145deg,#f8fafc,#ffffff 40%,#eaf2ff 100%)}.dkk-login-panel:after{content:"";position:absolute;right:-140px;bottom:-170px;width:520px;height:520px;border-radius:50%;background:linear-gradient(135deg,#0b4fb3,#003074);opacity:.98}.dkk-login-card{position:relative;z-index:2;width:min(500px,100%);background:rgba(255,255,255,.96);border:1px solid rgba(226,232,240,.92);border-radius:26px;padding:clamp(28px,3.3vw,48px);box-shadow:0 30px 90px rgba(15,23,42,.18);backdrop-filter:blur(14px)}.dkk-login-head{text-align:center;margin-bottom:28px}.dkk-login-head h2{margin:0 0 8px;font-size:clamp(24px,2.2vw,32px);line-height:1.1;font-weight:900;color:#172033}.dkk-login-head p{margin:0 0 26px;color:#64748b;font-weight:600}.dkk-login-head img{width:min(270px,74%);height:auto;display:block;margin:0 auto}.dkk-login-card label{font-size:13px;font-weight:800;color:#334155;margin-bottom:8px}.dkk-input{display:flex;align-items:center;gap:12px;width:100%;border:1px solid #d5dde8;border-radius:13px;background:#fff;padding:0 14px;margin-bottom:16px;box-shadow:0 6px 14px rgba(15,23,42,.035)}.dkk-input span{width:22px;text-align:center;color:#64748b}.dkk-input input{border:0;outline:0;background:transparent;width:100%;padding:15px 0;font-size:15px;color:#0f172a}.dkk-input:focus-within{border-color:#1d8f45;box-shadow:0 0 0 4px rgba(34,197,94,.12)}.dkk-login-row{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:8px 0 22px;font-size:13px}.dkk-login-row a{color:#0b63ce;font-weight:800}.dkk-check{display:flex!important;align-items:center;gap:8px;margin:0!important;color:#64748b!important;font-weight:700!important}.dkk-check input{width:16px;height:16px}.dkk-login-btn{width:100%;height:58px;border:0;border-radius:13px;cursor:pointer;color:#fff;font-size:17px;font-weight:900;background:linear-gradient(90deg,#159947 0%,#7daf1f 31%,#ffa20b 62%,#ec1d25 100%);box-shadow:0 14px 26px rgba(236,29,37,.18);transition:transform .15s ease,filter .15s ease}.dkk-login-btn:hover{transform:translateY(-1px);filter:saturate(1.08)}.dkk-divider{display:flex;align-items:center;gap:14px;margin:26px 0 22px;color:#94a3b8;font-weight:700;font-size:13px}.dkk-divider:before,.dkk-divider:after{content:"";height:1px;background:#e2e8f0;flex:1}.dkk-role-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dkk-role-grid div{border:1px solid #e2e8f0;border-radius:14px;background:#fff;padding:17px 16px;text-align:center;box-shadow:0 12px 26px rgba(15,23,42,.06)}.dkk-role-grid strong{display:block;font-size:17px;color:#15803d;margin-bottom:5px}.dkk-role-grid div:nth-child(2) strong{color:#0b63ce}.dkk-role-grid small{display:block;color:#64748b;font-weight:600}.dkk-login-card footer{text-align:center;color:#94a3b8;font-size:12px;font-weight:700;margin-top:28px}.dkk-login-card .alert,.dkk-login-card .notice{margin:0 0 16px!important}@media(max-width:980px){.dkk-login-page{grid-template-columns:1fr;overflow:auto}.dkk-brand-panel{min-height:auto;padding:34px 22px 24px}.dkk-brand-content{margin:0}.dkk-main-logo{width:min(330px,82%);margin-bottom:20px}.dkk-brand-content h1{font-size:28px}.dkk-brand-content p{font-size:14px;margin-bottom:24px}.dkk-features{grid-template-columns:repeat(2,1fr);gap:10px}.dkk-login-panel{min-height:auto;padding:24px 16px 38px}.dkk-login-panel:after{display:none}.dkk-login-card{max-width:520px}.dkk-red{width:430px;height:430px;left:-310px;top:-315px}.dkk-yellow{width:500px;height:500px;left:-360px;top:-355px}.dkk-green{width:760px;height:620px;left:-330px;bottom:-385px}.dkk-blue{width:600px;height:480px;left:-280px;bottom:-360px}}@media(max-height:720px) and (min-width:981px){.dkk-main-logo{width:min(350px,70%);margin-bottom:22px}.dkk-brand-content h1{font-size:34px;margin-bottom:12px}.dkk-brand-content p{font-size:15px;margin-bottom:26px}.dkk-features div{padding:13px 8px}.dkk-features span{width:40px;height:40px;font-size:20px}.dkk-login-card{padding:30px}.dkk-login-head{margin-bottom:20px}.dkk-login-head img{width:220px}.dkk-input input{padding:12px 0}.dkk-login-btn{height:52px}.dkk-divider{margin:18px 0}.dkk-role-grid div{padding:13px 12px}.dkk-login-card footer{margin-top:18px}}

/* =========================================================
   DKK FLOOR Premium Internal Theme
   Basis fitur tetap dari paket Rupiah + Bonus Sync + Catatan Invoice.
   Perubahan ini hanya menyentuh tampilan dashboard/menu setelah login.
   ========================================================= */
:root{
  --dkk-red:#e92722;
  --dkk-yellow:#f8c20d;
  --dkk-green:#169b4b;
  --dkk-blue:#0756bd;
  --dkk-navy:#071429;
  --dkk-ink:#0b1b33;
  --dkk-soft:#eef8f4;
  --dkk-border:#d9e6f2;
  --dkk-card:#ffffff;
  --primary:#0b66d8;
  --green:#11b873;
  --red:#ef4444;
  --bg:#f4f9fb;
  --line:#dbe7f0;
}
body{
  background:
    radial-gradient(circle at 8% 0%, rgba(233,39,34,.13), transparent 28%),
    radial-gradient(circle at 28% 0%, rgba(248,194,13,.13), transparent 25%),
    radial-gradient(circle at 78% 0%, rgba(22,155,75,.13), transparent 28%),
    linear-gradient(135deg,#f8fbff 0%,#eef8f4 48%,#eef5ff 100%);
  color:var(--dkk-ink);
}
.layout{grid-template-columns:254px 1fr;background:transparent}.layout>section{min-width:0;background:linear-gradient(180deg,rgba(255,255,255,.75),rgba(239,248,255,.8))}.sidebar{
  background:
    radial-gradient(circle at 12% 5%, rgba(255,255,255,.12), transparent 18%),
    linear-gradient(180deg,#061427 0%,#0a1b34 56%,#061225 100%);
  border-right:1px solid rgba(255,255,255,.06);
  box-shadow:18px 0 38px rgba(7,20,41,.18);
}
.sidebar:before{content:"";position:absolute;left:0;top:0;width:5px;height:100%;background:linear-gradient(180deg,var(--dkk-red),var(--dkk-yellow),var(--dkk-green),var(--dkk-blue))}.brand{padding:6px 4px 22px;margin-bottom:18px;border-bottom:1px solid rgba(255,255,255,.08)}.brand h1{font-size:17px;letter-spacing:.01em}.brand p{color:#bdd7f9}.badge{background:linear-gradient(135deg,var(--dkk-green),var(--dkk-blue));box-shadow:0 10px 22px rgba(6,182,212,.25)}.app-brand-logo{width:52px;height:52px;object-fit:contain;border-radius:14px;background:#fff;padding:5px;box-shadow:0 14px 26px rgba(0,0,0,.25)}.nav a{position:relative;margin:7px 0;padding:13px 14px 13px 17px;border:1px solid transparent;color:#eaf6ff;transition:.18s ease}.nav a:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.10);transform:translateX(2px)}.nav a.active{background:linear-gradient(90deg,rgba(22,155,75,.95),rgba(7,86,189,.92));border-color:rgba(255,255,255,.20);box-shadow:0 12px 24px rgba(7,86,189,.22)}.nav a.active:before{content:"";position:absolute;left:7px;top:50%;transform:translateY(-50%);width:4px;height:22px;border-radius:999px;background:var(--dkk-yellow)}.sidebar-foot{left:22px;color:#c9e4ff;line-height:1.45}.topbar{height:72px;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--dkk-border);box-shadow:0 8px 26px rgba(15,23,42,.05)}.topbar h2{font-size:21px;font-weight:900;color:#081831}.topbar h2:after{content:"";display:block;width:54px;height:4px;border-radius:99px;margin-top:8px;background:linear-gradient(90deg,var(--dkk-green),var(--dkk-yellow),var(--dkk-red))}.user-pill{background:#fff;border:1px solid #d7e5ef;box-shadow:0 8px 20px rgba(15,23,42,.06)}.avatar{background:linear-gradient(135deg,var(--dkk-blue),var(--dkk-green));box-shadow:0 6px 14px rgba(7,86,189,.22)}.main{padding:26px;background:transparent}.card{border:1px solid rgba(204,221,234,.95);border-radius:22px;box-shadow:0 18px 45px rgba(7,20,41,.08);overflow:hidden;background:rgba(255,255,255,.94)}.card:before{content:"";display:block;height:4px;background:linear-gradient(90deg,var(--dkk-red),var(--dkk-yellow),var(--dkk-green),var(--dkk-blue))}.card-head{background:linear-gradient(180deg,#ffffff,#f8fbff);padding:17px 20px}.card-head h3{font-size:17px;font-weight:900;color:#081831}.card-head p{margin:5px 0 0;color:#55708a}.card-body{padding:20px}.hero{background:linear-gradient(135deg,#081831 0%,#0b438f 46%,#109652 100%);box-shadow:0 22px 50px rgba(7,86,189,.22);border:1px solid rgba(255,255,255,.14);position:relative;overflow:hidden}.hero:before{content:"";position:absolute;left:-120px;top:-150px;width:430px;height:430px;border-radius:50%;background:radial-gradient(circle,rgba(248,194,13,.35),rgba(233,39,34,.2),transparent 68%)}.hero>*{position:relative}.hero h1{font-weight:900;letter-spacing:.01em}.kpi{border-radius:20px;border:1px solid rgba(213,228,238,.95);box-shadow:0 14px 34px rgba(7,20,41,.07)}.kpi:after{background:linear-gradient(135deg,rgba(22,155,75,.18),rgba(7,86,189,.16));width:92px;height:92px}.kpi small{color:#58718b}.kpi b{color:#071429}.btn{border-radius:12px;box-shadow:0 6px 16px rgba(15,23,42,.05);transition:.16s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 11px 23px rgba(15,23,42,.10)}.btn.primary{background:linear-gradient(135deg,var(--dkk-blue),#2f74ff);border-color:#1768e7;color:#fff}.btn.green{background:linear-gradient(135deg,var(--dkk-green),#18c98b);border-color:#12a86a;color:#fff}.btn.red{background:linear-gradient(135deg,#fff1f1,#fee2e2);color:#b91c1c;border-color:#fecaca}.top-actions .btn:first-child{background:#fff;color:#0b438f;border-color:#d5e4ee}.input,select,textarea{border-radius:13px;border:1px solid #cddceb;background:#fff;box-shadow:inset 0 1px 0 rgba(15,23,42,.02);transition:.16s ease}.input:focus,select:focus,textarea:focus{outline:none;border-color:#0b66d8;box-shadow:0 0 0 4px rgba(11,102,216,.12)}label{color:#081831;letter-spacing:.01em}.table-wrap{border-radius:16px;border:1px solid #d7e5ef;box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}table{background:#fff}th{background:linear-gradient(180deg,#f9fbff,#eef5ff);color:#092140;border-bottom:1px solid #d7e5ef;font-size:11px}td{border-bottom:1px solid #e5edf4}tbody tr:hover{background:#fbfeff}.status{box-shadow:inset 0 0 0 1px rgba(255,255,255,.55)}.status.green{background:#dcfce7;color:#116232}.status.red{background:#ffe3e3;color:#9b1717}.status.yellow{background:#fff2c2;color:#7a5600}.notice{background:linear-gradient(90deg,#eff6ff,#ecfdf5);border:1px dashed #79b6ff;color:#0b438f}.collapsible-card summary,.toggle-card summary{cursor:pointer;list-style:none}.collapsible-card summary::-webkit-details-marker,.toggle-card summary::-webkit-details-marker{display:none}.form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:14px}.row-actions .btn{white-space:nowrap}.profile-image-preview{background:linear-gradient(180deg,#f8fbff,#f1fbf7);border-color:#b9d5ef}.invoice-a4,.slip-page,.report-page{box-shadow:0 18px 48px rgba(7,20,41,.10)}
@media(max-width:900px){.layout{grid-template-columns:1fr}.sidebar:before{width:100%;height:4px}.brand{margin-bottom:10px}.topbar h2:after{display:none}.main{padding:16px}.card{border-radius:18px}}
@media print{.card:before,.topbar h2:after,.sidebar:before{display:none!important}.btn:hover{transform:none;box-shadow:none}.layout>section{background:#fff!important}}

/* Update: collapsible premium sidebar + menu icons */
.top-title{display:flex;align-items:center;gap:14px;min-width:0}
.sidebar-toggle{width:44px;height:44px;border-radius:14px;border:1px solid #d7e5ef;background:#fff;display:inline-grid;place-items:center;gap:3px;padding:10px;cursor:pointer;box-shadow:0 8px 20px rgba(15,23,42,.06);transition:.18s ease;flex:0 0 44px}
.sidebar-toggle:hover{transform:translateY(-1px);box-shadow:0 13px 28px rgba(15,23,42,.10);border-color:#a9c7e2}
.sidebar-toggle span{display:block;width:18px;height:2px;border-radius:99px;background:linear-gradient(90deg,var(--dkk-green,#159947),var(--dkk-blue,#0b63ce));transition:.18s ease}
.nav a{display:flex!important;align-items:center;gap:12px;min-height:48px}
.nav-icon{width:32px;height:32px;border-radius:12px;background:rgba(255,255,255,.10);display:grid;place-items:center;font-size:17px;flex:0 0 32px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.nav a.active .nav-icon{background:#fff;color:#0b438f;box-shadow:0 9px 18px rgba(0,0,0,.16)}
.nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:.16s ease}
html.sidebar-collapsed .layout{grid-template-columns:82px 1fr}
html.sidebar-collapsed .sidebar{padding:16px 12px}
html.sidebar-collapsed .brand{justify-content:center;padding-bottom:16px}
html.sidebar-collapsed .brand-text,html.sidebar-collapsed .nav-label,html.sidebar-collapsed .sidebar-foot{display:none!important}
html.sidebar-collapsed .app-brand-logo{width:48px;height:48px}
html.sidebar-collapsed .nav a{justify-content:center;padding:11px!important;border-radius:16px;margin:8px 0;transform:none!important}
html.sidebar-collapsed .nav a.active:before{left:4px;height:26px}
html.sidebar-collapsed .nav-icon{width:38px;height:38px;font-size:19px;background:rgba(255,255,255,.12)}
html.sidebar-collapsed .sidebar-toggle span:nth-child(1){transform:translateY(5px) rotate(45deg)}
html.sidebar-collapsed .sidebar-toggle span:nth-child(2){opacity:0}
html.sidebar-collapsed .sidebar-toggle span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}
html.sidebar-collapsed .topbar h2:after{width:42px}
.layout,.sidebar,.layout>section,.brand-text,.nav-label,.sidebar-foot{transition:all .22s ease}
@media(max-width:900px){
  .topbar{padding:0 14px;height:auto;min-height:66px;gap:12px;align-items:center}.top-title h2{font-size:18px}.top-actions{gap:6px}.top-actions .btn{padding:8px 10px}.user-pill span{display:none}
  html.sidebar-collapsed .layout,.layout{grid-template-columns:1fr!important}
  .sidebar{position:relative;height:auto;padding:14px 16px!important}.brand{margin-bottom:8px}.nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.nav a{margin:0!important;justify-content:flex-start!important}.sidebar-foot{position:static!important;margin-top:10px}.brand-text,.nav-label,.sidebar-foot{display:block!important}
  html.sidebar-collapsed .nav{display:none}html.sidebar-collapsed .brand-text,html.sidebar-collapsed .sidebar-foot{display:none!important}
}
@media print{.sidebar-toggle,.nav-icon{display:none!important}}

/* Hotfix: sidebar auto-collapse and compact menu spacing */
.sidebar{
  display:flex;
  flex-direction:column;
  overflow-y:auto;
  scrollbar-width:thin;
}
.nav{
  flex:1;
  padding:4px 0 10px;
}
.brand{
  margin-bottom:10px!important;
  padding-bottom:14px!important;
}
.nav a{
  min-height:40px!important;
  margin:3px 0!important;
  padding:8px 12px 8px 14px!important;
  border-radius:13px!important;
  gap:10px!important;
  line-height:1.1!important;
}
.nav-icon{
  width:28px!important;
  height:28px!important;
  border-radius:10px!important;
  font-size:15px!important;
  flex-basis:28px!important;
}
.nav a.active:before{
  left:6px!important;
  height:18px!important;
}
.sidebar-foot{
  position:static!important;
  left:auto!important;
  bottom:auto!important;
  margin-top:auto!important;
  padding:10px 4px 0!important;
  font-size:11px!important;
  line-height:1.3!important;
  border-top:1px solid rgba(255,255,255,.08);
}
html.sidebar-collapsed .layout{grid-template-columns:76px 1fr!important}
html.sidebar-collapsed .sidebar{padding:14px 10px!important}
html.sidebar-collapsed .brand{padding-bottom:12px!important;margin-bottom:8px!important}
html.sidebar-collapsed .app-brand-logo{width:44px!important;height:44px!important}
html.sidebar-collapsed .nav a{
  min-height:38px!important;
  padding:7px!important;
  margin:4px 0!important;
  border-radius:14px!important;
}
html.sidebar-collapsed .nav-icon{width:34px!important;height:34px!important;font-size:17px!important;flex-basis:34px!important}
@media(max-width:1366px) and (min-width:901px){
  .nav a{min-height:38px!important;margin:2px 0!important;padding-top:7px!important;padding-bottom:7px!important}
  .brand h1{font-size:15px!important}.brand p{font-size:11px!important}
}

/* V5 cleanup */
.stacked-forms{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:16px}
.item-row.invoice-item-with-batch{grid-template-columns:.75fr 1.35fr 1fr 120px auto}
@media(max-width:900px){.item-row.invoice-item-with-batch{grid-template-columns:1fr}}

/* V7: rapikan tombol hapus item invoice agar kecil dan sejajar di samping Qty */
.item-row.invoice-item-with-batch{
  grid-template-columns:minmax(180px,.8fr) minmax(280px,1.45fr) minmax(160px,.9fr) minmax(150px,.7fr)!important;
  align-items:end!important;
}
.invoice-qty-action{
  display:grid;
  grid-template-columns:1fr 34px;
  gap:8px;
  align-items:end;
}
.invoice-remove-btn{
  width:34px!important;
  height:34px!important;
  min-width:34px!important;
  padding:0!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-radius:10px!important;
  font-size:15px!important;
  line-height:1!important;
  align-self:end!important;
  margin:0 0 1px 0!important;
}
@media(max-width:900px){
  .item-row.invoice-item-with-batch{grid-template-columns:1fr!important}
  .invoice-qty-action{grid-template-columns:1fr 34px}
}

/* V8: sejajarkan 1 garis item invoice, kecilkan No Batch dan Qty */
.item-row.invoice-item-with-batch{
  grid-template-columns:minmax(150px,.62fr) minmax(250px,1.35fr) minmax(140px,.95fr) 86px 38px !important;
  align-items:end !important;
  column-gap:12px;
}
.item-row.invoice-item-with-batch > div{
  min-width:0;
}
.invoice-batch-field .input{
  max-width:170px;
}
.invoice-qty-field .input{
  width:86px;
  min-width:86px;
  text-align:center;
  padding-left:8px;
  padding-right:8px;
}
.invoice-remove-wrap{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.invoice-remove-wrap label{
  visibility:hidden;
  height:18px;
  margin-bottom:7px;
}
.invoice-remove-btn{
  width:38px !important;
  height:38px !important;
  min-width:38px !important;
  padding:0 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:16px !important;
  line-height:1 !important;
  border-radius:12px !important;
}
@media(max-width:900px){
  .item-row.invoice-item-with-batch{grid-template-columns:1fr !important}
  .invoice-batch-field .input,
  .invoice-qty-field .input{max-width:none;width:100%;min-width:0}
  .invoice-remove-wrap label{display:none}
}

/* V9: paksa tombol X tepat di sebelah kanan Qty */
.item-row.invoice-item-with-batch{
  grid-template-columns:minmax(140px,.62fr) minmax(220px,1.35fr) minmax(130px,.9fr) minmax(128px,.75fr) !important;
  align-items:end !important;
  gap:12px !important;
}
.invoice-batch-field .input{
  max-width:160px !important;
}
.invoice-qty-action{
  display:grid !important;
  grid-template-columns:88px 38px !important;
  gap:8px !important;
  align-items:end !important;
}
.invoice-qty-field .input{
  width:88px !important;
  min-width:88px !important;
  max-width:88px !important;
  text-align:center !important;
  padding-left:8px !important;
  padding-right:8px !important;
}
.invoice-remove-inline{
  display:flex !important;
  flex-direction:column !important;
  justify-content:flex-end !important;
  align-items:flex-start !important;
}
.invoice-remove-inline label{
  visibility:hidden !important;
  height:18px !important;
  margin-bottom:7px !important;
}
.invoice-remove-btn{
  width:38px !important;
  height:38px !important;
  min-width:38px !important;
  margin:0 !important;
  padding:0 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:12px !important;
  font-size:16px !important;
  line-height:1 !important;
}
@media(max-width:900px){
  .item-row.invoice-item-with-batch{grid-template-columns:1fr !important;}
  .invoice-batch-field .input,.invoice-qty-field .input{max-width:none !important; width:100% !important; min-width:0 !important;}
  .invoice-qty-action{grid-template-columns:1fr 38px !important;}
  .invoice-remove-inline label{display:none !important;}
}

/* V10: paksa baris item invoice memakai flex agar X pasti di kanan Qty */
#invoiceItems .item-row.invoice-item-with-batch,
#invoiceItemTemplate .item-row.invoice-item-with-batch{
  display:flex !important;
  flex-wrap:nowrap !important;
  align-items:flex-end !important;
  gap:12px !important;
}
#invoiceItems .item-row.invoice-item-with-batch > div,
#invoiceItemTemplate .item-row.invoice-item-with-batch > div{
  min-width:0 !important;
}
#invoiceItems .item-row.invoice-item-with-batch .invoice-batch-field,
#invoiceItemTemplate .item-row.invoice-item-with-batch .invoice-batch-field{
  flex:0 0 160px !important;
}
#invoiceItems .item-row.invoice-item-with-batch > div:nth-child(2),
#invoiceItemTemplate .item-row.invoice-item-with-batch > div:nth-child(2){
  flex:1 1 290px !important;
}
#invoiceItems .item-row.invoice-item-with-batch > div:nth-child(3),
#invoiceItemTemplate .item-row.invoice-item-with-batch > div:nth-child(3){
  flex:0 0 140px !important;
}
#invoiceItems .item-row.invoice-item-with-batch .invoice-qty-action,
#invoiceItemTemplate .item-row.invoice-item-with-batch .invoice-qty-action{
  flex:0 0 136px !important;
  display:flex !important;
  flex-wrap:nowrap !important;
  align-items:flex-end !important;
  gap:8px !important;
}
#invoiceItems .invoice-qty-field,
#invoiceItemTemplate .invoice-qty-field{
  flex:0 0 90px !important;
}
#invoiceItems .invoice-qty-field .input,
#invoiceItemTemplate .invoice-qty-field .input{
  width:90px !important;
  min-width:90px !important;
  max-width:90px !important;
  text-align:center !important;
}
#invoiceItems .invoice-remove-inline,
#invoiceItemTemplate .invoice-remove-inline{
  flex:0 0 38px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:flex-end !important;
}
#invoiceItems .invoice-remove-inline label,
#invoiceItemTemplate .invoice-remove-inline label{
  visibility:hidden !important;
  height:18px !important;
  margin-bottom:7px !important;
}
#invoiceItems .invoice-remove-btn,
#invoiceItemTemplate .invoice-remove-btn{
  width:38px !important;
  height:38px !important;
  min-width:38px !important;
  margin:0 !important;
  padding:0 !important;
}
@media(max-width:900px){
  #invoiceItems .item-row.invoice-item-with-batch,
  #invoiceItemTemplate .item-row.invoice-item-with-batch{
    display:grid !important;
    grid-template-columns:1fr !important;
  }
  #invoiceItems .item-row.invoice-item-with-batch .invoice-batch-field,
  #invoiceItems .item-row.invoice-item-with-batch > div:nth-child(2),
  #invoiceItems .item-row.invoice-item-with-batch > div:nth-child(3),
  #invoiceItems .item-row.invoice-item-with-batch .invoice-qty-action,
  #invoiceItemTemplate .item-row.invoice-item-with-batch .invoice-batch-field,
  #invoiceItemTemplate .item-row.invoice-item-with-batch > div:nth-child(2),
  #invoiceItemTemplate .item-row.invoice-item-with-batch > div:nth-child(3),
  #invoiceItemTemplate .item-row.invoice-item-with-batch .invoice-qty-action{
    flex:initial !important;
    width:100% !important;
  }
}

/* V13: tanda wajib isi dan notifikasi validasi form */
.required-star{color:#dc2626;font-weight:900;margin-left:2px}
.form-required-notice{display:none;margin:0 0 14px 0;padding:11px 14px;border-radius:12px;background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;font-weight:800}
.input.is-required-error,select.is-required-error,textarea.is-required-error,input.is-required-error{border-color:#ef4444!important;background:#fff7f7!important;box-shadow:0 0 0 3px rgba(239,68,68,.14)!important}

/* V17: Arus Keuangan menu */
.nav-section-title{margin:14px 12px 6px;color:#93c5fd;font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;opacity:.85}
.sidebar-collapsed .nav-section-title{display:none}
.finance-summary{font-weight:800;color:#0f172a}

/* V18: Harga Jual Sales pindah ke Input Penjualan per item */
#invoiceItems .item-row.invoice-item-with-batch,
#invoiceItemTemplate .item-row.invoice-item-with-batch{
  display:flex !important;
  flex-wrap:nowrap !important;
  align-items:flex-end !important;
  gap:10px !important;
}
#invoiceItems .item-row.invoice-item-with-batch .invoice-batch-field,
#invoiceItemTemplate .item-row.invoice-item-with-batch .invoice-batch-field{flex:0 0 140px !important;}
#invoiceItems .item-row.invoice-item-with-batch > div:nth-child(2),
#invoiceItemTemplate .item-row.invoice-item-with-batch > div:nth-child(2){flex:1 1 230px !important;}
#invoiceItems .item-row.invoice-item-with-batch > div:nth-child(3),
#invoiceItemTemplate .item-row.invoice-item-with-batch > div:nth-child(3){flex:0 0 130px !important;}
#invoiceItems .item-row.invoice-item-with-batch .invoice-price-field,
#invoiceItemTemplate .item-row.invoice-item-with-batch .invoice-price-field{flex:0 0 150px !important;}
#invoiceItems .item-row.invoice-item-with-batch .invoice-qty-action,
#invoiceItemTemplate .item-row.invoice-item-with-batch .invoice-qty-action{
  flex:0 0 136px !important;
  display:flex !important;
  flex-wrap:nowrap !important;
  align-items:flex-end !important;
  gap:8px !important;
}
#invoiceItems .invoice-price-field small,
#invoiceItemTemplate .invoice-price-field small{display:block;font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
@media(max-width:900px){
  #invoiceItems .item-row.invoice-item-with-batch,
  #invoiceItemTemplate .item-row.invoice-item-with-batch{display:grid !important;grid-template-columns:1fr !important;}
  #invoiceItems .item-row.invoice-item-with-batch .invoice-batch-field,
  #invoiceItems .item-row.invoice-item-with-batch > div:nth-child(2),
  #invoiceItems .item-row.invoice-item-with-batch > div:nth-child(3),
  #invoiceItems .item-row.invoice-item-with-batch .invoice-price-field,
  #invoiceItems .item-row.invoice-item-with-batch .invoice-qty-action{flex:initial !important;width:100% !important;}
}

/* V19: export invoice tanpa bayangan dan layout Project */
.invoice-a4{box-shadow:none!important;}
.project-report{background:#fff;color:#000;max-width:1120px;margin:0 auto;padding:18px;font-family:Arial,sans-serif;}
.project-report h2{text-align:center;font-size:18px;margin:12px 0 16px;}
.project-box{border:1px solid #111;margin:16px 0 24px;padding:10px;background:#fff;page-break-inside:avoid;}
.project-box h3{margin:0 0 10px;font-size:15px;text-align:left;}
.project-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:14px;align-items:start;}
.project-report .table-wrap{border-radius:0;border:1px solid #111;margin-bottom:10px;}
.project-report table{border-collapse:collapse;}
.project-report th,.project-report td{border:1px solid #111!important;padding:5px 7px!important;font-size:11px!important;color:#000!important;}
.project-report th{background:#fff200!important;text-align:center!important;font-weight:800!important;}
.project-summary th{text-align:left!important;width:55%;}
.project-summary td{text-align:right!important;font-weight:700;}
.reward-report .table-wrap{border-radius:0;border:1px solid #111;}
.reward-report th,.reward-report td{border:1px solid #111!important;padding:5px 7px!important;font-size:11px!important;color:#000!important;text-align:center;}
.reward-report th{background:#d9d9d9!important;font-weight:800!important;}
.reward-report tbody tr:last-child td{background:#fff200!important;font-weight:800!important;}
@media print{.invoice-a4{box-shadow:none!important}.project-report{padding:0;max-width:none}.project-grid{grid-template-columns:1.1fr 1fr!important}.project-box{page-break-inside:avoid}@page{size:A4 landscape;margin:10mm}}


/* V20: invoice A4 presisi dan arus keuangan debit merah + menjorok */
body.invoice-box,
.invoice-box{
  background:#fff !important;
}
.invoice-a4{
  width:190mm !important;
  max-width:190mm !important;
  min-height:277mm !important;
  margin:0 auto !important;
  padding:0 !important;
  box-shadow:none !important;
  border:0 !important;
  page-break-after:auto;
}
.invoice-print{
  max-width:190mm !important;
  margin:0 auto !important;
  padding:0 !important;
  background:#fff !important;
  box-shadow:none !important;
}
.invoice-head-clean{
  margin-bottom:6px !important;
  padding-bottom:6px !important;
}
.invoice-head-clean img{
  max-width:84px !important;
  max-height:84px !important;
}
.invoice-head-clean h1{
  font-size:22px !important;
  margin:3px 0 2px !important;
}
.invoice-head-clean p,
.invoice-info-table td,
.invoice-table th,
.invoice-table td,
.invoice-bottom-table td,
.invoice-footer-text{
  font-size:11px !important;
  line-height:1.25 !important;
}
.invoice-table th,.invoice-table td,
.invoice-info-table td,
.invoice-bottom-table td{
  padding:5px 6px !important;
}
.signature-cell{
  height:42mm !important;
}
.signature-cell .stamp-sign-wrap{
  min-height:68px !important;
}
.invoice-bottom-logo img{
  max-width:82px !important;
  max-height:44px !important;
}
.invoice-footer-text{
  margin-top:6px !important;
}
@media print{
  html,body,.layout,.main{background:#fff !important;}
  .invoice-print,
  .invoice-a4{
    width:190mm !important;
    max-width:190mm !important;
    min-height:auto !important;
    margin:0 auto !important;
    padding:0 !important;
    box-shadow:none !important;
    border:0 !important;
  }
  @page{size:A4 portrait;margin:10mm;}
}
.finance-ledger .finance-money{
  text-align:right;
  white-space:nowrap;
}
.finance-ledger .finance-red-text{
  color:#dc2626 !important;
  font-weight:700;
}
.finance-ledger .finance-indent{
  padding-left:72px !important;
}
.finance-ledger tr.finance-debit-row td{
  background:#fff;
}
.finance-ledger tr.finance-debit-row td:nth-child(2),
.finance-ledger tr.finance-debit-row td:nth-child(3),
.finance-ledger tr.finance-debit-row td:nth-child(4){
  color:#dc2626 !important;
}


/* V24: Arus Keuangan debit menjorok 3 tab dan merah */
.finance-ledger .finance-indent{padding-left:72px !important;}
.finance-ledger tr.finance-debit-row td:nth-child(2),
.finance-ledger tr.finance-debit-row td:nth-child(3),
.finance-ledger tr.finance-debit-row td:nth-child(4){color:#dc2626 !important;font-weight:700;}

/* V26 Project dynamic input + laporan project */
.project-section{margin:18px 0;padding:14px;border:1px dashed #93c5fd;border-radius:16px;background:linear-gradient(90deg,#eff6ff,#ecfdf5)}
.project-section-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px}
.project-section-head h3{margin:0;font-size:16px;color:#0b438f}
.project-item-row{display:grid;grid-template-columns:minmax(240px,1fr) 90px 160px 42px;gap:10px;align-items:end;margin-bottom:10px;padding:10px;border:1px solid #dbeafe;border-radius:12px;background:#fff}
.project-worker-row{display:grid;grid-template-columns:minmax(150px,1fr) minmax(130px,.9fr) 70px 130px 130px 130px 130px 42px;gap:10px;align-items:end;margin-bottom:10px;padding:10px;border:1px solid #dbeafe;border-radius:12px;background:#fff}
.project-remove-col label{visibility:hidden;height:18px;margin-bottom:7px}.project-remove-btn{width:38px!important;height:38px!important;min-width:38px!important;padding:0!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;border-radius:12px!important}
.project-summary-live{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:16px 0}.project-summary-live div{background:#fff;border:1px solid #dbeafe;border-radius:12px;padding:12px}.project-summary-live b{display:block;font-size:12px;color:#64748b;text-transform:uppercase}.project-summary-live span{display:block;margin-top:5px;font-weight:900;color:#0b438f}
.project-report-excel .project-report-banner{display:grid;grid-template-columns:160px 1fr 160px;gap:12px;align-items:center;background:#ffff00;border:2px solid #111;margin-bottom:10px;padding:6px 10px;text-align:center}.project-report-excel .project-report-banner img{max-height:64px;max-width:150px;object-fit:contain;margin:auto}.project-report-excel .project-report-banner h1{font-size:20px;line-height:1.1;margin:0;color:#000}.project-report-excel .project-report-banner p{margin:2px 0 0;font-weight:800;color:#111}.project-report-excel .project-box{border:2px solid #111;margin-bottom:14px;padding:0;background:#fff}.project-report-excel .project-box h3{margin:0;padding:7px 10px;background:#fff;font-size:15px;border-bottom:1px solid #111}.project-report-excel .table-wrap{border-radius:0;border:0;box-shadow:none}.project-report-excel table{border-collapse:collapse}.project-report-excel th{background:#ffff00!important;color:#000!important;border:1px solid #111!important;text-align:center!important;font-size:10.5px!important;padding:5px!important}.project-report-excel td{border:1px solid #111!important;color:#000!important;font-size:10.5px!important;padding:5px!important}.project-report-excel .project-summary th{background:#8bd24c!important}.project-report-excel .project-summary td{font-weight:800;text-align:right}.project-report-excel .project-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:8px;padding:8px}.project-report-excel .project-summary{margin-top:10px}
@media(max-width:1100px){.project-worker-row{grid-template-columns:1fr 1fr}.project-item-row{grid-template-columns:1fr 1fr}.project-summary-live{grid-template-columns:1fr 1fr}.project-grid{grid-template-columns:1fr!important}}
@media print{.project-report-excel{padding:0!important;max-width:none!important}.project-report-excel .project-grid{grid-template-columns:1.05fr 1fr!important}.project-report-excel th,.project-report-excel td{font-size:9.2px!important;padding:4px!important}@page{size:A4 landscape;margin:8mm}}

/* V28: Project PDF/print dibuat sama persis dengan preview layar */
.project-report-excel{
  max-width:1120px !important;
  width:1120px !important;
  background:#fff !important;
  color:#000 !important;
  padding:18px !important;
  margin:0 auto !important;
  font-family:Arial,sans-serif !important;
}
.project-report-excel .project-report-banner{
  display:grid !important;
  grid-template-columns:160px 1fr 160px !important;
  gap:12px !important;
  align-items:center !important;
  background:#ffff00 !important;
  border:2px solid #111 !important;
  margin-bottom:10px !important;
  padding:6px 10px !important;
  text-align:center !important;
}
.project-report-excel .project-report-banner img{
  max-height:64px !important;
  max-width:150px !important;
  object-fit:contain !important;
  margin:auto !important;
}
.project-report-excel .project-report-banner h1{
  font-size:20px !important;
  line-height:1.1 !important;
  margin:0 !important;
  color:#000 !important;
}
.project-report-excel .project-report-banner p{
  margin:2px 0 0 !important;
  font-weight:800 !important;
  color:#111 !important;
}
.project-report-excel .project-box{
  border:2px solid #111 !important;
  margin-bottom:14px !important;
  padding:0 !important;
  background:#fff !important;
  page-break-inside:avoid !important;
}
.project-report-excel .project-box h3{
  margin:0 !important;
  padding:7px 10px !important;
  background:#fff !important;
  font-size:15px !important;
  border-bottom:1px solid #111 !important;
}
.project-report-excel .project-grid{
  display:grid !important;
  grid-template-columns:1.05fr 1fr !important;
  gap:8px !important;
  padding:8px !important;
}
.project-report-excel .table-wrap{
  border-radius:0 !important;
  border:0 !important;
  box-shadow:none !important;
  overflow:visible !important;
}
.project-report-excel table{
  width:100% !important;
  border-collapse:collapse !important;
  table-layout:auto !important;
}
.project-report-excel th,
.project-report-excel td{
  border:1px solid #111 !important;
  color:#000 !important;
  font-size:10.5px !important;
  padding:5px !important;
  line-height:1.15 !important;
  vertical-align:top !important;
}
.project-report-excel th{
  background:#ffff00 !important;
  text-align:center !important;
  font-weight:800 !important;
}
.project-report-excel .project-summary{
  margin-top:10px !important;
}
.project-report-excel .project-summary th{
  background:#8bd24c !important;
}
.project-report-excel .project-summary td{
  font-weight:800 !important;
  text-align:right !important;
}
@media print{
  html,body{
    background:#fff !important;
    -webkit-print-color-adjust:exact !important;
    print-color-adjust:exact !important;
  }
  .project-report-excel{
    width:1120px !important;
    max-width:1120px !important;
    padding:18px !important;
    margin:0 auto !important;
    transform-origin:top center !important;
    box-shadow:none !important;
  }
  .project-report-excel .project-grid{
    grid-template-columns:1.05fr 1fr !important;
    gap:8px !important;
    padding:8px !important;
  }
  .project-report-excel th,
  .project-report-excel td{
    font-size:10.5px !important;
    padding:5px !important;
    line-height:1.15 !important;
  }
  .project-report-excel .project-report-banner h1{
    font-size:20px !important;
  }
  @page{size:A4 landscape;margin:8mm;}
}

/* V34: filter pencarian dan penomoran daftar */
.list-filter{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin:0 0 14px 0;
}
.list-filter .input{
  max-width:360px;
}
.finance-ledger th:first-child,
.finance-ledger td:first-child,
.table-wrap table th:first-child,
.table-wrap table td:first-child{
  white-space:nowrap;
}

/* V37 Bootstrap Modern Theme - database unchanged */
:root{
  --modern-primary:#2563eb;
  --modern-primary-dark:#1e3a8a;
  --modern-accent:#10b981;
  --modern-warning:#f59e0b;
  --modern-danger:#ef4444;
  --modern-bg:#f4f7fb;
  --modern-surface:#ffffff;
  --modern-border:#dbe6f3;
  --modern-text:#0f172a;
}
html,body{background:radial-gradient(circle at top left,#eef6ff 0,#f6f8fc 38%,#eef4f8 100%)!important;color:var(--modern-text)!important;font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif!important;}
.layout{grid-template-columns:260px minmax(0,1fr)!important;background:transparent!important;}
.sidebar{background:linear-gradient(180deg,#071229 0%,#0f1c36 50%,#071229 100%)!important;border-right:1px solid rgba(255,255,255,.08)!important;box-shadow:16px 0 40px rgba(15,23,42,.12)!important;}
.sidebar:before{background:linear-gradient(180deg,#ef4444,#f59e0b,#10b981,#2563eb)!important;width:6px!important;}
.brand{background:rgba(255,255,255,.04)!important;border:1px solid rgba(255,255,255,.08)!important;border-radius:20px!important;padding:14px!important;margin:0 0 18px!important;}
.app-brand-logo{width:54px!important;height:54px!important;border-radius:16px!important;box-shadow:0 18px 30px rgba(0,0,0,.26)!important;}
.brand h1{font-size:18px!important;font-weight:900!important;letter-spacing:.02em!important;}
.brand p{font-size:12px!important;color:#bfdbfe!important;}
.nav a{display:flex!important;align-items:center!important;gap:11px!important;border-radius:16px!important;margin:7px 0!important;padding:12px 14px!important;color:#e8f3ff!important;font-weight:800!important;border:1px solid transparent!important;}
.nav a:hover{background:rgba(255,255,255,.09)!important;border-color:rgba(255,255,255,.12)!important;transform:translateX(3px)!important;}
.nav a.active{background:linear-gradient(135deg,#0ea5e9,#2563eb 55%,#10b981)!important;border-color:rgba(255,255,255,.22)!important;box-shadow:0 14px 30px rgba(37,99,235,.28)!important;}
.nav-icon{width:28px!important;height:28px!important;display:inline-grid!important;place-items:center!important;background:rgba(255,255,255,.11)!important;border-radius:10px!important;}
.nav-section-title{margin:20px 10px 8px!important;font-size:11px!important;letter-spacing:.12em!important;color:#93c5fd!important;text-transform:uppercase!important;font-weight:900!important;}
.topbar{height:76px!important;background:rgba(255,255,255,.82)!important;backdrop-filter:blur(18px)!important;border-bottom:1px solid rgba(219,230,243,.9)!important;box-shadow:0 14px 36px rgba(15,23,42,.06)!important;}
.topbar h2{font-size:24px!important;font-weight:950!important;color:#0b1930!important;}
.topbar h2:after{height:5px!important;width:58px!important;border-radius:999px!important;background:linear-gradient(90deg,#10b981,#f59e0b,#ef4444)!important;}
.sidebar-toggle,.top-actions .btn,.account-menu .user-pill{border-radius:16px!important;border:1px solid var(--modern-border)!important;background:#fff!important;box-shadow:0 10px 24px rgba(15,23,42,.07)!important;}
.btn{border-radius:14px!important;font-weight:900!important;box-shadow:0 9px 20px rgba(15,23,42,.07)!important;}
.btn.primary,.btn.btn-primary{background:linear-gradient(135deg,#2563eb,#0ea5e9)!important;border-color:#2563eb!important;color:#fff!important;}
.btn.green,.btn.btn-success{background:linear-gradient(135deg,#10b981,#22c55e)!important;border-color:#10b981!important;color:#fff!important;}
.btn.red,.btn.btn-danger{background:linear-gradient(135deg,#fee2e2,#fecaca)!important;border-color:#fecaca!important;color:#b91c1c!important;}
.main{padding:28px!important;}
.card{border:1px solid rgba(210,225,240,.95)!important;border-radius:24px!important;background:rgba(255,255,255,.94)!important;box-shadow:0 22px 48px rgba(15,23,42,.08)!important;overflow:hidden!important;}
.card:before{height:5px!important;background:linear-gradient(90deg,#ef4444,#f59e0b,#10b981,#2563eb)!important;}
.card-head,.toggle-card summary,.collapsible-card summary{background:linear-gradient(180deg,#fff,#f8fbff)!important;padding:18px 22px!important;border-bottom:1px solid var(--modern-border)!important;}
.card-head h3,.toggle-card summary h3,.collapsible-card summary h3{font-size:18px!important;font-weight:950!important;color:#0b1930!important;}
.card-body{padding:22px!important;}
.kpi{border-radius:22px!important;background:linear-gradient(180deg,#fff,#f8fbff)!important;border:1px solid var(--modern-border)!important;box-shadow:0 18px 38px rgba(15,23,42,.07)!important;}
.kpi small{font-size:11px!important;letter-spacing:.06em!important;color:#64748b!important;}
.kpi b{font-size:26px!important;font-weight:950!important;color:#0b1930!important;}
.hero{border-radius:26px!important;background:linear-gradient(135deg,#0f172a,#1d4ed8 55%,#10b981)!important;box-shadow:0 26px 56px rgba(37,99,235,.25)!important;}
.input,select,textarea,.form-control,.form-select{border-radius:15px!important;border:1px solid #cbdced!important;background:#fff!important;padding:11px 13px!important;box-shadow:inset 0 1px 0 rgba(15,23,42,.03)!important;}
.input:focus,select:focus,textarea:focus,.form-control:focus,.form-select:focus{border-color:#2563eb!important;box-shadow:0 0 0 .25rem rgba(37,99,235,.13)!important;}
label{font-weight:900!important;color:#0f172a!important;}
.table-wrap{border-radius:18px!important;border:1px solid var(--modern-border)!important;box-shadow:0 14px 34px rgba(15,23,42,.05)!important;}
table{border-collapse:separate!important;border-spacing:0!important;background:#fff!important;}
th{background:linear-gradient(180deg,#f9fbff,#eef6ff)!important;color:#0f2440!important;font-size:11px!important;font-weight:950!important;border-bottom:1px solid var(--modern-border)!important;}
td{border-bottom:1px solid #e7eef7!important;color:#0f172a!important;}
tbody tr:hover{background:#f8fbff!important;}
.status{border-radius:999px!important;padding:7px 10px!important;font-weight:950!important;}
.notice{background:linear-gradient(135deg,#eff6ff,#ecfdf5)!important;border-color:#93c5fd!important;border-radius:18px!important;}
.dkk-login-page{background:radial-gradient(circle at top left,#dbeafe,#f8fafc 45%,#ecfdf5)!important;}
.dkk-login-card{border-radius:30px!important;border:1px solid rgba(219,230,243,.95)!important;box-shadow:0 28px 70px rgba(15,23,42,.14)!important;}
.dkk-login-btn{border-radius:16px!important;background:linear-gradient(135deg,#2563eb,#10b981)!important;box-shadow:0 18px 32px rgba(37,99,235,.22)!important;}
@media(max-width:1180px){.layout{grid-template-columns:88px minmax(0,1fr)!important}.sidebar-collapsed .layout{grid-template-columns:88px minmax(0,1fr)!important}}
@media(max-width:900px){.layout{grid-template-columns:1fr!important}.main{padding:16px!important}.topbar{height:auto!important;padding:14px!important}.grid-4,.grid-3,.grid-2,.form-row,.form-row.three{grid-template-columns:1fr!important}}
@media print{.sidebar,.topbar,.no-print,.btn{display:none!important}.card,.invoice-a4,.report-landscape,.slip-a4{box-shadow:none!important;border-color:#000!important}.main{padding:0!important;background:#fff!important}}

/* V38: pagination + large data friendly controls */
.list-pager{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:12px;padding:10px 0;color:#475569;font-weight:700}
.list-pager span{margin-right:8px}
.list-filter{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.list-filter .input{max-width:360px}

/* V40: clean A4 exports/prints */
body.invoice-box,
body:has(.report-landscape),
body:has(.invoice-a4),
body:has(.slip-a4){background:#fff!important;}
.report-landscape,.report-sales-detail,.profit-report,.project-report,.invoice-a4,.slip-a4{
  background:#fff!important;
  box-shadow:none!important;
}
.report-landscape:after,.report-sales-detail:after,.profit-report:after,.project-report:after,.invoice-a4:after,.slip-a4:after{display:none!important;content:none!important;}
@media print{
  html,body,.layout,.main{background:#fff!important;}
  .report-landscape,.report-sales-detail,.profit-report,.project-report,.invoice-a4,.slip-a4,.card{
    background:#fff!important;
    box-shadow:none!important;
  }
  .report-landscape,.report-sales-detail,.project-report,.profit-report{max-width:none!important;padding:0!important;}
  .invoice-a4,.slip-a4{max-width:190mm!important;width:190mm!important;margin:0 auto!important;padding:0!important;}
  @page{size:A4 portrait;margin:10mm;}
  @page landscape{size:A4 landscape;margin:10mm;}
}

/* V41: notifikasi NIK customer duplikat */
.validation-error,
.notice.validation-error{
  background:#fee2e2!important;
  border:1px solid #fca5a5!important;
  color:#991b1b!important;
  font-weight:800!important;
}


/* V49: multi jenis/warna stok + hapus massal */
.stock-variant-box{margin-top:14px}
.stock-multi-row{
  grid-template-columns:minmax(240px,1.2fr) 150px minmax(210px,.8fr) 42px!important;
  align-items:end!important;
  margin-top:10px;
}
.stock-variant-remove{
  width:42px!important;
  height:42px!important;
  padding:0!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-radius:12px!important;
}
.stock-bulk-form th:nth-child(2),
.stock-bulk-form td:nth-child(2){
  text-align:center;
  width:58px;
}
.stock-bulk-form input[type="checkbox"]{
  width:18px;
  height:18px;
  cursor:pointer;
}
@media(max-width:900px){
  .stock-multi-row{grid-template-columns:1fr!important}
  .stock-variant-remove{width:100%!important}
}

/* V51: rapikan jarak sidebar, khususnya role Gudang yang hanya punya sedikit menu */
.sidebar{
  display:flex !important;
  flex-direction:column !important;
  gap:0 !important;
}
.sidebar .brand{
  margin-bottom:14px !important;
  flex:0 0 auto !important;
}
.sidebar .nav{
  display:flex !important;
  flex-direction:column !important;
  gap:4px !important;
  flex:0 0 auto !important;
  padding:4px 0 10px !important;
  justify-content:flex-start !important;
  align-content:flex-start !important;
}
.sidebar .nav a,
.sidebar .nav a.active,
.sidebar .nav a:hover{
  min-height:46px !important;
  height:46px !important;
  max-height:46px !important;
  margin:3px 0 !important;
  padding:9px 13px !important;
  border-radius:14px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:11px !important;
  line-height:1.15 !important;
  transform:none !important;
}
.sidebar .nav a.active{
  box-shadow:0 10px 22px rgba(37,99,235,.24) !important;
}
.sidebar .nav-icon{
  width:28px !important;
  height:28px !important;
  min-width:28px !important;
  flex:0 0 28px !important;
}
.sidebar .nav-label{
  display:inline-flex !important;
  align-items:center !important;
  min-height:1px !important;
}
.sidebar .nav-section-title{
  margin:13px 10px 6px !important;
}
.sidebar .sidebar-foot{
  margin-top:auto !important;
}
html.sidebar-collapsed .sidebar .nav{
  gap:6px !important;
}
html.sidebar-collapsed .sidebar .nav a,
html.sidebar-collapsed .sidebar .nav a.active,
html.sidebar-collapsed .sidebar .nav a:hover{
  width:46px !important;
  height:46px !important;
  min-height:46px !important;
  max-height:46px !important;
  padding:8px !important;
  margin:4px auto !important;
  justify-content:center !important;
}
@media(max-width:900px){
  .sidebar .nav a,
  .sidebar .nav a.active,
  .sidebar .nav a:hover{
    height:44px !important;
    min-height:44px !important;
  }
}

/* V52: rapikan sidebar Role Admin agar jarak menu tidak berjauhan */
.layout > .sidebar{
  display:flex !important;
  flex-direction:column !important;
  justify-content:flex-start !important;
  align-items:stretch !important;
  gap:0 !important;
  overflow-y:auto !important;
}
.layout > .sidebar .brand{
  margin:0 0 14px 0 !important;
  padding:10px 10px 16px !important;
  flex:0 0 auto !important;
}
.layout > .sidebar .nav{
  display:flex !important;
  flex-direction:column !important;
  justify-content:flex-start !important;
  align-items:stretch !important;
  gap:4px !important;
  flex:0 0 auto !important;
  width:100% !important;
  margin:0 !important;
  padding:0 0 12px 0 !important;
}
.layout > .sidebar .nav a,
.layout > .sidebar .nav a.active,
.layout > .sidebar .nav a:hover{
  width:100% !important;
  min-height:44px !important;
  height:44px !important;
  max-height:44px !important;
  margin:2px 0 !important;
  padding:8px 13px !important;
  border-radius:13px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:10px !important;
  line-height:1.15 !important;
  transform:none !important;
}
.layout > .sidebar .nav a.active{
  min-height:44px !important;
  height:44px !important;
  box-shadow:0 10px 22px rgba(37,99,235,.22) !important;
}
.layout > .sidebar .nav-icon{
  width:27px !important;
  height:27px !important;
  min-width:27px !important;
  flex:0 0 27px !important;
}
.layout > .sidebar .nav-label{
  min-height:0 !important;
  display:inline-flex !important;
  align-items:center !important;
  white-space:nowrap !important;
}
.layout > .sidebar .nav-section-title{
  margin:11px 10px 5px !important;
  padding:0 !important;
  flex:0 0 auto !important;
}
.layout > .sidebar .sidebar-foot{
  position:static !important;
  margin-top:auto !important;
  padding-top:12px !important;
  flex:0 0 auto !important;
}
html.sidebar-collapsed .layout > .sidebar .nav a,
html.sidebar-collapsed .layout > .sidebar .nav a.active,
html.sidebar-collapsed .layout > .sidebar .nav a:hover{
  width:44px !important;
  height:44px !important;
  min-height:44px !important;
  max-height:44px !important;
  padding:8px !important;
  margin:3px auto !important;
  justify-content:center !important;
}
@media(max-width:900px){
  .layout > .sidebar .nav{
    gap:5px !important;
  }
  .layout > .sidebar .nav a,
  .layout > .sidebar .nav a.active,
  .layout > .sidebar .nav a:hover{
    height:42px !important;
    min-height:42px !important;
    max-height:42px !important;
  }
}

/* V53: pagination rapi untuk data besar */
.list-pager{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:14px;padding:12px 0;color:#475569;font-weight:700}
.list-pager span{margin-right:6px}
.per-page-form{display:inline-flex;align-items:center;margin:0 4px}
.per-page-form .input{width:82px;padding:7px 9px;border-radius:10px;font-size:12px}
.list-pager .btn.small{padding:7px 10px;min-width:34px;justify-content:center}

/* V55: Modal Pilih Barang untuk Input Penjualan */
.stock-selected-box{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
.stock-selected-label{background:#f8fafc!important;cursor:pointer}
.stock-picker-overlay{position:fixed;inset:0;background:rgba(2,6,23,.55);z-index:9999;align-items:center;justify-content:center;padding:20px}
.stock-picker-modal{width:min(1100px,96vw);max-height:90vh;overflow:auto;background:#fff;border-radius:22px;border:1px solid #d7e5ef;box-shadow:0 30px 80px rgba(2,6,23,.35)}
.stock-picker-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 20px;border-bottom:1px solid #d7e5ef;background:linear-gradient(180deg,#fff,#f8fbff)}
.stock-picker-head h3{margin:0;font-size:18px;font-weight:900;color:#081831}.stock-picker-head p{margin:4px 0 0;color:#55708a;font-size:13px}
.stock-picker-filter{display:grid;grid-template-columns:1.5fr 1fr 140px auto;gap:10px;padding:16px 20px;background:#f8fbff;border-bottom:1px solid #d7e5ef}
.stock-picker-result{padding:16px 20px}.stock-picker-table th,.stock-picker-table td{font-size:12px;padding:9px 10px}.stock-picker-table tbody tr:hover{background:#eef6ff}
.stock-picker-pager{display:flex;align-items:center;justify-content:center;gap:12px;padding:0 20px 18px;color:#334155;font-weight:700}
@media(max-width:800px){.stock-picker-filter{grid-template-columns:1fr}.stock-selected-box{grid-template-columns:1fr}.stock-picker-head{align-items:flex-start;flex-direction:column}.stock-picker-modal{max-height:94vh}}
@media print{.stock-picker-overlay{display:none!important}}

/* V56: multi-select barang di modal Input Penjualan */
.stock-picker-bulkbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 20px;
  background:#f8fafc;
  border-bottom:1px solid #d7e5ef;
  color:#0f172a;
  font-size:13px;
}
.stock-picker-table input[type="checkbox"]{
  width:18px;
  height:18px;
  cursor:pointer;
  accent-color:#2563eb;
}
.stock-picker-table tr:has(.stock-picker-check:checked){
  background:#eaf4ff!important;
}
@media(max-width:800px){
  .stock-picker-bulkbar{flex-direction:column;align-items:stretch}
}

/* V59: invoice print hotfix - jangan cetak sidebar/topbar */
body.invoice-only-page,
.invoice-only-page{
  background:#fff!important;
}
.invoice-only-page .sidebar,
.invoice-only-page .topbar{
  display:none!important;
}
.invoice-only-page .layout{
  display:block!important;
  grid-template-columns:none!important;
  min-height:auto!important;
}
.invoice-only-page .main{
  padding:0!important;
  background:#fff!important;
}
.invoice-only-page .invoice-print,
.invoice-only-page .invoice-a4{
  width:190mm!important;
  max-width:190mm!important;
  margin:0 auto!important;
  padding:0!important;
  box-shadow:none!important;
  border:0!important;
  background:#fff!important;
}
@media print{
  body.invoice-only-page .sidebar,
  body.invoice-only-page .topbar,
  body.invoice-only-page .no-print,
  body.invoice-only-page .btn{
    display:none!important;
  }
  body.invoice-only-page .layout,
  body.invoice-only-page .layout>section,
  body.invoice-only-page .main{
    display:block!important;
    width:100%!important;
    min-height:0!important;
    margin:0!important;
    padding:0!important;
    background:#fff!important;
  }
  body.invoice-only-page .invoice-print,
  body.invoice-only-page .invoice-a4{
    width:190mm!important;
    max-width:190mm!important;
    margin:0 auto!important;
    padding:0!important;
    box-shadow:none!important;
    border:0!important;
    background:#fff!important;
  }
}

/* V64: Server-side variant picker */
.stock-picker-modal-v64{max-width:1120px;width:min(96vw,1120px)}
.stock-variant-inline{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:end}
.stock-variant-inline .btn{white-space:nowrap}
.variant-filter{grid-template-columns:auto 1.1fr 1fr 170px auto!important;align-items:end}
.variant-title-wrap{display:flex;flex-direction:column;gap:3px;color:#0f172a}
.variant-title-wrap small{color:#64748b;font-weight:600}
.stock-picker-table td,.stock-picker-table th{vertical-align:middle!important}
@media(max-width:900px){
  .variant-filter{grid-template-columns:1fr!important}
  .stock-variant-inline{grid-template-columns:1fr!important}
}


/* V66: rapikan Input Penjualan - Daftar Barang Invoice */

#invoiceItems{display:flex;flex-direction:column;gap:14px;margin-top:14px}
#invoiceItems .item-row.invoice-item-with-batch,
#invoiceItemTemplate .item-row.invoice-item-with-batch{
  display:grid !important;
  grid-template-columns:minmax(120px,.85fr) minmax(260px,2fr) minmax(220px,1.35fr) minmax(160px,1fr) minmax(120px,.75fr) 52px !important;
  gap:12px !important;
  align-items:end !important;
  padding:14px !important;
  border:1px solid #dbe7f3 !important;
  border-radius:18px !important;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%) !important;
  box-shadow:0 8px 20px rgba(15,23,42,.04) !important;
}
#invoiceItems .item-row.invoice-item-with-batch > div,
#invoiceItemTemplate .item-row.invoice-item-with-batch > div{
  min-width:0 !important;
}
#invoiceItems .item-row.invoice-item-with-batch label,
#invoiceItemTemplate .item-row.invoice-item-with-batch label{
  display:block;
  margin:0 0 8px 2px;
  font-size:12px;
  font-weight:800;
  color:#0f172a;
}
#invoiceItems .item-row.invoice-item-with-batch .invoice-batch-field,
#invoiceItemTemplate .item-row.invoice-item-with-batch .invoice-batch-field,
#invoiceItems .item-row.invoice-item-with-batch > div:nth-child(2),
#invoiceItemTemplate .item-row.invoice-item-with-batch > div:nth-child(2),
#invoiceItems .item-row.invoice-item-with-batch > div:nth-child(3),
#invoiceItemTemplate .item-row.invoice-item-with-batch > div:nth-child(3),
#invoiceItems .item-row.invoice-item-with-batch .invoice-price-field,
#invoiceItemTemplate .item-row.invoice-item-with-batch .invoice-price-field,
#invoiceItems .item-row.invoice-item-with-batch .invoice-qty-action,
#invoiceItemTemplate .item-row.invoice-item-with-batch .invoice-qty-action{
  flex:initial !important;width:auto !important;
}
#invoiceItems .stock-selected-box,
#invoiceItemTemplate .stock-selected-box,
#invoiceItems .stock-variant-inline,
#invoiceItemTemplate .stock-variant-inline{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
}
#invoiceItems .stock-selected-label,
#invoiceItems .stock-variant-display,
#invoiceItemTemplate .stock-selected-label,
#invoiceItemTemplate .stock-variant-display{
  min-width:0;
  background:#fff !important;
  border-color:#cfe0f0 !important;
}
#invoiceItems .stock-variant-display,
#invoiceItemTemplate .stock-variant-display{
  color:#334155;
}
#invoiceItems .invoice-price-field .input,
#invoiceItemTemplate .invoice-price-field .input,
#invoiceItems .invoice-qty-field .input,
#invoiceItemTemplate .invoice-qty-field .input{
  text-align:left;
}
#invoiceItems .invoice-qty-action,
#invoiceItemTemplate .invoice-qty-action{
  display:grid !important;
  grid-template-columns:minmax(86px,1fr) 44px !important;
  gap:10px !important;
  align-items:end !important;
}
#invoiceItems .invoice-qty-field,
#invoiceItemTemplate .invoice-qty-field{min-width:0}
#invoiceItems .invoice-remove-inline,
#invoiceItemTemplate .invoice-remove-inline{
  display:flex !important;
  flex-direction:column;
  justify-content:flex-end;
}
#invoiceItems .invoice-remove-inline label,
#invoiceItemTemplate .invoice-remove-inline label{visibility:hidden;height:20px;margin:0 0 8px 0}
#invoiceItems .invoice-remove-btn,
#invoiceItemTemplate .invoice-remove-btn{
  width:44px;
  min-width:44px;
  height:44px;
  padding:0;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  line-height:1;
}
#invoiceItems .notice,
#invoiceItemTemplate .notice{overflow:visible}
@media (max-width: 1180px){
  #invoiceItems .item-row.invoice-item-with-batch,
  #invoiceItemTemplate .item-row.invoice-item-with-batch{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
  #invoiceItems .item-row.invoice-item-with-batch .invoice-qty-action,
  #invoiceItemTemplate .item-row.invoice-item-with-batch .invoice-qty-action{
    grid-template-columns:minmax(86px,1fr) 44px !important;
  }
}
@media (max-width: 700px){
  #invoiceItems .item-row.invoice-item-with-batch,
  #invoiceItemTemplate .item-row.invoice-item-with-batch{
    grid-template-columns:1fr !important;
    padding:12px !important;
  }
  #invoiceItems .stock-selected-box,
  #invoiceItemTemplate .stock-selected-box,
  #invoiceItems .stock-variant-inline,
  #invoiceItemTemplate .stock-variant-inline{
    grid-template-columns:1fr !important;
  }
}


/* V67: rapikan form Input Penjualan - Daftar Barang Invoice */
#invoiceForm .notice > b{display:inline-block;font-size:22px;font-weight:800;color:#12356b;margin-bottom:14px}
#invoiceForm .notice > .btn.small{float:none !important;display:inline-flex;align-items:center;justify-content:center;height:42px;padding:0 16px;border-radius:14px;font-weight:700}
#invoiceForm .notice{position:relative}
#invoiceForm .notice > .btn.small{position:absolute;top:14px;right:16px}
#invoiceItems{margin-top:18px;gap:12px}
#invoiceItems .item-row.invoice-item-with-batch,
#invoiceItemTemplate .item-row.invoice-item-with-batch{
  grid-template-columns:130px minmax(250px,2fr) minmax(250px,1.8fr) 150px 110px 44px !important;
  gap:12px !important;
  padding:14px 16px !important;
  border-radius:16px !important;
  background:#f8fbff !important;
  border:1px solid #d7e4f1 !important;
  box-shadow:none !important;
}
#invoiceItems .item-row.invoice-item-with-batch label,
#invoiceItemTemplate .item-row.invoice-item-with-batch label{
  font-size:13px;
  margin-bottom:6px;
}
#invoiceItems .stock-selected-box,
#invoiceItemTemplate .stock-selected-box,
#invoiceItems .stock-variant-inline,
#invoiceItemTemplate .stock-variant-inline{
  grid-template-columns:1fr 108px !important;
  gap:8px !important;
}
#invoiceItems .stock-selected-box .btn,
#invoiceItemTemplate .stock-selected-box .btn,
#invoiceItems .stock-variant-inline .btn,
#invoiceItemTemplate .stock-variant-inline .btn{
  width:108px;
  min-width:108px;
  justify-content:center;
  padding:0 10px;
  white-space:nowrap;
}
#invoiceItems .stock-selected-label,
#invoiceItemTemplate .stock-selected-label,
#invoiceItems .stock-variant-display,
#invoiceItemTemplate .stock-variant-display{
  height:42px;
}
#invoiceItems .invoice-price-field .input,
#invoiceItemTemplate .invoice-price-field .input,
#invoiceItems .invoice-qty-field .input,
#invoiceItemTemplate .invoice-qty-field .input,
#invoiceItems .invoice-batch-field .input,
#invoiceItemTemplate .invoice-batch-field .input{
  height:42px;
}
#invoiceItems .invoice-qty-action,
#invoiceItemTemplate .invoice-qty-action{
  grid-template-columns:1fr !important;
  gap:0 !important;
}
#invoiceItems .invoice-remove-inline,
#invoiceItemTemplate .invoice-remove-inline{align-self:end}
#invoiceItems .invoice-remove-inline label,
#invoiceItemTemplate .invoice-remove-inline label{display:none !important}
#invoiceItems .invoice-remove-btn,
#invoiceItemTemplate .invoice-remove-btn{
  width:42px;height:42px;min-width:42px;border-radius:14px;margin-top:22px;
}
#invoiceItems .invoice-price-field small,
#invoiceItemTemplate .invoice-price-field small{display:none !important}
#invoiceForm .notice.grid.grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;background:#eef8f6 !important}
#invoiceForm .notice.grid.grid-4 > div{padding:4px 6px}
@media (max-width: 1280px){
  #invoiceItems .item-row.invoice-item-with-batch,
  #invoiceItemTemplate .item-row.invoice-item-with-batch{grid-template-columns:130px 1fr 1fr 150px 90px 44px !important;}
}
@media (max-width: 1080px){
  #invoiceItems .item-row.invoice-item-with-batch,
  #invoiceItemTemplate .item-row.invoice-item-with-batch{grid-template-columns:1fr 1fr !important;}
  #invoiceItems .invoice-remove-btn,
  #invoiceItemTemplate .invoice-remove-btn{margin-top:0}
}
@media (max-width: 700px){
  #invoiceForm .notice > .btn.small{position:static;display:inline-flex;margin-top:10px}
  #invoiceItems .item-row.invoice-item-with-batch,
  #invoiceItemTemplate .item-row.invoice-item-with-batch{grid-template-columns:1fr !important;}
  #invoiceItems .stock-selected-box,
  #invoiceItemTemplate .stock-selected-box,
  #invoiceItems .stock-variant-inline,
  #invoiceItemTemplate .stock-variant-inline{grid-template-columns:1fr !important;}
}


/* V68: premium summary Input Penjualan */
#invoiceForm .notice.grid.grid-4{
  margin-top:14px !important;
  padding:14px 18px !important;
  border:1px dashed #7db6ff !important;
  border-radius:18px !important;
  background:linear-gradient(90deg,#eef7ff 0%,#eefdf6 100%) !important;
  box-shadow:0 10px 26px rgba(15,23,42,.04) !important;
}
#invoiceForm .notice.grid.grid-4 > div{
  min-height:56px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  border-right:1px solid rgba(59,130,246,.18);
}
#invoiceForm .notice.grid.grid-4 > div:last-child{border-right:0}
#invoiceForm .notice.grid.grid-4 b{
  font-size:14px;
  font-weight:900;
  color:#064289;
  margin-bottom:4px;
}
#invoiceForm .notice.grid.grid-4 span,
#invoiceForm .notice.grid.grid-4 div{
  color:#073b7a;
}
#summarySubtotal,#summaryPaid,#summaryBalance,#summaryQty{
  font-size:15px;
  font-weight:700;
}
@media (max-width:900px){
  #invoiceForm .notice.grid.grid-4{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  #invoiceForm .notice.grid.grid-4 > div:nth-child(2){border-right:0}
}
@media (max-width:560px){
  #invoiceForm .notice.grid.grid-4{grid-template-columns:1fr !important;}
  #invoiceForm .notice.grid.grid-4 > div{border-right:0;border-bottom:1px solid rgba(59,130,246,.18)}
  #invoiceForm .notice.grid.grid-4 > div:last-child{border-bottom:0}
}
