*{margin:0;padding:0;box-sizing:border-box}body{margin:0;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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{width:100%;height:100vh}.message-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.message-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.message-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid #e5e7eb}.message-modal-title{font-size:20px;font-weight:600;color:#111827;margin:0;flex:1;line-height:1.4;padding-right:16px}.message-modal-close{background:none;border:none;font-size:28px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s;flex-shrink:0}.message-modal-close:hover{background-color:#f3f4f6;color:#111827}.message-modal-content{padding:24px;overflow-y:auto;flex:1}.message-text-large{font-size:18px;line-height:1.6;color:#111827;margin-bottom:24px;padding:16px;background-color:#f9fafb;border-radius:8px;border-left:4px solid #3b82f6}.message-metadata{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.metadata-item{display:flex;flex-direction:column;gap:4px}.metadata-label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.metadata-value{font-size:14px;color:#111827;font-weight:500}.no-gps-badge{color:#ef4444;font-size:12px;margin-left:8px}.message-media-section{margin-top:24px}.image-container{position:relative;margin-bottom:16px}.message-image-thumbnail{width:100%;max-height:400px;object-fit:contain;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;background-color:#f9fafb}.message-image-thumbnail:hover{transform:scale(1.02);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.image-hint{font-size:12px;color:#6b7280;text-align:center;margin-top:8px;font-style:italic}.image-download-button{position:absolute;top:12px;right:12px;background-color:#000000b3;border-radius:6px;padding:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s;z-index:10}.image-download-button:hover{background-color:#000000e6}.audio-container{margin-top:16px}.message-audio-player{width:100%;margin-bottom:12px}.audio-transcription{font-size:14px;color:#4b5563;padding:12px;background-color:#f9fafb;border-radius:6px;line-height:1.5}.audio-transcription strong{color:#111827;display:block;margin-bottom:4px}.image-lightbox-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:40px;animation:fadeIn .2s ease-out}.image-lightbox-content{position:relative;max-width:95vw;max-height:95vh;display:flex;align-items:center;justify-content:center}.image-lightbox-close{position:absolute;top:-40px;right:0;background:#fff3;border:none;color:#fff;font-size:32px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.image-lightbox-close:hover{background:#ffffff4d;transform:scale(1.1)}.image-lightbox-download{position:absolute;top:-40px;right:50px;background:#fff3;border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.image-lightbox-download:hover{background:#ffffff4d;transform:scale(1.1)}.image-lightbox-image{max-width:100%;max-height:95vh;object-fit:contain;border-radius:8px;box-shadow:0 25px 50px -12px #00000080}@media (max-width: 640px){.message-modal{max-width:100%;max-height:100vh;border-radius:0}.message-modal-header{padding:20px 20px 16px}.message-modal-content{padding:20px}.message-text-large{font-size:16px;padding:12px}.message-metadata{grid-template-columns:1fr;gap:12px}.image-lightbox-backdrop{padding:20px}.image-lightbox-close{top:-30px;right:-10px}}.app-container{display:flex;flex-direction:column;height:100vh;width:100%}.app-loading,.app-login,.app-error{display:flex;align-items:center;justify-content:center;height:100vh;width:100%}.login-container{text-align:center;padding:40px;background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a}.login-button{padding:12px 24px;font-size:16px;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;margin-top:20px}.login-button:hover{background-color:#2563eb}.app-error{flex-direction:column;padding:40px}.app-error h1{color:#ef4444;margin-bottom:16px}.app-header{background-color:#1f2937;color:#fff;padding:12px 16px;box-shadow:0 2px 4px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:100%}.header-content h1{font-size:20px;font-weight:600;margin:0}.header-actions{display:flex;align-items:center;gap:12px}.user-info{font-size:14px;color:#d1d5db}.logout-button{padding:6px 12px;font-size:14px;background-color:#ef4444;color:#fff;border:none;border-radius:4px;cursor:pointer}.logout-button:hover{background-color:#dc2626}.app-main{display:flex;flex:1;overflow:hidden}.app-sidebar{width:300px;background-color:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;overflow:hidden}.filter-panel{border-right:1px solid #e5e7eb}.message-list{border-left:1px solid #e5e7eb}.app-map{flex:1;position:relative;background-color:#f3f4f6}.error-banner{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:1000;background-color:#ef4444;color:#fff;padding:12px 16px;border-radius:6px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 6px #0000001a}.error-banner button{padding:4px 8px;background-color:#fff;color:#ef4444;border:none;border-radius:4px;cursor:pointer;font-size:12px}.list-header{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid #e5e7eb;background-color:#f9fafb;font-weight:600}.close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;outline:none}.close-button:hover{color:#1f2937}.close-button:focus{outline:2px solid #3b82f6;outline-offset:2px;border-radius:4px}.refresh-button{background:none;border:none;font-size:18px;cursor:pointer;color:#6b7280;padding:2px 4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;outline:none}.refresh-button:hover:not(:disabled){background-color:#f3f4f6;color:#3b82f6}.refresh-button:focus:not(:disabled){outline:2px solid #3b82f6;outline-offset:2px}.refresh-button:disabled{opacity:.5;cursor:not-allowed}.refresh-button:active:not(:disabled){transform:rotate(180deg)}.toggle-list-button{position:absolute;bottom:20px;right:20px;z-index:1000;padding:8px 12px;background-color:#3b82f6d9;color:#fff;border:none;border-radius:6px;cursor:pointer;box-shadow:0 2px 4px #00000026;font-size:16px;font-weight:300;transition:background-color .2s ease;outline:none}.toggle-list-button:hover{background-color:#2563ebe6}.toggle-list-button:focus{outline:2px solid white;outline-offset:2px}.zoom-fit-button{position:absolute;top:85px;left:15px;z-index:1000;width:32px;height:32px;padding:0;background-color:#fff;color:#6e6e6e;border:none;border-radius:0;cursor:pointer;box-shadow:0 1px 2px #0000004d;font-size:22px;display:flex;align-items:center;justify-content:center;transition:background-color .125s ease-in-out;outline:none}.zoom-fit-button:hover{background-color:#f3f4f6;color:#2b2b2b}.zoom-fit-button:active{background-color:#e5e5e5}.zoom-fit-button:focus{outline:2px solid #3b82f6;outline-offset:2px}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffd9;display:flex;align-items:center;justify-content:center;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.loading-dots{display:flex;gap:8px}.loading-dots span{width:12px;height:12px;background-color:#3b82f6;border-radius:50%;animation:bounce 1.4s ease-in-out infinite both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}.loading-dots span:nth-child(3){animation-delay:0s}@keyframes bounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}@media (max-width: 768px){.app-sidebar{width:100%;position:absolute;z-index:1000;height:100%;background-color:#fff}.filter-panel{top:0;left:0}.message-list{top:0;right:0}}
