.ptt-group-header{display:flex;align-items:center;gap:12px;padding:8px 16px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;border:1px solid #e5e7eb;min-width:300px;margin-right:16px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.ptt-group-header.active{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #3b82f6;color:#111827}.ptt-group-header.connecting{background:#e0f2fe;color:#1f2937}.group-icon{font-size:20px;display:flex;align-items:center;justify-content:center;min-width:24px;flex-shrink:0}.group-icon.pulse{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.group-info{flex:1;min-width:0}.group-title{font-weight:600;font-size:13px;color:#111827;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-subtitle{font-size:11px;color:#6b7280;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ptt-group-header.active .group-subtitle{color:#6b7280}.group-actions{display:flex;gap:8px;align-items:center}.group-btn{padding:6px 12px;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:36px;height:32px}.ptt-group-header.active .group-btn{background:#6b7280;color:#fff;border:none}.ptt-group-header.active .group-btn:hover:not(:disabled){background:#4b5563;transform:scale(1.05)}.ptt-group-header.active .group-btn:active{transform:scale(.95)}.ptt-group-header.active .ptt-btn{background:#6b7280;color:#fff;font-size:16px;width:40px;-webkit-user-select:none;user-select:none}.ptt-group-header.active .ptt-btn.active{background:#ef4444;box-shadow:0 0 0 3px #ef444433;animation:pttPulse .5s ease-in-out infinite}@keyframes pttPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.ptt-group-header.active .ptt-btn:hover:not(:disabled){background:#4b5563}.group-btn.leave-btn{background:#ef4444;color:#fff}.group-btn.retry-btn{background:#3b82f6;color:#fff}.group-btn.retry-btn:hover:not(:disabled){background:#2563eb}.retry-icon{animation:spin 1s linear infinite}.ptt-group-header.active .group-btn.leave-btn:hover{background:#dc2626;transform:scale(1.05)}@media (max-width: 768px){.ptt-group-header{min-width:250px;padding:6px 12px}.group-title{font-size:.75rem}.group-subtitle{font-size:.7rem}.group-btn{padding:5px 10px;font-size:.75rem}}.app-layout{display:flex;height:100vh;background-color:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.sidebar{background:#1e40af;color:#fff;transition:all .3s ease;display:flex;flex-direction:column;box-shadow:2px 0 12px #1e40af33;z-index:1000;position:relative}.sidebar.open{width:280px}.sidebar-header{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;min-height:80px}.sidebar-header h2{margin:0;font-size:20px;font-weight:700;color:#fff;transition:opacity .3s ease;white-space:nowrap}.sidebar.closed .sidebar-header h2{opacity:0;pointer-events:none}.sidebar-header-toggle{background:#ffffff1a;border:none;color:#fff;width:36px;height:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s ease}.sidebar-header-toggle:hover{background:#fff3;transform:scale(1.05)}.sidebar-nav{flex:1;padding:20px 0;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;padding:16px 20px;color:#fffc;text-decoration:none;transition:all .2s ease;border-radius:0;border:none;background:none;width:100%;cursor:pointer;font-size:14px;font-weight:500;position:relative}.nav-item:hover{background:#ffffff1a;color:#fff;transform:translate(4px)}.nav-item.active{background:#6366f133;color:#fff;border-right:3px solid #6366f1}.nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#6366f1;border-radius:0 4px 4px 0}.nav-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;margin-right:16px;flex-shrink:0}.nav-label{transition:opacity .3s ease;white-space:nowrap;overflow:hidden}.sidebar.closed .nav-label{opacity:0;pointer-events:none}.sidebar.closed .nav-item{justify-content:center;padding:16px}.sidebar.closed .nav-icon{margin-right:0}.nav-button{text-align:left;font-family:inherit}.nav-button.logout{margin-top:auto;border-top:1px solid rgba(255,255,255,.1);background:none;color:#fffc}.nav-button.logout:hover{background:#ffffff1a;color:#fff}.nav-divider{height:1px;background:#ffffff1a;margin:16px 20px}.sidebar.closed .nav-divider{margin:16px 12px}.main-content{flex:1;transition:all .3s ease;overflow-x:hidden;position:relative;display:flex;flex-direction:column;min-height:100vh}.main-content.sidebar-open,.main-content.sidebar-closed{margin-left:0}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 20px;height:60px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:100}.sidebar-toggle{background:#f8fafc;border:1px solid #e2e8f0;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:#64748b}.sidebar-toggle:hover{background:#f1f5f9;border-color:#cbd5e1;color:#1e40af;transform:scale(1.05)}.sidebar-toggle svg{width:20px;height:20px}.topbar-title{margin:0;font-size:1.3rem;font-weight:600;color:#1e293b;letter-spacing:-.025em}.topbar-user{display:flex;align-items:center;gap:12px;padding:8px 16px;border-radius:12px;background:linear-gradient(135deg,#fff,#fff);border:1px solid #e2e8f0;transition:all .2s ease;min-width:140px}.topbar-user:hover{border-color:#1e40af;box-shadow:0 4px 12px #1e40af26;transform:translateY(-1px)}.user-avatar{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:50%;color:#fff;position:relative;z-index:1;box-shadow:0 2px 8px #1e40af33}.user-avatar svg{width:18px;height:18px}.user-info{display:flex;flex-direction:column;align-items:flex-start;position:relative;z-index:1;min-width:0}.user-name{font-weight:600;color:#1e293b;font-size:.9rem;margin:0;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.user-role{font-weight:400;color:#64748b;font-size:.75rem;margin:0;line-height:1.2}.page-content{flex:1;padding:24px;overflow-y:auto}@media (max-width: 1024px){.sidebar{position:fixed;height:100vh;z-index:1001;transform:translate(-100%)}.sidebar.open{transform:translate(0);width:280px}.sidebar.closed{transform:translate(-100%);width:280px}.main-content{margin-left:0!important;width:100%}.main-content.sidebar-open:before{content:"";position:fixed;inset:0;background:#00000080;z-index:1000}}@media (max-width: 768px){.sidebar-header{padding:20px 16px}.sidebar-header h2{font-size:18px}.nav-item{padding:14px 16px}.nav-divider{margin:12px 16px}.topbar-title{font-size:1.1rem}.page-content{padding:16px}.topbar-user{min-width:auto;padding:6px 12px}.user-info{display:none}.user-avatar{width:32px;height:32px}.user-avatar svg{width:16px;height:16px}}@media (max-width: 1024px){.mobile-sidebar-toggle{position:fixed;top:20px;left:20px;z-index:1002;background:#1e293b;color:#fff;border:none;width:44px;height:44px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 4px 12px #0003;transition:all .2s ease}.mobile-sidebar-toggle:hover{background:#334155;transform:scale(1.05)}}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff80}.nav-item svg{transition:transform .2s ease}.nav-item:hover svg{transform:scale(1.1)}.nav-item:focus{outline:2px solid #6366f1;outline-offset:-2px}.sidebar-header-toggle:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.app-layout{display:flex;min-height:100vh;background-color:#f8fafc}.sidebar{width:280px;background:#f9fafb;color:#374151;display:flex;flex-direction:column;transition:all .3s ease;box-shadow:2px 0 10px #0000001a;border-right:1px solid #e5e7eb}.app-layout .sidebar .nav-item.active{background-color:#e5e7eb!important;color:#111827!important;border-left:3px solid #111827!important;border-right:none!important;border-top:none!important;border-bottom:none!important;outline:none!important;box-shadow:none!important}.app-layout .sidebar .nav-item.active:before{display:none!important}.app-layout .sidebar .nav-item.active:after{display:none!important}.app-layout .sidebar .nav-item,.app-layout .sidebar .nav-item:hover{border-right:none!important;border-top:none!important;border-bottom:none!important;outline:none!important;box-shadow:none!important}.sidebar.closed{width:80px}.sidebar-header{padding:24px 20px;border-bottom:1px solid #e5e7eb}.sidebar-brand{display:flex;align-items:center;gap:12px}.sidebar-logo{width:72px;height:72px;object-fit:contain;flex-shrink:0}.sidebar.closed .sidebar-logo{width:56px;height:56px}.sidebar-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#111827;white-space:nowrap}.sidebar.closed .sidebar-header h2{display:none}.sidebar-nav{flex:1;padding:20px 0}.nav-item{display:flex;align-items:center;padding:12px 20px;color:#6b7280!important;text-decoration:none;transition:all .3s ease;border-left:3px solid transparent!important;margin:4px 8px;border-radius:8px}.nav-item:hover{background-color:#f3f4f6!important;color:#374151!important;border-left-color:#d1d5db!important}.nav-item.active{background-color:#e5e7eb!important;color:#111827!important;border-left-color:#111827!important;border-right:none!important}.nav-item.active:before{display:none!important}.nav-icon{margin-right:12px;display:flex;align-items:center}.nav-label{font-weight:500;white-space:nowrap}.sidebar.closed .nav-label{display:none}.sidebar-footer{padding:20px;border-top:1px solid #e5e7eb}.logout-button{display:flex;align-items:center;width:100%;padding:12px 0;background:none;border:none;color:#6b7280;cursor:pointer;transition:all .3s ease;font-size:1rem}.logout-button:hover{color:#374151}.main-content{flex:1;display:flex;flex-direction:column}.impersonation-banner{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:12px 24px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000001a;z-index:1000}.impersonation-content{max-width:1400px;width:100%;display:flex;align-items:center;gap:12px;font-size:14px}.impersonation-content svg{flex-shrink:0}.impersonation-content span{flex:1}.exit-impersonation-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:6px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.exit-impersonation-button:hover{background:#ffffff4d;border-color:#ffffff80}.topbar{background:#fff;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;border-bottom:1px solid #e2e8f0}.topbar-left{display:flex;align-items:center;gap:16px}.sidebar-toggle{background:none;border:none;color:#64748b;cursor:pointer;padding:8px;border-radius:6px;transition:all .3s ease}.sidebar-toggle:hover{background-color:#f1f5f9;color:#475569}.page-title{margin:0;font-size:1.5rem;font-weight:600;color:#1e293b}.topbar-right{display:flex;align-items:center}.user-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.user-name{font-weight:600;color:#1e293b;font-size:.9rem}.user-role{font-size:.75rem;color:#64748b;background-color:#f1f5f9;padding:2px 8px;border-radius:12px}.page-content{flex:1;padding:24px;background-color:#f8fafc}@media (max-width: 768px){.sidebar{position:fixed;left:0;top:0;height:100vh;z-index:1000;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.page-title{font-size:1.25rem}.user-info{display:none}}.sidebar{transition:transform .3s ease,width .3s ease}.user-list-page{padding:24px;max-width:1400px;margin:0 auto;background:#f8fafc;min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding:32px;background:#fff;border-radius:20px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e2e8f0}.header-content h1{margin:0 0 8px;color:#1e293b;font-size:2.25rem;font-weight:800;line-height:1.2;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:#64748b;font-size:1.125rem;margin:0;font-weight:400}.btn-add{display:flex;align-items:center;gap:8px;padding:14px 28px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 14px #667eea66}.btn-add:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea80}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px 16px;background:#f8fafc;border-radius:8px;transition:all .2s ease}.stat-item:hover{background:#f1f5f9;transform:translateY(-1px)}.users-table th,.users-table td{padding:16px;text-align:left;border-bottom:1px solid #f3f4f6}.users-table td:first-child{min-width:200px;max-width:400px;word-wrap:break-word;white-space:normal}.users-table th:first-child{min-width:200px;max-width:400px}.users-table th{background-color:#f9fafb;font-weight:600;color:#374151;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.users-table td:last-child,.users-table th:last-child{text-align:right}.users-table tr:last-child td{border-bottom:none}.users-table tbody tr:nth-child(2n) td{background-color:#f9fafb}.users-table tbody tr:hover td{background-color:#f3f4f6}.priority-badge,.user-type-badge{display:inline-block;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background-color:#f3f4f6;color:#374151}.company-badge{display:inline-block;padding:4px 8px;background-color:#374151;color:#fff;border-radius:6px;font-size:12px;font-weight:600}.no-company{display:inline-block;padding:4px 8px;background-color:#f3f4f6;color:#6b7280;border-radius:6px;font-size:12px;font-weight:600}.status-badge{display:inline-block;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background-color:#374151;color:#fff}.status-badge.inactive{background-color:#f3f4f6;color:#6b7280}.table-actions{display:flex;gap:8px;justify-content:flex-end}.user-name{word-wrap:break-word;white-space:normal;overflow-wrap:break-word;max-width:none;font-size:14px;font-weight:600;color:#111827}.btn-icon{padding:8px;border:none;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6;color:#374151}.btn-icon.btn-secondary,.btn-icon.btn-info,.btn-icon.btn-danger{background-color:#f3f4f6;color:#374151}.loading-container p{margin:0;font-size:14px}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:#fff;border-radius:12px;padding:0;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group input[type=number],.form-group select{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-group input::placeholder{color:#9ca3af}.disabled-input{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.btn{padding:12px 20px;border:none;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.btn-primary{background-color:#6366f1;color:#fff}.error-message{background-color:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;border:1px solid #fecaca;font-size:14px}@media (max-width: 768px){.user-list-page{padding:16px}.page-header{flex-direction:column;gap:16px;padding:24px}.header-content h1{font-size:1.875rem}.search-container{flex-direction:column;gap:16px;padding:20px}.search-input-wrapper{max-width:none}.user-stats{justify-content:center}.user-list-item{flex-direction:column;gap:12px}.user-list-info{text-align:center}.user-list-details{flex-direction:column;gap:8px;text-align:center}.user-list-status,.user-list-actions{justify-content:center}.form-row{grid-template-columns:1fr}.modal{width:95%;margin:20px}.modal-header,.modal form{padding:20px}}@media (max-width: 480px){.user-list-item{padding:16px}.user-list-status,.user-list-actions{flex-direction:column;gap:8px}}@media (max-width: 1024px){.users-table{font-size:12px}.table-header,.table-cell{padding:8px}.user-avatar{width:32px;height:32px}.avatar-text{font-size:12px}.user-name{font-size:14px;word-wrap:break-word;white-space:normal;overflow-wrap:break-word}.user-email{font-size:12px}.table-actions{gap:4px}.btn-icon{padding:6px}.btn-icon svg{width:14px;height:14px}}@media (max-width: 768px){.users-table-container{overflow-x:auto}.users-table{min-width:600px}.table-header,.table-cell{padding:12px 8px}.user-cell{min-width:120px}.actions-cell{min-width:100px}.user-info{flex-direction:column}.user-avatar{margin-bottom:8px}.avatar-text{font-size:10px}.table-actions{flex-direction:column;gap:4px}.btn-icon{padding:8px}.btn-icon svg{width:16px;height:16px}}@media (max-width: 480px){.users-table{min-width:400px}.table-header,.table-cell{padding:8px 4px}.user-cell,.actions-cell{min-width:80px}.user-info{flex-direction:column}.user-avatar{margin-bottom:4px}.avatar-text{font-size:8px}.user-name{font-size:12px;word-wrap:break-word;white-space:normal;overflow-wrap:break-word}.user-email{font-size:10px}.table-actions{flex-direction:column;gap:2px}.btn-icon{padding:6px}.btn-icon svg{width:12px;height:12px}}@media (max-width: 768px){.users-table th,.users-table td{padding:8px}.btn-icon{padding:6px}.btn-icon svg{width:14px;height:14px}}.add-user-bar{display:flex;align-items:center;gap:12px}.add-user-icon-wrapper{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 4px 14px #667eea66}.add-user-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 14px #667eea66}.add-user-btn .btn-icon.add-user-plus{width:20px;height:20px;color:#fff}.add-user-btn .add-user-text{font-size:14px;font-weight:600;color:#fff}.add-user-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea80}.add-user-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;opacity:0;transition:opacity .3s ease;z-index:-1}.btn-add,.page-header,.header-content,.subtitle{display:none}.user-groups-page{padding:20px;background-color:#fff}.user-groups-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #808080}.user-groups-page .page-header h1{margin:0 0 8px;color:#000;font-size:2rem;font-weight:700}.user-info{margin:0;color:gray;font-size:14px;line-height:1.5}.groups-section{margin-bottom:40px}.groups-section h2{margin-bottom:20px;color:#000;font-size:1.5rem;font-weight:600}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.group-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 4px #0000001a;border:1px solid #808080;transition:all .2s}.group-card:hover{transform:translateY(-2px)!important;box-shadow:0 8px 25px #0000004d!important;border-color:gray!important}.group-card:hover:before{opacity:0!important;background:none!important}.group-card h3{margin:0 0 12px;color:#000;font-size:1.25rem;font-weight:600}.group-card p{margin:0 0 20px;color:gray;font-size:14px;line-height:1.5}.already-member{display:inline-block;padding:8px 16px;background-color:#f0f0f0;color:gray;border-radius:8px;font-size:12px;font-weight:500}.no-groups{color:gray;font-style:italic;text-align:center;padding:40px;background:#f8f8f8;border-radius:12px;border:2px dashed #808080}.loading{text-align:center;padding:60px 20px;color:gray;font-size:16px}.error-message{background-color:#f8f8f8;color:#000;padding:16px;border-radius:8px;margin-bottom:20px;border:1px solid #808080;font-size:14px}.user-groups-page .btn-danger{background-color:gray!important;color:#fff!important;border:1px solid #808080!important}.user-groups-page .btn-danger:hover{background-color:#666!important;border-color:#666!important}.user-groups-page .btn-primary{background-color:gray!important;color:#fff!important;border:1px solid #808080!important}.user-groups-page .btn-primary:hover{background-color:#666!important;border-color:#666!important}.user-groups-page .btn-secondary{background-color:#000!important;color:#fff!important;border:1px solid black!important}.user-groups-page .btn-secondary:hover{background-color:#333!important;border-color:#333!important}@media (max-width: 768px){.user-groups-page{padding:16px}.user-groups-page .page-header{flex-direction:column;gap:16px;align-items:flex-start}.groups-grid{grid-template-columns:1fr;gap:16px}.group-card{padding:20px}}.draggable-item{cursor:grab;transition:all .2s ease}.draggable-item:active{cursor:grabbing}.draggable-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.drop-zone{background-color:#f8f8f8;border:2px dashed #808080;border-radius:12px;padding:20px;margin:10px 0}.device-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.drag-handle{color:gray;cursor:grab;padding:4px;border-radius:4px;transition:all .2s ease}.drag-handle:hover{background-color:#f0f0f0;color:#000}.drag-handle:active{cursor:grabbing}.device-title{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.gps-badge{background:#e8f5e8;color:#388e3c}.mobile_app-badge{background:#fff3e0;color:#f57c00}.device-details{margin:12px 0}.device-info-grid{display:grid;gap:8px}.device-info-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid #f0f0f0}.device-info-item:last-child{border-bottom:none}.info-label{font-weight:500;color:#666;font-size:14px}.info-value{font-weight:600;color:#333;font-size:14px;text-align:right;max-width:60%;word-break:break-all}.group-card{min-height:200px;display:flex;flex-direction:column}.device-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.device-actions{margin-top:auto;padding-top:12px}.group-list-page{padding:24px;max-width:1400px;margin:0 auto;min-height:calc(100vh - 48px);background-color:#f8f9fa}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb;margin:20px 0}.loading-content{text-align:center}.loading-text{color:#374151;font-size:14px;margin:0}.search-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:24px 32px;background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb;gap:24px}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#94a3b8}.search-input{width:100%;padding:12px 16px 12px 48px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background-color:#fff;transition:border-color .2s}.user-stats{display:flex;align-items:center;gap:20px}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px 16px;background:#f9fafb;border-radius:8px;transition:all .2s ease;border:1px solid #e5e7eb}.stat-item:hover{background:#f3f4f6;transform:translateY(-1px);border-color:#d1d5db}.stat-label{font-size:12px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.add-user-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#000;border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 14px #0003;text-decoration:none}.add-user-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000004d;background:#1a1a1a}.btn-icon.add-user-plus{width:20px;height:20px;color:#fff;stroke:#fff}.add-user-text{font-size:14px;font-weight:600;color:#fff}.error-message{background-color:#fef2f2;color:#dc2626;padding:16px 20px;border-radius:12px;margin-bottom:24px;border:1px solid #fecaca;font-size:14px;display:flex;align-items:center;gap:12px;box-shadow:0 1px 3px #0000001a}.error-icon{font-size:20px}.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb}.empty-state-icon{margin:0 auto 20px;color:#9ca3af}.empty-state-title{margin:0 0 8px;color:#111827;font-size:18px;font-weight:600}.empty-state-description{margin:0 0 20px;color:#374151;font-size:14px}.primary-button{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background-color:#000;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.primary-button:hover{background-color:#1a1a1a;transform:translateY(-1px)}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px;margin-top:24px;max-width:100%}.group-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb;transition:all .3s ease;width:100%}.group-card:hover{transform:translateY(-2px);box-shadow:0 10px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border-color:#d1d5db}.group-card-icon svg{color:#fff!important;stroke:#fff!important}.group-card-info{flex:1}.group-card-title{margin:0 0 4px;font-size:18px;font-weight:600;color:#111827;line-height:1.2}.group-card-status{display:inline-block;padding:4px 8px;background-color:#f3f4f6;color:#374151;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border:1px solid #e5e7eb}.group-card-description{color:#374151;font-size:14px;line-height:1.5;margin:0 0 20px}.group-card-actions{display:flex;gap:12px;justify-content:flex-end}.join-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:#000;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.join-button:hover{background-color:#1a1a1a;transform:translateY(-1px)}.join-button svg{width:16px;height:16px;color:#fff!important;stroke:#fff!important}@media (max-width: 768px){.group-list-page{padding:16px}.search-container{flex-direction:column;gap:16px;padding:20px}.search-input-wrapper{max-width:none}.user-stats{justify-content:center}.groups-grid{grid-template-columns:1fr;gap:16px}.group-card{padding:20px}.group-card-header{flex-direction:column;align-items:center;text-align:center}.group-card-actions{justify-content:center}}@media (max-width: 480px){.group-card{padding:16px}.group-card-icon{width:40px;height:40px}.group-card-title{font-size:16px}}.group-card-header{display:flex;justify-content:space-between;align-items:center}.group-card-left{display:flex;align-items:center;gap:12px}.group-card-actions{display:flex;gap:8px;align-items:center}.group-card-actions .icon-button{background:transparent;border:none;cursor:pointer;color:#374151;padding:6px;border-radius:4px;transition:color .2s ease}.group-card-actions .icon-button:hover{color:#111827;background:transparent}.company-list-page{padding:24px;max-width:1400px;margin:0 auto;min-height:calc(100vh - 48px)}.search-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.company-stats{display:flex;align-items:center;gap:20px}.add-company-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;background-color:#000;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background-color .2s}.add-company-btn:hover{background-color:#333}.btn-icon{width:20px;height:20px}.companies-table-container{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid #e2e8f0;overflow:hidden}.companies-table{width:100%;border-collapse:collapse;font-size:14px}.companies-table th{background-color:#f8fafc;padding:16px 20px;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.companies-table td{padding:16px 20px;border-bottom:1px solid #f3f4f6;color:#1f2937;vertical-align:middle}.companies-table tr:hover{background-color:#f9fafb}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px;border-radius:8px;margin-bottom:16px;font-size:14px;display:flex;align-items:center;gap:8px}.error-message:before{content:"⚠️";font-size:16px}.modal{background:#fff;border-radius:12px;padding:0;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a;display:flex;flex-direction:column}.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-hint{display:block;margin-top:6px;font-size:12px;color:#6b7280;font-style:italic}.limits-list-container{margin-top:16px;padding:16px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;max-height:300px;overflow-y:auto}.limits-list-label{display:block;font-weight:600;font-size:14px;color:#374151;margin-bottom:12px}.limits-count-info{font-weight:400;color:#6b7280;font-size:13px}.limits-list-loading,.limits-list-empty{text-align:center;padding:20px;color:#6b7280;font-size:14px}.limits-list{display:flex;flex-direction:column;gap:8px}.limits-list-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#fff;border-radius:6px;border:1px solid #e5e7eb;transition:all .2s ease}.limits-list-item:hover{border-color:#d1d5db;box-shadow:0 1px 3px #0000001a}.limits-item-info{display:flex;flex-direction:column;gap:4px;flex:1}.limits-item-name{font-weight:500;font-size:14px;color:#1f2937}.limits-item-details{font-size:12px;color:#6b7280}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;margin-left:12px}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.3s;border-radius:24px}.btn-primary{background-color:#6366f1;color:#fff;padding:12px 20px;font-weight:600}.btn-primary:hover{background-color:#5855eb}.company-details-page{min-height:100vh;background:#fff}.page-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:24px 0;position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.header-info{display:flex;flex-direction:column;gap:8px}.back-button{display:inline-flex;align-items:center;gap:8px;background:none;border:none;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;padding:4px 0;transition:color .2s ease}.back-button:hover{color:#374151}.impersonate-button{display:inline-flex;align-items:center;gap:8px;background:#3b82f6;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.impersonate-button:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 6px #3b82f64d}.impersonate-button svg{width:18px;height:18px}.page-title{font-size:32px;font-weight:700;color:#000;margin:0}.page-subtitle{font-size:14px;color:#6b7280;margin:0;font-weight:500}.header-actions{display:flex;gap:12px}.page-content{max-width:1400px;margin:0 auto;padding:32px 24px;width:100%}.stats-section{margin-bottom:40px}.section-title{font-size:24px;font-weight:600;color:#000;margin:0 0 24px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}.stat-card{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a;border:1px solid #e5e7eb;transition:all .3s ease;position:relative;overflow:hidden}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-card-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.stat-icon-wrapper{width:56px;height:56px;border-radius:8px;background:#000;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000001a;flex-shrink:0}.stat-icon-wrapper svg{color:#fff}.stat-info{flex:1}.stat-count{font-size:36px;font-weight:700;color:#1f2937;line-height:1;margin-bottom:4px}.stat-label{font-size:16px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.stat-card-footer{border-top:1px solid #f3f4f6;padding-top:16px}.manage-button{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;color:#000;font-weight:600;font-size:14px;cursor:pointer;padding:8px 0;transition:all .2s ease}.manage-button:hover{color:#666;transform:translate(4px)}.additional-sections{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.subscription-card,.transactions-card{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a;border:1px solid #e5e7eb;transition:all .3s ease;min-height:200px;display:flex;flex-direction:column}.subscription-card:hover,.transactions-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.subscription-header,.transactions-header{margin-bottom:24px}.subscription-info,.transactions-info{width:100%}.subscription-title,.transactions-title{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 8px}.subscription-details{display:flex;align-items:center;gap:12px;margin-bottom:8px}.subscription-status{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.subscription-status.active{background:#dcfce7;color:#166534}.subscription-status.inactive{background:#fee2e2;color:#dc2626}.subscription-plan{font-size:14px;font-weight:600;color:#6b7280;background:#f3f4f6;padding:4px 12px;border-radius:12px}.subscription-expiry{font-size:14px;color:#6b7280;margin:0}.transactions-description{font-size:14px;color:#6b7280;margin:0;line-height:1.5}.subscription-actions,.transactions-actions{border-top:1px solid #f3f4f6;padding-top:16px;margin-top:auto}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;text-decoration:none}.btn-primary{background:#000;color:#fff;box-shadow:0 2px 4px #0000001a}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0003}.btn-secondary{background:#f8fafc;color:#64748b;border:1px solid #e2e8f0}.btn-secondary:hover{background:#f1f5f9;color:#475569}.btn-outline{background:transparent;color:#000;border:1px solid #000000}.btn-white{background:#fff;color:#000;border:1px solid #e5e7eb;box-shadow:0 2px 4px #0000001a}.btn-white:hover{background:#000;color:#fff;border:1px solid #000000;box-shadow:0 4px 8px #00000026}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.header-content{flex-direction:column;align-items:flex-start;gap:16px}.page-content{padding:24px 16px}.stats-grid,.additional-sections{grid-template-columns:1fr}.page-title{font-size:24px}.stat-count{font-size:28px}}@media (min-width: 1400px){.stats-grid{grid-template-columns:repeat(5,1fr)}}.device-list-page{padding:24px;max-width:1400px;margin:0 auto;min-height:calc(100vh - 48px)}.device-stats{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.add-device-btn{display:flex;align-items:center;justify-content:center;padding:12px 20px;background-color:#000;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background-color .2s}.add-device-btn:hover{background-color:#374151}.devices-table-container{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid #e2e8f0;overflow:hidden}.devices-table th{background-color:#f8fafc;padding:16px 20px;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.devices-table td{padding:16px 20px;border-bottom:1px solid #f3f4f6;color:#1f2937;vertical-align:middle}.devices-table tr:hover{background-color:#f9fafb}.device-type-badge{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.device-type-ptt,.device-type-gps,.device-type-mobile{color:#374151}.devices-table .btn-outline{background-color:#f3f4f6!important;color:#4b5563!important;border:1px solid #d1d5db!important;padding:8px 16px;font-weight:500}.devices-table .btn-outline:hover{background-color:#e5e7eb!important;color:#374151!important}.devices-table .btn-danger{background-color:#d1d5db!important;color:#4b5563!important;border:1px solid #9ca3af!important}.devices-table .btn-danger:hover{background-color:#9ca3af!important;color:#374151!important}.btn-icon{width:16px;height:16px}.btn-icon:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-icon svg{width:16px;height:16px}.form-group textarea{resize:vertical;min-height:80px}.admin-dashboard{padding:24px;background-color:#f9fafb;min-height:100vh}.dashboard-header-card{background:#fff;border-radius:12px;padding:24px;margin-bottom:32px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb}.dashboard-header-card h1{font-size:28px;font-weight:700;color:#1f2937;margin:0}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #000000;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.loading-container p{color:#6b7280;font-size:16px;margin:0}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.error-message{color:#dc2626;font-size:16px;margin-bottom:16px}.retry-button{background-color:#000;color:#fff;border:none;padding:8px 16px;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s}.retry-button:hover{background-color:#374151}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:24px}.stat-card{background-color:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;transition:transform .2s,box-shadow .2s;display:flex;align-items:center;gap:16px}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.stat-card.white{background-color:#fff}.stat-icon{width:48px;height:48px;border-radius:12px;background-color:#f3f4f6;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon svg{width:24px;height:24px;color:#000}.stat-icon.online svg{color:#059669}.stat-icon.offline svg{color:#dc2626}.stat-content{flex:1;min-width:0}.stat-number{font-size:32px;font-weight:700;color:#1f2937;line-height:1;margin-bottom:4px}.stat-label{font-size:14px;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.05em}@media (max-width: 768px){.admin-dashboard{padding:16px}.stats-grid{grid-template-columns:1fr;gap:16px}.stat-card{padding:20px}.stat-number{font-size:28px}.dashboard-header h1{font-size:24px}}@media (max-width: 480px){.stat-card{flex-direction:column;text-align:center;gap:12px}.stat-icon{width:40px;height:40px}.stat-icon svg{width:20px;height:20px}}.app-version-list-page{padding:24px;max-width:1400px;margin:0 auto}.btn-primary{background-color:#3b82f6;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:#2563eb}.quick-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000001a}.stat-label{font-size:14px;color:#6b7280;margin-bottom:8px}.stat-value{font-size:24px;font-weight:600;color:#1f2937}.versions-table-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.versions-table{width:100%;border-collapse:collapse}.versions-table thead{background-color:#f9fafb}.versions-table th{padding:12px 16px;text-align:left;font-size:14px;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.versions-table td{padding:12px 16px;border-bottom:1px solid #e5e7eb;font-size:14px;color:#1f2937}.versions-table tbody tr:hover{background-color:#f9fafb}.versions-table tbody tr:last-child td{border-bottom:none}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#d1d5db;transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#10b981}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.table-actions{display:flex;gap:8px}.versions-table .btn-outline{background-color:#f3f4f6!important;color:#4b5563!important;border:1px solid #d1d5db!important;padding:8px 16px;font-weight:500}.versions-table .btn-outline:hover{background-color:#e5e7eb!important;color:#374151!important}.versions-table .btn-danger{background-color:#d1d5db!important;color:#4b5563!important;border:1px solid #9ca3af!important}.versions-table .btn-danger:hover{background-color:#9ca3af!important;color:#374151!important}.empty-state{text-align:center;padding:40px;color:#6b7280}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:12px 16px;border-radius:6px;margin-bottom:24px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{margin-top:16px;color:#6b7280}.analytics-container{display:flex;flex-direction:column;gap:32px}.analytics-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a}.analytics-section h2{margin:0 0 20px;font-size:20px;font-weight:600;color:#1f2937}.list-container{margin-top:16px}.version-list{list-style:none;padding:0;margin:0}.version-list-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #e5e7eb}.version-list-item:last-child{border-bottom:none}.rank{font-weight:600;color:#6b7280;min-width:24px}.version-name{font-weight:500;color:#1f2937;flex:1}.download-count,.upload-time{color:#6b7280;font-size:14px}.stat-subtext{font-size:12px;color:#6b7280;margin-top:4px}.app-version-upload-page{padding:24px;max-width:800px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-header h1{margin:0;font-size:28px;font-weight:600;color:#1f2937}.btn-secondary{background-color:#6b7280;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background-color:#4b5563}.info-box{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:12px 16px;margin-bottom:24px;color:#1e40af;font-size:14px}.upload-form{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:32px;box-shadow:0 1px 3px #0000001a}.form-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.form-group label small{font-weight:400;color:#6b7280;margin-left:4px}.required{color:#ef4444}.form-group input[type=text],.form-group input[type=number],.form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{font-family:inherit;resize:vertical}.form-hint{display:block;margin-top:6px;font-size:12px;color:#6b7280}.radio-models-list{display:flex;flex-direction:column;gap:12px}.radio-model-row{display:flex;gap:8px;align-items:center}.radio-model-input{flex:1;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s}.radio-model-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-remove-row{padding:10px 16px;background-color:#ef4444;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-remove-row:hover{background-color:#dc2626}.btn-add-row{padding:10px 16px;background-color:#f3f4f6;color:#4b5563;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;align-self:flex-start}.btn-add-row:hover{background-color:#e5e7eb;color:#374151}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;margin:0;flex-shrink:0;vertical-align:middle}.checkbox-label span{display:inline-block;vertical-align:middle;line-height:1.2}.file-upload-area{border:2px dashed #d1d5db;border-radius:6px;padding:24px;text-align:center;transition:border-color .2s}.file-upload-area:hover{border-color:#3b82f6}.file-upload-area input[type=file]{width:100%;padding:8px;cursor:pointer}.file-info{margin-top:12px;padding:12px;background-color:#f0f9ff;border-radius:6px;display:flex;justify-content:space-between;align-items:center}.file-size{color:#6b7280;font-size:13px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.btn-cancel{padding:10px 20px;background-color:#fff;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel:hover{background-color:#f9fafb}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-submit{padding:10px 20px;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-submit:hover:not(:disabled){background-color:#2563eb}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:12px 16px;border-radius:6px;margin-bottom:24px;font-size:14px}.upload-progress-container{margin-bottom:24px;padding:16px;background-color:#f0f9ff;border:1px solid #bae6fd;border-radius:6px}.upload-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px;font-weight:500;color:#0369a1}.upload-stats{font-size:13px;color:#0284c7;font-weight:400}.upload-progress-bar{width:100%;height:8px;background-color:#e0f2fe;border-radius:4px;overflow:hidden}.upload-progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#2563eb);transition:width .3s ease;border-radius:4px}.user-list-page{padding:24px;max-width:1400px;margin:0 auto;min-height:calc(100vh - 48px)}.search-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:24px 32px;background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid #e2e8f0;gap:24px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#6b7280}.search-input{width:100%;padding:12px 12px 12px 40px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background-color:#fff;transition:border-color .2s}.user-stats{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.btn.add-user-btn{display:flex;align-items:center;justify-content:center;padding:12px 20px;background-color:#000!important;color:#fff!important;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn.add-user-btn:hover{background-color:#374151!important}.company-add-user-button{display:flex;align-items:center;justify-content:center;padding:12px 20px;background-color:#000;background:#000;color:#fff;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:background-color .2s;text-decoration:none}.company-add-user-button:hover{background-color:#374151;background:#374151;color:#fff}.company-add-user-button:focus{outline:none;box-shadow:0 0 0 3px #0000001a}.users-table-container{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid #e2e8f0;overflow:hidden}.users-table{width:100%;border-collapse:collapse;font-size:14px}.users-table th{background-color:#f8fafc;padding:16px 20px;text-align:left!important;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.users-table th:nth-child(5){text-align:center!important}.users-table td{padding:16px 20px;border-bottom:1px solid #f3f4f6;color:#1f2937;vertical-align:middle;text-align:left!important}.users-table td:nth-child(5){text-align:center!important}.users-table tr:hover{background-color:#f9fafb}.priority-badge,.user-type-badge,.status-badge,.role-badge{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:4px 8px;border-radius:6px;display:inline-block}.status-badge.active{background-color:#fff;color:#374151;border:1px solid #d1d5db}.status-badge.inactive{background-color:#000;color:#fff;border:1px solid #000000}.role-badge{background-color:#f3f4f6;color:#374151;border:1px solid #d1d5db}.table-actions{display:flex;gap:8px;justify-content:center}.btn{padding:8px;border:none;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-secondary{background-color:#f3f4f6;color:#374151}.users-table .btn-outline{background-color:#f3f4f6!important;color:#4b5563!important;border:1px solid #d1d5db!important;padding:8px 16px;font-weight:500}.users-table .btn-outline:hover{background-color:#e5e7eb!important;color:#374151!important}.users-table .btn-danger{background-color:#d1d5db!important;color:#4b5563!important;border:1px solid #9ca3af!important}.users-table .btn-danger:hover{background-color:#9ca3af!important;color:#374151!important}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:12px;padding:0;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:18px;color:#1f2937}.modal-close{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;color:#6b7280;transition:background-color .2s}.modal-close:hover{background-color:#f3f4f6}.modal-close svg{width:20px;height:20px}.modal form{padding:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:14px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#000;box-shadow:0 0 0 3px #0000001a}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;font-size:14px}.checkbox-label input[type=checkbox]{width:16px;height:16px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.modal .btn-primary{background-color:#000!important;color:#fff!important;padding:12px 20px;font-weight:600}.modal .btn-primary:hover{background-color:#374151!important}.btn-secondary{background-color:#f3f4f6;color:#374151;padding:12px 20px;font-weight:600}.btn-secondary:hover{background-color:#e5e7eb}@media (max-width: 768px){.user-list-page{padding:16px}.search-container{flex-direction:column;align-items:stretch;gap:16px}.search-input-wrapper{max-width:none}.user-stats{justify-content:space-around;gap:12px;flex-wrap:wrap}.stat-number{font-size:20px}.stat-label{font-size:11px}.users-table-container{overflow-x:auto}.users-table{min-width:700px;font-size:13px}.users-table th,.users-table td{padding:12px 8px}.form-row{grid-template-columns:1fr}}.form-card{display:block;background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid #e2e8f0;padding:24px 32px;margin-top:24px;width:100%!important;max-width:none!important;box-sizing:border-box;margin-left:0;margin-right:0;flex:none}.form-card form{width:100%;max-width:none}.form-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #f3f4f6}.form-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .5rem}.form-subtitle{font-size:1rem;color:#6b7280;margin:0}.form-section{margin-bottom:2rem;width:100%}.section-title{font-size:1.125rem;font-weight:600;color:#374151;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #f3f4f6}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;width:100%}.form-group{margin-bottom:1.5rem;width:100%}.form-label{display:block;font-weight:500;color:#374151;margin-bottom:.5rem;font-size:.875rem}.form-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:border-color .2s;background:#fff}.form-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-input::placeholder{color:#9ca3af}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:#374151}.checkbox-label input[type=checkbox]{width:1rem;height:1rem;accent-color:#6366f1}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1rem;border-top:1px solid #f3f4f6;width:100%}.cancel-button{padding:.75rem 1.5rem;border:1px solid #d1d5db;border-radius:.375rem;background:#fff;color:#374151;text-decoration:none;font-size:.875rem;font-weight:500;transition:all .2s}.primary-button{padding:.75rem 1.5rem;background:#000!important;color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.primary-button:hover:not(:disabled){background:#1a1a1a!important}.primary-button:disabled{opacity:.6;cursor:not-allowed}.permissions-container{max-height:none;overflow:visible}.permissions-list{max-height:none;overflow:visible;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;background:#fff;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.permission-module{margin-bottom:0;border:1px solid #e2e8f0;border-radius:.5rem;padding:1rem;background:#f8fafc}.permission-module:last-child{margin-bottom:0}.module-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #f3f4f6}.module-title{font-size:1rem;font-weight:600;color:#374151;margin:0}.module-actions{display:flex;gap:.5rem}.select-all-btn,.deselect-all-btn{padding:.25rem .5rem;font-size:.75rem;border:1px solid #d1d5db;border-radius:.25rem;background:#fff;color:#374151;cursor:pointer;transition:all .2s}.select-all-btn:hover,.deselect-all-btn:hover{background:#f9fafb;border-color:#9ca3af}.permission-items{display:flex;flex-direction:column;gap:.5rem}.permission-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border:1px solid #f3f4f6;border-radius:.375rem;cursor:pointer;transition:all .2s;background:#fff}.permission-item:hover{background:#f9fafb;border-color:#d1d5db}.permission-item input[type=checkbox]{margin-top:.125rem;width:1rem;height:1rem;accent-color:#6366f1}.permission-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.permission-name{font-weight:500;color:#111827;font-size:.875rem}.permission-description{font-size:.75rem;color:#6b7280;line-height:1.4}@media (max-width: 768px){.form-row{grid-template-columns:1fr;gap:1rem}.form-card{padding:1.5rem}.permissions-container{padding:1rem}.module-header{flex-direction:column;align-items:flex-start;gap:.5rem}.module-actions{width:100%;justify-content:flex-end}}.permissions-display{max-width:300px}.permissions-list{display:flex;flex-wrap:wrap;gap:.25rem}.permission-tag{display:inline-block;padding:4px 8px;background:#f3f4f6;color:#374151;border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap}.more-permissions{font-size:12px;color:#6366f1;font-weight:600;padding:4px 8px}.no-permissions{font-size:12px;color:#9ca3af;font-style:italic}.no-description{color:#9ca3af;font-style:italic}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:1rem;border-radius:.375rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.error-icon{font-size:1.125rem}.devices-page{padding:24px;background:#f8fafc;min-height:100vh}.search-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:20px}.search-input-wrapper{position:relative;flex:1;max-width:400px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#9ca3af}.search-input{width:100%;padding:12px 12px 12px 44px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.search-input:focus{outline:none;border-color:#000;box-shadow:0 0 0 3px #0000001a}.search-input::placeholder{color:#9ca3af}.device-stats{display:flex;gap:20px;align-items:center;flex-wrap:wrap}.stat-number{font-size:24px;font-weight:700;color:#1f2937;line-height:1}.stat-label{font-size:12px;color:#6b7280;text-transform:uppercase;font-weight:500;letter-spacing:.5px}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.devices-container{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;text-align:center}.empty-icon{color:#9ca3af;margin-bottom:24px}.empty-state h3{font-size:20px;font-weight:600;color:#374151;margin:0 0 8px}.empty-state p{color:#6b7280;font-size:16px;margin:0 0 16px}.devices-table-container{overflow-x:auto;padding:0}.devices-table{width:100%;border-collapse:collapse;font-size:14px}.devices-table thead{background:#f3f4f6}.devices-table th{padding:16px 12px;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb;white-space:nowrap}.devices-table td{padding:16px 12px;border-bottom:1px solid #f3f4f6;vertical-align:middle}.device-row{transition:background-color .2s ease}.device-row:hover{background:#f3f4f6}.device-type{color:#374151;font-weight:500;text-transform:uppercase;font-size:13px}.device-model{font-weight:600;color:#1f2937}.device-imei,.device-sim{font-family:Monaco,Menlo,Ubuntu Mono,monospace;color:#6b7280;font-size:13px}.created-date{color:#6b7280;font-size:13px}.device-actions{display:flex;gap:8px;justify-content:flex-start}.btn{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;min-height:36px}.btn-primary{background:#000;color:#fff}.btn-primary:hover{background:#374151}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover{background:#e5e7eb}.btn-outline{background:transparent;color:#000;border:1px solid #000000;font-weight:500}.btn-outline:hover{background:#000;color:#fff}.btn-sm{padding:6px 12px;font-size:12px;min-height:32px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;margin-bottom:24px}.modal-header h2{font-size:24px;font-weight:700;color:#1f2937;margin:0}.modal-close{background:none;border:none;cursor:pointer;padding:8px;border-radius:6px;color:#6b7280;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#374151}.modal-form{padding:0 24px 24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:500;color:#374151;margin-bottom:6px;font-size:14px}.form-input,.form-select{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s ease;background:#fff}.form-input:focus,.form-select:focus{outline:none;border-color:#000;box-shadow:0 0 0 3px #0000001a}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.error-message{background:#fef2f2;color:#dc2626;padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px;border:1px solid #fecaca}@media (max-width: 768px){.devices-page{padding:16px}.search-container{flex-direction:column;align-items:stretch;gap:16px}.search-input-wrapper{max-width:none}.device-stats{justify-content:space-around;gap:12px;flex-wrap:wrap}.stat-number{font-size:20px}.stat-label{font-size:11px}.devices-container{border-radius:8px}.devices-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.devices-table{min-width:700px;font-size:13px}.devices-table th,.devices-table td{padding:12px 8px}.modal{margin:20px;max-width:none}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status-badge.online{background-color:#dcfce7;color:#166534}.status-badge.offline{background-color:#fee2e2;color:#991b1b}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.status-dot.online{background-color:#22c55e}.status-dot.offline{background-color:#ef4444}.device-status{text-align:left;vertical-align:middle}.device-user{text-align:left;vertical-align:middle;color:#374151;font-weight:500}.device-actions{text-align:left;vertical-align:middle}.device-info-display{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:12px;margin-top:8px}.device-info-display p{margin:4px 0;font-size:14px;color:#374151}.device-info-display p:last-child{margin-bottom:0}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.leaflet-draw-section{position:relative}.leaflet-draw-toolbar{margin-top:12px}.leaflet-draw-toolbar-top{margin-top:0}.leaflet-draw-toolbar-notop a:first-child{border-top-right-radius:0}.leaflet-draw-toolbar-nobottom a:last-child{border-bottom-right-radius:0}.leaflet-draw-toolbar a{background-image:url(data:image/png;base64,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);background-image:linear-gradient(transparent,transparent),url(/assets/spritesheet-DpIxuf5L.svg);background-repeat:no-repeat;background-size:300px 30px;background-clip:padding-box}.leaflet-retina .leaflet-draw-toolbar a{background-image:url(data:image/png;base64,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);background-image:linear-gradient(transparent,transparent),url(/assets/spritesheet-DpIxuf5L.svg)}.leaflet-draw a{display:block;text-align:center;text-decoration:none}.leaflet-draw a .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.leaflet-draw-actions{display:none;list-style:none;margin:0;padding:0;position:absolute;left:26px;top:0;white-space:nowrap}.leaflet-touch .leaflet-draw-actions{left:32px}.leaflet-right .leaflet-draw-actions{right:26px;left:auto}.leaflet-touch .leaflet-right .leaflet-draw-actions{right:32px;left:auto}.leaflet-draw-actions li{display:inline-block}.leaflet-draw-actions li:first-child a{border-left:0}.leaflet-draw-actions li:last-child a{-webkit-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.leaflet-right .leaflet-draw-actions li:last-child a{-webkit-border-radius:0;border-radius:0}.leaflet-right .leaflet-draw-actions li:first-child a{-webkit-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px}.leaflet-draw-actions a{background-color:#919187;border-left:1px solid #AAA;color:#fff;font:11px/19px Helvetica Neue,Arial,Helvetica,sans-serif;line-height:28px;text-decoration:none;padding-left:10px;padding-right:10px;height:28px}.leaflet-touch .leaflet-draw-actions a{font-size:12px;line-height:30px;height:30px}.leaflet-draw-actions-bottom{margin-top:0}.leaflet-draw-actions-top{margin-top:1px}.leaflet-draw-actions-top a,.leaflet-draw-actions-bottom a{height:27px;line-height:27px}.leaflet-draw-actions a:hover{background-color:#a0a098}.leaflet-draw-actions-top.leaflet-draw-actions-bottom a{height:26px;line-height:26px}.leaflet-draw-toolbar .leaflet-draw-draw-polyline{background-position:-2px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-polyline{background-position:0 -1px}.leaflet-draw-toolbar .leaflet-draw-draw-polygon{background-position:-31px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-polygon{background-position:-29px -1px}.leaflet-draw-toolbar .leaflet-draw-draw-rectangle{background-position:-62px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-rectangle{background-position:-60px -1px}.leaflet-draw-toolbar .leaflet-draw-draw-circle{background-position:-92px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-circle{background-position:-90px -1px}.leaflet-draw-toolbar .leaflet-draw-draw-marker{background-position:-122px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-marker{background-position:-120px -1px}.leaflet-draw-toolbar .leaflet-draw-draw-circlemarker{background-position:-273px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-draw-circlemarker{background-position:-271px -1px}.leaflet-draw-toolbar .leaflet-draw-edit-edit{background-position:-152px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-edit{background-position:-150px -1px}.leaflet-draw-toolbar .leaflet-draw-edit-remove{background-position:-182px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-remove{background-position:-180px -1px}.leaflet-draw-toolbar .leaflet-draw-edit-edit.leaflet-disabled{background-position:-212px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-edit.leaflet-disabled{background-position:-210px -1px}.leaflet-draw-toolbar .leaflet-draw-edit-remove.leaflet-disabled{background-position:-242px -2px}.leaflet-touch .leaflet-draw-toolbar .leaflet-draw-edit-remove.leaflet-disabled{background-position:-240px -2px}.leaflet-mouse-marker{background-color:#fff;cursor:crosshair}.leaflet-draw-tooltip{background:#363636;background:#00000080;border:1px solid transparent;-webkit-border-radius:4px;border-radius:4px;color:#fff;font:12px/18px Helvetica Neue,Arial,Helvetica,sans-serif;margin-left:20px;margin-top:-21px;padding:4px 8px;position:absolute;visibility:hidden;white-space:nowrap;z-index:6}.leaflet-draw-tooltip:before{border-right:6px solid black;border-right-color:#00000080;border-top:6px solid transparent;border-bottom:6px solid transparent;content:"";position:absolute;top:7px;left:-7px}.leaflet-error-draw-tooltip{background-color:#f2dede;border:1px solid #e6b6bd;color:#b94a48}.leaflet-error-draw-tooltip:before{border-right-color:#e6b6bd}.leaflet-draw-tooltip-single{margin-top:-12px}.leaflet-draw-tooltip-subtext{color:#f8d5e4}.leaflet-draw-guide-dash{font-size:1%;opacity:.6;position:absolute;width:5px;height:5px}.leaflet-edit-marker-selected{background-color:#fe57a11a;border:4px dashed rgba(254,87,161,.6);-webkit-border-radius:4px;border-radius:4px;box-sizing:content-box}.leaflet-edit-move{cursor:move}.leaflet-edit-resize{cursor:pointer}.leaflet-oldie .leaflet-draw-toolbar{border:1px solid #999}.dashboard-page{padding:20px;max-width:1200px;margin:0 auto}.page-header{margin-bottom:30px}.page-header h1{font-size:2rem;font-weight:600;color:#1f2937;margin:0}.dashboard-content{min-height:400px}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 20px;background:#f9fafb;border-radius:12px;border:2px dashed #d1d5db}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.error-message{color:#dc2626;font-weight:500}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:30px}.stat-card{display:flex;align-items:center;padding:24px;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out}.stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.stat-card.clickable{cursor:pointer;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out,background-color .2s ease-in-out}.stat-card.clickable:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.stat-card.clickable:active{transform:translateY(0);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.white-card{background:#fff;border:1px solid #e5e7eb}.white-card .stat-icon{color:#374151}.white-card .stat-number{color:#111827}.white-card .stat-label{color:#6b7280}.grey-card{background:#6b7280;border:1px solid #9ca3af}.grey-card .stat-icon,.grey-card .stat-number{color:#fff}.grey-card .stat-label{color:#f3f4f6}.stat-icon{margin-right:16px;flex-shrink:0}.stat-content{flex:1}.stat-number{font-size:2rem;font-weight:700;line-height:1;margin-bottom:4px}.stat-label{font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stat-icon.online{color:#10b981}.stat-icon.offline{color:#ef4444}.stat-icon.users{color:#000}.stat-icon.roles{color:#fff}.stat-icon.geofences{color:#000}.stat-icon.groups{color:#fff}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr;gap:16px}.stat-card{padding:20px}.stat-number{font-size:1.75rem}}.geofence-report-page{padding:24px;max-width:1400px;margin:0 auto;min-height:calc(100vh - 48px)}.search-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:24px 32px;background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid #e2e8f0;gap:24px;flex-wrap:wrap}.date-filter-form{display:flex;gap:16px;align-items:flex-end;flex:1;flex-wrap:wrap}.date-input-wrapper{display:flex;flex-direction:column;gap:8px}.date-label{font-size:12px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.date-input{padding:12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background-color:#fff;transition:border-color .2s;min-width:200px}.date-input:focus{outline:none;border-color:#000;box-shadow:0 0 0 3px #0000001a}.fetch-button{display:flex;align-items:center;justify-content:center;padding:12px 20px;background-color:#000;color:#fff;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:background-color .2s;height:fit-content}.fetch-button:hover:not(:disabled){background-color:#374151}.fetch-button:disabled{background-color:#9ca3af;cursor:not-allowed}.report-stats{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-number{font-size:24px;font-weight:700;color:#1f2937}.stat-label{font-size:12px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.events-table-container{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid #e2e8f0;overflow:hidden}.events-table{width:100%;border-collapse:collapse;font-size:14px}.events-table th{background-color:#f8fafc;padding:16px 20px;text-align:left!important;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.events-table td{padding:16px 20px;border-bottom:1px solid #f3f4f6;color:#1f2937;vertical-align:middle;text-align:left!important}.events-table tr:hover{background-color:#f9fafb}.empty-table-cell{text-align:center!important;color:#6b7280;padding:40px 20px!important}.details-cell{color:#6b7280;font-size:12px}.details-text{display:inline-block}.event-type-badge{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:4px 8px;border-radius:6px;display:inline-block}.event-type-badge.enter{background-color:#fff;color:#374151;border:1px solid #d1d5db}.event-type-badge.exit{background-color:#000;color:#fff;border:1px solid #000000}.empty-state{text-align:center;padding:60px 20px;color:#6b7280}.empty-icon{width:64px;height:64px;margin:0 auto 20px;color:#d1d5db}.empty-state h3{margin:0 0 8px;color:#374151;font-size:18px}.empty-state p{margin:0 0 20px;font-size:14px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#6b7280}.loading-spinner{width:40px;height:40px;border:3px solid #f3f4f6;border-top:3px solid #000000;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.error-message{background-color:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;border:1px solid #fecaca}@media (max-width: 768px){.geofence-report-page{padding:16px}.search-container{flex-direction:column;align-items:stretch;gap:16px}.date-filter-form{flex-direction:column;align-items:stretch}.date-input{min-width:100%}.fetch-button{width:100%}.report-stats{justify-content:space-around;gap:12px;flex-wrap:wrap}.stat-number{font-size:20px}.stat-label{font-size:11px}.events-table-container{overflow-x:auto}.events-table{min-width:700px;font-size:13px}.events-table th,.events-table td{padding:12px 8px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f5f5f5;color:#333}*{scrollbar-width:auto;scrollbar-color:auto}*::-webkit-scrollbar,*::-webkit-scrollbar-track,*::-webkit-scrollbar-thumb,*::-webkit-scrollbar-corner{all:unset}.container{max-width:1200px;margin:0 auto;padding:20px}.form-container{max-width:400px;margin:50px auto;padding:30px;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a}.login-logo-container{display:flex;justify-content:center;align-items:center;margin-bottom:12px}.login-logo{max-width:240px;max-height:160px;object-fit:contain}.form-title{text-align:center;margin-bottom:30px;color:#333;font-size:24px;font-weight:700}.form-group{margin-bottom:24px}.form-label{display:block;margin-bottom:8px;font-weight:500;color:#555}.form-input{width:100%;padding:14px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s;background-color:#fff}.form-input:focus{outline:none;border-color:#000;box-shadow:0 0 0 3px #0000001a}.form-button{width:100%;padding:12px;background-color:#4f46e5;color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:500;cursor:pointer}.form-button:hover{background-color:#4338ca}.form-button:disabled{background-color:#9ca3af;cursor:not-allowed}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:16px 20px;border-radius:8px;margin-bottom:24px;font-size:14px;display:flex;align-items:center;gap:12px}.card{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block}.btn-primary{background-color:#000;color:#fff}.btn-success{background-color:#16a34a;color:#fff}.btn-danger{background-color:#dc2626;color:#fff}.ptt-container{background-color:#1f2937;color:#fff;min-height:100vh;padding:20px}.ptt-button{width:200px;height:200px;border-radius:50%;border:none;font-size:18px;font-weight:700;cursor:pointer;margin:20px auto;display:block}.ptt-button.inactive{background-color:#6b7280}.ptt-button.active{background-color:#dc2626;box-shadow:0 0 20px #dc262680}.loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:18px;color:#666}.page-container{max-width:1200px;margin:0 auto;padding:32px 24px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;padding:32px 40px 24px;border-bottom:1px solid #e5e7eb;position:relative;background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb}.page-title-section{flex:1;padding-right:24px}.page-header h1,.page-header h2,.page-header h3,.page-header h4,.page-header h5,.page-header h6{margin:0}.page-title{font-size:2rem;font-weight:700;color:#111827;margin:0 0 12px}.page-subtitle{color:#374151;font-size:1.1rem;margin:0;line-height:1.5}.add-group-button{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;text-decoration:none;border-radius:50px;font-weight:600;transition:all .2s;border:2px solid #1e40af;cursor:pointer;font-size:14px;box-shadow:0 2px 8px #1e40af33;position:relative;z-index:10;min-width:120px}.add-group-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #1e40af4d;background:linear-gradient(135deg,#1d4ed8,#2563eb)}.add-group-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#fff3;border-radius:50%;padding:4px}.add-group-icon svg{width:12px;height:12px;color:#fff}.add-group-text{color:#fff;font-weight:600;white-space:nowrap}.primary-button{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#000!important;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:all .2s;border:none;cursor:pointer;font-size:14px}.primary-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000004d;background:#1a1a1a!important}.button-icon{font-size:16px}.loading-container{display:flex;align-items:center;justify-content:center;min-height:400px}.loading-spinner{font-size:1.2rem;color:#6b7280}.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a}.empty-state-icon{font-size:4rem;margin-bottom:20px}.empty-state-title{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0 0 10px}.empty-state-description{color:#6b7280;margin:0 0 30px;font-size:1.1rem}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-top:24px}.group-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 1px 3px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid #e5e7eb;position:relative;overflow:hidden}.group-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#1e40af,#3b82f6);opacity:0;transition:opacity .3s ease}.group-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000001f;border-color:#d1d5db}.group-card:hover:before{opacity:1}.group-card-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px}.group-card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#000;border-radius:12px;color:#fff;flex-shrink:0}.group-card-icon svg{width:24px;height:24px;color:#fff!important;stroke:#fff!important}.group-card-info{flex:1;min-width:0}.group-card-title{font-size:1.1rem;font-weight:600;color:#111827;margin:0 0 4px;line-height:1.3}.group-card-status{display:inline-flex;align-items:center;background:#f3f4f6;color:#374151;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;border:1px solid #e5e7eb}.group-card-description{color:#374151;margin:0 0 20px;line-height:1.5;font-size:.9rem}.group-card-actions{display:flex;gap:12px}.join-button{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;background:#000;color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;text-decoration:none;position:relative;overflow:hidden}.join-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.join-button:hover{transform:translateY(-1px);box-shadow:0 6px 20px #0000004d;background:#1a1a1a}.join-button:hover:before{left:100%}.join-button svg{width:18px;color:#fff!important;stroke:#fff!important;height:18px}.loading-container{display:flex;justify-content:center;align-items:center;min-height:400px}.loading-content{display:flex;flex-direction:column;align-items:center;gap:16px;color:#6b7280}.loading-content svg{color:#1e40af;animation:spin 2s linear infinite}.loading-text{font-size:1rem;font-weight:500;margin:0}.error-message{display:flex;align-items:center;gap:12px;background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:16px 20px;border-radius:12px;margin:20px 0;font-weight:500}.error-icon{font-size:1.2rem}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 20px;color:#6b7280}.empty-state-icon{margin-bottom:24px;color:#d1d5db}.empty-state-icon svg{width:64px;height:64px}.empty-state-title{font-size:1.5rem;font-weight:600;color:#374151;margin:0 0 12px}.empty-state-description{font-size:1rem;line-height:1.6;margin:0 0 32px;max-width:400px}.primary-button,.secondary-button{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:10px;font-weight:600;font-size:.9rem;text-decoration:none;transition:all .2s ease;border:none;cursor:pointer}.primary-button{background:#000!important;color:#fff}.primary-button:hover{transform:translateY(-1px);box-shadow:0 6px 20px #0000004d;background:#1a1a1a!important}.secondary-button{background:#fff;color:#1e40af;border:1px solid #d1d5db}.secondary-button:hover{background:#f8fafc;border-color:#1e40af;transform:translateY(-1px)}.primary-button svg,.secondary-button svg{width:18px;height:18px}.users-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px;margin-top:20px}.user-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 4px #0000001a;transition:all .2s;border:1px solid #e5e7eb}.user-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.user-card-header{display:flex;align-items:center;margin-bottom:20px}.user-avatar{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#7c3aed);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.2rem;margin-right:16px}.user-info{flex:1}.user-name{font-size:14px;font-weight:600;color:#1f2937;margin:0 0 4px}.user-email{color:#6b7280;font-size:.9rem;margin:0 0 8px}.user-priority{background:#dbeafe;color:#1e40af;padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600}.user-card-details{border-top:1px solid #e5e7eb;padding-top:16px}.user-detail{display:flex;justify-content:space-between;margin-bottom:8px}.user-detail:last-child{margin-bottom:0}.detail-label{font-weight:500;color:#6b7280}.detail-value{color:#1f2937;font-weight:500}.form-card{background:#fff;border-radius:16px;padding:40px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb;max-width:600px;margin:0 auto}.form-label{display:block;margin-bottom:10px;font-weight:600;color:#111827;font-size:14px}.form-actions{display:flex;gap:16px;justify-content:flex-end;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.secondary-button{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#fff;color:#6b7280;text-decoration:none;border-radius:8px;font-weight:600;transition:all .2s;border:1px solid #d1d5db;cursor:pointer;font-size:14px}.secondary-button:hover{background:#f9fafb;border-color:#9ca3af}.cancel-button{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#fff;color:#6b7280;text-decoration:none;border-radius:8px;font-weight:600;transition:all .2s;border:1px solid #d1d5db;cursor:pointer;font-size:14px}.cancel-button:hover{background:#f9fafb;border-color:#9ca3af}.ptt-control-section{background:#fff;border-radius:12px;padding:40px;box-shadow:0 2px 4px #0000001a;border:1px solid #e5e7eb;margin-bottom:30px;text-align:center}.ptt-button-container{display:flex;flex-direction:column;align-items:center;gap:20px}.ptt-main-button{width:200px;height:200px;border-radius:50%;border:none;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;box-shadow:0 4px 12px #00000026;-webkit-user-select:none;user-select:none}.ptt-main-button.inactive{background:#374151;color:#fff}.ptt-main-button.inactive:hover{transform:scale(1.05);box-shadow:0 8px 25px #3741514d;background:#4b5563}.ptt-main-button.active{background:#111827;color:#fff;transform:scale(.95);box-shadow:0 8px 25px #11182766;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.ptt-button-content{display:flex;flex-direction:column;align-items:center;gap:8px}.ptt-button-icon{font-size:2rem}.ptt-button-text{font-size:.9rem;font-weight:600;letter-spacing:.5px}.ptt-instruction{color:#6b7280;font-size:14px;margin:0}.ptt-instruction kbd{background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;padding:2px 6px;font-size:12px;font-weight:600;color:#374151}.current-speaker-status{margin-top:30px;padding:20px;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb}.speaker-indicator{display:flex;align-items:center;justify-content:center;gap:12px}.speaker-icon{font-size:1.5rem}.speaker-text{color:#374151;font-size:16px}.participants-section{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 4px #0000001a;border:1px solid #e5e7eb;margin-bottom:30px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.section-title{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0}.participant-count{background:#f3f4f6;color:#6b7280;padding:6px 12px;border-radius:20px;font-size:.9rem;font-weight:500}.participants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.participant-card{background:#f9fafb;border-radius:12px;padding:20px;border:1px solid #e5e7eb;transition:all .2s}.participant-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.participant-card.local{background:#f3f4f6;border-color:#d1d5db}.participant-card.remote{background:#f9fafb}.participant-avatar{width:50px;height:50px;border-radius:50%;background:#374151;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.2rem;margin-bottom:16px}.participant-card.local .participant-avatar{background:#111827}.participant-avatar span{filter:brightness(0) invert(1)}.participant-info{text-align:left}.participant-name{font-size:1.1rem;font-weight:600;color:#1f2937;margin:0 0 4px}.participant-status{color:#6b7280;font-size:.9rem;margin:0 0 12px}.participant-indicators{display:flex;flex-direction:column;gap:6px}.status-indicator{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:20px;font-size:.8rem;font-weight:500;width:fit-content}.status-indicator.connected{background:#f3f4f6;color:#374151}.status-indicator.speaking{background:#111827;color:#fff}.audio-indicator{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:20px;font-size:.8rem;font-weight:500;width:fit-content}.audio-indicator.has-audio{background:#374151;color:#fff}.audio-indicator.no-audio{background:#f3f4f6;color:#6b7280}.connection-status{display:flex;justify-content:center;margin-top:20px}.status-card{display:flex;align-items:center;gap:12px;padding:16px 24px;border-radius:12px;font-weight:500}.status-card.connected{background:#f9fafb;color:#374151;border:1px solid #e5e7eb}.status-icon{font-size:1.2rem}.status-text{font-size:14px}@media (max-width: 768px){.ptt-main-button{width:150px;height:150px}.ptt-button-icon{font-size:1.5rem}.ptt-button-text{font-size:.8rem}.participants-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:12px}}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}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background-color:#f8fafc}.loading-spinner{width:40px;height:40px;border:3px solid #f3f4f6;border-top:3px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-container,.access-denied-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background-color:#f8fafc;padding:20px;text-align:center}.error-container h2,.access-denied-container h2{color:#dc2626;margin-bottom:16px;font-size:24px}.error-container p,.access-denied-container p{color:#6b7280;margin-bottom:12px;font-size:16px;max-width:500px}.error-container button,.access-denied-container button{background-color:#6366f1;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:16px}.error-container button:hover,.access-denied-container button:hover{background-color:#5855eb}
