@import "https://fonts.googleapis.com/css2?family=Nunito+Sans:wght@300;400;500;600;700;800&family=Varela+Round&display=swap";:root{--color-primary:#0ea5a0;--color-primary-dark:#0c8a85;--color-primary-light:#e0f7f6;--color-primary-100:#ccefee;--color-secondary:#1d4ed8;--color-secondary-light:#eff6ff;--color-success:#16a34a;--color-success-light:#dcfce7;--color-warning:#d97706;--color-warning-light:#fef3c7;--color-danger:#dc2626;--color-danger-light:#fee2e2;--color-info:#0284c7;--color-info-light:#e0f2fe;--color-orange:#ea580c;--color-orange-light:#ffedd5;--color-bg:#f0faf9;--color-surface:#fff;--color-surface-2:#f8fffe;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--color-text:#0f172a;--color-text-muted:#475569;--color-text-light:#94a3b8;--font-heading:"Varela Round", sans-serif;--font-body:"Nunito Sans", sans-serif;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000f;--shadow-lg:0 10px 15px #00000014, 0 4px 6px #0000000d;--shadow-xl:0 20px 25px #00000014, 0 10px 10px #0000000a;--shadow-card:0 2px 8px #0ea5a014, 0 1px 3px #0000000f;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--transition:.2s ease;--transition-slow:.35s ease;--sidebar-width:260px;--topbar-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}h1,h2,h3{font-family:var(--font-heading);color:var(--color-text);line-height:1.3}h4,h5,h6{font-family:var(--font-body);font-weight:700}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}input,select,textarea,button{font-family:var(--font-body)}.app-layout{min-height:100vh;display:flex}.app-main{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-slow);flex-direction:column;flex:1;display:flex}.app-content{padding:24px;padding-top:calc(var(--topbar-height) + 24px);flex:1;width:100%;max-width:1400px}.sidebar{height:100vh;width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);z-index:100;box-shadow:var(--shadow-md);transition:width var(--transition-slow), transform var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.app-layout.collapsed .sidebar{width:80px}.app-layout.collapsed .sidebar-logo{justify-content:center;padding:20px 0 16px}.app-layout.collapsed .sidebar-logo-text,.app-layout.collapsed .sidebar-section-label,.app-layout.collapsed .sidebar-item-label,.app-layout.collapsed .sidebar-badge,.app-layout.collapsed .user-info{display:none}.app-layout.collapsed .sidebar-item{justify-content:center;padding:12px}.app-layout.collapsed .sidebar-item-icon{margin:0}.app-layout.collapsed .sidebar-user-card{justify-content:center}.app-layout.collapsed .sidebar-user-card button{display:none}.app-layout.collapsed .app-main{margin-left:80px}.app-layout.collapsed .topbar{left:80px}.sidebar-logo{border-bottom:1px solid var(--color-border-light);align-items:center;gap:10px;padding:20px 20px 16px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 4px 12px #0ea5a04d}.sidebar-logo-text .brand-name{font-family:var(--font-heading);color:var(--color-primary);font-size:15px;font-weight:700;line-height:1.1;display:block}.sidebar-logo-text .brand-tagline{color:var(--color-text-muted);font-size:10px;display:block}.sidebar-nav{flex:1;padding:12px 12px 8px}.sidebar-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-light);padding:12px 8px 4px;font-size:10px;font-weight:700}.sidebar-item{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);color:var(--color-text-muted);text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;margin-bottom:2px;padding:10px 12px;font-size:14px;font-weight:500;display:flex;position:relative}.sidebar-item:hover{background:var(--color-primary-light);color:var(--color-primary-dark)}.sidebar-item.active{background:linear-gradient(135deg, var(--color-primary-light), #d0f0ef);color:var(--color-primary-dark);font-weight:700}.sidebar-item.active:before{content:"";background:var(--color-primary);border-radius:0 2px 2px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-item-icon{flex-shrink:0;width:18px;height:18px}.sidebar-badge{background:var(--color-danger);color:#fff;border-radius:var(--radius-full);text-align:center;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.sidebar-user{border-top:1px solid var(--color-border-light);padding:12px}.sidebar-user-card{border-radius:var(--radius-md);background:var(--color-bg);align-items:center;gap:10px;padding:10px;display:flex}.user-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.user-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.user-role{color:var(--color-text-muted);font-size:11px}.topbar{top:0;left:var(--sidebar-width);height:var(--topbar-height);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);z-index:99;box-shadow:var(--shadow-xs);transition:left var(--transition-slow);background:#fffffff2;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:fixed;right:0}.topbar-title{font-size:18px;font-family:var(--font-heading);font-weight:700}.topbar-subtitle{color:var(--color-text-muted);font-size:12px}.topbar-actions{align-items:center;gap:8px;display:flex}.topbar-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;width:38px;height:38px;transition:all var(--transition);color:var(--color-text-muted);justify-content:center;align-items:center;display:flex;position:relative}.topbar-btn:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.notif-dot{background:var(--color-danger);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-card)}.card-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.card-title{color:var(--color-text);font-size:16px;font-weight:700}.card-subtitle{color:var(--color-text-muted);margin-top:2px;font-size:13px}.card-body{padding:20px 24px}.stat-card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-card);transition:transform var(--transition), box-shadow var(--transition);cursor:default;align-items:center;gap:16px;padding:20px;display:flex}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.stat-icon.primary{background:var(--color-primary-light);color:var(--color-primary)}.stat-icon.success{background:var(--color-success-light);color:var(--color-success)}.stat-icon.warning{background:var(--color-warning-light);color:var(--color-warning)}.stat-icon.danger{background:var(--color-danger-light);color:var(--color-danger)}.stat-icon.info{background:var(--color-info-light);color:var(--color-info)}.stat-info{flex:1;min-width:0}.stat-label{color:var(--color-text-muted);font-size:13px;font-weight:500}.stat-value{color:var(--color-text);font-size:24px;font-weight:800;line-height:1.2;font-family:var(--font-heading)}.stat-change{color:var(--color-text-muted);margin-top:2px;font-size:12px}.btn{border-radius:var(--radius-md);font-family:var(--font-body);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:1.5px solid #0000;justify-content:center;align-items:center;gap:7px;padding:9px 18px;font-size:14px;font-weight:600;line-height:1;display:inline-flex}.btn-sm{border-radius:var(--radius-sm);padding:6px 12px;font-size:13px}.btn-lg{border-radius:var(--radius-lg);padding:13px 28px;font-size:16px}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 2px 8px #0ea5a040}.btn-primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px #0ea5a059}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover{background:var(--color-bg);border-color:var(--color-primary);color:var(--color-primary)}.btn-success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn-success:hover{background:#15803d;transform:translateY(-1px)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover{background:#b91c1c;transform:translateY(-1px)}.btn-warning{background:var(--color-warning);color:#fff;border-color:var(--color-warning)}.btn-warning:hover{background:#b45309;transform:translateY(-1px)}.btn-ghost{color:var(--color-text-muted);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--color-bg);color:var(--color-text)}.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none!important;transform:none!important}.badge{border-radius:var(--radius-full);align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger)}.badge-info{background:var(--color-info-light);color:var(--color-info)}.badge-orange{background:var(--color-orange-light);color:var(--color-orange)}.badge-default{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.badge-primary{background:var(--color-primary-light);color:var(--color-primary-dark)}.form-group{margin-bottom:16px}.form-label{color:var(--color-text);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-label .required{color:var(--color-danger);margin-left:2px}.form-control{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;font-family:var(--font-body);color:var(--color-text);background:var(--color-surface);transition:all var(--transition);appearance:none;outline:none;padding:10px 14px;font-size:14px}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0ea5a01f}.form-control::placeholder{color:var(--color-text-light)}.form-control:disabled{background:var(--color-bg);color:var(--color-text-muted);cursor:not-allowed}.form-helper{color:var(--color-text-muted);margin-top:4px;font-size:12px}.form-error{color:var(--color-danger);margin-top:4px;font-size:12px}.input-group{border:1.5px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition);background:var(--color-surface);align-items:center;display:flex;overflow:hidden}.input-group:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #0ea5a01f}.input-group .form-control{box-shadow:none;border:none}.input-group .form-control:focus{box-shadow:none}.input-addon{color:var(--color-text-muted);background:var(--color-bg);border-right:1px solid var(--color-border);white-space:nowrap;align-items:center;height:100%;padding:0 12px;font-size:13px;font-weight:600;display:flex}.table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-surface);width:100%;overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{background:var(--color-bg);text-align:left;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:700}tbody td{color:var(--color-text);border-bottom:1px solid var(--color-border-light);vertical-align:middle;padding:14px 16px;font-size:14px}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background var(--transition)}tbody tr:hover{background:var(--color-bg)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0006;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:560px;max-height:90vh;animation:.2s slideUp;overflow-y:auto}.modal-lg{max-width:780px}.modal-xl{max-width:1000px}.modal-header{border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{font-size:18px;font-family:var(--font-heading)}.modal-close{border-radius:var(--radius-sm);border:1px solid var(--color-border);cursor:pointer;width:32px;height:32px;color:var(--color-text-muted);transition:all var(--transition);background:0 0;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--color-danger-light);color:var(--color-danger);border-color:var(--color-danger)}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--color-border-light);justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px;display:flex}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.text-sm{font-size:13px}.text-xs{font-size:12px}.text-muted{color:var(--color-text-muted)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-primary{color:var(--color-primary)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-right{text-align:right}.text-center{text-align:center}.w-full{width:100%}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.grid-5{grid-template-columns:repeat(5,1fr);gap:16px;display:grid}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:24px;display:flex}.page-title{font-size:24px;font-family:var(--font-heading);color:var(--color-text);align-items:center;gap:10px;display:flex}.page-title-icon{border-radius:var(--radius-md);background:var(--color-primary-light);width:36px;height:36px;color:var(--color-primary);justify-content:center;align-items:center;display:flex}.page-subtitle{color:var(--color-text-muted);margin-top:3px;font-size:14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.spinner{border:2.5px solid var(--color-primary-light);border-top-color:var(--color-primary);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}.skeleton{background:linear-gradient(90deg, var(--color-border-light) 25%, var(--color-border) 50%, var(--color-border-light) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state-icon{border-radius:var(--radius-lg);background:var(--color-bg);width:64px;height:64px;color:var(--color-text-light);justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.empty-state-title{color:var(--color-text);margin-bottom:6px;font-size:16px;font-weight:700}.empty-state-text{color:var(--color-text-muted);font-size:14px}.tabs{background:var(--color-bg);border-radius:var(--radius-lg);gap:4px;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.tab{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);color:var(--color-text-muted);white-space:nowrap;background:0 0;border:none;padding:8px 18px;font-size:14px;font-weight:600}.tab.active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-sm)}.tab:hover:not(.active){color:var(--color-text)}.search-bar{align-items:center;display:flex;position:relative}.search-bar-icon{color:var(--color-text-light);pointer-events:none;position:absolute;left:12px}.search-bar input{min-width:280px;padding-left:38px}.member-layout{background:var(--color-bg);flex-direction:column;min-height:100vh;display:flex}.member-header{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff;padding:20px}.member-nav-bottom{background:var(--color-surface);border-top:1px solid var(--color-border);z-index:100;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 12px #0000000f}.member-nav-item{cursor:pointer;transition:all var(--transition);color:var(--color-text-muted);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:8px 4px;font-size:11px;font-weight:600;display:flex}.member-nav-item.active,.member-nav-item:hover{color:var(--color-primary)}.member-content{flex:1;padding:20px 20px 80px}.balance-card{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);border-radius:var(--radius-xl);color:#fff;padding:24px;position:relative;overflow:hidden}.balance-card:before{content:"";background:#ffffff14;border-radius:50%;width:150px;height:150px;position:absolute;top:-40px;right:-40px}.balance-card:after{content:"";background:#ffffff0f;border-radius:50%;width:100px;height:100px;position:absolute;bottom:-30px;right:30px}.balance-label{opacity:.8;font-size:13px;font-weight:500}.balance-amount{font-size:32px;font-weight:800;font-family:var(--font-heading);margin:4px 0}.balance-cif{opacity:.7;font-size:12px}.quick-actions{grid-template-columns:repeat(4,1fr);gap:12px;margin-top:20px;display:grid}.quick-action-btn{cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition);background:0 0;border:none;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;display:flex}.quick-action-btn:hover{background:var(--color-primary-light)}.quick-action-icon{border-radius:var(--radius-md);background:var(--color-primary-light);width:48px;height:48px;color:var(--color-primary);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;display:flex}.quick-action-label{color:var(--color-text-muted);text-align:center;font-size:11px;font-weight:600}.tx-item{border-radius:var(--radius-md);transition:background var(--transition);cursor:default;align-items:center;gap:12px;padding:12px;display:flex}.tx-item:hover{background:var(--color-bg)}.tx-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.tx-icon.credit{background:var(--color-success-light);color:var(--color-success)}.tx-icon.debit{background:var(--color-danger-light);color:var(--color-danger)}.tx-info{flex:1;min-width:0}.tx-name{font-size:14px;font-weight:600}.tx-date{color:var(--color-text-muted);font-size:12px}.tx-amount{text-align:right;font-size:15px;font-weight:700}.tx-amount.credit{color:var(--color-success)}.tx-amount.debit{color:var(--color-danger)}.progress-bar{background:var(--color-border);border-radius:99px;width:100%;height:8px;overflow:hidden}.progress-fill{height:100%;transition:width var(--transition-slow);border-radius:99px}.progress-fill.primary{background:var(--color-primary)}.progress-fill.success{background:var(--color-success)}.progress-fill.warning{background:var(--color-warning)}.progress-fill.danger{background:var(--color-danger)}.coll-lancar{color:var(--color-success)}.coll-dalam_perhatian{color:var(--color-warning)}.coll-kurang_lancar{color:var(--color-orange)}.coll-diragukan{color:var(--color-danger)}.coll-macet{color:var(--color-danger);font-weight:700}.auth-wrapper{background:linear-gradient(135deg, var(--color-bg) 0%, #d0f0ef 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:420px;padding:40px}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-icon{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));border-radius:var(--radius-lg);justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 12px;display:flex;box-shadow:0 8px 24px #0ea5a04d}.auth-logo h1{color:var(--color-primary);font-size:22px}.auth-logo p{color:var(--color-text-muted);margin-top:2px;font-size:13px}.notif-dropdown{background:var(--color-surface);border-radius:var(--radius-lg);width:340px;box-shadow:var(--shadow-xl);border:1px solid var(--color-border);z-index:200;animation:.2s slideUp;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.notif-header{border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.notif-item{cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--color-border-light);gap:12px;padding:12px 16px;display:flex}.notif-item:hover{background:var(--color-bg)}.notif-item.unread{background:var(--color-primary-light)}.notif-item.unread:hover{background:var(--color-primary-100)}.notif-icon-wrap{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.notif-content{flex:1;min-width:0}.notif-title{font-size:13px;font-weight:700}.notif-msg{color:var(--color-text-muted);font-size:12px}.notif-time{color:var(--color-text-light);margin-top:2px;font-size:11px}.ppob-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.ppob-cat-btn{border-radius:var(--radius-lg);border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;transition:all var(--transition);flex-direction:column;align-items:center;gap:8px;padding:16px 8px;display:flex}.ppob-cat-btn:hover,.ppob-cat-btn.active{border-color:var(--color-primary);background:var(--color-primary-light)}.ppob-cat-icon{border-radius:var(--radius-md);background:var(--color-primary-light);width:44px;height:44px;color:var(--color-primary);justify-content:center;align-items:center;display:flex}.ppob-cat-label{color:var(--color-text-muted);text-align:center;font-size:11px;font-weight:600}.chart-container{height:220px}.alert{border-radius:var(--radius-md);align-items:flex-start;gap:12px;margin-bottom:16px;padding:12px 16px;font-size:14px;display:flex}.alert-info{background:var(--color-info-light);color:var(--color-info);border:1px solid #bae6fd}.alert-success{background:var(--color-success-light);color:var(--color-success);border:1px solid #bbf7d0}.alert-warning{background:var(--color-warning-light);color:var(--color-warning);border:1px solid #fde68a}.alert-danger{background:var(--color-danger-light);color:var(--color-danger);border:1px solid #fecaca}@media (width<=1024px){.grid-4,.grid-5{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.app-main,.app-layout.collapsed .app-main{margin-left:0}.topbar{left:0}.grid-3,.grid-4,.grid-5,.grid-2{grid-template-columns:1fr}.ppob-grid{grid-template-columns:repeat(2,1fr)}.quick-actions{grid-template-columns:repeat(4,1fr)}.app-content{padding:16px;padding-top:calc(var(--topbar-height) + 16px)}}
