*{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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;max-width:400px;padding:40px;width:100%}.auth-card h1{color:#1f2937;font-size:32px;margin-bottom:8px;text-align:center}.logo-container{align-items:center;display:flex;flex-direction:column;margin-bottom:24px}.app-logo{height:80px;margin-bottom:12px;width:80px}.app-logo-small{height:48px;margin-right:12px;width:48px}.logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:700;margin:0}.subtitle{color:#6b7280;font-size:14px;margin-bottom:32px;text-align:center}.success-message{border-left:4px solid #10b981;font-size:14px}.auth-link{color:#6b7280;margin-top:24px;text-align:center}.auth-link a{color:#3b82f6;font-weight:600;text-decoration:none}.auth-link a:hover{text-decoration:underline}.notification-bell-container{position:relative}.notification-bell{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;justify-content:center;padding:8px;position:relative;transition:color .2s ease}.notification-bell:hover{color:#3b82f6}.notification-badge{background:#ef4444;border-radius:10px;color:#fff;font-size:11px;font-weight:600;line-height:1.4;min-width:18px;padding:2px 6px;position:absolute;right:4px;text-align:center;top:4px}.notification-panel{background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;display:flex;flex-direction:column;max-height:600px;max-width:90vw;position:absolute;right:0;top:calc(100% + 10px);width:400px;z-index:1000}.notification-panel-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:16px 20px}.notification-panel-header h3{color:#1f2937;font-size:18px;margin:0}.mark-all-read-btn{background:none;border:none;border-radius:4px;color:#3b82f6;cursor:pointer;font-size:14px;padding:4px 8px;transition:background .2s ease}.mark-all-read-btn:hover{background:#f3f4f6}.notification-list{max-height:500px;overflow-y:auto}.notification-item{border-bottom:1px solid #f3f4f6;cursor:pointer;padding:16px 20px;transition:background .2s ease}.notification-item:hover{background:#f9fafb}.notification-item.unread{background:#eff6ff;border-left:3px solid #3b82f6}.notification-item.accepted,.notification-item.rejected{opacity:.7}.notification-content{display:flex;gap:12px;margin-bottom:12px}.notification-icon{flex-shrink:0;font-size:24px}.notification-text{flex:1 1}.notification-message{color:#1f2937;font-size:14px;line-height:1.5;margin:0 0 4px}.notification-time{color:#9ca3af;display:block;font-size:12px;margin-top:4px}.notification-status{color:#6b7280;display:block;font-size:12px;font-weight:500;margin-top:2px}.notification-actions{display:flex;gap:8px;margin-top:8px}.btn-accept,.btn-reject{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.btn-accept{background:#10b981;color:#fff}.btn-accept:hover:not(:disabled){background:#059669}.btn-reject{background:#f3f4f6;color:#374151}.btn-reject:hover:not(:disabled){background:#e5e7eb}.btn-accept:disabled,.btn-reject:disabled{cursor:not-allowed;opacity:.6}.notification-empty,.notification-loading{color:#6b7280;font-size:14px;padding:40px 20px;text-align:center}.notification-divider{background:#f9fafb;color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 20px;text-transform:uppercase}@media (max-width:480px){.notification-panel{max-width:calc(100vw - 40px);right:-20px;width:100vw}}.user-menu{display:inline-block;position:relative}.user-menu-trigger{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:center;padding:0;transition:transform .2s ease,opacity .2s ease}.user-menu-trigger:hover{opacity:.8;transform:scale(1.05)}.user-menu-trigger:focus{border-radius:50%;outline:2px solid #667eea;outline-offset:2px}.user-avatar-img,.user-avatar-placeholder{border:2px solid #e5e7eb;border-radius:50%;height:40px;object-fit:cover;transition:border-color .2s ease;width:40px}.user-menu-trigger:hover .user-avatar-img,.user-menu-trigger:hover .user-avatar-placeholder{border-color:#667eea}.user-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #e5e7eb;color:#fff;display:flex;font-size:16px;font-weight:600;justify-content:center}.user-menu-dropdown{animation:slideDown .2s ease;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026,0 0 0 1px #0000000d;min-width:220px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.user-menu-header{align-items:center;background:#f9fafb;display:flex;gap:12px;padding:16px}.user-menu-avatar-img,.user-menu-avatar-placeholder{border:2px solid #e5e7eb;border-radius:50%;flex-shrink:0;height:48px;object-fit:cover;width:48px}.user-menu-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #e5e7eb;color:#fff;display:flex;font-size:20px;font-weight:600;justify-content:center}.user-menu-info{flex:1 1;min-width:0}.user-menu-name{color:#1f2937;font-size:14px;font-weight:600;margin-bottom:2px}.user-menu-email,.user-menu-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-email{color:#6b7280;font-size:12px}.user-menu-divider{background:#e5e7eb;height:1px;margin:4px 0}.user-menu-item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:14px;padding:12px 16px;text-align:left;transition:background-color .2s ease;width:100%}.user-menu-item:focus,.user-menu-item:hover{background-color:#f3f4f6}.user-menu-item:focus{outline:none}.user-menu-item-logout{color:#dc2626}.user-menu-item-logout:hover{background-color:#fee2e2;color:#991b1b}@media (max-width:640px){.user-menu-dropdown{min-width:200px;right:-8px}}.dashboard{background-color:#f5f5f5;min-height:100vh}.dashboard-header{background:#fff;box-shadow:0 2px 4px #0000001a;margin-bottom:30px;padding:20px 0}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px}.header-content h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;font-size:24px;font-weight:700;margin:0}.app-logo-header{height:40px;margin-right:12px;width:40px}.user-info{align-items:center;display:flex;gap:16px}.user-info span{color:#374151;font-weight:500}.dashboard-content{margin:0 auto;max-width:1200px;padding:0 20px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.section-header h2{color:#1f2937;font-size:28px}.create-circle-form{margin-bottom:24px}.form-actions{gap:12px}.circles-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.circle-card{align-items:flex-start;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;display:flex;gap:16px;padding:20px;transition:transform .2s ease,box-shadow .2s ease}.circle-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.circle-color{height:48px;width:48px}.circle-info{flex:1 1}.circle-info h3{color:#1f2937;font-size:20px;margin-bottom:8px}.circle-description{color:#6b7280;font-size:14px;margin-bottom:8px}.circle-members{color:#9ca3af;font-size:12px}.empty-state{color:#6b7280;padding:60px 20px;text-align:center}.empty-state p{font-size:18px}.header-actions{align-items:center;display:flex;gap:10px}.circle-header-row{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px}.btn-invite{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:background .2s ease;white-space:nowrap}.btn-invite:hover{background:#2563eb}.invite-form-inline{border-top:1px solid #e5e7eb;margin-top:12px;padding-top:12px}.invite-input-group{display:flex;gap:8px;margin-bottom:6px}.invite-email-input{border:1px solid #d1d5db;border-radius:6px;flex:1 1;font-size:14px;outline:none;padding:8px 12px}.btn-invite-submit{background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:background .2s ease;white-space:nowrap}.btn-invite-submit:hover{background:#059669}.invite-help-text-small{color:#9ca3af;font-size:11px;margin:4px 0 0}.map-view{display:flex;flex-direction:column;height:100vh}#map-container,.map-view{position:relative;width:100%}#map-container{flex:1 1;height:calc(100vh - 140px);padding-bottom:70px}.map-header{align-items:center;background:#fff;box-shadow:0 2px 8px #0000001a;display:flex;gap:20px;left:0;padding:16px 20px;position:absolute;right:0;top:0;z-index:1000}.back-btn{background:#f3f4f6;border-radius:8px;color:#374151;font-size:14px;font-weight:500;padding:8px 16px}.back-btn:hover{background:#e5e7eb}.map-header h2{color:#1f2937;font-size:20px;margin:0}.members-list-bottom{background:#fff;bottom:0;box-shadow:0 -2px 8px #0000001a;display:flex;gap:12px;left:0;overflow-x:auto;overflow-y:hidden;padding:12px 20px;position:absolute;right:0;scrollbar-color:#d1d5db #0000;scrollbar-width:thin;z-index:1000}.members-list-bottom::-webkit-scrollbar{height:6px}.members-list-bottom::-webkit-scrollbar-track{background:#0000}.members-list-bottom::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:3px}.member-item-bottom{align-items:center;background:#f9fafb;border-radius:20px;display:flex;flex-shrink:0;gap:8px;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.member-item-bottom.clickable:hover{background:#e5e7eb;box-shadow:0 2px 4px #0000001a;transform:translateY(-2px)}.member-item-bottom.selected{background:#dbeafe;border:2px solid #3b82f6;box-shadow:0 2px 8px #3b82f64d}.member-item-bottom.selected:hover{background:#bfdbfe;box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.member-following{color:#3b82f6!important;font-size:11px!important;font-weight:600!important;margin-left:4px}.member-avatar{font-size:12px}.member-avatar,.member-avatar-img{flex-shrink:0;height:28px;width:28px}.member-avatar-img{border:2px solid #e5e7eb;border-radius:50%;object-fit:cover}.member-item-bottom span{color:#374151;font-size:14px;font-weight:500}.member-info{align-items:flex-start;display:flex;flex-direction:column;gap:2px}.member-speed{color:#059669!important;font-size:11px!important;font-weight:600!important;margin-top:2px}.member-offline{color:#9ca3af!important;font-size:11px!important;font-style:italic;font-weight:400!important}.location-warning{align-items:center;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;box-shadow:0 4px 6px #0000001a;display:flex;gap:12px;left:50%;max-width:90%;padding:12px 16px;position:absolute;top:80px;transform:translateX(-50%);z-index:1000}.location-warning span{color:#92400e;flex:1 1;font-size:14px}.btn-manual-location{background:#f59e0b;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;white-space:nowrap}.btn-manual-location:hover{background:#d97706}.error-container,.loading-container{height:calc(100vh - 80px)}.marker-label{line-height:1.2;text-align:center}.marker-speed-label{background-color:#ffffffe6;border:1px solid #059669;border-radius:4px;box-shadow:0 1px 3px #0003;padding:2px 4px}.marker-info-window{max-width:300px;min-width:250px;padding:0}.marker-info-name{border-bottom:1px solid #e5e7eb;margin-bottom:12px;padding-bottom:12px}.marker-info-name h3{color:#1f2937;font-size:18px;font-weight:600;margin:0}.marker-info-coordinates,.marker-info-location,.marker-info-speed{margin-bottom:12px;padding:8px 0}.marker-info-coordinates:last-child,.marker-info-location:last-child,.marker-info-speed:last-child{margin-bottom:0}.marker-info-coordinates strong,.marker-info-location strong,.marker-info-speed strong{color:#374151;display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.address-text{word-wrap:break-word;color:#1f2937;font-size:14px;line-height:1.4;margin:4px 0 0}.loading-address{color:#6b7280;font-size:12px;font-style:italic;margin:4px 0 0}.address-error{color:#dc2626;font-size:12px;margin:4px 0 0}.marker-info-speed p{color:#1f2937;font-size:14px;margin:4px 0 0}.coordinates-text{color:#6b7280;font-family:Courier New,monospace;font-size:12px;margin:4px 0 0;word-break:break-all}@keyframes slideDown{0%{opacity:0;transform:translateX(-50%) translateY(-20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.places-toggle-btn{align-items:center;display:flex;gap:6px;transition:all .2s ease}.places-toggle-btn:hover{transform:scale(1.05)}@keyframes markerBounce{0%{opacity:0;transform:translateY(-100px)}50%{opacity:1;transform:translateY(10px)}70%{transform:translateY(-8px)}85%{transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes markerPulse{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1)}}.stacked-marker-container{animation:markerBounce .6s cubic-bezier(.34,1.56,.64,1) forwards;position:relative}.stacked-marker-container.pulse{animation:markerPulse 2s ease-in-out infinite}.stacked-avatar{border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #0000004d;position:absolute;transition:transform .3s ease,box-shadow .3s ease}.stacked-avatar:first-child{border-color:#3b82f6;z-index:4}.stacked-avatar:nth-child(2){transform:translateY(10px);z-index:3}.stacked-avatar:nth-child(3){transform:translateY(20px);z-index:2}.stacked-avatar:nth-child(4){transform:translateY(30px);z-index:1}.stacked-marker-container:hover .stacked-avatar{box-shadow:0 4px 12px #0006}.stacked-marker-container:hover .stacked-avatar:first-child{transform:translateY(-5px)}.stack-count-badge{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 6px #0000004d;color:#fff;display:flex;font-size:11px;font-weight:700;height:24px;justify-content:center;position:absolute;right:-5px;top:-5px;width:24px;z-index:10}.marker-pointer{border-left:8px solid #0000;border-right:8px solid #0000;border-top:12px solid #fff;bottom:-12px;filter:drop-shadow(0 2px 2px rgba(0,0,0,.2));height:0;left:50%;position:absolute;transform:translateX(-50%);width:0}.marker-pointer:before{border-left:6px solid #0000;border-right:6px solid #0000;border-top:10px solid #3b82f6;content:"";height:0;left:-6px;position:absolute;top:-14px;width:0}.circles-page{background-color:#f5f5f5;min-height:100vh;padding:40px 0}.circles-page h1{color:#1f2937;margin-bottom:30px}.circles-list{display:flex;flex-direction:column;gap:24px}.circle-detail-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px}.circle-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.circle-header h2{color:#1f2937;margin:0}.members-section{margin-top:24px}.members-section h3{color:#374151;font-size:18px;margin-bottom:16px}.members-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:24px}.member-card{align-items:center;background:#f9fafb;border-radius:8px;display:flex;gap:12px;padding:12px;position:relative;transition:background .2s ease}.member-card:hover{background:#f3f4f6}.member-avatar{align-items:center;background:#3b82f6;border-radius:50%;color:#fff;display:flex;font-size:16px;font-weight:600;height:40px;justify-content:center;width:40px}.member-info{flex:1 1}.member-name{color:#1f2937;font-size:14px;font-weight:600;margin:0 0 4px}.member-email{color:#6b7280;font-size:12px;margin:0 0 4px}.member-role{background:#dbeafe;border-radius:4px;color:#1e40af;display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;text-transform:uppercase}.you-badge{color:#6b7280;font-size:12px;font-style:italic;font-weight:400}.btn-remove-member{align-items:center;background:#fee2e2;border:none;border-radius:6px;color:#dc2626;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:600;height:32px;justify-content:center;margin-left:auto;transition:all .2s ease;width:32px}.btn-remove-member:hover:not(:disabled){background:#fecaca;color:#b91c1c;transform:scale(1.1)}.btn-remove-member:disabled{cursor:not-allowed;opacity:.5}.add-member-section{border-top:1px solid #e5e7eb;margin-top:24px;padding-top:24px}.add-member-section h3{color:#374151;font-size:18px;margin-bottom:16px}.add-member-section form{align-items:flex-end;display:flex;gap:12px}.add-member-section .form-group{flex:1 1;margin:0}.invite-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.invite-section-header h3{align-items:center;color:#374151;display:flex;font-size:18px;gap:8px;margin:0}.admin-badge{background:#10b981}.invite-help-text{color:#6b7280;font-size:14px;margin-bottom:16px}.invite-email-input{border:2px solid #d1d5db;border-radius:8px;font-size:16px;padding:12px;transition:border-color .2s ease;width:100%}.invite-email-input:focus{border-color:#3b82f6;outline:none}.btn-invite-large{font-size:16px;font-weight:600;margin-top:12px;padding:12px 24px}.non-admin-message{background:#f3f4f6;border-left:4px solid #f59e0b;border-radius:8px;padding:16px}.non-admin-message p{color:#374151;font-size:14px;margin:0 0 8px}.admin-info{color:#6b7280!important;font-size:12px!important;font-style:italic}.shareable-link-section{background:#f0fdf4;border:2px solid #10b981;border-radius:12px;margin-bottom:24px;padding:20px}.shareable-link-section h4{align-items:center;color:#059669;display:flex;font-size:16px;font-weight:600;gap:8px;margin:0 0 12px}.shareable-link-container{display:flex;flex-direction:column;gap:12px}.shareable-link-input-group{align-items:stretch;display:flex;gap:8px}.shareable-link-input{background:#fff;border:2px solid #d1d5db;border-radius:8px;color:#1f2937;flex:1 1;font-family:Courier New,monospace;font-size:14px;padding:12px;word-break:break-all}.shareable-link-input:focus{border-color:#10b981;outline:none}.btn-copy{background:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .2s ease;white-space:nowrap}.btn-copy:hover{background:#059669;box-shadow:0 4px 8px #10b9814d;transform:translateY(-1px)}.btn-copy.copied{animation:pulse .3s ease;background:#059669}.btn-generate-link{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .2s ease;width:100%}.btn-generate-link:hover:not(:disabled){box-shadow:0 6px 12px #10b9814d;transform:translateY(-2px)}.btn-generate-link:disabled{cursor:not-allowed;opacity:.6}.btn-regenerate{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s ease}.btn-regenerate:hover{background:#e5e7eb;border-color:#9ca3af}.invite-divider{align-items:center;display:flex;margin:24px 0;text-align:center}.invite-divider:after,.invite-divider:before{border-bottom:1px solid #e5e7eb;content:"";flex:1 1}.invite-divider span{color:#9ca3af;font-size:14px;font-weight:500;padding:0 16px}.email-invite-section{margin-top:24px}.email-invite-section h4{align-items:center;color:#374151;display:flex;font-size:16px;font-weight:600;gap:8px;margin:0 0 12px}.pending-invitations-section{border-top:1px solid #e5e7eb;margin-top:24px;padding-top:24px}.pending-invitations-section h3{color:#374151;font-size:18px;margin-bottom:16px}.pending-invitations-list{display:flex;flex-direction:column;gap:12px}.pending-invitation-card{background:#fff7ed;border:1px solid #fed7aa;border-radius:8px;padding:12px;transition:all .2s ease}.pending-invitation-card:hover{background:#ffedd5;border-color:#fdba74}.pending-invitation-info{align-items:flex-start;display:flex;gap:12px}.pending-invitation-avatar{align-items:center;background:#f59e0b;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:600;height:40px;justify-content:center;width:40px}.pending-invitation-details{flex:1 1}.pending-invitation-name{color:#1f2937;font-size:14px;font-weight:600;margin:0 0 4px}.pending-invitation-email{color:#6b7280;font-size:12px;margin:0 0 4px}.pending-invitation-code{color:#92400e;font-size:12px;margin:4px 0}.pending-invitation-code strong{color:#b45309;font-family:Courier New,monospace;font-size:14px;letter-spacing:1px}.pending-invitation-status{background:#fef3c7;border-radius:4px;color:#92400e;display:inline-block;font-size:11px;font-weight:600;margin-right:8px;margin-top:4px;padding:2px 8px}.pending-invitation-time{color:#9ca3af;display:block;font-size:11px;margin-top:4px}.members-section h3 .member-count-clickable{color:#3b82f6!important;cursor:pointer!important;font-weight:600!important;text-decoration:underline!important;transition:color .2s ease;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.members-section h3 .member-count-clickable:hover{color:#2563eb!important;text-decoration:underline!important}.members-section h3 .member-count-clickable:active{color:#1d4ed8!important}.member-item-modal{position:relative}.btn-remove-member-modal{align-items:center;background:#fee2e2;border:none;border-radius:6px;color:#dc2626;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:600;height:36px;justify-content:center;margin-left:auto;transition:all .2s ease;width:36px}.btn-remove-member-modal:hover:not(:disabled){background:#fecaca;color:#b91c1c;transform:scale(1.1)}.btn-remove-member-modal:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.members-modal{margin:10px;max-height:90vh;max-width:100%}.modal-header{padding:20px}.modal-header h2{font-size:20px}.modal-content{padding:20px}.member-item-modal{padding:12px}.member-avatar-modal{height:48px;width:48px}.member-avatar-img-modal,.member-avatar-placeholder-modal{font-size:18px;height:48px;width:48px}}.profile-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.profile-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;margin:0 auto;max-width:600px;overflow:hidden}.profile-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;gap:15px;padding:20px}.profile-header h2{color:#1f2937;margin:0}.back-btn{background:none;border:none;border-radius:6px;color:#667eea;cursor:pointer;font-size:18px;padding:5px 10px;transition:background-color .2s}.back-btn:hover{background-color:#f3f4f6}.profile-form{padding:30px}.avatar-section{margin-bottom:30px;text-align:center}.avatar-preview{margin-bottom:15px}.avatar-preview img{object-fit:cover}.avatar-placeholder,.avatar-preview img{border:4px solid #667eea;border-radius:50%;box-shadow:0 4px 12px #0000001a;height:120px;width:120px}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:inline-flex;font-size:48px;font-weight:700;justify-content:center}.avatar-upload-label{cursor:pointer;display:inline-block;margin-bottom:10px}.avatar-help-text{color:#6b7280;font-size:12px;margin-top:8px}.form-group input{transition:border-color .2s}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.disabled-input{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed}.field-help-text{color:#6b7280;font-size:12px;margin-top:5px}.form-actions{display:flex;gap:10px;margin-top:30px}.btn{font-weight:500}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2)}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#f3f4f6}.btn-secondary:hover{background:#e5e7eb}.error-message{border:1px solid #fecaca;margin-bottom:20px}.success-message{background-color:#d1fae5;border:1px solid #a7f3d0;border-radius:8px;color:#065f46;margin-bottom:20px;padding:12px}.error-container,.loading-container{align-items:center;color:#6b7280;display:flex;flex-direction:column;font-size:18px;justify-content:center;min-height:calc(100vh - 80px);padding:40px;text-align:center}.error-container button{margin-top:20px}@media (max-width:640px){.profile-container{padding:10px}.profile-card{border-radius:8px}.profile-form{padding:20px}.form-actions{flex-direction:column}.btn{width:100%}}.admin-panel{background-color:#f5f5f5;min-height:100vh;padding:20px}.admin-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin:0 auto 30px;max-width:1400px;padding:20px 30px}.admin-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:700;margin:0}.header-logo-container{align-items:center;display:flex}.admin-tabs{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;gap:10px;margin:0 auto 20px;max-width:1400px;padding:10px}.admin-tabs button{background:#0000;border:none;border-radius:8px;color:#6b7280;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px 20px;transition:all .2s}.admin-tabs button:hover{background:#f3f4f6;color:#3b82f6}.admin-tabs button.active{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff}.admin-content{margin:0 auto;max-width:1400px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:24px;text-align:center}.stat-card h3{color:#6b7280;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.stat-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;font-size:36px;font-weight:700;margin:0}.table-container{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%}.admin-table thead{background:#f9fafb}.admin-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-size:14px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.admin-table td{border-bottom:1px solid #e5e7eb;color:#1f2937;padding:16px}.admin-table tbody tr:hover{background:#f9fafb}.user-cell{align-items:center;display:flex;gap:12px}.user-avatar,.user-avatar-small{border-radius:50%;height:40px;object-fit:cover;width:40px}.user-avatar-small{height:32px;width:32px}.user-avatar-placeholder,.user-avatar-placeholder-small{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;display:flex;font-size:16px;font-weight:600;height:40px;justify-content:center;width:40px}.user-avatar-placeholder-small{font-size:14px;height:32px;width:32px}.circle-cell{align-items:center;display:flex;gap:12px}.circle-color{border-radius:50%;flex-shrink:0;height:16px;width:16px}.status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.admin-badge{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.error-message{background-color:#fee2e2;border-radius:8px;color:#dc2626;font-size:14px;margin:0 auto 20px;max-width:1400px;padding:12px}.error-message.success-message{background-color:#d1fae5;color:#065f46}.loading{color:#6b7280;font-size:16px;padding:40px;text-align:center}.btn{font-size:14px;padding:10px 20px;transition:all .2s}.btn-secondary{background:#e5e7eb;color:#374151}.btn-secondary:hover{background:#d1d5db}.admin-actions{display:flex;gap:8px}.btn-add-admin,.btn-remove-admin{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.btn-add-admin{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff}.btn-add-admin:hover:not(:disabled){box-shadow:0 4px 8px #3b82f64d;transform:translateY(-1px)}.btn-add-admin:disabled{cursor:not-allowed;opacity:.5}.btn-remove-admin{background:#fee2e2;color:#dc2626}.btn-remove-admin:hover:not(:disabled){background:#fecaca;box-shadow:0 4px 8px #dc262633;transform:translateY(-1px)}.btn-remove-admin:disabled{cursor:not-allowed;opacity:.5}.member-count-clickable{color:#3b82f6;cursor:pointer;font-weight:600;text-decoration:underline;transition:color .2s ease}.member-count-clickable:hover{color:#2563eb}.modal-overlay{background:#00000080}.members-modal{animation:modalSlideIn .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:80vh;max-width:600px;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid #e5e7eb;padding:24px}.modal-header h2{color:#1f2937;font-size:24px;margin:0}.modal-close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.modal-close-btn:hover{background:#f3f4f6;color:#1f2937}.modal-content{flex:1 1;padding:24px}.members-list-modal{display:flex;flex-direction:column;gap:16px}.member-item-modal{align-items:center;background:#f9fafb;border-radius:12px;display:flex;gap:16px;padding:16px;transition:background .2s ease}.member-item-modal:hover{background:#f3f4f6}.member-avatar-modal{flex-shrink:0;height:56px;position:relative;width:56px}.member-avatar-img-modal{border-radius:50%;height:56px;object-fit:cover;width:56px}.member-avatar-placeholder-modal{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;display:flex;font-size:20px;font-weight:600;height:56px;justify-content:center;width:56px}.member-details-modal{flex:1 1}.member-name-modal{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 4px}.member-email-modal{color:#6b7280;font-size:14px;margin:0 0 4px}.member-phone-modal{color:#9ca3af;font-size:13px;margin:0 0 8px}.member-meta-modal{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.member-role-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.member-role-badge.admin{background:#fef3c7;color:#92400e}.member-role-badge.member{background:#dbeafe;color:#1e40af}.member-joined-date{color:#9ca3af;font-size:12px}.no-members{color:#6b7280;font-size:16px;padding:40px 20px;text-align:center}.access-logs-container{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:24px}.access-logs-filters{grid-gap:16px;border-bottom:1px solid #e5e7eb;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px;padding-bottom:24px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{color:#374151;font-size:14px;font-weight:600}.filter-group input,.filter-group select{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px;transition:border-color .2s}.filter-group input:focus,.filter-group select:focus{border-color:#3b82f6;outline:none}.btn-primary{align-self:flex-end;background:linear-gradient(135deg,#3b82f6,#8b5cf6);margin-top:auto}.btn-primary:hover{box-shadow:0 4px 8px #3b82f64d;transform:translateY(-1px)}.action-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.action-login{background:#d1fae5;color:#065f46}.action-logout{background:#fee2e2;color:#991b1b}.action-api_access{background:#dbeafe;color:#1e40af}.action-page_view{background:#f3f4f6;color:#374151}.action-location_update{background:#fef3c7;color:#92400e}.action-circle_access{background:#e9d5ff;color:#6b21a8}.method-badge{border-radius:6px;display:inline-block;font-family:monospace;font-size:11px;font-weight:600;padding:4px 8px}.method-GET{background:#d1fae5;color:#065f46}.method-POST{background:#dbeafe;color:#1e40af}.method-PUT{background:#fef3c7;color:#92400e}.method-DELETE{background:#fee2e2;color:#991b1b}.method-PATCH{background:#e9d5ff;color:#6b21a8}.pagination{align-items:center;border-top:1px solid #e5e7eb;display:flex;gap:16px;justify-content:center;margin-top:24px;padding-top:24px}.pagination span{color:#6b7280;font-size:14px}.pagination button:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.admin-header{align-items:flex-start;gap:16px}.admin-header,.admin-tabs{flex-direction:column}.stats-grid{grid-template-columns:1fr}.table-container{overflow-x:scroll}.members-modal{margin:10px;max-height:90vh;max-width:100%}.modal-header{padding:20px}.modal-header h2{font-size:20px}.modal-content{padding:20px}.member-item-modal{padding:12px}.member-avatar-modal{height:48px;width:48px}.member-avatar-img-modal,.member-avatar-placeholder-modal{font-size:18px;height:48px;width:48px}.access-logs-filters{grid-template-columns:1fr}.btn-primary{align-self:stretch;margin-top:0}.pagination{flex-direction:column;gap:12px}}.gps-prompt-overlay{align-items:center;animation:fadeIn .3s ease;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.gps-prompt-container{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000004d;max-width:400px;padding:32px 24px;text-align:center;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.gps-prompt-icon{animation:pulse 2s infinite;font-size:64px;margin-bottom:16px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.gps-prompt-container h2{color:#1f2937;font-size:24px;font-weight:600;margin:0 0 12px}.gps-prompt-container p{color:#6b7280;font-size:16px;line-height:1.5;margin:0 0 24px}.gps-prompt-actions{display:flex;gap:12px;margin-bottom:16px}.gps-prompt-button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px 24px;transition:all .2s ease}.gps-prompt-button-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.gps-prompt-button-primary:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.gps-prompt-button-secondary{background:#f3f4f6;color:#374151}.gps-prompt-button-secondary:hover{background:#e5e7eb}.gps-prompt-help{color:#9ca3af!important;font-size:12px!important;margin:0!important}@media (max-width:480px){.gps-prompt-container{padding:24px 20px}.gps-prompt-icon{font-size:48px}.gps-prompt-container h2{font-size:20px}.gps-prompt-container p{font-size:14px}.gps-prompt-actions{flex-direction:column}.gps-prompt-button{width:100%}}.download-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.download-container{max-width:600px;width:100%}.download-header{color:#fff;margin-bottom:30px;text-align:center}.download-header h1{font-size:2.5rem;font-weight:700;margin:0 0 10px;text-shadow:0 2px 4px #0003}.download-subtitle{font-size:1.1rem;margin:0;opacity:.9}.download-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;text-align:center}.download-icon{color:#3b82f6;display:flex;justify-content:center;margin-bottom:20px}.download-card h2{color:#1f2937;font-size:1.8rem;font-weight:600;margin:0 0 15px}.app-description{color:#6b7280;font-size:1rem;line-height:1.6;margin:0 0 30px}.download-info{background:#f9fafb;border-radius:12px;margin:30px 0;padding:20px;text-align:left}.info-item{border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:10px 0}.info-item:last-child{border-bottom:none}.info-label{color:#374151;font-weight:600}.info-value{color:#6b7280}.download-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:12px;box-shadow:0 4px 15px #3b82f666;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:10px;justify-content:center;margin:30px 0;padding:16px 32px;transition:all .3s ease;width:100%}.download-button:hover{box-shadow:0 6px 20px #3b82f680;transform:translateY(-2px)}.download-button:active{transform:translateY(0)}.download-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.download-error{background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;margin-top:20px;padding:15px}.download-error p{font-size:.95rem;line-height:1.5;margin:0}.install-instructions{border-top:2px solid #e5e7eb;margin-top:40px;padding-top:30px;text-align:left}.install-instructions h3{color:#1f2937;font-size:1.2rem;font-weight:600;margin:0 0 15px}.install-instructions ol{color:#6b7280;line-height:1.8;margin:0;padding-left:20px}.install-instructions li{margin-bottom:10px}.download-footer{border-top:1px solid #e5e7eb;margin-top:30px;padding-top:20px}.back-link{color:#3b82f6;font-weight:500;text-decoration:none;transition:color .2s ease}.back-link:hover{color:#2563eb;text-decoration:underline}@media (max-width:640px){.download-header h1{font-size:2rem}.download-card{padding:30px 20px}.download-button{font-size:1rem;padding:14px 24px}}.places-container{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);max-width:100%;min-height:100vh;padding:20px}.places-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;display:flex;justify-content:space-between;margin-bottom:20px;padding:15px 20px}.places-header .back-btn{background:#0000;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:18px;padding:10px;transition:background .2s}.places-header .back-btn:hover{background:#ffffff1a}.places-header h2{color:#fff;font-size:20px;margin:0}.add-place-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:25px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:transform .2s,box-shadow .2s}.add-place-btn:hover{box-shadow:0 5px 20px #3b82f666;transform:scale(1.05)}.places-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.place-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #ffffff1a;border-radius:15px;padding:20px;transition:transform .2s,box-shadow .2s}.place-card:hover{box-shadow:0 10px 30px #0000004d;transform:translateY(-5px)}.place-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.place-icon-name{gap:12px}.place-icon,.place-icon-name{align-items:center;display:flex}.place-icon{border-radius:12px;font-size:24px;height:50px;justify-content:center;width:50px}.place-name{color:#fff;font-size:18px;font-weight:600;margin:0 0 4px}.place-address{color:#fff9;font-size:12px;margin:0;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.place-delete-btn{background:#0000;border:none;border-radius:8px;color:#ffffff80;cursor:pointer;padding:8px;transition:background .2s,color .2s}.place-delete-btn:hover{background:#ef444433;color:#ef4444}.place-details{margin-bottom:15px}.place-detail-row{align-items:center;color:#ffffffb3;display:flex;font-size:13px;gap:8px;margin-bottom:8px}.place-detail-row svg{height:16px;opacity:.7;width:16px}.place-users-section{background:#0003;border-radius:10px;padding:12px}.place-users-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.place-users-title{color:#fffc;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.place-users-count{background:linear-gradient(135deg,#10b981,#059669);border-radius:10px;color:#fff;font-size:11px;font-weight:600;padding:2px 8px}.place-users-list{display:flex;flex-wrap:wrap;gap:8px}.place-user-avatar{object-fit:cover}.place-user-avatar,.place-user-initial{border:2px solid #10b981;border-radius:50%;height:32px;width:32px}.place-user-initial{align-items:center;color:#fff;display:flex;font-size:14px;font-weight:600;justify-content:center}.no-users-text{color:#fff6;font-size:12px;font-style:italic}.place-actions{border-top:1px solid #ffffff1a;display:flex;gap:10px;margin-top:15px;padding-top:15px}.place-action-btn{align-items:center;background:#ffffff1a;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:500;gap:6px;justify-content:center;padding:10px;transition:background .2s}.place-action-btn:hover{background:#fff3}.place-action-btn.view-map{background:linear-gradient(135deg,#3b82f6,#2563eb)}.empty-places{color:#fff9;padding:60px 20px;text-align:center}.empty-places-icon{font-size:64px;margin-bottom:20px}.empty-places h3{color:#fff;font-size:22px;margin:0 0 10px}.empty-places p{font-size:14px;margin:0 auto;max-width:300px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:20px}.modal-header h3{color:#fff;font-size:20px;margin:0}.modal-close{background:#0000;border:none;color:#ffffff80;cursor:pointer;font-size:24px;line-height:1;padding:5px}.modal-close:hover{color:#fff}.modal-body{padding:20px}.form-group label{color:#fffc;font-size:14px}.form-group input,.form-group select{background:#ffffff1a;border:1px solid #fff3;border-radius:10px;color:#fff;font-size:14px;padding:12px 15px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus{border-color:#3b82f6;outline:none}.form-group input::placeholder{color:#fff6}.icon-picker{display:flex;flex-wrap:wrap;gap:10px}.icon-option{align-items:center;background:#ffffff1a;border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;font-size:20px;height:45px;justify-content:center;transition:border-color .2s,background .2s;width:45px}.icon-option:hover{background:#fff3}.icon-option.selected{background:#3b82f633;border-color:#3b82f6}.map-picker{border-radius:15px;height:250px;margin-bottom:15px;overflow:hidden}.map-picker-help{color:#ffffff80;font-size:12px;margin-top:8px}.radius-slider{align-items:center;display:flex;gap:15px}.radius-slider input[type=range]{-webkit-appearance:none;background:#fff3;border-radius:3px;flex:1 1;height:6px;outline:none}.radius-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:#3b82f6;border-radius:50%;cursor:pointer;height:18px;width:18px}.radius-value{color:#fff;font-size:14px;font-weight:600;min-width:60px}.modal-footer{border-top:1px solid #ffffff1a;display:flex;gap:15px;padding:20px}.btn-cancel{background:#ffffff1a;border:none;border-radius:10px;color:#fff;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:12px;transition:background .2s}.btn-cancel:hover{background:#fff3}.btn-save{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:10px;color:#fff;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:12px;transition:transform .2s,box-shadow .2s}.btn-save:hover{box-shadow:0 5px 20px #3b82f666;transform:scale(1.02)}.btn-save:disabled{cursor:not-allowed;opacity:.5;transform:none}.alert-settings{background:#0003;border-radius:12px;padding:15px}.alert-option{align-items:center;display:flex;justify-content:space-between;padding:10px 0}.alert-option:not(:last-child){border-bottom:1px solid #ffffff1a}.alert-option-label{align-items:center;color:#fff;display:flex;font-size:14px;gap:10px}.alert-option-icon{font-size:18px}.toggle-switch{height:26px;position:relative;width:50px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background:#fff3;border-radius:26px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:background .3s}.toggle-slider:before{background:#fff;border-radius:50%;bottom:3px;content:"";height:20px;left:3px;position:absolute;transition:transform .3s;width:20px}.toggle-switch input:checked+.toggle-slider{background:#10b981}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(24px)}.loading-places{align-items:center;color:#fff9;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #ffffff1a;border-radius:50%;border-top-color:#3b82f6;height:40px;margin-bottom:15px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.places-container{padding:15px}.places-header{flex-wrap:wrap;gap:15px}.places-header h2{order:2;text-align:center;width:100%}.add-place-btn{justify-content:center;order:3;width:100%}.places-list{grid-template-columns:1fr}.modal-content{border-radius:0;max-height:100vh}}.App{min-height:100vh}.loading{align-items:center;color:#666;display:flex;font-size:18px;height:100vh;justify-content:center}.btn{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-size:16px;font-weight:600;padding:12px 24px;text-align:center;transition:all .3s ease}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover{background-color:#2563eb}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover{background-color:#4b5563}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover{background-color:#dc2626}.form-group{margin-bottom:20px}.form-group label{color:#374151;display:block;font-weight:500;margin-bottom:8px}.form-group input{border:1px solid #d1d5db;border-radius:8px;font-size:16px;padding:12px;transition:border-color .3s ease;width:100%}.form-group input:focus{border-color:#3b82f6;outline:none}.card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px;padding:24px}.container{margin:0 auto;max-width:1200px;padding:20px}
/*# sourceMappingURL=main.201fd919.css.map*/