body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{animation:fadeIn .5s ease;background:#fff;border-radius:15px;box-shadow:0 15px 35px #00000026;max-width:400px;padding:2.5rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.logo-container{margin-bottom:1.5rem}.miraa-logo{align-items:center;display:flex;gap:.75rem;justify-content:center;margin-bottom:.5rem}.logo-icon{font-size:2.5rem}.logo-text{color:#2c5530;font-size:2rem;font-weight:700;margin:0}.logo-subtitle{color:#6c757d;font-size:.9rem;font-weight:500;letter-spacing:1px;text-transform:uppercase}.login-header h2{color:#333;font-size:1.5rem;font-weight:600;margin:0}.form-group{margin-bottom:1.25rem}.form-group label{font-size:.95rem}.form-group input{border:1px solid #ddd;border-radius:8px;font-size:1rem;padding:.85rem;transition:all .3s;width:100%}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.btn{border-radius:8px;padding:.85rem 1.5rem}.btn-primary{background-color:#2c5530}.btn-primary:hover:not(:disabled){background-color:#234125;box-shadow:0 5px 15px #2c55304d;transform:translateY(-2px)}.btn-primary:disabled{background-color:#ccc;cursor:not-allowed}.alert{border-radius:8px;margin-bottom:1.5rem;padding:.85rem}.alert-error{background-color:#fee;border-color:#fcc;color:#c33}.login-footer{border-top:1px solid #eee;margin-top:2rem;padding-top:1.5rem;text-align:center}.copyright{color:#666;font-size:.9rem;margin-bottom:.25rem}.designer{color:#999;font-size:.85rem;font-style:italic;margin:0}.dashboard-layout{background:#f0f9f0;display:flex;min-height:100vh}.main-container{display:flex;min-height:100vh;width:100%}.sidebar{background:#fff;border-right:1px solid #e9ecef;box-shadow:2px 0 10px #0000000d;display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;transition:all .3s ease;width:250px;z-index:1000}.sidebar.closed{min-width:0;transform:translateX(-100%);width:0}.sidebar.open{transform:translateX(0)}.sidebar-header{align-items:center;background:#fff;border-bottom:1px solid #e9ecef;display:flex;flex-shrink:0;gap:1rem;padding:1.5rem 1.25rem}.sidebar-header h3{color:#2c5530;font-size:1.1rem;font-weight:600;margin:0}.sidebar-toggle{align-items:center;background:none;border:1px solid #dee2e6;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;padding:.5rem;width:32px}.sidebar-toggle:hover{background:#f8f9fa}.sidebar-nav{flex:1 1}.sidebar-menu{list-style:none;margin:0;padding:1rem 0}.menu-item{margin:.25rem .75rem}.menu-btn{align-items:center;background:none;border:none;border-radius:6px;color:#495057;cursor:pointer;display:flex;font-size:.95rem;gap:1rem;padding:.875rem 1rem;text-align:left;transition:all .2s ease;width:100%}.menu-btn:hover{background:#f0f9f0;color:#2c5530}.menu-btn.active{background:#2c5530;color:#fff;font-weight:500}.menu-icon{font-size:1.1rem;text-align:center;width:24px}.menu-text{flex:1 1;font-weight:500}.dropdown-arrow{color:#6c757d;font-size:.75rem;transition:transform .2s ease}.menu-btn.active .dropdown-arrow{color:#fff}.submenu{background:#f8f9fa;border-radius:0 0 6px 6px;list-style:none;margin:0;overflow:hidden;padding:.5rem 0}.submenu-btn{background:none;border:none;border-left:3px solid #0000;color:#495057;cursor:pointer;font-size:.9rem;padding:.75rem 1rem .75rem 3.25rem;text-align:left;transition:all .2s ease;width:100%}.submenu-btn:hover{background:#e9ecef;border-left-color:#2c5530;color:#2c5530}.submenu-btn.active{background:#e9f5e9;border-left-color:#4caf50;color:#2c5530;font-weight:500}.sidebar-footer{background:#fff;border-top:1px solid #e9ecef;flex-shrink:0;margin-top:auto;padding:1.25rem}.system-health-footer{background:#e9f5e9;border:1px solid #d4edda;border-radius:8px;margin-bottom:.75rem;padding:.75rem}.health-status{align-items:center;display:flex;gap:.75rem}.health-indicator{font-size:.7rem}.health-indicator.online{animation:pulse 2s infinite;color:#28a745}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.health-text{color:#2c5530;font-size:.85rem}.copyright-footer{text-align:center}.copyright-footer p{color:#6c757d;font-size:.75rem;margin:.25rem 0}.copyright-footer .designer{color:#999;font-size:.7rem;font-style:italic}.content-wrapper{display:flex;flex:1 1;flex-direction:column;margin-left:250px;min-height:100vh;transition:margin-left .3s ease}.sidebar.closed~.content-wrapper{margin-left:0}.top-header{align-items:center;background:linear-gradient(135deg,#2c5530,#3a7c3a);border-bottom:3px solid #4caf50;box-shadow:0 4px 12px #0000001a;display:flex;flex-shrink:0;justify-content:space-between;padding:1.25rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:999}.header-left{flex:0 0 auto;width:100px}.header-center{flex:1 1;text-align:center}.back-btn{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.back-btn:hover{background:#ffffff4d;transform:translateX(-2px)}.system-title h1{align-items:center;color:#fff;display:flex;font-size:1.75rem;font-weight:800;gap:.75rem;justify-content:center;margin:0 0 .25rem}.title-icon{font-size:2rem}.system-tagline{color:#ffffffe6;font-size:.95rem;font-weight:400;letter-spacing:.5px;margin:0}.header-right{align-items:center;display:flex;gap:1.5rem}.user-welcome{align-items:flex-end;display:flex;flex-direction:column}.welcome-text{color:#fffc;font-size:.85rem;margin-bottom:.15rem}.user-name{color:#fff;font-size:1rem;font-weight:600}.header-btn{align-items:center;background:#ffffff26;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.6rem 1.25rem;transition:all .3s ease}.header-btn:hover{background:#ffffff40;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.header-btn.logout-btn:hover{background:#dc3545e6;border-color:#dc3545}.btn-icon{font-size:1.1rem}.main-content{background:#f8faf8;flex:1 1;min-height:calc(100vh - 100px);overflow-y:auto;padding:2rem}.dashboard-content{margin:0 auto;max-width:1200px}.dashboard-overview{animation:fadeIn .5s ease;padding-bottom:2rem}.dashboard-header{background:linear-gradient(135deg,#2c5530,#4caf50);border-radius:15px;box-shadow:0 6px 20px #2c553026;color:#fff;margin-bottom:2rem;padding:2.5rem;text-align:center}.dashboard-header h2{font-size:2rem;font-weight:700;margin:0 0 .5rem}.dashboard-header p{font-size:1rem;font-weight:400;margin:0;opacity:.9}.section-separator{background:linear-gradient(90deg,#0000,#d4edda,#0000);height:2px;margin:2rem 0}.role-dashboard-section{background:#fff;border-left:4px solid #2c5530;border-radius:12px;box-shadow:0 4px 15px #0000000d;margin-bottom:2rem;padding:2rem;transition:all .3s ease}.role-dashboard-section:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-3px)}.section-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.section-title{color:#2c5530;font-size:1.5rem;font-weight:600;margin:0 0 .25rem}.section-subtitle{color:#6c757d;font-size:.95rem;font-weight:400;margin:0}.analytics-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:1.5rem}.analytics-card{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:10px;box-shadow:0 3px 10px #0000000d;display:flex;gap:1.25rem;padding:1.5rem;transition:all .3s ease}.analytics-card:hover{box-shadow:0 5px 15px #0000001a;transform:translateY(-3px)}.analytics-card.revenue{border-left-color:#28a745}.analytics-card.clients{border-left-color:#17a2b8}.analytics-card.deliveries{border-left-color:#ffc107}.analytics-card.users{border-left-color:#dc3545}.analytics-card.growth{border-left-color:#6f42c1}.analytics-card.earnings{border-left-color:#20c997}.analytics-card.performance{border-left-color:#fd7e14}.card-icon{font-size:2.5rem;min-width:50px;opacity:.8;text-align:center}.card-content{flex:1 1}.card-content h3{color:#495057;font-size:.9rem;font-weight:600;letter-spacing:.5px;margin:0 0 .5rem;text-transform:uppercase}.analytics-value{color:#2c5530;font-size:1.75rem;font-weight:700;line-height:1;margin:0 0 .25rem}.card-subtext{color:#6c757d;font-size:.85rem;font-weight:400;margin:0}.secondary-metrics{background:#fff;border:1px solid #e9ecef;border-radius:10px;box-shadow:0 2px 10px #0000000d;margin-bottom:1.5rem;padding:1.5rem}.metric-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.metric-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;padding:1rem}.metric-label{color:#495057}.metric-value{color:#2c5530;font-size:1.1rem;font-weight:600}.system-health{background:#fff;border:1px solid #e9ecef;border-radius:10px;box-shadow:0 2px 10px #0000000d;margin-bottom:1.5rem;padding:1.5rem}.system-health h3{color:#495057;margin:0 0 1rem}.health-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.health-card{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;gap:1rem;padding:1rem}.health-status{font-size:1.2rem}.health-text{color:#495057;font-weight:500}.collections-section,.insights-section,.performance-summary,.targets-section{background:#fff;border:1px solid #e9ecef;border-radius:10px;box-shadow:0 2px 10px #0000000d;margin-bottom:1.5rem;padding:1.5rem}.collections-section h3,.insights-section h3,.performance-summary h3,.targets-section h3{color:#495057;margin:0 0 1rem}.collections-grid,.insights-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.collection-card,.insight-card{background:#f8f9fa;border-radius:8px;padding:1.5rem 1rem;text-align:center;transition:transform .3s ease}.collection-card:hover,.insight-card:hover{transform:translateY(-2px)}.collection-value,.insight-value{color:#2c5530;font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.collection-label,.insight-label{color:#6c757d;font-size:.9rem}.performance-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;padding:1rem}.stat-label{color:#495057;font-size:.9rem}.stat-value{color:#2c5530;font-weight:600}.targets-list{display:flex;flex-direction:column;gap:1rem}.target-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:background .3s ease}.target-item:hover{background:#e9ecef}.target-icon{font-size:1.2rem}.target-text{color:#495057;flex:1 1;font-weight:500}.target-status.completed{color:#28a745}.target-status.pending{color:#ffc107}.loading{background:#f8f9fa;border:2px dashed #dee2e6;border-radius:10px;color:#6c757d;font-size:1.1rem;padding:3rem;text-align:center}.main-content::-webkit-scrollbar{width:8px}.main-content::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}.main-content::-webkit-scrollbar-thumb{background:#2c5530;border-radius:4px}.main-content::-webkit-scrollbar-thumb:hover{background:#234125}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#0000000d}.sidebar::-webkit-scrollbar-thumb{background:#2c55304d;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#2c553080}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.sidebar{bottom:0;left:0;position:fixed;top:0;transform:translateX(-100%);width:280px;z-index:9999}.sidebar.open{transform:translateX(0)}.content-wrapper{margin-left:0;width:100%}.top-header{flex-direction:column;gap:1rem;padding:1rem;text-align:center}.header-center,.header-right{width:100%}.system-title h1{font-size:1.4rem;justify-content:center}.system-tagline{font-size:.85rem}.header-right{gap:1rem;justify-content:center}.user-welcome{align-items:center}.dashboard-header{margin-bottom:1.5rem;padding:1.5rem}.dashboard-header h2{font-size:1.5rem}.dashboard-header p{font-size:.95rem}.role-dashboard-section{margin-bottom:1.5rem;padding:1.5rem}.section-header{flex-direction:column;gap:1rem;text-align:center}.section-title{font-size:1.5rem}.analytics-grid{gap:1rem;grid-template-columns:1fr}.analytics-card{flex-direction:column;gap:1rem;padding:1.5rem;text-align:center}.analytics-value{font-size:1.8rem}.main-content{padding:1rem}.section-separator{margin:1.5rem 0}.collections-grid,.health-grid,.insights-grid,.metric-row,.performance-stats{grid-template-columns:1fr}}.menu-btn,.submenu-btn{cursor:pointer;z-index:1}.menu-btn,.submenu,.submenu-btn{pointer-events:auto;position:relative}.submenu{z-index:100}.menu-item{position:relative;z-index:10}.menu-btn:after,.submenu-btn:after{display:none}.menu-btn:hover{background-color:#f0f9f0!important}.submenu-btn:hover{background-color:#e9ecef!important}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{min-height:100vh}.loading{align-items:center;color:#666;display:flex;font-size:1.2rem;height:100vh;justify-content:center}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mr-1{margin-right:.5rem}.mr-2{margin-right:1rem}.mr-3{margin-right:1.5rem}.ml-1{margin-left:.5rem}.ml-2{margin-left:1rem}.ml-3{margin-left:1.5rem}.card{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:1rem;overflow:hidden}.card-header{background:#f8f9fa;border-bottom:1px solid #eee;padding:1rem 1.5rem}.card-header h3{color:#333;font-size:1.25rem;margin:0}.card-body{padding:1.5rem}.form-group{margin-bottom:1rem}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:.5rem}.form-control{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .3s;width:100%}.form-control:focus{border-color:#667eea;outline:none}.form-control:invalid{border-color:#dc3545}.form-control:valid{border-color:#28a745}.btn{border:none;border-radius:4px;cursor:pointer;display:inline-block;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;text-align:center;text-decoration:none;transition:all .3s}.btn-primary{background-color:#667eea;color:#fff}.btn-primary:hover{background-color:#5a6fd8;transform:translateY(-1px)}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover{background-color:#218838;transform:translateY(-1px)}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268;transform:translateY(-1px)}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333;transform:translateY(-1px)}.btn-warning{background-color:#ffc107;color:#212529}.btn-warning:hover{background-color:#e0a800;transform:translateY(-1px)}.btn-info{background-color:#17a2b8;color:#fff}.btn-info:hover{background-color:#138496;transform:translateY(-1px)}.btn-outline{background-color:initial;border:1px solid #667eea;color:#667eea}.btn-outline:hover{background-color:#667eea;color:#fff}.btn-sm{font-size:.8rem;padding:.25rem .5rem}.btn-block{width:100%}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.table{border-collapse:collapse;margin-top:1rem;width:100%}.table td,.table th{border-bottom:1px solid #ddd;padding:.75rem;text-align:left}.table th{color:#333;font-weight:600}.table tbody tr:hover,.table th{background-color:#f8f9fa}.table-responsive{margin-bottom:1rem;overflow-x:auto}.row{display:flex;flex-wrap:wrap;margin:0 -.75rem}.col{flex:1 1}.col,.col-md-12{padding:0 .75rem}.col-md-12{flex:0 0 100%;max-width:100%}.col-md-6{flex:0 0 50%;max-width:50%;padding:0 .75rem}.col-md-4{flex:0 0 33.333%;max-width:33.333%;padding:0 .75rem}.col-md-3{flex:0 0 25%;max-width:25%;padding:0 .75rem}.alert{border:1px solid #0000;border-radius:4px;margin-bottom:1rem;padding:.75rem 1rem}.alert-success{background-color:#d4edda;border-color:#c3e6cb;color:#155724}.alert-error{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24}.alert-info{background-color:#d1ecf1;border-color:#bee5eb;color:#0c5460}.alert-warning{background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.status-badge{border-radius:4px;display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .5rem;text-transform:capitalize}.status-pending{background-color:#fff3cd;color:#856404}.status-paid{background-color:#d1edff;color:#004085}.status-partially_paid{background-color:#fff3cd;color:#856404}.status-active{background-color:#d4edda;color:#155724}.status-inactive{background-color:#f8d7da;color:#721c24}.role-badge{border-radius:4px;display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .5rem;text-transform:capitalize}.role-admin{background-color:#dc3545;color:#fff}.role-manager{background-color:#fd7e14;color:#fff}.role-field_agent{background-color:#20c997;color:#fff}.payment-method{border-radius:4px;display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .5rem;text-transform:capitalize}.payment-cash{background-color:#d4edda;color:#155724}.payment-mpesa{background-color:#d1ecf1;color:#0c5460}.payment-bank_transfer{background-color:#e2e3e5;color:#383d41}.payment-other{background-color:#fff3cd;color:#856404}.spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:40px;margin:0 auto;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.metric-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1.5rem;text-align:center;transition:transform .2s}.metric-card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.metric-value{color:#667eea;font-size:2rem;font-weight:700;margin-bottom:.5rem}.metric-label{color:#6c757d;font-size:.9rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.form-text{color:#6c757d;display:block;font-size:.875rem;margin-top:.25rem}.is-invalid{border-color:#dc3545!important}.is-valid{border-color:#28a745!important}.invalid-feedback{color:#dc3545;font-size:.875rem;margin-top:.25rem;width:100%}@media (max-width:768px){.row{margin:0 -.5rem}.col,.col-md-12,.col-md-3,.col-md-4,.col-md-6{padding:0 .5rem}.col-md-3,.col-md-4,.col-md-6{flex:0 0 100%;margin-bottom:1rem;max-width:100%}.table-responsive table{font-size:.9rem}.table-responsive td,.table-responsive th{padding:.5rem}.card-body,.card-header{padding:1rem}.btn{font-size:.9rem;padding:.5rem 1rem}}@media print{.btn,.header-btn,.sidebar-toggle{display:none!important}.card{box-shadow:none}.card,.table,.table td,.table th{border:1px solid #ddd}}.visually-hidden{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}a:focus,button:focus,input:focus,select:focus,textarea:focus{outline:2px solid #667eea;outline-offset:2px}@media (prefers-contrast:high){.btn-primary{background-color:#004085;border:2px solid #002752}.alert-success{border:2px solid #155724}.alert-error{border:2px solid #721c24}} /*# sourceMappingURL=main.50c4e0ce.css.map*/