.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1f2937,#111827);padding:20px}.login-card{background:#1f2937;border-radius:20px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px #00000080;border:1px solid #374151}.logo-section{text-align:center;margin-bottom:40px}.logo-icon{width:80px;height:80px;background:#3b82f6;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:40px;margin:0 auto 20px}.logo-section h1{font-size:32px;font-weight:700;color:#fff;margin-bottom:8px}.logo-section p{color:#9ca3af;font-size:14px}.login-form{margin-bottom:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#d1d5db;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px 16px;background:#374151;border:1px solid #4B5563;border-radius:8px;font-size:16px;color:#fff;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#3b82f6}.form-group input::placeholder{color:#6b7280}.password-input{position:relative}.password-input input{padding-right:45px}.eye-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:20px;padding:0;color:#9ca3af}.signin-button{width:100%;padding:14px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:8px}.signin-button:hover:not(:disabled){background:#2563eb}.signin-button:disabled{opacity:.6;cursor:not-allowed}.login-links{text-align:center;margin-bottom:20px}.back-link{color:#fff;text-decoration:none;font-size:14px;display:block;text-align:center;padding:12px;background:#ffffff1a;border-radius:8px;transition:background .2s}.back-link:hover{background:#fff3;text-decoration:none}.disclaimer{text-align:center;color:#6b7280;font-size:12px;margin-top:20px}.error-message{background:#7f1d1d;color:#fca5a5;padding:12px;border-radius:8px;margin-bottom:16px;font-size:14px}.success-message{background:#064e3b;color:#6ee7b7;padding:12px;border-radius:8px;margin-bottom:16px;font-size:14px;text-align:center}.cancel-button{width:100%;padding:12px;background:#6b7280;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:8px}.cancel-button:hover{background:#4b5563}.forgot-password{display:block;color:#fff;text-decoration:none;font-size:14px;margin-bottom:16px;text-align:center}.forgot-password:hover{text-decoration:underline}.sidebar{width:260px;height:100vh;background:#111827;display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:1000}.sidebar-header{padding:24px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #374151}.logo{width:48px;height:48px;background:#3b82f6;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.logo-text{flex:1}.logo-title{font-size:18px;font-weight:600;color:#fff}.logo-subtitle{font-size:12px;color:#9ca3af}.sidebar-nav{flex:1;padding:16px 0;overflow-y:auto}.nav-item{width:100%;padding:12px 24px;background:none;border:none;color:#d1d5db;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s;text-align:left}.nav-item:hover{background:#1f2937}.nav-item.active{background:#3b82f6;color:#fff}.nav-icon{font-size:20px}.nav-label{font-size:14px;font-weight:500}.sidebar-footer{padding:20px;border-top:1px solid #374151}.user-info{display:flex;align-items:center;gap:12px;margin-bottom:16px}.user-avatar{width:40px;height:40px;background:#374151;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff}.user-details{flex:1}.user-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:2px}.user-email{font-size:12px;color:#9ca3af}.signout-button{width:100%;padding:10px;background:#374151;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s}.signout-button:hover{background:#4b5563}.dashboard-layout{display:flex;min-height:100vh;background:#1f2937}.dashboard-content{flex:1;margin-left:260px;padding:32px;overflow-y:auto}.dashboard-header{margin-bottom:32px}.dashboard-header h1{font-size:32px;font-weight:600;color:#fff;margin-bottom:8px}.dashboard-header p{font-size:16px;color:#9ca3af}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:32px}.stat-card{background:#374151;border-radius:16px;padding:24px;border:1px solid #4B5563}.stat-icon{font-size:32px;margin-bottom:12px}.stat-icon.orange{color:#f59e0b}.stat-icon.blue{color:#3b82f6}.stat-icon.red{color:#ef4444}.stat-icon.green{color:#10b981}.stat-value{font-size:32px;font-weight:700;color:#fff;margin-bottom:4px}.stat-label{font-size:14px;color:#9ca3af;margin-bottom:8px}.stat-change{font-size:12px;color:#6b7280}.dashboard-sections{display:grid;grid-template-columns:1fr 1fr;gap:24px}.section-card{background:#374151;border-radius:16px;padding:24px;border:1px solid #4B5563}.section-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.section-icon{font-size:24px}.section-header h3{font-size:18px;font-weight:600;color:#fff}.activity-list{display:flex;flex-direction:column;gap:16px}.activity-item{display:flex;align-items:flex-start;gap:12px}.activity-dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0}.activity-text{flex:1;font-size:14px;color:#d1d5db}.activity-time{font-size:12px;color:#6b7280;margin-top:4px}.weekly-stats{display:flex;flex-direction:column;gap:20px}.weekly-stat-item{display:flex;flex-direction:column;gap:8px}.weekly-stat-label{font-size:14px;color:#9ca3af}.weekly-stat-value{font-size:24px;font-weight:700;color:#fff}.progress-bar{width:100%;height:8px;background:#1f2937;border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px}.progress-fill.blue{background:#3b82f6}.progress-fill.green{background:#10b981}.progress-fill.orange{background:#f59e0b}.reports-list{display:flex;flex-direction:column;gap:1.5rem;margin-top:2rem}.report-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;border:1px solid #e5e7eb}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.report-priority{display:flex;align-items:center;gap:.5rem}.priority-dot{width:12px;height:12px;border-radius:50%}.priority-text{font-weight:600;color:#374151}.report-status{display:flex;gap:.5rem}.status-badge{padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-pending{background-color:#fef3c7;color:#92400e}.status-assigned{background-color:#dbeafe;color:#1e40af}.status-cleaned,.status-verified{background-color:#d1fae5;color:#065f46}.status-fake{background-color:#fee2e2;color:#991b1b}.report-body{display:grid;grid-template-columns:200px 1fr;gap:1.5rem}.report-image img{width:100%;height:150px;object-fit:cover;border-radius:8px;border:1px solid #e5e7eb}.report-details{display:flex;flex-direction:column;gap:.75rem}.detail-row{display:flex;gap:1rem;align-items:center}.detail-label{font-weight:600;color:#6b7280;min-width:120px;font-size:.875rem}.detail-value{color:#111827;font-size:.875rem}.badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#fff}.badge-gray{background-color:#6b7280}.severity-badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#fff}.severity-red{background-color:#ef4444}.severity-yellow{background-color:#f59e0b}.severity-green{background-color:#10b981}.report-actions{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb;display:flex;align-items:center;gap:1rem}.report-actions label{font-weight:600;color:#374151}.report-actions select{flex:1;padding:.5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem}.report-actions select:disabled{background-color:#f3f4f6;cursor:not-allowed}.assigning{color:#6b7280;font-size:.875rem}.filter-tabs{display:flex;gap:1rem;margin-top:1.5rem;border-bottom:2px solid #e5e7eb}.filter-tabs button{padding:.75rem 1.5rem;border:none;background:none;font-size:.875rem;font-weight:600;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.filter-tabs button:hover{color:#111827}.filter-tabs button.active{color:#3b82f6;border-bottom-color:#3b82f6}.empty-state{text-align:center;padding:3rem;color:#6b7280}.report-group-card{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000001a;border:2px solid #3B82F6}.group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.group-header h3{margin:0;color:#1f2937}.group-stats{display:flex;gap:1rem;font-size:.875rem;color:#6b7280}.group-reports{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.report-card-inline{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.report-preview img{width:80px;height:80px;object-fit:cover;border-radius:6px}.report-info-inline{flex:1}.report-meta-inline{display:flex;gap:.5rem;margin-top:.5rem;font-size:.75rem;color:#6b7280}.badge-small{display:inline-block;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;color:#fff;background-color:#6b7280}.assign-group-button{width:100%;padding:.75rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;margin-top:1rem}.assign-group-button:hover{background:#2563eb}@media (max-width: 768px){.report-body{grid-template-columns:1fr}.report-image{width:100%}}.page-header{margin-bottom:32px}.page-header h1{font-size:32px;font-weight:600;color:#fff;margin-bottom:8px}.page-header p{font-size:16px;color:#9ca3af}.approval-card{background:#374151;border-radius:16px;padding:24px;border:1px solid #4B5563}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.card-header h3{font-size:20px;font-weight:600;color:#fff}.filter-buttons{display:flex;gap:8px}.filter-btn{padding:8px 16px;background:#1f2937;border:1px solid #4B5563;border-radius:8px;color:#9ca3af;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.filter-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.approval-table{width:100%;border-collapse:collapse}.approval-table thead{border-bottom:1px solid #4B5563}.approval-table th{text-align:left;padding:12px;font-size:14px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.approval-table td{padding:16px 12px;border-bottom:1px solid #4B5563;color:#d1d5db;font-size:14px}.user-cell{display:flex;align-items:center;gap:8px}.user-icon{font-size:20px}.contact-cell{display:flex;flex-direction:column;gap:4px}.contact-cell div:last-child{font-size:12px;color:#6b7280}.role-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.role-badge.citizen{background:#10b98120;color:#10b981}.role-badge.sweeper{background:#f59e0b20;color:#f59e0b}.action-buttons{display:flex;gap:8px}.approve-btn,.reject-btn{padding:6px 12px;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .2s}.approve-btn{background:#10b981;color:#fff}.reject-btn{background:#ef4444;color:#fff}.approve-btn:hover,.reject-btn:hover{opacity:.8}.loading,.no-users{text-align:center;padding:60px 20px;color:#9ca3af}.map-container{display:grid;grid-template-columns:1fr 300px;gap:24px}.map-area{background:#374151;border-radius:16px;padding:24px;border:1px solid #4B5563;position:relative;min-height:500px}.map-header{margin-bottom:20px}.map-label{background:#1f2937;padding:12px 16px;border-radius:8px;display:inline-block}.map-label div:first-child{font-size:16px;font-weight:600;color:#fff;margin-bottom:4px}.map-subtitle{font-size:12px;color:#9ca3af}.map-grid{width:100%;height:400px;background:#1f2937;border-radius:8px;position:relative;background-image:linear-gradient(rgba(59,130,246,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.1) 1px,transparent 1px);background-size:20px 20px}.map-pin{position:absolute;font-size:24px;cursor:pointer;transition:transform .2s}.map-pin:hover{transform:scale(1.2)}.map-sidebar{display:flex;flex-direction:column;gap:24px}.legend-section,.summary-section{background:#374151;border-radius:16px;padding:24px;border:1px solid #4B5563}.legend-section h3,.summary-section h3{font-size:18px;font-weight:600;color:#fff;margin-bottom:16px}.legend-item{display:flex;align-items:center;gap:12px;margin-bottom:16px}.legend-item:last-child{margin-bottom:0}.legend-pin{font-size:20px}.legend-label{font-size:14px;color:#d1d5db;margin-bottom:2px}.legend-count{font-size:12px;color:#6b7280}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #4B5563}.summary-item:last-child{border-bottom:none}.summary-label{font-size:14px;color:#9ca3af}.summary-value{font-size:20px;font-weight:600;color:#fff}.tabs{display:flex;gap:12px;margin-bottom:32px}.tab{padding:12px 24px;background:#374151;border:1px solid #4B5563;border-radius:8px;color:#9ca3af;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.tab.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.top-three{display:flex;justify-content:center;align-items:flex-end;gap:16px;margin-bottom:32px}.top-card{background:#374151;border-radius:16px;padding:24px;text-align:center;border:1px solid #4B5563;flex:1;max-width:200px}.top-card.first{border:3px solid #FCD34D}.medal-icon{font-size:48px;margin-bottom:12px}.top-avatar{width:60px;height:60px;background:#1f2937;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;color:#fff;margin:0 auto 12px}.top-name{font-size:16px;font-weight:600;color:#fff;margin-bottom:4px}.top-zone{font-size:12px;color:#9ca3af;margin-bottom:12px}.top-score{font-size:28px;font-weight:700;color:#3b82f6;margin-bottom:4px}.top-reports{font-size:12px;color:#6b7280}.leaderboard-table{background:#374151;border-radius:16px;padding:24px;border:1px solid #4B5563;overflow-x:auto}.leaderboard-table table{width:100%;border-collapse:collapse}.leaderboard-table thead{border-bottom:1px solid #4B5563}.leaderboard-table th{text-align:left;padding:12px;font-size:14px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.leaderboard-table td{padding:16px 12px;border-bottom:1px solid #4B5563;color:#d1d5db;font-size:14px}.user-cell{display:flex;align-items:center;gap:12px}.user-avatar-small{width:32px;height:32px;background:#1f2937;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;font-size:12px}.zone-badge{padding:4px 12px;background:#1f2937;border-radius:12px;font-size:12px;color:#9ca3af}.points-cell{font-size:18px;font-weight:700;color:#3b82f6}.loading{text-align:center;padding:60px;color:#9ca3af}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#1f2937;color:#fff}#root{min-height:100vh}
