.app{min-height:100vh;background-color:#f3f4f6}.btn-primary.green{background-color:#059669}.btn-primary.green:hover{background-color:#047857}.btn-primary.red{background-color:#dc2626}.btn-primary.red:hover{background-color:#b91c1c}:root{font-size:16px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,system-ui,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f3f4f6;color:#1f2937}.container{margin:0 auto;padding:1rem}.form-container{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-label{display:block;font-weight:600;margin-bottom:.5rem;color:#374151}.form-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn{padding:.75rem 1.5rem;border:none;border-radius:.375rem;font-weight:600;cursor:pointer;transition:all .2s;font-size:1rem}.btn-primary{background-color:#ca8a04;color:#fff}.btn-primary:hover{background-color:#a16207}.btn-primary:active{background-color:#713f12}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover{background-color:#4b5563}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover{background-color:#059669}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover{background-color:#dc2626}.btn-full{width:100%}.error-message{color:#ef4444;font-size:1rem;margin-top:.25rem}.success-message{color:#10b981;font-size:1rem;margin-top:.25rem}.nav-bar{background-color:#1f2937;color:#fff;padding:1rem;display:flex;justify-content:space-between;align-items:center}.nav-title{font-size:1.25rem;font-weight:600}.status-indicator{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.status-online{background-color:#dcfce7;color:#166534}.status-offline{background-color:#fee2e2;color:#991b1b}.card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem}.grid{display:grid;gap:1rem}.grid-2{grid-template-columns:repeat(2,1fr)}.text-center{text-align:center}.mb-4{margin-bottom:1rem}.mt-4{margin-top:1rem}.hidden{display:none}.map-container{height:300px;width:100%;border-radius:.375rem;margin:1rem 0;border:1px solid #d1d5db;overflow:hidden;position:relative;z-index:1}#map{height:100%;width:100%;border-radius:.375rem;position:relative;z-index:1}.leaflet-container{height:100%!important;width:100%!important;max-height:300px!important;border-radius:.375rem}.leaflet-map-pane,.leaflet-tile-pane,.leaflet-overlay-pane,.leaflet-control-container{position:relative!important}.saved-users-container{margin-top:2rem;margin-bottom:1rem}.saved-users-title{font-size:1.125rem;font-weight:600;color:#374151;margin-bottom:.5rem;text-align:center}.saved-users-subtitle{font-size:.875rem;color:#6b7280;text-align:center;margin-bottom:1rem}.saved-users-list{display:flex;flex-direction:column;gap:.75rem}.saved-user-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;cursor:pointer;transition:all .2s ease-in-out;display:flex;align-items:center;justify-content:space-between;position:relative}.saved-user-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a;transform:translateY(-1px)}.saved-user-content{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.saved-user-avatar{width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1rem;flex-shrink:0}.saved-user-info{min-width:0;flex:1}.saved-user-name{font-weight:600;color:#1f2937;font-size:.875rem;line-height:1.25}.saved-user-email{color:#6b7280;font-size:.75rem;line-height:1.25;margin-top:.125rem}.saved-user-project{color:#9ca3af;font-size:.75rem;line-height:1.25;margin-top:.125rem}.saved-user-remove{width:2rem;height:2rem;padding:.2rem;border:none;background:#ef4444;color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;flex-shrink:0;opacity:1}.saved-users-warning{background:#fef3cd;border:1px solid #f6d55c;border-radius:.5rem;padding:1rem;margin:1rem 0;text-align:center;color:#92400e;font-size:.875rem}.action-sheet-trigger{display:flex;justify-content:space-between;align-items:center;text-align:left;background:#fff;cursor:pointer;font-family:inherit;width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;transition:all .2s ease-in-out}.action-sheet-trigger:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.action-sheet-trigger:disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed;opacity:.7}.action-sheet-trigger.loading{opacity:.6;cursor:wait}.action-sheet-trigger .placeholder{color:#6b7280}.action-sheet-trigger .selected{color:#1f2937}.dropdown-arrow{width:1rem;height:1rem;stroke:currentColor;stroke-width:2;fill:none;flex-shrink:0;margin-left:.5rem}.action-sheet-trigger:disabled .dropdown-arrow{opacity:.5}@media (max-width: 768px){.action-sheet-trigger{min-height:52px;padding:1rem;font-size:16px;border-radius:8px}.action-sheet-trigger:focus{transform:scale(1.02);box-shadow:0 0 0 4px #3b82f626}}@media (prefers-color-scheme: dark){.action-sheet-trigger{background-color:#fff;color:#1f2937;border-color:#d1d5db}.action-sheet-trigger:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.action-sheet-trigger:disabled{background-color:#f9fafb;color:#6b7280}}pwa-action-sheet{--background: white;--color: #1f2937;--border-radius: 12px;--box-shadow: 0 10px 25px rgba(0, 0, 0, .3);--backdrop-opacity: .5}pwa-action-sheet .action-sheet-group{border-radius:12px;overflow:hidden}pwa-action-sheet .action-sheet-button{font-size:16px;padding:16px 20px;border-bottom:1px solid #f3f4f6}pwa-action-sheet .action-sheet-button:last-child{border-bottom:none}pwa-action-sheet .action-sheet-title{font-weight:600;color:#6b7280;font-size:14px;padding:16px 20px 8px}@media (prefers-color-scheme: dark){pwa-action-sheet{--background: #374151;--color: white}pwa-action-sheet .action-sheet-button{border-bottom-color:#4b5563}pwa-action-sheet .action-sheet-title{color:#9ca3af}}.fuzzy-select-dropdown{position:absolute;top:100%;left:0;right:0;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;box-shadow:0 10px 15px -3px #0000001a;z-index:1000;max-height:300px;overflow-y:auto}.fuzzy-select-search{padding:.75rem;border-bottom:1px solid #f3f4f6}.fuzzy-select-search input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:16px;background:#fff}.fuzzy-select-search input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.fuzzy-select-option{padding:1rem 1.25rem;cursor:pointer;border-bottom:1px solid #f3f4f6;font-size:1rem;line-height:1.5;min-height:48px;display:flex;align-items:center;transition:background-color .15s ease}.fuzzy-select-option:last-child{border-bottom:none}.fuzzy-select-option:hover,.fuzzy-select-option.focused{background-color:#f9fafb}.fuzzy-select-option:active{background-color:#f3f4f6}.fuzzy-select-message{padding:1rem 1.25rem;color:#6b7280;font-size:.875rem;text-align:center;font-style:italic}@media (max-width: 768px){.fuzzy-select-dropdown{max-height:60vh;border-radius:8px}.fuzzy-select-search{padding:1rem}.fuzzy-select-search input{padding:1rem;font-size:16px;border-radius:8px}.fuzzy-select-option{padding:1.25rem 1.5rem;min-height:52px;font-size:16px}.fuzzy-select-message{padding:1.25rem 1.5rem;font-size:1rem}}@media (prefers-contrast: high){.fuzzy-select-option{border-bottom-width:2px;border-bottom-color:#000}.fuzzy-select-option:hover,.fuzzy-select-option.focused{background-color:#06c;color:#fff}}@media (prefers-reduced-motion: reduce){.fuzzy-select-option{transition:none}}
