:root{--bg:#f4f7fb;--card:#fff;--text:#172033;--muted:#64748b;--primary:#0f766e;--primary2:#14b8a6;--danger:#dc2626;--warning:#d97706;--success:#15803d;--border:#e2e8f0;--shadow:0 12px 35px rgba(15,23,42,.08)}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}input,select,textarea,button{font:inherit}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:14px;padding:12px 14px;background:#fff;color:var(--text);outline:none}textarea{min-height:90px;resize:vertical}label{display:block;font-weight:700;font-size:13px;margin:12px 0 6px}.app-shell{display:grid;grid-template-columns:270px 1fr;min-height:100vh}.sidebar{background:#0f172a;color:#e2e8f0;padding:22px 16px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}.brand-icon,.login-logo{width:48px;height:48px;border-radius:18px;background:linear-gradient(135deg,var(--primary),var(--primary2));display:grid;place-items:center;font-weight:900;color:white}.brand span{display:block;color:#94a3b8;font-size:12px;margin-top:2px}.menu{display:grid;gap:6px}.menu a{padding:12px 14px;border-radius:14px;color:#cbd5e1}.menu a:hover{background:rgba(255,255,255,.08);color:white}.main{min-width:0}.topbar{height:82px;display:flex;align-items:center;justify-content:space-between;padding:0 26px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.82);/* backdrop-filter disabled for faster rendering */;position:sticky;top:0;z-index:5}.topbar h1{font-size:22px;margin:0}.topbar p{margin:4px 0 0;color:var(--muted);font-size:13px}.hamburger{display:none;border:0;background:#fff;border-radius:12px;padding:10px 12px;box-shadow:var(--shadow)}.user-chip{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid var(--border);border-radius:999px;padding:8px 12px}.user-chip a{color:var(--primary);font-weight:700}.content{padding:26px}.card{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:22px;box-shadow:var(--shadow)}.card.warning{border-color:#fbbf24;background:#fffbeb}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.card h2,.card h3{margin-top:0}.grid{display:grid;gap:18px}.cards-6{grid-template-columns:repeat(6,minmax(0,1fr))}.cards-4{grid-template-columns:repeat(4,minmax(0,1fr))}.two{grid-template-columns:1fr 1fr}.metric span{color:var(--muted);font-size:13px;font-weight:700}.metric strong{display:block;font-size:24px;margin-top:8px}.metric.danger strong{color:var(--danger)}.mt{margin-top:22px}.mt-sm{margin-top:12px}.span-2{grid-column:span 2}.form-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.form-actions{display:flex;align-items:end}.narrow{max-width:720px}.btn{border:0;border-radius:14px;padding:11px 16px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff}.btn-success{background:#16a34a;color:#fff}.btn-danger{background:#dc2626;color:#fff}.btn-light{background:#f1f5f9;color:#0f172a}.btn-block{width:100%}.btn-sm{padding:8px 12px;border-radius:12px;font-size:13px}.disabled{opacity:.45;pointer-events:none}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse;min-width:760px}th,td{text-align:left;padding:13px;border-bottom:1px solid var(--border);vertical-align:top}th{font-size:12px;text-transform:uppercase;color:var(--muted);letter-spacing:.04em}.badge{display:inline-flex;border-radius:999px;padding:5px 10px;background:#e2e8f0;color:#334155;font-size:12px;font-weight:900}.status-pending_verification,.status-open,.status-partial{background:#fef3c7;color:#92400e}.status-verified,.status-paid,.status-closed{background:#dcfce7;color:#166534}.status-rejected,.status-cancelled{background:#fee2e2;color:#991b1b}.alert{padding:12px 14px;border-radius:16px;margin-bottom:12px;font-weight:700}.alert-success{background:#dcfce7;color:#166534}.alert-danger{background:#fee2e2;color:#991b1b}.alert-warning{background:#fef3c7;color:#92400e}.flash-wrap{padding:18px 26px 0}.auth-page{background:linear-gradient(135deg,#0f172a,#134e4a)}.login-screen{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(420px,100%);background:#fff;border-radius:30px;padding:30px;box-shadow:0 30px 80px rgba(0,0,0,.28)}.login-card h1{margin-bottom:4px}.login-card p{color:var(--muted);margin-top:0}.login-logo{margin-bottom:12px}.demo-box,.helper-box{margin-top:18px;background:#f8fafc;border:1px dashed var(--border);border-radius:16px;padding:14px;color:#475569;font-size:13px}.auth-flash{position:fixed;top:20px;left:50%;transform:translateX(-50%);z-index:10;width:min(420px,90%)}.mobile-hero{background:linear-gradient(135deg,#0f766e,#14b8a6);color:#fff;border-radius:28px;padding:24px;margin-bottom:18px;box-shadow:var(--shadow)}.mobile-hero h2{margin:0 0 6px}.mobile-hero p{margin:0;opacity:.9}.action-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.action-card{background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);border-radius:22px;padding:22px;font-weight:900}.gps-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.gps-banner p{margin:4px 0 0;color:var(--muted)}.outlet-list{display:grid;gap:14px}.outlet-card{background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);border-radius:22px;padding:18px;display:flex;justify-content:space-between;gap:16px;align-items:center}.outlet-card h3{margin:8px 0 4px}.outlet-card p{margin:0 0 8px;color:var(--muted)}.meta,.distance{font-size:13px;color:#475569;margin-top:4px}.approval-actions{display:grid;gap:10px;margin-top:18px}.approval-actions form{display:flex;gap:8px}.offline-panel p{color:var(--muted)}@media(max-width:1100px){.cards-6{grid-template-columns:repeat(3,1fr)}.form-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:760px){.app-shell{display:block}.sidebar{position:fixed;left:-280px;top:0;bottom:0;width:270px;z-index:30;transition:.2s}.sidebar-open .sidebar{left:0}.topbar{height:auto;padding:14px;gap:10px}.hamburger{display:block}.topbar h1{font-size:18px}.topbar p{display:none}.user-chip span{display:none}.content{padding:14px}.cards-6,.cards-4,.two,.action-grid{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.span-2{grid-column:auto}.gps-banner,.outlet-card{align-items:stretch;flex-direction:column}.btn{width:100%}.card{border-radius:20px;padding:16px}.approval-actions form{flex-direction:column}}@media print{.sidebar,.topbar,.btn{display:none!important}.app-shell{display:block}.content{padding:0}.card{box-shadow:none;border:0}}

.split-bill-list{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.split-bill-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr 1fr auto;gap:8px;align-items:end;padding:10px;border:1px solid var(--border);border-radius:16px;background:#f8fafc}
.split-bill-row small{display:block;color:var(--muted);font-weight:700;margin-bottom:4px}
.split-bill-row .remove-method{height:42px;min-width:42px;font-size:20px;padding:0}
@media(max-width:900px){.split-bill-row{grid-template-columns:1fr 1fr}.split-bill-row .remove-method{grid-column:1/-1;width:100%}}

/* Modern dashboard refresh */
:root{--bg:#eef4ff;--card:rgba(255,255,255,.88);--text:#0f172a;--muted:#64748b;--primary:#2563eb;--primary2:#06b6d4;--accent:#8b5cf6;--danger:#ef4444;--warning:#f59e0b;--success:#22c55e;--border:rgba(148,163,184,.28);--shadow:0 12px 28px rgba(15,23,42,.09)}
body{background:radial-gradient(circle at top left,rgba(37,99,235,.18),transparent 34%),radial-gradient(circle at top right,rgba(14,165,233,.14),transparent 30%),var(--bg)}
.sidebar{background:linear-gradient(180deg,#0b1220,#111827 48%,#172554);box-shadow:10px 0 26px rgba(15,23,42,.14);border-right:1px solid rgba(255,255,255,.08)}
.brand{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:12px;margin-bottom:22px}.brand-icon,.login-logo{background:linear-gradient(135deg,#38bdf8,#6366f1,#a855f7);box-shadow:0 14px 32px rgba(59,130,246,.35)}
.menu-label{margin:18px 12px 6px;font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:#64748b;font-weight:900}.menu a{display:flex;align-items:center;gap:10px;color:#cbd5e1;border:1px solid transparent}.menu a:hover{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.08);transform:translateX(2px)}
.topbar{background:rgba(255,255,255,.74);box-shadow:0 12px 35px rgba(15,23,42,.05);border-bottom:1px solid rgba(148,163,184,.22)}.user-chip{box-shadow:0 12px 28px rgba(15,23,42,.07)}.user-chip span{display:flex;flex-direction:column;line-height:1.1}.user-chip small{font-size:11px;color:var(--muted);font-weight:600}.user-chip a{background:#eff6ff;color:#1d4ed8;border-radius:999px;padding:8px 11px}
.content{padding:30px}.glass-card,.card{/* backdrop-filter disabled for faster rendering */}.card{border:1px solid rgba(255,255,255,.72);box-shadow:var(--shadow)}.card-header p,.page-intro p,.dashboard-hero p{margin:4px 0 0;color:var(--muted)}
.page-intro,.dashboard-hero{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:22px;background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(255,255,255,.62));border:1px solid rgba(255,255,255,.72);box-shadow:var(--shadow);border-radius:30px;padding:24px}.page-intro h2,.dashboard-hero h2{font-size:30px;line-height:1.05;margin:6px 0}.eyebrow{font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.16em;color:#2563eb}.intro-actions{display:flex;gap:10px;align-items:center}.hero-kpi{min-width:190px;text-align:right;background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff;border-radius:24px;padding:18px}.hero-kpi span{display:block;opacity:.85;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.hero-kpi strong{font-size:34px;display:block;margin-top:3px}.metric.modern{position:relative;overflow:hidden;background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(255,255,255,.7))}.metric.modern:after{content:"";position:absolute;right:-22px;top:-22px;width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,rgba(37,99,235,.16),rgba(6,182,212,.10))}.metric.modern strong{font-size:26px;letter-spacing:-.04em}.metric.modern span{color:#475569}.dashboard-charts{grid-template-columns:1.4fr 1fr 1fr}.chart-card{min-height:330px}.chart-card canvas{width:100%;display:block}.btn{transition:.18s ease;box-shadow:0 12px 22px rgba(15,23,42,.08)}.btn:hover{transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,#2563eb,#06b6d4)}.btn-success{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff}.btn-light{background:rgba(248,250,252,.92)}.table-actions{display:flex;gap:8px;align-items:center}.table-actions form{margin:0}.status-active{background:#dcfce7;color:#166534}.status-inactive{background:#fee2e2;color:#991b1b}.action-badge{background:#e0e7ff;color:#3730a3}.role-developer{background:#ede9fe;color:#5b21b6}.role-owner{background:#dbeafe;color:#1e40af}.role-admin_head{background:#e0e7ff;color:#3730a3}.role-admin_debitur{background:#ccfbf1;color:#115e59}.role-kasir{background:#fef3c7;color:#92400e}.role-collector{background:#dcfce7;color:#166534}.roles-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.role-card .card-header{align-items:flex-start}.permission-group{border-top:1px solid var(--border);padding-top:14px;margin-top:14px}.permission-group h3{font-size:14px;color:#334155;margin:0 0 10px;text-transform:uppercase;letter-spacing:.08em}.permission-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.check-row{display:flex;gap:10px;align-items:flex-start;margin:0!important;background:#f8fafc;border:1px solid rgba(148,163,184,.25);border-radius:14px;padding:10px}.check-row input{width:auto;margin-top:4px}.check-row small{display:block;color:#64748b;font-weight:600;margin-top:2px}.dev-access-box{background:linear-gradient(135deg,#ede9fe,#e0f2fe);border:1px solid #c4b5fd;border-radius:18px;padding:14px;font-weight:800;color:#312e81}.compact.form-grid{grid-template-columns:2fr 1fr 2fr auto}.login-card{background:rgba(255,255,255,.92);/* backdrop-filter disabled for faster rendering */;border:1px solid rgba(255,255,255,.5)}
@media(max-width:1180px){.dashboard-charts,.roles-grid{grid-template-columns:1fr}.dashboard-charts .span-2{grid-column:auto}.compact.form-grid{grid-template-columns:1fr 1fr}}
@media(max-width:760px){.content{padding:16px}.page-intro,.dashboard-hero{flex-direction:column;align-items:stretch;border-radius:24px}.intro-actions{flex-direction:column}.hero-kpi{text-align:left}.permission-list{grid-template-columns:1fr}.table-actions{flex-direction:column;align-items:stretch}.compact.form-grid{grid-template-columns:1fr}.user-chip small{display:none}}


/* Performance tuning */
.ar-chart{max-height:280px}
.card,.dashboard-hero,.page-intro{will-change:auto}
@media (prefers-reduced-motion: reduce){.btn,.menu a,.sidebar{transition:none!important}.btn:hover,.menu a:hover{transform:none!important}}

/* V6 security helper styles */
.muted{color:#64748b;font-size:.85rem}.d-block{display:block}.badge.role-developer{background:#111827;color:#fff;border-color:#111827}.badge[title]{cursor:help}

/* V7 modal create forms + wider edit layout */
.modal-layer{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:24px;z-index:1000}
.modal-layer.is-open{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.55)}
.modal-panel{position:relative;width:min(720px,100%);max-height:92vh;overflow:auto;background:#fff;border:1px solid rgba(226,232,240,.85);border-radius:28px;box-shadow:0 28px 90px rgba(15,23,42,.28);padding:24px}
.modal-lg{width:min(920px,100%)}.modal-xl{width:min(1080px,100%)}
.modal-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.modal-header h2{margin:4px 0 4px}.modal-header p{margin:0;color:var(--muted)}
.modal-close{width:42px;height:42px;border:0;border-radius:14px;background:#f1f5f9;color:#0f172a;font-size:26px;line-height:1;cursor:pointer;font-weight:800}.modal-close:hover{background:#e2e8f0}
.modal-actions{gap:10px;align-items:end}.modal-actions .btn{min-width:120px}
body.modal-open{overflow:hidden}.edit-wide{max-width:1120px}.edit-form{grid-template-columns:repeat(3,minmax(0,1fr))}.edit-form .form-actions{grid-column:1/-1;justify-content:flex-end;gap:10px}
@media(max-width:900px){.modal-panel{padding:18px;border-radius:22px}.modal-layer{padding:14px}.modal-panel .form-grid,.edit-form{grid-template-columns:1fr}.modal-panel .span-2{grid-column:auto}}

/* V8 modern login, invoice detail, logout confirmation */
.auth-page{min-height:100vh;background:#06111f;overflow-x:hidden}.login-modern-screen{position:relative;min-height:100vh;display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:center;padding:42px;isolation:isolate;color:#e5edf7}.login-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(148,163,184,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.08) 1px,transparent 1px);background-size:42px 42px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.9),rgba(0,0,0,.18));z-index:-3}.login-bg-orb{position:absolute;border-radius:50%;filter:blur(18px);opacity:.65;z-index:-2}.orb-one{width:420px;height:420px;background:radial-gradient(circle,#2563eb,transparent 65%);top:-120px;left:-80px}.orb-two{width:380px;height:380px;background:radial-gradient(circle,#06b6d4,transparent 65%);right:10%;bottom:-110px}.login-hero-panel,.login-card-modern{border:1px solid rgba(255,255,255,.14);background:linear-gradient(135deg,rgba(255,255,255,.13),rgba(255,255,255,.07));box-shadow:0 30px 100px rgba(0,0,0,.38);border-radius:36px}.login-hero-panel{padding:36px;min-height:640px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;position:relative}.login-hero-panel:after{content:"";position:absolute;right:-80px;top:80px;width:280px;height:280px;border-radius:50%;background:linear-gradient(135deg,rgba(59,130,246,.32),rgba(168,85,247,.18));z-index:-1}.login-brand-row{display:flex;gap:14px;align-items:center}.login-logo-modern{width:58px;height:58px;border-radius:20px;display:grid;place-items:center;font-weight:1000;color:white;background:linear-gradient(135deg,#38bdf8,#6366f1,#a855f7);box-shadow:0 18px 44px rgba(37,99,235,.45)}.login-brand-row strong{display:block;font-size:22px}.login-brand-row span{display:block;color:#a7b5c7;font-size:13px;font-weight:800}.login-hero-copy{max-width:760px}.eyebrow.light{color:#67e8f9}.login-hero-copy h1{font-size:54px;line-height:.98;letter-spacing:-.055em;margin:12px 0 18px;color:#fff}.login-hero-copy p{font-size:17px;line-height:1.7;color:#b6c3d3;max-width:720px}.login-feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.login-feature-grid div{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:16px}.login-feature-grid strong{display:block;font-size:21px;color:#fff}.login-feature-grid span{display:block;color:#b7c6d8;font-size:12px;margin-top:4px;font-weight:800}.login-form-panel{display:flex;justify-content:center}.login-card-modern{width:min(460px,100%);padding:30px;background:rgba(255,255,255,.96);color:#0f172a}.login-card-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:22px}.login-card-head h2{font-size:32px;margin:6px 0 4px;letter-spacing:-.04em}.login-card-head p{margin:0;color:#64748b}.login-lock{width:54px;height:54px;border-radius:18px;background:#eff6ff;display:grid;place-items:center;font-size:24px}.modern-login-form label{font-weight:900;font-size:13px;color:#334155;margin:14px 0 7px;display:block}.input-icon-wrap{display:flex;align-items:center;gap:10px;border:1px solid #dbe3ef;border-radius:18px;background:#f8fafc;padding:0 14px}.input-icon-wrap span{color:#64748b;font-weight:900}.input-icon-wrap input{border:0!important;background:transparent!important;box-shadow:none!important;padding:15px 0!important;width:100%}.login-submit{margin-top:18px;border-radius:18px;height:52px;font-size:15px}.demo-box-modern{margin-top:22px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:22px;padding:16px}.demo-title{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:#2563eb;font-weight:1000;margin-bottom:10px}.demo-list{display:grid;gap:7px}.demo-list span{font-size:13px;color:#334155;background:#fff;border:1px solid #edf2f7;border-radius:12px;padding:8px 10px;font-weight:800}.btn-sm{padding:8px 11px;font-size:12px;border-radius:12px}.invoice-detail-hero h2{font-size:34px}.invoice-summary-grid{margin-bottom:18px}.invoice-progress-card .card-header strong{font-size:28px;color:#2563eb}.progress-track{height:14px;background:#e2e8f0;border-radius:999px;overflow:hidden;margin:14px 0 18px}.progress-track div{height:100%;background:linear-gradient(90deg,#2563eb,#06b6d4);border-radius:999px}.invoice-info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.invoice-info-grid div{background:#f8fafc;border:1px solid rgba(148,163,184,.25);border-radius:16px;padding:12px}.invoice-info-grid small{display:block;color:#64748b;font-weight:900;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.invoice-info-grid strong{display:block;color:#0f172a}.method-pill-list{display:flex;flex-direction:column;gap:6px;min-width:230px}.method-pill-list span{display:block;background:#eef2ff;color:#312e81;border:1px solid #c7d2fe;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:900}.empty-row{text-align:center;color:#64748b;font-weight:800;padding:28px!important}.logout-modal-panel{width:min(440px,100%);text-align:center;padding:30px}.logout-icon{width:70px;height:70px;margin:0 auto 16px;border-radius:24px;background:linear-gradient(135deg,#fee2e2,#eff6ff);display:grid;place-items:center;font-size:34px;color:#dc2626;font-weight:900}.logout-modal-panel h2{margin:0 0 8px;font-size:28px}.logout-modal-panel p{margin:0 0 22px;color:#64748b}.logout-modal-actions{display:flex;gap:12px;justify-content:center}.logout-modal-actions .btn{min-width:128px}@media(max-width:1100px){.login-modern-screen{grid-template-columns:1fr;padding:24px}.login-hero-panel{min-height:auto}.login-hero-copy h1{font-size:42px}.login-feature-grid{grid-template-columns:repeat(2,1fr)}.invoice-info-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:760px){.login-modern-screen{padding:14px}.login-hero-panel{padding:22px;border-radius:26px}.login-hero-copy h1{font-size:34px}.login-card-modern{padding:22px;border-radius:26px}.login-feature-grid{grid-template-columns:1fr}.invoice-info-grid{grid-template-columns:1fr}.logout-modal-actions{flex-direction:column}.logout-modal-actions .btn{width:100%}}

/* V9 premium theme polish */
:root{--bg:#eef4ff;--card:#ffffff;--text:#0b1220;--muted:#667085;--primary:#2563eb;--primary2:#06b6d4;--accent:#7c3aed;--border:#dbe5f2;--shadow:0 18px 55px rgba(15,23,42,.09);--soft:#f8fbff}
body:not(.auth-page){background:radial-gradient(circle at 22% -10%,rgba(59,130,246,.20),transparent 34%),radial-gradient(circle at 95% 5%,rgba(6,182,212,.18),transparent 30%),linear-gradient(180deg,#f7fbff 0%,#edf4ff 46%,#f8fafc 100%);color:var(--text)}
body:not(.auth-page)::before{content:"";position:fixed;inset:0;z-index:-1;background-image:linear-gradient(rgba(37,99,235,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.045) 1px,transparent 1px);background-size:42px 42px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.9),rgba(0,0,0,.1));pointer-events:none}.app-shell{grid-template-columns:282px minmax(0,1fr)}.sidebar{background:linear-gradient(180deg,#07111f 0%,#0c1830 46%,#0f172a 100%);border-right:1px solid rgba(148,163,184,.18);box-shadow:18px 0 55px rgba(15,23,42,.16);padding:24px 16px}.brand{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);border-radius:24px;padding:14px;margin-bottom:22px}.brand-icon{width:50px;height:50px;border-radius:18px;background:linear-gradient(135deg,#38bdf8,#2563eb 55%,#7c3aed);box-shadow:0 16px 40px rgba(37,99,235,.35)}.brand strong{color:#fff;letter-spacing:-.02em}.brand span{color:#93a4ba;font-weight:800}.menu-label{color:#7d90aa;margin-top:22px}.menu a{position:relative;padding:12px 14px 12px 42px;border-radius:16px;font-weight:850;color:#cbd5e1;min-height:44px}.menu a::before{content:"";position:absolute;left:14px;top:50%;width:12px;height:12px;border-radius:5px;transform:translateY(-50%);background:linear-gradient(135deg,#38bdf8,#6366f1);box-shadow:0 0 0 4px rgba(56,189,248,.10)}.menu a:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.10);color:#fff;transform:translateX(3px)}.main{min-width:0}.topbar{height:78px;background:rgba(255,255,255,.84);border-bottom:1px solid rgba(219,229,242,.86);box-shadow:0 14px 40px rgba(15,23,42,.06)}.topbar h1{font-size:22px;letter-spacing:-.04em}.topbar p{color:#667085}.user-chip{background:rgba(255,255,255,.92);border:1px solid rgba(219,229,242,.9);box-shadow:0 14px 36px rgba(15,23,42,.08);padding:8px 10px 8px 16px}.user-chip a{background:linear-gradient(135deg,#eff6ff,#e0f2fe);color:#1d4ed8}.content{padding:30px;max-width:1600px;margin:0 auto;width:100%}.card,.page-intro,.dashboard-hero{background:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.88);box-shadow:var(--shadow)}.card{border-radius:28px}.page-intro,.dashboard-hero{border-radius:32px;background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(232,244,255,.84));overflow:hidden;position:relative}.page-intro::after,.dashboard-hero::after{content:"";position:absolute;right:-70px;top:-100px;width:260px;height:260px;border-radius:50%;background:linear-gradient(135deg,rgba(37,99,235,.13),rgba(6,182,212,.12));pointer-events:none}.page-intro h2,.dashboard-hero h2{font-size:34px;letter-spacing:-.055em}.eyebrow{color:#2563eb;letter-spacing:.17em}.btn{border-radius:16px;box-shadow:0 12px 24px rgba(15,23,42,.08)}.btn-primary{background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff}.btn-light{background:#f8fafc;border:1px solid #e6edf7;color:#0f172a}.table-wrap{border-radius:20px;overflow:auto}table{border-collapse:separate;border-spacing:0;min-width:900px}th{background:#f8fbff;color:#5b6b82;font-weight:1000}td,th{border-bottom:1px solid #e6edf7}.badge{border:1px solid rgba(15,23,42,.04)}.login-lock{display:none!important}.login-card-head{align-items:flex-start}.login-card-head>div:first-child{width:100%}

/* V9 invoice detail cleanup */
.invoice-page{display:grid;gap:18px}.invoice-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;border-radius:32px;padding:28px;background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(229,244,255,.90));border:1px solid rgba(255,255,255,.88);box-shadow:var(--shadow);position:relative;overflow:hidden}.invoice-hero::after{content:"";position:absolute;right:-60px;top:-95px;width:260px;height:260px;border-radius:50%;background:linear-gradient(135deg,rgba(37,99,235,.14),rgba(6,182,212,.13));pointer-events:none}.invoice-title-block{position:relative;z-index:1}.invoice-title-block h2{font-size:42px;line-height:1;margin:8px 0 6px;letter-spacing:-.06em}.invoice-title-block p{margin:0;color:#53657f;font-weight:650}.invoice-hero .intro-actions{position:relative;z-index:1}.invoice-summary-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.invoice-stat-card{background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.94);border-radius:24px;padding:18px;box-shadow:0 14px 36px rgba(15,23,42,.07);min-height:108px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.invoice-stat-card::after{content:"";position:absolute;right:-36px;top:-40px;width:108px;height:108px;border-radius:50%;background:linear-gradient(135deg,rgba(37,99,235,.14),rgba(6,182,212,.10))}.invoice-stat-card span{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#5b6b82;font-weight:1000;position:relative;z-index:1}.invoice-stat-card strong{font-size:26px;letter-spacing:-.045em;position:relative;z-index:1}.invoice-stat-card.paid strong{color:#047857}.invoice-stat-card.balance strong{color:#b45309}.invoice-stat-card.status-card strong{font-size:14px}.invoice-layout-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:18px;align-items:stretch}.invoice-main-card,.invoice-side-card,.payment-history-card{background:rgba(255,255,255,.90);border:1px solid rgba(255,255,255,.92)}.slim-header{align-items:flex-start;margin-bottom:14px}.slim-header h2{font-size:25px;margin:0 0 6px;letter-spacing:-.04em}.slim-header p{margin:0;color:#667085}.progress-percent{font-size:34px;color:#2563eb;letter-spacing:-.04em}.progress-track{height:12px;background:#e5edf7;border-radius:999px;overflow:hidden;margin:16px 0 20px}.progress-track div{height:100%;background:linear-gradient(90deg,#2563eb,#06b6d4,#7c3aed);border-radius:999px}.invoice-info-grid.refined{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.invoice-info-grid.refined div{background:#f8fbff;border:1px solid #e5edf7;border-radius:18px;padding:14px}.invoice-info-grid.refined small{color:#667085}.invoice-side-card h3{font-size:20px;letter-spacing:-.035em;margin:0 0 16px}.relation-flow{display:grid;gap:12px}.relation-flow div{display:grid;grid-template-columns:42px 1fr;gap:4px 12px;align-items:center;background:#f8fbff;border:1px solid #e5edf7;border-radius:18px;padding:13px}.relation-flow span{grid-row:1/3;width:42px;height:42px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff;font-weight:1000}.relation-flow strong{font-size:14px}.relation-flow small{color:#667085;font-weight:750}.invoice-history-table td{vertical-align:middle}.invoice-history-table small{color:#667085;font-weight:750}.method-pill-list{gap:7px}.method-pill-list span{border-radius:14px;background:#eef4ff;border:1px solid #cddcff;color:#1e3a8a;line-height:1.35}.empty-row{background:#fbfdff;color:#667085}.logout-icon{background:linear-gradient(135deg,#fee2e2,#dbeafe);color:#dc2626}

@media(max-width:1180px){.invoice-layout-grid{grid-template-columns:1fr}.invoice-summary-row,.invoice-info-grid.refined{grid-template-columns:repeat(2,minmax(0,1fr))}.content{padding:22px}}
@media(max-width:760px){.app-shell{display:block}.sidebar{position:fixed;left:-290px;width:282px}.sidebar-open .sidebar{left:0}.content{padding:16px}.topbar{height:auto}.invoice-hero{flex-direction:column;align-items:stretch;padding:22px;border-radius:26px}.invoice-title-block h2{font-size:34px}.invoice-summary-row,.invoice-info-grid.refined{grid-template-columns:1fr}.invoice-stat-card{min-height:98px}.slim-header{flex-direction:column}.progress-percent{font-size:28px}.table-wrap{border-radius:16px}.login-card-head h2{font-size:29px}}


/* V10 Sidebar Professional Icons + Mobile Close */
.sidebar-head{display:flex;align-items:stretch;gap:10px;margin-bottom:22px}.sidebar .brand{flex:1;display:flex;align-items:center;gap:12px;margin:0;padding:14px;border-radius:24px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);text-decoration:none}.brand-copy{min-width:0}.brand-copy strong{display:block;color:#fff;white-space:nowrap}.brand-copy span{display:block;color:#93a4ba;font-weight:800;font-size:12px;margin-top:3px}.menu a.menu-item,.menu .menu-item{position:relative;display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:16px;font-weight:850;color:#cbd5e1;min-height:46px;border:1px solid transparent;transition:background .18s ease,border-color .18s ease,color .18s ease,transform .18s ease}.menu a.menu-item::before{display:none!important;content:none!important}.menu a.menu-item:hover,.menu a.menu-item.active{background:rgba(37,99,235,.16);border-color:rgba(96,165,250,.20);color:#fff;transform:translateX(3px)}.menu a.menu-item.active{box-shadow:inset 3px 0 0 #38bdf8}.menu-icon{width:34px;height:34px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 34px;color:#7dd3fc;background:rgba(14,165,233,.10);border:1px solid rgba(125,211,252,.14)}.menu a.menu-item:hover .menu-icon,.menu a.menu-item.active .menu-icon{color:#fff;background:linear-gradient(135deg,#2563eb,#06b6d4);border-color:transparent;box-shadow:0 10px 22px rgba(37,99,235,.25)}.menu-text{line-height:1.2}.nav-svg{width:19px;height:19px;display:block}.sidebar-close{display:none;width:44px;height:44px;border:0;border-radius:16px;background:rgba(255,255,255,.08);color:#fff;align-items:center;justify-content:center;cursor:pointer;border:1px solid rgba(255,255,255,.10)}.sidebar-close:hover{background:rgba(255,255,255,.14)}.sidebar-close .nav-svg,.hamburger .nav-svg{width:22px;height:22px}.sidebar-overlay{position:fixed;inset:0;background:rgba(2,8,23,.58);z-index:55;opacity:0;visibility:hidden;transition:opacity .22s ease,visibility .22s ease}.page-title-block{min-width:0}.hamburger{align-items:center;justify-content:center;width:44px;height:44px;padding:0;color:#0f172a}.user-chip a{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:10px 14px;line-height:1}.user-chip small{display:block;color:#64748b}@media(max-width:760px){.app-shell{display:block}.sidebar{position:fixed!important;left:0!important;top:0!important;bottom:0!important;width:min(86vw,292px)!important;height:100dvh!important;z-index:60!important;transform:translateX(-105%);transition:transform .22s ease!important;overflow-y:auto;padding:20px 14px}.sidebar-open .sidebar{left:0!important;transform:translateX(0)}body.sidebar-open{overflow:hidden}.sidebar-open .sidebar-overlay{opacity:1;visibility:visible}.sidebar-close{display:inline-flex}.sidebar-head{align-items:flex-start}.sidebar .brand{padding:12px}.brand-icon{width:46px;height:46px}.hamburger{display:inline-flex!important;box-shadow:0 12px 28px rgba(15,23,42,.10);background:#fff;border:1px solid #e5edf7;border-radius:14px;flex:0 0 44px}.topbar{align-items:center;grid-template-columns:auto 1fr auto}.topbar h1{font-size:18px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-title-block{flex:1;min-width:0}.user-chip{padding:6px;border-radius:18px}.user-chip a{padding:9px 11px}.menu a.menu-item{padding:12px 12px;transform:none!important}.menu a.menu-item:hover,.menu a.menu-item.active{transform:none!important}.menu-icon{width:36px;height:36px;flex-basis:36px}}@media(min-width:761px){.sidebar-overlay{display:none!important}.sidebar-close{display:none!important}.hamburger{display:none!important}}


/* V11 Sidebar scroll fix + compact professional menu */
.sidebar{
  height:100vh!important;
  max-height:100vh!important;
  overflow:hidden!important;
  display:flex!important;
  flex-direction:column!important;
}
.sidebar-head{
  flex:0 0 auto!important;
  margin-bottom:14px!important;
}
.menu{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding:0 4px 24px 0!important;
  scrollbar-width:thin;
  scrollbar-color:rgba(125,211,252,.45) transparent;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
}
.menu::-webkit-scrollbar{width:6px}
.menu::-webkit-scrollbar-track{background:transparent}
.menu::-webkit-scrollbar-thumb{background:rgba(125,211,252,.35);border-radius:999px}
.menu::-webkit-scrollbar-thumb:hover{background:rgba(125,211,252,.55)}
.menu a.menu-item,.menu .menu-item{
  gap:10px!important;
  padding:9px 11px!important;
  min-height:40px!important;
  border-radius:13px!important;
  font-size:14px!important;
}
.menu-icon{
  width:30px!important;
  height:30px!important;
  flex:0 0 30px!important;
  border-radius:10px!important;
}
.nav-svg{width:17px!important;height:17px!important}
.menu-text{font-size:14px!important;line-height:1.15!important}
.menu-label{
  margin:16px 10px 8px!important;
  font-size:11px!important;
  letter-spacing:.16em!important;
}
.sidebar .brand{padding:11px 12px!important;border-radius:20px!important}
.brand-icon{width:44px!important;height:44px!important;border-radius:15px!important;font-size:15px!important}
.brand-copy strong{font-size:14px!important}
.brand-copy span{font-size:11px!important}
.sidebar-close{width:40px!important;height:40px!important;border-radius:14px!important}
@media(max-width:760px){
  .sidebar{
    height:100dvh!important;
    max-height:100dvh!important;
    overflow:hidden!important;
    padding:16px 12px!important;
    width:min(84vw,280px)!important;
  }
  .menu{padding-bottom:34px!important}
  .sidebar-head{margin-bottom:12px!important}
  .menu a.menu-item{padding:9px 10px!important;min-height:39px!important}
  .menu-icon{width:30px!important;height:30px!important;flex-basis:30px!important}
  .menu-text{font-size:13.5px!important}
  .brand-icon{width:42px!important;height:42px!important}
  .sidebar .brand{padding:10px!important}
}

/* V13 Collector outlet GPS automation, nearest sorting, Google Maps action */
.auto-gps-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:18px;
}
.auto-gps-card h2{
  margin:6px 0 5px;
  letter-spacing:-.04em;
}
.auto-gps-card p{
  margin:0;
  color:#64748b;
  font-weight:700;
}
.gps-status-ok{color:#166534!important}
.gps-status-bad{color:#991b1b!important}
.gps-status-loading{color:#1d4ed8!important}
.collector-outlet-card{
  position:relative;
  align-items:stretch;
  gap:18px;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;
}
.collector-outlet-card:hover{
  transform:translateY(-2px);
  border-color:#bfdbfe;
  box-shadow:0 18px 42px rgba(15,23,42,.10);
}
.outlet-card-main{min-width:0;flex:1}
.outlet-card-head{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.radius-chip{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:5px 10px;
  background:#eff6ff;
  color:#1d4ed8;
  font-size:12px;
  font-weight:900;
  border:1px solid #dbeafe;
}
.collector-outlet-card h3{
  letter-spacing:-.025em;
}
.radius-status{
  margin-top:10px;
  width:max-content;
}
.status-checking{background:#e0f2fe;color:#075985}
.status-radius-ok{background:#dcfce7;color:#166534}
.status-radius-bad{background:#fee2e2;color:#991b1b}
.status-radius-warning{background:#fef3c7;color:#92400e}
.outlet-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  min-width:250px;
}
.outlet-actions .btn{
  white-space:nowrap;
}
.maps-btn{
  color:#0f172a;
}
@media(max-width:760px){
  .auto-gps-card{
    flex-direction:column;
    align-items:stretch;
  }
  .collector-outlet-card{
    flex-direction:column;
  }
  .outlet-actions{
    min-width:0;
    width:100%;
    display:grid;
    grid-template-columns:1fr 1fr;
  }
  .outlet-actions .btn{width:100%}
}

/* V16 Input Pembayaran polish + stable GPS init + direct camera UI */
.payment-outlet-header{max-width:1200px;margin:0 auto}.outlet-payment-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.outlet-payment-head h2{margin:8px 0 8px;letter-spacing:-.035em}.outlet-payment-head p{margin:0;color:#475569;font-weight:650}.payment-page-grid{display:grid;grid-template-columns:minmax(0,1.22fr) minmax(420px,.78fr);gap:18px;max-width:1200px;margin-left:auto;margin-right:auto}.payment-invoice-card,.payment-form-card{min-width:0}.card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}.card-title-row.compact{margin-bottom:12px}.card-title-row h2{margin:0 0 8px;font-size:24px;letter-spacing:-.04em}.muted{color:#64748b;font-weight:650}.payment-invoice-table table{min-width:620px}.payment-invoice-table tfoot th{background:#f8fbff}.payment-method-list{gap:14px}.payment-method-row{display:grid!important;grid-template-columns:repeat(12,minmax(0,1fr))!important;gap:10px!important;align-items:end!important;padding:14px!important;border-radius:20px!important;background:linear-gradient(135deg,#fbfdff,#f4f8ff)!important;border:1px solid #dbe7f5!important;box-shadow:0 10px 24px rgba(15,23,42,.04)}.payment-method-row .method-field{min-width:0}.payment-method-row small{display:block;margin:0 0 5px;color:#53657f;font-size:11px;font-weight:900;letter-spacing:.02em}.payment-method-row input,.payment-method-row select{min-height:42px;border-radius:13px;padding:10px 11px;background:#fff}.method-type-field{grid-column:span 4}.method-amount-field{grid-column:span 8}.method-ref-field,.method-bank-field,.method-date-field,.method-note-field{grid-column:span 6}.payment-method-row .remove-method{grid-column:span 12;height:40px!important;width:100%;min-width:0!important;border:1px solid #fecaca!important;background:#fff5f5!important;color:#991b1b!important;font-size:18px!important}.payment-method-row .remove-method:disabled{opacity:.45;cursor:not-allowed}.add-method-btn{width:100%;border:1px dashed #bfdbfe!important;background:#f8fbff!important;color:#1d4ed8!important}.camera-file-input{position:absolute!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important}.camera-capture-box{border:1px solid #dbe7f5;background:linear-gradient(135deg,#fbfdff,#f8fbff);border-radius:18px;padding:14px;display:grid;gap:12px}.camera-open-btn{width:100%;border:1px dashed #93c5fd!important;color:#1d4ed8!important;background:#eff6ff!important}.camera-preview-wrap{display:grid;gap:10px}.camera-preview-wrap img{width:100%;max-height:260px;object-fit:cover;border-radius:16px;border:1px solid #dbe7f5;background:#fff}.camera-capture-box small{color:#64748b;font-weight:750}.camera-capture-box small.photo-status-ok{color:#166534}.form-help{display:block;margin-top:10px;color:#64748b;font-weight:650}.camera-modal.show{display:flex!important;opacity:1;visibility:visible}.camera-modal .modal-backdrop{position:absolute;inset:0;background:rgba(2,8,23,.62)}.camera-modal-panel{width:min(560px,calc(100vw - 28px));position:relative;z-index:2;border-radius:24px;padding:18px;background:#fff;box-shadow:0 30px 80px rgba(15,23,42,.30)}.camera-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px}.camera-modal-head h2{margin:0;font-size:22px;letter-spacing:-.035em}.camera-modal-head p{margin:4px 0 0;color:#64748b;font-weight:650}#cameraVideo{width:100%;height:min(56vh,420px);object-fit:cover;background:#020617;border-radius:18px;border:1px solid #e5edf7}.camera-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}.camera-error{display:block;color:#991b1b;font-weight:750;margin-top:8px}.modal-open{overflow:hidden}.payment-form-card #submitPaymentBtn{margin-top:14px}
@media(max-width:1180px){.payment-page-grid{grid-template-columns:1fr}.payment-form-card{max-width:none}.payment-method-row{grid-template-columns:repeat(12,minmax(0,1fr))!important}.method-type-field,.method-amount-field{grid-column:span 6}.method-ref-field,.method-bank-field,.method-date-field,.method-note-field{grid-column:span 6}}
@media(max-width:760px){.payment-outlet-header,.payment-page-grid{max-width:none}.outlet-payment-head{flex-direction:column}.payment-page-grid{grid-template-columns:1fr}.card-title-row{flex-direction:column}.payment-method-row{grid-template-columns:1fr!important}.method-type-field,.method-amount-field,.method-ref-field,.method-bank-field,.method-date-field,.method-note-field,.payment-method-row .remove-method{grid-column:1/-1}.camera-modal-actions{grid-template-columns:1fr;display:grid}.camera-modal-actions .btn{width:100%}}

/* V17 Payment method UX: conditional fields, per-method camera, compact delete button */
.payment-method-row .conditional-field[hidden],
.payment-method-row .remove-method[hidden],
.method-photo-preview[hidden]{display:none!important}
.payment-method-row{grid-template-columns:repeat(12,minmax(0,1fr))!important;align-items:end!important}
.payment-method-row .method-type-field{grid-column:span 3!important}
.payment-method-row .method-amount-field{grid-column:span 3!important}
.payment-method-row .method-ref-field{grid-column:span 3!important}
.payment-method-row .method-bank-field{grid-column:span 3!important}
.payment-method-row .method-date-field{grid-column:span 3!important}
.payment-method-row .method-note-field{grid-column:span 4!important}
.payment-method-row .method-photo-field{grid-column:span 7!important}
.payment-method-row .remove-method{grid-column:span 1!important;width:42px!important;min-width:42px!important;height:42px!important;padding:0!important;justify-self:end!important;border-radius:14px!important;background:#fff5f5!important;color:#991b1b!important;border:1px solid #fecaca!important}
.method-photo-field{display:grid;gap:8px}
.method-camera-btn{width:100%;border:1px dashed #93c5fd!important;color:#1d4ed8!important;background:#eff6ff!important;min-height:42px!important}
.method-photo-preview{display:grid;grid-template-columns:68px 1fr;align-items:center;gap:10px;padding:8px;border:1px solid #bbf7d0;border-radius:14px;background:#f0fdf4;color:#166534;font-weight:800}
.method-photo-preview img{width:68px;height:52px;border-radius:10px;object-fit:cover;border:1px solid #dcfce7;background:#fff}
.payment-method-row select:invalid{color:#94a3b8}
.payment-method-row .method-reference:required,
.payment-method-row .method-bank:required,
.payment-method-row .method-due-date:required{border-color:#bfdbfe;background:#f8fbff}
@media(max-width:1180px){
  .payment-method-row .method-type-field,
  .payment-method-row .method-amount-field,
  .payment-method-row .method-ref-field,
  .payment-method-row .method-bank-field,
  .payment-method-row .method-date-field,
  .payment-method-row .method-note-field{grid-column:span 6!important}
  .payment-method-row .method-photo-field{grid-column:span 11!important}
  .payment-method-row .remove-method{grid-column:span 1!important}
}
@media(max-width:760px){
  .payment-method-row .method-type-field,
  .payment-method-row .method-amount-field,
  .payment-method-row .method-ref-field,
  .payment-method-row .method-bank-field,
  .payment-method-row .method-date-field,
  .payment-method-row .method-note-field,
  .payment-method-row .method-photo-field,
  .payment-method-row .remove-method{grid-column:1/-1!important;width:100%!important}
}


/* V18: Rapikan jumlah faktur dan form metode pembayaran */
.invoice-count-badge{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  flex-direction:row!important;
  gap:5px!important;
  white-space:nowrap!important;
  min-width:max-content!important;
  width:auto!important;
  line-height:1!important;
  padding:10px 13px!important;
}
.invoice-count-badge strong,
.invoice-count-badge span{
  display:inline!important;
  white-space:nowrap!important;
  line-height:1!important;
}
.payment-invoice-card .card-title-row{
  align-items:flex-start!important;
}
.payment-form-card .payment-method-row{
  position:relative!important;
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
  align-items:end!important;
  padding:18px!important;
  border-radius:20px!important;
}
.payment-form-card .payment-method-row .method-field,
.payment-form-card .payment-method-row .method-type-field,
.payment-form-card .payment-method-row .method-amount-field,
.payment-form-card .payment-method-row .method-ref-field,
.payment-form-card .payment-method-row .method-bank-field,
.payment-form-card .payment-method-row .method-date-field,
.payment-form-card .payment-method-row .method-note-field{
  grid-column:auto!important;
  width:100%!important;
  min-width:0!important;
}
.payment-form-card .payment-method-row .method-photo-field{
  grid-column:1/-1!important;
  width:100%!important;
}
.payment-form-card .payment-method-row .method-photo-field small{
  margin-bottom:8px!important;
}
.payment-form-card .method-camera-btn{
  min-height:46px!important;
  border-radius:14px!important;
}
.payment-form-card .payment-method-row .remove-method{
  position:absolute!important;
  right:12px!important;
  top:12px!important;
  grid-column:auto!important;
  width:36px!important;
  min-width:36px!important;
  height:36px!important;
  padding:0!important;
  border-radius:12px!important;
  z-index:2!important;
}
.payment-form-card .payment-method-row.has-remove-method{
  padding-top:56px!important;
}
.payment-form-card .payment-method-row input,
.payment-form-card .payment-method-row select{
  width:100%!important;
  min-height:46px!important;
}
@media(max-width:760px){
  .payment-form-card .payment-method-row{
    grid-template-columns:1fr!important;
    gap:12px!important;
  }
  .payment-form-card .payment-method-row .method-field,
  .payment-form-card .payment-method-row .method-photo-field,
  .payment-form-card .payment-method-row .remove-method{
    grid-column:1/-1!important;
  }
  .invoice-count-badge{
    align-self:flex-start!important;
  }
}

/* V20: pastikan konten pembayaran benar-benar tersembunyi saat lokasi belum valid.
   Author CSS display:grid sebelumnya bisa mengalahkan attribute hidden bawaan browser. */
[hidden],
.js-payment-locked,
#paymentContent[hidden]{display:none!important}


/* V21: mobile spacing pada halaman input pembayaran collector.
   Tombol Kembali dan status lokasi tidak boleh berdempetan. */
.payment-outlet-header .outlet-payment-head{
  margin-bottom:14px!important;
}
.payment-outlet-header .payment-radius-status{
  margin-top:0!important;
}
@media(max-width:760px){
  .payment-outlet-header .outlet-payment-head{
    gap:12px!important;
    margin-bottom:14px!important;
  }
  .payment-outlet-header .btn-kembali-tagih{
    width:100%!important;
    min-height:48px!important;
    margin:0!important;
  }
  .payment-outlet-header .payment-radius-status{
    display:block!important;
    width:100%!important;
    margin-top:14px!important;
    margin-bottom:0!important;
    padding:14px 16px!important;
    border-radius:16px!important;
    line-height:1.45!important;
  }
}
