:root{--text-color:#000;--font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--sidebar-text:#1f2937;--header-bg:#fff;--header-text:#1f2937}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f1f5f9;color:#000;color:var(--text-color);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-family:var(--font-family)}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-family:var(--font-family)}.sidebar{background:#1e293b;color:#cbd5e1;display:flex;flex-direction:column;height:100vh;left:0;min-width:192px;position:fixed;top:0;width:192px;z-index:100}.sidebar-logo{align-items:center;border-bottom:1px solid #ffffff14;display:flex;gap:8px;padding:16px 16px 12px}.logo-icon{font-size:24px}.logo-text{display:flex;flex-direction:column;line-height:1.2}.logo-bpn{color:#fff;font-size:14px;font-weight:700}.logo-syariah{color:#60a5fa;font-size:12px;font-weight:600}.logo-subtitle{color:#94a3b8;font-size:10px}.sidebar-section-label{color:#64748b;font-size:11px;font-weight:600;letter-spacing:.5px;padding:16px 16px 8px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:0 8px}.sidebar-link{align-items:center;background:none;border:none;border-radius:8px;color:#cbd5e1;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:10px 12px;text-align:left;text-decoration:none;transition:all .15s;width:100%}.sidebar-link:hover{background:#ffffff14;color:#fff}.sidebar-link.active{background:#3b82f6;color:#fff;font-weight:500}.sidebar-icon{font-size:16px;text-align:center;width:20px}.sidebar-footer{border-top:1px solid #ffffff14;padding:8px}.logout-btn{color:#cbd5e1}.logout-btn:hover{background:#ef444433;color:#fca5a5}.layout{display:flex;min-height:100vh}.layout-main{background:#f1f5f9;flex:1 1;margin-left:192px;min-height:100vh}.login-page{align-items:center;background:linear-gradient(135deg,#1e293b,#334155);display:flex;justify-content:center;min-height:100vh}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:40px;width:100%}.login-header{margin-bottom:24px;text-align:center}.login-logo{font-size:40px;margin-bottom:8px}.login-header h1{color:#1f2937;font-size:20px;font-weight:700;margin:0 0 4px}.login-header p{color:#6b7280;font-size:14px;margin:0}.login-error{background:#fee2e2;border-radius:8px;color:#dc2626;font-size:13px;padding:10px 14px}.form-group,.login-error{margin-bottom:16px}.form-group label{color:#374151;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.form-group input{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-size:14px;padding:10px 14px;transition:border-color .15s;width:100%}.form-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.login-btn{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px;transition:background .15s;width:100%}.login-btn:hover{background:#2563eb}.login-btn:disabled{cursor:not-allowed;opacity:.6}.login-hint{background:#f0f9ff;border-radius:8px;margin-top:20px;padding:12px;text-align:center}.login-hint p{color:#6b7280;font-size:12px;margin:0}.login-hint p:first-child{margin-bottom:4px}.login-hint strong{color:#374151}.header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;box-sizing:border-box;display:flex;height:64px;justify-content:space-between;padding:16px 24px}.header-title{color:#1f2937;font-size:18px;font-weight:600;margin:0}.header-right{align-items:center;display:flex;gap:16px}.notification-wrapper{position:relative}.notification-btn{background:none;border:none;cursor:pointer;font-size:20px;padding:4px;position:relative}.notif-badge{align-items:center;background:#ef4444;border-radius:50%;color:#fff;display:flex;font-size:10px;height:16px;justify-content:center;position:absolute;right:-2px;top:-2px;width:16px}.notif-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:300px;overflow-y:auto;position:absolute;right:0;top:36px;width:300px;z-index:200}.notif-item{border-bottom:1px solid #f3f4f6;padding:12px 16px}.notif-item.unread{background:#eff6ff}.notif-title{color:#1f2937;font-size:13px;font-weight:600}.notif-message{color:#6b7280;font-size:12px;margin-top:2px}.notif-empty{color:#9ca3af;font-size:13px;padding:16px;text-align:center}.user-info{align-items:center;display:flex;gap:10px}.user-details{align-items:flex-end;display:flex;flex-direction:column}.user-name{color:#1f2937;font-size:14px;font-weight:600}.user-role{color:#6b7280;font-size:12px;text-transform:capitalize}.user-avatar{align-items:center;background:#6366f1;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:600;height:36px;justify-content:center;width:36px}.dashboard-content{padding:24px}.dashboard-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.dash-stat-card{background:#fff;box-shadow:0 1px 3px #0000000f;gap:16px;padding:20px}.dash-stat-card,.dash-stat-icon{align-items:center;border-radius:12px;display:flex}.dash-stat-icon{font-size:20px;height:48px;justify-content:center;width:48px}.pending-icon{background:#fef3c7}.approved-icon{background:#d1fae5}.rejected-icon{background:#fee2e2}.paidoff-icon{background:#dbeafe}.dash-stat-label{color:#6b7280;font-size:13px;margin-bottom:4px}.dash-stat-value{color:#1f2937;font-size:24px;font-weight:700}.dashboard-total{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;padding:24px}.dashboard-total h3{color:#374151;font-size:16px;font-weight:600;margin:0 0 8px}.total-amount{color:#16a34a;font-size:28px;font-weight:700;margin:0}@media (max-width:768px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}.pinjaman-content{padding:24px}.pinjaman-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;overflow:hidden}.pinjaman-card-header{align-items:flex-start;display:flex;justify-content:space-between;padding:24px 24px 16px}.pinjaman-card-title{color:#1f2937;font-size:18px;font-weight:700;margin:0 0 4px}.pinjaman-card-subtitle{color:#6b7280;font-size:14px;margin:0}.export-csv-btn{align-items:center;background:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:background .15s;white-space:nowrap}.export-csv-btn:hover{background:#059669}.pinjaman-tabs{border-bottom:1px solid #e5e7eb;display:flex;gap:0;padding:0 24px}.pinjaman-tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .15s}.pinjaman-tab:hover{color:#374151}.pinjaman-tab.active{border-bottom-color:#3b82f6;color:#1f2937;font-weight:600}.pinjaman-table-wrapper{overflow-x:auto}.pinjaman-table{border-collapse:collapse;width:100%}.pinjaman-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 24px;text-align:left;text-transform:uppercase}.pinjaman-table td{border-bottom:1px solid #f3f4f6;color:#374151;font-size:14px;padding:14px 24px}.empty-message{color:#9ca3af;font-style:italic;padding:40px 24px!important;text-align:center}.action-buttons{display:flex;gap:8px}.btn-approve{background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px}.btn-approve:hover{background:#059669}.btn-reject{background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px}.btn-reject:hover{background:#dc2626}.btn-paidoff{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px}.btn-paidoff:hover{background:#2563eb}.status-label{color:#6b7280;font-size:12px;font-style:italic}.nasabah-content{padding:24px}.nasabah-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;overflow:hidden}.nasabah-card-header{padding:24px 24px 16px}.nasabah-card-header h2{color:#1f2937;font-size:18px;font-weight:700;margin:0 0 4px}.nasabah-card-header p{color:#6b7280;font-size:14px;margin:0}.nasabah-table-wrapper{overflow-x:auto}.nasabah-table{border-collapse:collapse;width:100%}.nasabah-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:12px;font-weight:600;padding:12px 24px;text-align:left;text-transform:uppercase}.nasabah-table td{border-bottom:1px solid #f3f4f6;color:#374151;font-size:14px;padding:14px 24px}.empty-msg{color:#9ca3af;font-style:italic;padding:40px 24px!important;text-align:center}.status-badge{border-radius:12px;font-size:12px;font-weight:600;padding:4px 10px;text-transform:capitalize}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.detail-btn{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px}.detail-btn:hover{background:#2563eb}.nasabah-detail-content{padding:24px}.back-btn{background:none;border:1px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;font-size:13px;margin-bottom:16px;padding:8px 16px}.back-btn:hover{background:#f3f4f6}.detail-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;padding:24px}.detail-card h2{color:#1f2937;font-size:20px;font-weight:700;margin:0 0 20px}.detail-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item label{color:#6b7280;font-size:12px;font-weight:600;text-transform:uppercase}.detail-item span{color:#1f2937;font-size:14px}.produk-content{padding:24px}.produk-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;overflow:hidden}.produk-card-header{align-items:flex-start;display:flex;justify-content:space-between;padding:24px 24px 16px}.produk-card-header h2{color:#1f2937;font-size:18px;font-weight:700;margin:0 0 4px}.produk-card-header p{color:#6b7280;font-size:14px;margin:0}.add-btn{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px}.add-btn:hover{background:#2563eb}.produk-form{border-bottom:1px solid #e5e7eb;padding:0 24px 20px}.form-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr);margin-bottom:12px}.produk-form .form-group{display:flex;flex-direction:column;gap:4px}.produk-form .form-group label{color:#374151;font-size:12px;font-weight:600}.produk-form .form-group input{border:1px solid #d1d5db;border-radius:6px;font-size:13px;padding:8px 12px}.produk-form .form-group input:focus{border-color:#3b82f6;outline:none}.submit-btn{background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 20px}.submit-btn:hover{background:#059669}.produk-table-wrapper{overflow-x:auto}.produk-table{border-collapse:collapse;width:100%}.produk-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:12px;font-weight:600;padding:12px 24px;text-align:left;text-transform:uppercase}.produk-table td{border-bottom:1px solid #f3f4f6;color:#374151;font-size:14px;padding:14px 24px}.edit-btn{background:#f59e0b;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px}.edit-btn:hover{background:#d97706}.delete-btn{background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px}.delete-btn:hover{background:#dc2626}.riwayat-content{padding:24px}.riwayat-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;overflow:hidden}.riwayat-card-header{padding:24px 24px 16px}.riwayat-card-header h2{color:#1f2937;font-size:18px;font-weight:700;margin:0 0 4px}.riwayat-card-header p{color:#6b7280;font-size:14px;margin:0}.riwayat-table-wrapper{overflow-x:auto}.riwayat-table{border-collapse:collapse;width:100%}.riwayat-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:12px;font-weight:600;padding:12px 24px;text-align:left;text-transform:uppercase}.riwayat-table td{border-bottom:1px solid #f3f4f6;color:#374151;font-size:14px;padding:14px 24px}.metode-text,.pay-status{text-transform:capitalize}.pay-status{border-radius:12px;font-size:12px;font-weight:600;padding:4px 10px}.pay-status.success{background:#d1fae5;color:#065f46}.pay-status.failed{background:#fee2e2;color:#991b1b}.pay-status.pending{background:#fef3c7;color:#92400e}.reports-content{padding:24px}.report-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;margin-bottom:24px;padding:24px}.section-title{color:#1f2937;font-size:18px;font-weight:700;margin:0 0 4px}.section-subtitle{color:#6b7280;font-size:14px;margin:0 0 20px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:16px}.stat-card{border-radius:10px;padding:20px;text-align:center}.stat-pending{background:#fef3c7;border:1px solid #fbbf24}.stat-approved{background:#d1fae5;border:1px solid #34d399}.stat-rejected{background:#fee2e2;border:1px solid #f87171}.stat-paidoff{background:#dbeafe;border:1px solid #60a5fa}.stat-label{color:#374151;font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.stat-value{color:#1f2937;font-size:32px;font-weight:700}.total-approved{align-items:center;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;display:flex;gap:12px;padding:16px 20px}.total-label{color:#374151;font-size:14px;font-weight:600}.total-value{color:#16a34a;font-size:20px;font-weight:700}.chart-container{min-height:200px}.bar-chart{align-items:flex-end;display:flex;gap:12px;height:220px;padding:0 8px}.bar-item{align-items:center;display:flex;flex:1 1;flex-direction:column;height:100%}.bar-value{color:#374151;font-size:12px;font-weight:600;margin-bottom:4px}.bar-fill-wrapper{align-items:flex-end;display:flex;flex:1 1;justify-content:center;max-width:48px;width:100%}.bar-fill{background:linear-gradient(180deg,#3b82f6,#1d4ed8);border-radius:4px 4px 0 0;min-height:4px;transition:height .5s ease;width:100%}.bar-label{color:#6b7280;font-size:11px;margin-top:6px;white-space:nowrap}.horizontal-chart{gap:16px}.h-bar-item,.horizontal-chart{display:flex;flex-direction:column}.h-bar-item{gap:4px}.h-bar-label{align-items:center;display:flex;justify-content:space-between}.h-bar-name{color:#1f2937;font-size:14px;font-weight:600}.h-bar-count{color:#6b7280;font-size:12px}.h-bar-track{background:#f3f4f6;border-radius:6px;height:24px;overflow:hidden}.h-bar-fill{background:linear-gradient(90deg,#3b82f6,#6366f1);border-radius:6px;height:100%;min-width:4px;transition:width .5s ease}.h-bar-value{color:#374151;font-size:13px;font-weight:600}.no-data{color:#9ca3af;font-style:italic;padding:40px 0;text-align:center}.export-buttons{display:flex;flex-wrap:wrap;gap:12px}.export-btn{align-items:center;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:10px 20px;transition:all .15s}.export-btn:hover{opacity:.9;transform:translateY(-1px)}.export-pending{background:#f59e0b}.export-approved{background:#10b981}.export-rejected{background:#ef4444}.export-paidoff{background:#3b82f6}@media (max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.export-buttons{flex-direction:column}}
/*# sourceMappingURL=main.5c0ee6e2.css.map*/