.sidebar-title { padding: 10px 12px; margin-bottom: 8px; color: var(--text-main); }
.text-muted-block { color: var(--text-muted); }
.text-small { font-size: 0.875em; }
.margin-top-5 { margin-top: 5px; }
.margin-top-10 { margin-top: 10px; }
.margin-top-20 { margin-top: 20px; }
.margin-bottom-5 { margin-bottom: 5px; }
.margin-bottom-10 { margin-bottom: 10px; }
.margin-bottom-15 { margin-bottom: 15px; }
.gap-20 { gap: 20px; }
.result-card-success { background: #f0fdf4; padding: 20px; border-radius: 12px; border: 1px solid #bbf7d0; }
.result-header-success { color: #15803d; margin-bottom: 10px; }
.result-value-success { font-size: 2.5em; font-weight: 800; color: #15803d; margin-bottom: 5px; }
.result-text-success { color: #166534; }
.hr-success { margin: 10px 0; border-color: #bbf7d0; }
.result-card-gray { background: #f8fafc; padding: 20px; border-radius: 12px; border: 1px solid #e2e8f0; }
.result-header-gray { color: #475569; margin-bottom: 10px; }
.result-value-gray { font-size: 2em; font-weight: 700; color: #475569; margin-bottom: 5px; }
.result-text-gray { color: #64748b; }
.hr-gray { margin: 10px 0; border-color: #e2e8f0; }
.result-card-blue { background: #eff6ff; padding: 20px; border-radius: 12px; border: 1px solid #dbeafe; }
.result-header-blue { color: #1e40af; margin-bottom: 10px; }
.result-desc-box { margin-top: 20px; padding: 15px; background: #eff6ff; border: 1px solid #dbeafe; border-radius: 8px; color: #1e40af; font-size: 0.95em; }
.result-card-warning { margin-top: 20px; padding: 15px; background: #fff7ed; border: 1px solid #fed7aa; border-radius: 8px; color: #9a3412; font-size: 0.95em; }
.result-card-danger { background: #fef2f2; padding: 20px; border-radius: 12px; border: 1px solid #fee2e2; }
.result-header-danger { color: #991b1b; margin-bottom: 5px; }
.result-value-danger { font-size: 1.8em; color: #ef4444; }
.result-text-danger { color: #7f1d1d; margin-top: 5px; }
.result-card-centered { text-align: center; background: #f8fafc; padding: 30px; border-radius: 12px; border: 1px solid #e2e8f0; }
.result-value-hero { font-size: 3.5em; font-weight: 800; color: var(--primary); margin-bottom: 5px; }
.hr-centered { margin: 20px auto; width: 50%; border-color: #e2e8f0; }
.result-flex-center { display: flex; justify-content: center; gap: 30px; }
.result-sub-value { font-size: 1.2em; font-weight: 600; color: var(--text-main); }
.loan-input-grid { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 10px; margin-bottom: 10px; align-items: end; }
.loan-input-grid-w { display: grid; grid-template-columns: 1fr 1fr auto; gap: 10px; margin-bottom: 10px; align-items: end; }
.btn-remove { padding: 10px 15px; }
.btn-add-loan { margin-top: 5px; width: 100%; border: 2px dashed #cbd5e1; background: #f8fafc; color: var(--primary); font-weight: 600; }
.result-row { display: flex; justify-content: space-between; }
.result-row-nav { display: flex; justify-content: space-between; margin-top: 5px; border-top: 1px solid #bbf7d0; padding-top: 5px; }
.icon-pslf { background: #e0f2fe; color: #0369a1; }
.icon-snow { background: #f0fdf4; color: #166534; }
.icon-idr { background: #fff7ed; color: #9a3412; }
.icon-invest { background: #faf5ff; color: #6b21a8; }
.icon-weight { background: #eff6ff; color: #1e40af; }
.icon-tax { background: #ecfdf5; color: #047857; }
