: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}
}
