.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px}.login-card{background:#fff;border-radius:20px;padding:40px;width:100%;max-width:420px;box-shadow:0 10px 40px #0000001a}.logo-section{text-align:center;margin-bottom:40px}.logo-icon{width:80px;height:80px;background:#10b981;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:40px;margin:0 auto 20px;color:#fff}.logo-section h1{font-size:32px;font-weight:700;color:#1f2937;margin-bottom:8px}.logo-section p{color:#6b7280;font-size:14px}.login-form{margin-bottom:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#374151;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:16px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#10b981}.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}.signin-button{width:100%;padding:14px;background:#10b981;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:#059669}.signin-button:disabled{opacity:.6;cursor:not-allowed}.login-links{text-align:center}.forgot-password{display:block;color:#10b981;text-decoration:none;margin-bottom:16px;font-size:14px}.forgot-password:hover{text-decoration:underline}.role-select{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:16px;background:#fff;color:#1f2937;cursor:pointer;transition:border-color .2s}.role-select:focus{outline:none;border-color:#10b981}.toggle-signup{text-align:center;font-size:14px;color:#6b7280;margin-top:16px}.toggle-signup a{color:#10b981;text-decoration:none;font-weight:500}.toggle-signup a:hover{text-decoration:underline}.back-to-main-link{margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.back-to-main{display:block;text-align:center;color:#10b981;text-decoration:none;font-size:14px;font-weight:500;margin-top:8px}.back-to-main:hover{text-decoration:underline}.error-message{background:#fee2e2;color:#dc2626;padding:12px;border-radius:8px;margin-bottom:16px;font-size:14px}.success-message{background:#d1fae5;color:#059669;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}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;display:flex;justify-content:space-around;padding:12px 0;z-index:1000}.nav-item{background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:8px 24px;color:#6b7280;transition:color .2s}.nav-item.active{color:#10b981}.nav-icon{font-size:24px}.nav-label{font-size:12px;font-weight:500}.dashboard-container{min-height:100vh;background:#f5f5f5;padding-bottom:80px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#fff}.user-info{display:flex;align-items:center;gap:12px}.user-avatar{width:48px;height:48px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px}.welcome-text{font-size:14px;color:#6b7280}.user-name{font-size:20px;font-weight:600;color:#1f2937}.logout-button{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280}.report-button{width:calc(100% - 40px);margin:20px;padding:24px;background:#10b981;color:#fff;border:none;border-radius:16px;font-size:18px;font-weight:600;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:0 4px 12px #10b9814d}.camera-icon{font-size:48px}.stats-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:0 20px;margin-bottom:24px}.stat-card{background:#fff;border-radius:16px;padding:20px;text-align:center;box-shadow:0 2px 8px #0000000d}.stat-icon{font-size:32px;margin-bottom:8px}.reports-icon{color:#3b82f6}.points-icon{color:#f59e0b}.stat-value{font-size:32px;font-weight:700;color:#1f2937;margin-bottom:4px}.stat-label{font-size:14px;color:#6b7280}.recent-activity{padding:0 20px}.section-title{font-size:12px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.activity-list{display:flex;flex-direction:column;gap:12px}.activity-item{background:#fff;border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #0000000d}.activity-dot{width:12px;height:12px;background:#10b981;border-radius:50%;flex-shrink:0}.activity-content{flex:1}.activity-title{font-size:16px;font-weight:600;color:#1f2937;margin-bottom:4px}.activity-details{font-size:14px;color:#6b7280}.activity-points{font-size:14px;font-weight:600;color:#10b981}.no-activity{text-align:center;color:#9ca3af;padding:40px 20px;background:#fff;border-radius:12px}.report-container{min-height:100vh;background:#000;position:relative}.report-header{position:absolute;top:0;left:0;right:0;padding:20px;z-index:10;display:flex;justify-content:flex-end}.close-button{width:40px;height:40px;background:#fff3;border:none;border-radius:50%;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center}.camera-view{position:relative;width:100%;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.camera-video{width:100%;height:100%;object-fit:cover}.camera-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center}.camera-frame{width:90%;max-width:400px;aspect-ratio:4/3;border:2px solid rgba(255,255,255,.5);border-radius:12px;box-shadow:0 0 0 9999px #00000080}.camera-instructions{position:absolute;bottom:120px;color:#fff;text-align:center;font-size:16px;padding:0 20px}.capture-button{position:absolute;bottom:40px;width:80px;height:80px;background:#ffffff4d;border:4px solid white;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.capture-button-inner{width:60px;height:60px;background:#fff;border-radius:50%}.photo-preview{width:100%;height:100vh;display:flex;flex-direction:column;background:#000}.preview-image{flex:1;width:100%;object-fit:contain;background:#000}.photo-actions{padding:20px;display:flex;gap:16px;background:#000c}.retake-button,.upload-button{flex:1;padding:16px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.retake-button{background:#fff3;color:#fff}.upload-button{background:#f59e0b;color:#fff}.upload-button:disabled{opacity:.6;cursor:not-allowed}.reports-container{min-height:100vh;background:#f5f5f5;padding-bottom:80px}.reports-header{display:flex;align-items:center;gap:16px;padding:20px;background:#fff}.reports-header h1{font-size:24px;font-weight:600;color:#1f2937}.reports-list{padding:20px;display:flex;flex-direction:column;gap:16px}.report-card{background:#fff;border-radius:12px;display:flex;align-items:center;gap:16px;padding:16px;box-shadow:0 2px 8px #0000000d}.report-indicator{width:4px;height:100%;border-radius:2px;flex-shrink:0}.report-content{flex:1}.report-title{font-size:18px;font-weight:600;color:#1f2937;margin-bottom:4px}.report-location{font-size:14px;color:#6b7280;margin-bottom:4px}.report-date{font-size:14px;color:#9ca3af}.report-status{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.no-reports{text-align:center;color:#9ca3af;padding:60px 20px;background:#fff;border-radius:12px}.report-details-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.report-header{display:flex;align-items:center;gap:20px;margin-bottom:30px}.back-button{background:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:16px;cursor:pointer;font-weight:600}.report-header h1{color:#fff;font-size:28px}.report-content{background:#fff;border-radius:16px;padding:30px;max-width:1200px;margin:0 auto}.image-section{margin-bottom:40px}.image-section h2{margin-bottom:20px;color:#1f2937}.report-image{width:100%;max-width:600px;border-radius:12px;border:2px solid #e5e7eb;margin-bottom:20px}.after-image{margin-top:30px;padding-top:30px;border-top:2px solid #e5e7eb}.after-image h3{margin-bottom:20px;color:#1f2937}.ai-analysis-section{margin-bottom:40px;padding:30px;background:#f9fafb;border-radius:12px;border:2px solid #e5e7eb}.ai-analysis-section h2{margin-bottom:25px;color:#1f2937;font-size:24px}.ai-results{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}.ai-result-card{background:#fff;padding:20px;border-radius:8px;border:1px solid #e5e7eb}.ai-result-card.highlight{border:2px solid #3b82f6;background:#eff6ff}.ai-label{font-size:12px;color:#6b7280;text-transform:uppercase;font-weight:600;margin-bottom:8px}.ai-value{font-size:16px;color:#1f2937;font-weight:600}.ai-value.description{font-weight:400;font-size:14px;color:#4b5563;line-height:1.5}.badge{display:inline-block;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;color:#fff}.badge-gray{background-color:#6b7280}.severity-badge{display:inline-block;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;color:#fff}.ai-pending{text-align:center;padding:40px;color:#6b7280}.status-text{margin-top:10px;font-size:14px}.location-section,.status-section{margin-bottom:40px;padding:25px;background:#f9fafb;border-radius:12px}.location-section h2,.status-section h2{margin-bottom:20px;color:#1f2937}.location-info,.status-info{display:flex;flex-direction:column;gap:15px}.info-item{display:flex;gap:15px;align-items:center}.info-label{font-weight:600;color:#6b7280;min-width:120px}.info-value{color:#1f2937}.status-badge-large{display:inline-block;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;text-transform:uppercase;margin-bottom:20px}.status-badge-large[data-status=assigned]{background-color:#dbeafe;color:#1e40af}.status-badge-large[data-status=verified]{background-color:#d1fae5;color:#065f46}.status-badge-large[data-status=fake]{background-color:#fee2e2;color:#991b1b}.status-badge-large[data-status=pending]{background-color:#fef3c7;color:#92400e}.loading,.error{text-align:center;padding:40px;color:#fff;font-size:18px}@media (max-width: 768px){.ai-results{grid-template-columns:1fr}.report-content{padding:20px}}.leaderboard-container{min-height:100vh;background:#f5f5f5;padding-bottom:80px}.leaderboard-header{display:flex;align-items:center;gap:16px;padding:20px;background:#fff}.back-button{background:none;border:none;font-size:24px;cursor:pointer;color:#1f2937}.leaderboard-header h1{font-size:24px;font-weight:600;color:#1f2937}.top-three{display:flex;justify-content:center;align-items:flex-end;gap:12px;padding:20px;background:#fff;margin-bottom:20px}.top-card{background:#fff;border-radius:16px;padding:20px;text-align:center;box-shadow:0 4px 12px #0000001a;flex:1;max-width:120px}.top-card.first{order:2;border:3px solid #FCD34D}.top-card.second{order:1}.top-card.third{order:3}.medal-icon{font-size:32px;margin-bottom:8px}.top-avatar{width:60px;height:60px;background:#e5e7eb;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;margin:0 auto 8px}.top-name{font-size:14px;font-weight:600;color:#1f2937;margin-bottom:4px}.top-score{font-size:20px;font-weight:700;color:#3b82f6}.leaderboard-list{padding:0 20px;display:flex;flex-direction:column;gap:12px}.leaderboard-item{background:#fff;border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #0000000d}.rank{font-size:20px;font-weight:600;width:40px;text-align:center}.user-avatar-small{width:40px;height:40px;background:#e5e7eb;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.user-info{flex:1}.user-name{font-size:16px;font-weight:600;color:#1f2937}.user-score{font-size:18px;font-weight:700;color:#3b82f6}.loading{text-align:center;padding:60px 20px;color:#6b7280}*{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:#f5f5f5}#root{min-height:100vh}
