.page{max-width:1400px;margin:0 auto;width:100%;padding:var(--spacing-xl)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-md)}.page-header h1{margin:0;font-size:var(--text-3xl);font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.filters-card{position:sticky;top:0;z-index:100;margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.header-actions{display:flex;gap:var(--spacing-md);align-items:center;width:100%}.parking-filter,.status-field{min-width:200px}.active-filter-badge{display:flex;align-items:center;gap:.5rem;background:#34e3ff26;color:#34e3ff;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;border:1px solid rgba(52,227,255,.3);margin-left:.5rem;cursor:pointer;white-space:nowrap}.active-filter-badge:hover{background:#34e3ff40}.remove-filter{font-weight:700;font-size:1rem}.search-field{flex:1;position:relative;display:flex;align-items:center}.search-reset{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:5px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:color var(--transition-base)}.search-reset:hover{color:var(--text-primary)}@media (max-width: 768px){.page{padding:.5rem}.page-header{flex-direction:column;align-items:stretch;gap:var(--spacing-xs)}.filters-card{padding:var(--spacing-sm);margin-bottom:var(--spacing-md)}.header-actions{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.parking-filter,.status-field,.search-field{min-width:100%;width:100%}}.add-parking-btn{white-space:nowrap}.form-input{width:100%;padding:.625rem var(--spacing-md);background-color:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);transition:border-color var(--transition-base)}.form-input:focus{outline:none;border-color:var(--accent)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.stat-card{padding:var(--spacing-xl);background-color:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-hover));transform:scaleX(0);transform-origin:left;transition:transform var(--transition-base)}.stat-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card:hover:before{transform:scaleX(1)}.stat-card h3{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-md);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:var(--text-4xl);font-weight:700;color:var(--accent);line-height:1;letter-spacing:-.03em}.devices-list,.events-list,.sensors-list,.parkings-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.parking-card{position:relative}.parking-form-card{background-color:var(--bg-tertiary)}.device-card,.event-card,.sensor-card{padding:var(--spacing-lg);background-color:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border);transition:all var(--transition-base)}.device-card:hover,.event-card:hover,.sensor-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translate(4px)}.device-card h3,.sensor-card h3{margin-bottom:var(--spacing-sm);font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.device-card p,.sensor-card p{margin:var(--spacing-xs) 0;font-size:var(--text-sm);color:var(--text-secondary)}.event-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md);gap:var(--spacing-md)}.event-type{font-weight:600;color:var(--accent);font-size:var(--text-base)}.event-time{font-size:var(--text-sm);color:var(--text-primary);font-weight:600;white-space:nowrap;background:var(--bg-tertiary);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border)}.event-body{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);display:flex;flex-direction:column;gap:var(--spacing-lg)}.event-media-full{width:100%;min-width:0}.event-bottom-section{display:grid;grid-template-columns:300px 1fr;gap:var(--spacing-lg);align-items:stretch}@media (min-width: 1200px){.event-body{flex-direction:row;align-items:flex-start}.event-media-full{flex:0 0 60%;max-width:60%}.event-bottom-section{flex:0 0 38%;max-width:38%;display:flex;flex-direction:column;gap:var(--spacing-lg)}.event-zoom-wrapper{width:100%}.event-zoom-wrapper .event-photo-zoom{max-width:100%}}.event-zoom-wrapper{min-width:0;display:flex;align-items:stretch}.event-zoom-wrapper .event-photo-zoom{width:100%;height:100%;display:flex;flex-direction:column}.event-details{display:flex;flex-direction:column;justify-content:flex-start}.event-body p{margin:var(--spacing-xs) 0}.event-details>p:last-child{margin-bottom:var(--spacing-md)}.event-media{min-width:0;width:100%}.event-details{min-width:0;display:flex;flex-direction:column;gap:var(--spacing-md)}.event-photo{position:relative;flex:1 1 auto;min-width:200px;max-width:100%;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-tertiary);border:1px solid var(--border);display:flex;flex-direction:column;min-height:300px}.event-photo img{display:block;width:100%;height:auto;cursor:pointer;flex:1;object-fit:contain}.event-photo-empty{display:flex;align-items:center;justify-content:center;aspect-ratio:16 / 9;color:var(--text-tertiary);font-size:var(--text-sm);padding:var(--spacing-lg);background:var(--bg-tertiary)}.event-photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.event-photo-zoom{width:100%;max-width:300px;min-height:auto;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-tertiary);border:1px solid var(--border);display:flex;flex-direction:column;margin-top:var(--spacing-md)}.event-photo-zoom img{display:block;width:100%;height:auto;flex:0 0 auto;object-fit:contain;max-width:100%}.event-photo-zoom-label{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-secondary);border-bottom:1px solid var(--border);font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-align:center}@media (max-width: 900px){.event-bottom-section{grid-template-columns:1fr;align-items:start;gap:var(--spacing-md)}.event-photo{min-width:100%;width:100%}.event-zoom-wrapper{width:100%;display:flex;justify-content:center}.event-photo-zoom{width:100%;max-width:300px;min-height:auto;overflow:hidden;margin-top:0;margin-bottom:var(--spacing-md)}.event-photo-zoom img{width:100%;height:auto;max-height:none;object-fit:contain;flex:0 0 auto}.event-details{width:100%;margin-top:var(--spacing-md)}}.events-footer{display:flex;justify-content:center;padding:var(--spacing-lg) 0}.event-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xs)}.event-viewer{width:min(1400px,100vw);height:calc(100vh - var(--spacing-sm));max-height:calc(100vh - var(--spacing-sm));display:flex;flex-direction:column;gap:var(--spacing-sm);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-md);overflow:hidden;box-sizing:border-box}.event-viewer-body{display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto}.event-viewer-content{display:flex;flex-direction:column;gap:var(--spacing-sm);flex:1;min-height:0;height:100%}.event-viewer-main-photo{flex:0 0 70%;width:100%;min-height:400px;max-height:70%;display:flex;align-items:stretch}.event-viewer-main-photo .event-photo{width:100%;height:100%;min-height:0;flex:1}.event-viewer-main-photo .event-photo img{max-height:100%;height:auto;object-fit:contain}.event-viewer-bottom{display:grid;grid-template-columns:320px 1fr;gap:var(--spacing-md);flex:0 0 auto;min-height:180px;align-items:flex-start}.event-viewer-plate-photo{flex:0 0 auto;display:flex;align-items:flex-start;height:180px;overflow:hidden}.event-viewer-plate-photo .event-photo-zoom{width:100%;max-width:320px;height:100%;min-height:0;margin-top:0;display:flex;flex-direction:column;overflow:hidden}.event-viewer-plate-photo .event-photo-zoom img{max-height:100%;height:auto;object-fit:contain;width:100%;flex:1}.event-viewer-details{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1;min-height:0}.event-viewer-info-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xs);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border)}.event-viewer-meta{display:flex;flex-direction:column;gap:2px}.event-viewer-id{font-size:var(--text-xs);color:var(--text-tertiary);font-family:ui-monospace,monospace}.event-viewer-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.event-viewer-nav-mini{display:flex;gap:2px}.event-viewer-details-content{overflow-y:auto;flex:1;padding-right:var(--spacing-xs)}.event-viewer-details-content::-webkit-scrollbar{width:4px}.event-viewer-details-content::-webkit-scrollbar-track{background:transparent}.event-viewer-details-content::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:2px}.event-viewer-details-content p{margin:0;font-size:var(--text-sm);line-height:1.4}@media (max-width: 900px){.event-viewer{padding:var(--spacing-md);width:100%;max-width:100%;max-height:100vh}.event-viewer-overlay{padding:0}.event-viewer-nav-mini{display:flex;gap:var(--spacing-sm)}.event-viewer-nav-mini button{flex:1;font-size:var(--text-xs);padding:var(--spacing-xs) var(--spacing-sm)}.event-viewer-main-photo{max-height:40vh;min-height:200px}.event-viewer-bottom{grid-template-columns:1fr;gap:var(--spacing-lg);max-height:none;overflow:visible;align-items:start}.event-viewer-plate-photo{max-height:none;height:auto;width:100%;display:flex;justify-content:center;overflow:visible}.event-viewer-plate-photo .event-photo-zoom{max-width:100%;width:100%;max-width:300px;height:auto;min-height:auto;max-height:none;overflow:visible;margin-bottom:var(--spacing-md)}.event-viewer-plate-photo .event-photo-zoom img{max-height:none;height:auto;width:100%;object-fit:contain;flex:0 0 auto;display:block}.event-viewer-details{max-height:none;width:100%}}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-tertiary)}.empty-state p{font-size:var(--text-base);margin:0}.devices-list:empty:before,.events-list:empty:before,.sensors-list:empty:before{content:"Нет данных";display:block;text-align:center;padding:var(--spacing-2xl);color:var(--text-tertiary);font-size:var(--text-base)}.main-content::-webkit-scrollbar{width:8px}.main-content::-webkit-scrollbar-track{background:var(--bg-primary)}.main-content::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}.main-content::-webkit-scrollbar-thumb:hover{background:var(--border)}.barrier-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);flex-wrap:wrap}.barrier-item-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;justify-content:flex-end}@media (max-width: 768px){.page{padding:.5rem}.event-card{padding:var(--spacing-sm);border-radius:var(--radius-md)}.event-body{gap:var(--spacing-sm)}.page h1{font-size:var(--text-xl)!important}.page h2{font-size:var(--text-lg)!important}.page h3,.page h4{font-size:var(--text-base)!important}.controllers-list,.barriers-list,.devices-list{gap:.5rem!important}.badge{font-size:var(--text-xs)!important;padding:.375rem .625rem!important}.barrier-item-actions{width:100%;flex-direction:column;align-items:stretch}.event-media-full{width:calc(100% + var(--spacing-sm) * 2);margin-left:calc(var(--spacing-sm) * -1);margin-right:calc(var(--spacing-sm) * -1)}.event-media-full .event-photo{width:100%;margin:0;border-radius:0;border-left:none;border-right:none}.event-media-full .event-photo-empty{width:100%;border-radius:0;border-left:none;border-right:none}}.scroll-to-top{position:fixed;bottom:80px;right:var(--spacing-xl);width:50px;height:50px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);z-index:1000;transition:all var(--transition-base);opacity:0;visibility:hidden}.scroll-to-top.visible{opacity:1;visibility:visible}.scroll-to-top:hover{transform:translateY(-5px);background:var(--accent-hover)}@media (min-width: 769px){.scroll-to-top{bottom:var(--spacing-xl)}}.login-logo-wrapper{display:flex;justify-content:center;margin-bottom:var(--spacing-lg)}.login-logo{width:280px;height:auto;display:block;background-color:transparent!important;border:none!important;box-shadow:none!important}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--bg-primary)}.login-container{background:var(--bg-secondary);padding:2.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:420px;border:1px solid var(--border)}.login-container h1{margin:0 0 2rem;text-align:center;color:var(--text-primary);font-size:var(--text-2xl);font-weight:700}.registration-link-section{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.registration-link-info{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.registration-link-label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:500}.registration-link-code{display:block;background:var(--bg-tertiary);padding:.5rem .75rem;border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent);overflow-x:auto;white-space:nowrap;border:1px solid var(--border)}.registration-link-actions{display:flex;gap:var(--spacing-sm);flex-shrink:0}@media (max-width: 768px){.registration-link-section{flex-direction:column;align-items:stretch;gap:var(--spacing-md)}.registration-link-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.registration-link-actions button{width:100%}}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-group input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:var(--radius-md);font-size:1rem;background:var(--bg-primary);color:var(--text-primary);box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--accent)}.login-container button{width:100%;padding:.75rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;cursor:pointer;font-weight:500;transition:background var(--transition-base)}.login-container button:hover:not(:disabled){background:var(--accent-hover)}.login-container button:disabled{opacity:.6;cursor:not-allowed}.error-message{color:#dc3545;margin-bottom:1rem;text-align:center;font-size:var(--text-sm)}.telegram-page{height:calc(100vh - 120px);display:flex;flex-direction:column;overflow-x:hidden;max-width:100%}.telegram-page .page-header{flex-shrink:0}.telegram-container{flex:1;display:grid;grid-template-columns:360px 1fr;gap:var(--spacing-lg);min-height:0}.chat-list-card{display:flex;flex-direction:column;overflow:hidden;padding:0!important}.chat-search{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-bottom:1px solid var(--border)}.chat-search svg{color:var(--text-muted);flex-shrink:0}.chat-search input{flex:1;border:none;background:none;font-size:var(--text-sm);color:var(--text-primary);outline:none}.chat-search input::placeholder{color:var(--text-muted)}.chat-list{flex:1;overflow-y:auto}.chat-list-empty{padding:var(--spacing-xl);text-align:center;color:var(--text-muted)}.chat-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);cursor:pointer;border-bottom:1px solid var(--border-light);transition:background var(--transition-base)}.chat-item:hover{background:var(--bg-secondary)}.chat-item.active{background:var(--accent-light)}.chat-item.selected{background:var(--bg-tertiary);border-left:4px solid var(--accent);padding-left:calc(var(--spacing-md) - 4px)}.chat-selection-checkbox{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:24px}.chat-selection-checkbox svg{transition:all .2s ease}.chat-selection-checkbox .checked{color:var(--accent);transform:scale(1.1)}.chat-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-lg);flex-shrink:0}.chat-info{flex:1;min-width:0}.chat-header-row{display:flex;justify-content:space-between;align-items:baseline;gap:var(--spacing-sm)}.chat-name{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-time{font-size:var(--text-xs);color:var(--text-muted);flex-shrink:0}.chat-preview{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.chat-preview-you{color:var(--accent)}.chat-meta{display:flex;gap:var(--spacing-md);margin-top:4px;font-size:var(--text-xs);color:var(--text-muted)}.chat-meta span{display:flex;align-items:center;gap:4px}.chat-blocked-badge{font-size:var(--text-xs);color:var(--danger);background:var(--danger-light);padding:2px 6px;border-radius:var(--radius-sm);flex-shrink:0}.chat-window-card{display:flex;flex-direction:column;overflow:hidden;padding:0!important}.chat-window-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);gap:var(--spacing-md)}.chat-window-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.chat-window-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.chat-window-info{flex:1;min-width:0}.chat-window-name{font-weight:600;color:var(--text-primary)}.chat-window-details{display:flex;gap:var(--spacing-md);font-size:var(--text-sm);color:var(--text-muted);flex-wrap:wrap}.chat-window-details span{display:flex;align-items:center;gap:4px}.chat-window-blocked{font-size:var(--text-sm);color:var(--danger);background:var(--danger-light);padding:4px 12px;border-radius:var(--radius-md)}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-md) var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-xs)}.chat-date-separator{text-align:center;margin:var(--spacing-md) 0}.chat-date-separator span{background:var(--bg-secondary);color:var(--text-muted);font-size:var(--text-xs);padding:4px 12px;border-radius:var(--radius-full)}.chat-message{display:flex;max-width:70%}.chat-message.incoming{align-self:flex-start}.chat-message.outgoing{align-self:flex-end}.message-bubble{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);max-width:100%;word-wrap:break-word}.chat-message.incoming .message-bubble{background:var(--bg-secondary);color:var(--text-primary);border-bottom-left-radius:4px}.chat-message.outgoing .message-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.message-text{white-space:pre-wrap;line-height:1.4}.message-time{font-size:var(--text-xs);opacity:.7;text-align:right;margin-top:4px}.chat-input-container{display:flex;align-items:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.emoji-picker-container{position:relative}.emoji-button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-base)}.emoji-button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.emoji-picker-popup{position:absolute;bottom:100%;left:0;margin-bottom:var(--spacing-sm);z-index:1000}.chat-input{flex:1;border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--text-base);background:var(--bg-primary);color:var(--text-primary);resize:none;min-height:40px;max-height:120px;font-family:inherit;line-height:1.4}.chat-input:focus{outline:none;border-color:var(--accent)}.chat-input:disabled{background:var(--bg-tertiary);cursor:not-allowed}.send-button{background:var(--accent);color:#fff;border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);flex-shrink:0}.send-button:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.05)}.send-button:disabled{opacity:.5;cursor:not-allowed}.chat-list-mobile-header,.mobile-chats-button,.mobile-back-button,.mobile-drawer-overlay{display:none}@media (max-width: 768px){.telegram-page{overflow-x:hidden;height:calc(100dvh - 140px);padding:var(--spacing-md)}.telegram-page .page-header{flex-direction:row;justify-content:space-between;align-items:center;padding:0;margin-bottom:var(--spacing-sm)}.telegram-page .page-header h1{font-size:var(--text-xl)}.mobile-chats-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:500}.mobile-drawer-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999}.telegram-container{grid-template-columns:1fr;height:100%;overflow:hidden}.chat-list-card{position:fixed;top:0;left:0;bottom:0;width:85%;max-width:320px;z-index:1000;border-radius:0;transform:translate(-100%);transition:transform .3s ease;overflow-y:auto}.chat-list-card.mobile-open{transform:translate(0)}.chat-list-mobile-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--border);background:var(--bg-secondary);font-weight:600;font-size:var(--text-lg);position:sticky;top:0;z-index:1}.chat-list-mobile-header button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm)}.chat-window-card{display:flex;flex-direction:column;height:100%;overflow:hidden;border-radius:var(--radius-md)}.chat-window-header{flex-shrink:0;padding:var(--spacing-sm) var(--spacing-md);min-height:auto}.chat-window-avatar{width:32px;height:32px;font-size:var(--text-sm)}.chat-window-name{font-size:var(--text-sm)}.chat-window-details{display:none}.chat-window-blocked{font-size:var(--text-xs);padding:2px 8px}.mobile-back-button{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:var(--spacing-xs);margin-right:var(--spacing-xs);border-radius:var(--radius-sm);flex-shrink:0}.chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-sm);-webkit-overflow-scrolling:touch}.chat-message{max-width:85%}.message-bubble{padding:var(--spacing-xs) var(--spacing-sm)}.message-text{font-size:var(--text-sm)}.message-time{font-size:10px}.chat-input-container{flex-shrink:0;padding:var(--spacing-sm);gap:var(--spacing-xs)}.chat-input{font-size:16px;padding:var(--spacing-xs) var(--spacing-sm);min-height:36px}.emoji-button{padding:var(--spacing-xs)}.emoji-button svg{width:20px;height:20px}.send-button{width:36px;height:36px}.send-button svg{width:18px;height:18px}.emoji-picker-popup{position:fixed;left:50%;bottom:70px;transform:translate(-50%);right:auto}.chat-window-empty{padding:var(--spacing-lg)}.chat-window-empty svg{width:48px;height:48px}.chat-window-empty p{font-size:var(--text-sm)}.chat-date-separator{margin:var(--spacing-sm) 0}.chat-date-separator span{font-size:10px;padding:2px 8px}}.sidebar{width:260px;flex-shrink:0;background-color:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:transform var(--transition-base);height:100%;overflow-y:auto}.sidebar-header{padding:var(--spacing-xl) var(--spacing-lg);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);border-bottom:1px solid var(--border);margin-bottom:var(--spacing-md)}.sidebar-logo{width:180px;height:auto;display:block;background-color:transparent!important;border:none!important;box-shadow:none!important}.sidebar-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);text-align:center;text-transform:uppercase;letter-spacing:.05em;opacity:.8}.sidebar-nav{padding:var(--spacing-lg) 0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.nav-item{display:flex;align-items:center;padding:var(--spacing-md) var(--spacing-xl);margin:0 var(--spacing-sm);color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-base);position:relative;overflow:hidden;min-width:0}.nav-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background-color:var(--accent);border-radius:0 2px 2px 0;transition:height var(--transition-base)}.nav-item:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background-color:var(--accent-light);color:var(--accent)}.nav-item.active:before{height:60%}.nav-icon{margin-right:var(--spacing-md);font-size:var(--text-xl);transition:transform var(--transition-fast)}.nav-item:hover .nav-icon{transform:scale(1.1)}.nav-label{font-size:var(--text-sm);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.sidebar-footer{margin-top:auto;padding:var(--spacing-lg) 0;border-top:1px solid var(--border)}.logout-button-sidebar{display:flex;align-items:center;width:calc(100% - var(--spacing-sm) * 2);padding:var(--spacing-md) var(--spacing-xl);margin:0 var(--spacing-sm);background:transparent;border:none;color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-align:left}.logout-button-sidebar:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background-color:#151515f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid var(--border);z-index:1000;padding-bottom:env(safe-area-inset-bottom,0px);height:auto;min-height:60px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;width:100%;transform:translateZ(0);-webkit-transform:translateZ(0)}.bottom-nav::-webkit-scrollbar{display:none}.bottom-nav-item{flex:0 0 auto;min-width:75px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xs) var(--spacing-sm);color:var(--text-secondary);text-decoration:none;transition:all var(--transition-base);position:relative}.bottom-nav-item:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:0;height:2px;background-color:var(--accent);border-radius:0 0 2px 2px;transition:width var(--transition-base)}.bottom-nav-item:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item.active:before{width:60%}.bottom-nav-icon{font-size:var(--text-xl);margin-bottom:var(--spacing-xs);transition:transform var(--transition-fast)}.bottom-nav-item:hover .bottom-nav-icon,.bottom-nav-item.active .bottom-nav-icon{transform:scale(1.1)}.bottom-nav-label{font-size:10px;font-weight:500;white-space:nowrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-family:var(--font-sans);font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;box-sizing:border-box;min-width:0}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-xs{padding:.25rem .5rem;font-size:var(--text-xs);border-radius:var(--radius-sm)}.btn-sm{padding:.5rem .75rem;font-size:var(--text-sm)}.btn-md{padding:.625rem 1rem;font-size:var(--text-base)}.btn-lg{padding:.75rem 1.5rem;font-size:var(--text-lg)}.btn-primary{background-color:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-elevated);border-color:var(--accent)}.btn-ghost{background-color:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-danger{background-color:var(--error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover:not(:disabled){background-color:#059669;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-success:active:not(:disabled){transform:translateY(0)}.btn-loading{position:relative;cursor:wait}.btn-spinner-container{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.btn-spinner{width:1em;height:1em;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btn-rotate .75s linear infinite}@keyframes btn-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.card{background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base)}.card-hover:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-sm);white-space:nowrap}.badge-default{background-color:var(--bg-tertiary);color:var(--text-secondary)}.badge-success{background-color:var(--success-light);color:var(--success)}.badge-warning{background-color:var(--warning-light);color:var(--warning)}.badge-error,.badge-danger{background-color:var(--error-light);color:var(--error)}.badge-info{background-color:var(--info-light);color:var(--info)}.switch-wrapper{display:inline-flex;align-items:center}.switch-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.switch-disabled{cursor:not-allowed;opacity:.5}.switch-container{position:relative;width:44px;height:24px}.switch-input{position:absolute;width:44px;height:24px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all var(--transition-base);margin:0;padding:0}.switch-input:checked{background-color:var(--accent);border-color:var(--accent)}.switch-input:disabled{cursor:not-allowed;opacity:.5}.switch-slider{position:absolute;top:2px;left:2px;width:20px;height:20px;background-color:#fff;border-radius:50%;transition:transform var(--transition-base);pointer-events:none}.switch-slider.checked{transform:translate(20px)}.switch-label-text{font-size:var(--text-sm);color:var(--text-primary)}.select-wrapper{display:flex;flex-direction:column;gap:var(--spacing-xs)}.select-label{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.select{width:100%;padding:.625rem 2.5rem .625rem .75rem;font-size:var(--text-base);font-family:var(--font-sans);color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23b0b0b0' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.select:hover:not(:disabled){border-color:var(--accent)}.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.select:disabled{opacity:.5;cursor:not-allowed}.select option{background-color:var(--bg-secondary);color:var(--text-primary)}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);animation:fadeIn .2s ease-out;overflow-x:hidden;overflow-y:auto;width:100vw;max-width:100vw;box-sizing:border-box}@media (max-width: 640px){.dialog-overlay{padding:var(--spacing-sm)}}.dialog-content{background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:500px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .2s ease-out;overflow:hidden;position:relative;box-sizing:border-box}@media (max-width: 640px){.dialog-content{max-width:calc(100vw - var(--spacing-sm) * 2);width:calc(100vw - var(--spacing-sm) * 2)}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.dialog-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border);gap:var(--spacing-md);width:100%;box-sizing:border-box;flex-shrink:0}.dialog-title{margin:0;font-size:var(--text-xl);font-weight:600;color:var(--text-primary);line-height:1.2;flex:1;min-width:0;word-break:break-word}@media (max-width: 640px){.dialog-header{padding:var(--spacing-md)}.dialog-title{font-size:var(--text-lg)}}.dialog-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-base);flex-shrink:0}.dialog-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.dialog-body{padding:var(--spacing-lg);overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;width:100%;box-sizing:border-box}@media (max-width: 640px){.dialog-body{padding:var(--spacing-md)}}.dialog-footer{padding:var(--spacing-lg);border-top:1px solid var(--border);display:flex;gap:var(--spacing-sm);justify-content:flex-end;background-color:var(--bg-secondary);width:100%;box-sizing:border-box;flex-shrink:0}@media (max-width: 640px){.dialog-footer{padding:var(--spacing-md);flex-direction:column-reverse}.dialog-footer button{width:100%}}.scroll-area{overflow-y:auto;overflow-x:hidden;padding-right:var(--spacing-xs)}.scroll-area::-webkit-scrollbar{width:8px}.scroll-area::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.scroll-area::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.scroll-area::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.toast{position:fixed;bottom:1.5rem;right:1.5rem;min-width:300px;max-width:500px;padding:1rem 1.25rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);cursor:pointer;animation:toastSlideIn .3s ease-out;z-index:10000;transition:all var(--transition-base)}.toast:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}.toast-content{display:flex;align-items:center;gap:.75rem}.toast-icon{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;flex-shrink:0}.toast-message{flex:1;font-size:var(--text-sm);line-height:1.5;color:var(--text-primary)}.toast-success{border-left:3px solid var(--status-success)}.toast-success .toast-icon{background:var(--status-success);color:var(--bg-primary)}.toast-error{border-left:3px solid var(--status-error)}.toast-error .toast-icon{background:var(--status-error);color:var(--bg-primary)}.toast-warning{border-left:3px solid var(--status-warning)}.toast-warning .toast-icon{background:var(--status-warning);color:var(--bg-primary)}.toast-info{border-left:3px solid var(--accent)}.toast-info .toast-icon{background:var(--accent);color:var(--bg-primary)}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-removing{animation:toastSlideOut .3s ease-in forwards}@keyframes toastSlideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.75rem;z-index:10000;pointer-events:none}.toast-container>*{pointer-events:auto}@media (max-width: 768px){.toast,.toast-container{right:1rem;left:1rem;min-width:auto;max-width:none}}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .2s ease-out}.confirm-dialog{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;min-width:320px;max-width:90vw;box-shadow:var(--shadow-xl);animation:dialogSlideIn .2s ease-out}.confirm-dialog-title{margin:0 0 1rem;font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.confirm-dialog-message{margin:0 0 1.5rem;font-size:var(--text-base);line-height:1.6;color:var(--text-primary)}.confirm-dialog-actions{display:flex;gap:.75rem;justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes dialogSlideIn{0%{transform:scale(.95) translateY(-10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.app-layout{display:flex;height:100vh;width:100%;background-color:var(--bg-primary);overflow:hidden}.app-content{flex:1;display:flex;flex-direction:column;min-width:0;height:100%;overflow-y:auto;overflow-x:hidden;position:relative}.main-content{flex:1;min-width:0;animation:fadeIn var(--transition-slow)}.mobile-header{padding:var(--spacing-sm) var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm);background-color:var(--bg-primary);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.mobile-logo{height:60px;width:auto;display:block;background-color:transparent!important;border:none!important;box-shadow:none!important}.mobile-title{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@media (max-width: 768px){.app-layout{height:auto;overflow:visible;flex-direction:column}.app-content{margin-left:0;height:auto;overflow:visible}.main-content{padding-bottom:7rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1100;padding:var(--spacing-lg);padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom))}.modal-content{max-width:520px;width:100%;max-height:calc(100dvh - 2 * var(--spacing-lg) - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow:auto;padding:0}.barrier-dropdown{position:relative}.barrier-dropdown-button{width:100%;padding:.5rem;border-radius:var(--radius-sm);border:1px solid var(--border);background-color:var(--bg-primary);color:var(--text-primary);text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:var(--text-base);transition:border-color var(--transition-base)}.barrier-dropdown-button:hover{border-color:var(--accent)}.barrier-dropdown-menu{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:1200;max-height:200px;overflow-y:auto}.barrier-dropdown-item{width:100%;padding:.5rem;text-align:left;background-color:transparent;color:var(--text-primary);border:none;cursor:pointer;font-size:var(--text-base);transition:background-color var(--transition-base)}.barrier-dropdown-item:first-child{border-top:none}.barrier-dropdown-item:not(:first-child){border-top:1px solid var(--border)}.barrier-dropdown-item:hover{background-color:var(--bg-tertiary)}.barrier-dropdown-item.selected{background-color:var(--accent-light)}.barrier-dropdown-menu::-webkit-scrollbar{width:6px}.barrier-dropdown-menu::-webkit-scrollbar-track{background:var(--bg-primary)}.barrier-dropdown-menu::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}.barrier-dropdown-menu::-webkit-scrollbar-thumb:hover{background:var(--border)}.cameras-list{display:flex;flex-direction:column;gap:1rem}.camera-dialog-form{display:flex;flex-direction:column;gap:1rem}.form-group label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary)}.form-group input,.form-group select{padding:.5rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:var(--text-base)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-alpha)}.form-checkbox{flex-direction:row;align-items:center}.form-checkbox input{width:auto;margin-right:.5rem}.equipment-management-page{padding:1.5rem;max-width:1400px;margin:0 auto}.equipment-section{margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{margin:0;font-size:var(--text-xl);font-weight:600}.cameras-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.camera-card{padding:1rem}.camera-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.camera-header h3{margin:0;font-size:var(--text-lg)}.camera-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.info-item{display:flex;align-items:center;gap:.5rem;font-size:var(--text-sm)}.info-item .label{color:var(--text-secondary);font-weight:500}.info-item code{font-family:monospace;background:var(--bg-secondary);padding:.125rem .375rem;border-radius:var(--radius-sm);font-size:var(--text-xs)}.binding-item{display:flex;align-items:center;gap:.5rem;font-size:var(--text-sm)}.binding-item .label{color:var(--text-secondary);font-weight:500}.camera-actions{display:flex;gap:.5rem;padding-top:.75rem;border-top:1px solid var(--border)}.malinas-list{display:flex;flex-direction:column;gap:1rem}.malina-card{padding:1rem}.malina-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.malina-header h3{margin:0;font-size:var(--text-lg)}.malina-section{margin-bottom:1rem}.malina-section:last-child{margin-bottom:0}.subsection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.subsection-header h4{margin:0;font-size:var(--text-base);font-weight:500;color:var(--text-secondary)}.items-list{display:flex;flex-direction:column;gap:.5rem}.item-with-action{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:var(--text-sm)}.empty-state{color:var(--text-tertiary);font-size:var(--text-sm);font-style:italic;margin:.5rem 0}.barriers-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1rem}.barrier-card{padding:1.25rem;transition:all .2s}.barrier-card.editing{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-alpha-10)}.barrier-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.barrier-title-group{display:flex;flex-direction:column;gap:.25rem}.barrier-header h3{margin:0;font-size:var(--text-lg);font-weight:600}.barrier-site-label{font-size:var(--text-xs);color:var(--text-secondary)}.barrier-actions{display:flex;flex-wrap:wrap;gap:.5rem}.barrier-content{display:flex;flex-direction:column;gap:1.25rem}.barrier-edit-form{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--bg-secondary);border-radius:var(--radius-md)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em}.barrier-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.barrier-info-grid .info-item{display:flex;flex-direction:column;gap:.5rem;align-items:flex-start}.barrier-info-grid .info-item .label{font-size:var(--text-xs);color:var(--text-tertiary)}.barrier-bindings-grid{display:grid;grid-template-columns:1fr;gap:1rem}.barrier-bindings-grid .binding-item{display:flex;flex-direction:column;gap:.5rem}.barrier-bindings-grid .binding-item label{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary)}.binding-controls{display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary);padding:.5rem .75rem;border-radius:var(--radius-md);min-height:2.5rem}.binding-name{font-size:var(--text-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:.5rem}.barrier-users-wrapper{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.react-international-phone-country-selector{position:relative}.react-international-phone-country-selector-button{display:flex;height:var(--react-international-phone-height, 36px);box-sizing:border-box;align-items:center;justify-content:center;padding:0;border:1px solid var(--react-international-phone-country-selector-border-color, var(--react-international-phone-border-color, gainsboro));margin:0;-moz-appearance:button;appearance:button;-webkit-appearance:button;background-color:var(--react-international-phone-country-selector-background-color, var(--react-international-phone-background-color, white));cursor:pointer;text-transform:none;-webkit-user-select:none;user-select:none}.react-international-phone-country-selector-button:hover{background-color:var(--react-international-phone-country-selector-background-color-hover, whitesmoke)}.react-international-phone-country-selector-button--hide-dropdown{cursor:auto}.react-international-phone-country-selector-button--hide-dropdown:hover{background-color:transparent}.react-international-phone-country-selector-button__button-content{display:flex;align-items:center;justify-content:center}.react-international-phone-country-selector-button__flag-emoji{margin:0 4px}.react-international-phone-country-selector-button__flag-emoji--disabled{opacity:.75}.react-international-phone-country-selector-button__dropdown-arrow{border-top:var(--react-international-phone-country-selector-arrow-size, 4px) solid var(--react-international-phone-country-selector-arrow-color, #777);border-right:var(--react-international-phone-country-selector-arrow-size, 4px) solid transparent;border-left:var(--react-international-phone-country-selector-arrow-size, 4px) solid transparent;margin-right:4px;transition:all .1s ease-out}.react-international-phone-country-selector-button__dropdown-arrow--active{transform:rotateX(180deg)}.react-international-phone-country-selector-button__dropdown-arrow--disabled{border-top-color:var(--react-international-phone-disabled-country-selector-arrow-color, #999)}.react-international-phone-country-selector-button--disabled,.react-international-phone-country-selector-button--disabled:hover{background-color:var(--react-international-phone-disabled-country-selector-background-color, var(--react-international-phone-disabled-background-color, whitesmoke))}.react-international-phone-country-selector-button--disabled{cursor:auto}.react-international-phone-flag-emoji{width:var(--react-international-phone-flag-width, 24px);height:var(--react-international-phone-flag-height, 24px);box-sizing:border-box}.react-international-phone-country-selector-dropdown{position:absolute;z-index:1;top:var(--react-international-phone-dropdown-top, 44px);left:var(--react-international-phone-dropdown-left, 0);display:flex;width:300px;max-height:200px;flex-direction:column;padding:4px 0;margin:0;background-color:var(--react-international-phone-dropdown-item-background-color, var(--react-international-phone-background-color, white));box-shadow:var(--react-international-phone-dropdown-shadow, 2px 2px 16px rgba(0, 0, 0, .25));color:var(--react-international-phone-dropdown-item-text-color, var(--react-international-phone-text-color, #222));list-style:none;overflow-y:scroll}.react-international-phone-country-selector-dropdown__preferred-list-divider{height:1px;border:none;margin:var(--react-international-phone-dropdown-preferred-list-divider-margin, 0);background:var(--react-international-phone-dropdown-preferred-list-divider-color, var(--react-international-phone-border-color, gainsboro))}.react-international-phone-country-selector-dropdown__list-item{display:flex;min-height:var(--react-international-phone-dropdown-item-height, 28px);box-sizing:border-box;align-items:center;padding:2px 8px}.react-international-phone-country-selector-dropdown__list-item-flag-emoji{margin-right:8px}.react-international-phone-country-selector-dropdown__list-item-country-name{overflow:hidden;margin-right:8px;font-size:var(--react-international-phone-dropdown-item-font-size, 14px);text-overflow:ellipsis;white-space:nowrap}.react-international-phone-country-selector-dropdown__list-item-dial-code{color:var(--react-international-phone-dropdown-item-dial-code-color, gray);font-size:var(--react-international-phone-dropdown-item-font-size, 14px)}.react-international-phone-country-selector-dropdown__list-item:hover{background-color:var(--react-international-phone-selected-dropdown-item-background-color, var(--react-international-phone-selected-dropdown-item-background-color, whitesmoke));cursor:pointer}.react-international-phone-country-selector-dropdown__list-item--selected,.react-international-phone-country-selector-dropdown__list-item--focused{background-color:var(--react-international-phone-selected-dropdown-item-background-color, whitesmoke);color:var(--react-international-phone-selected-dropdown-item-text-color, var(--react-international-phone-text-color, #222))}.react-international-phone-country-selector-dropdown__list-item--selected .react-international-phone-country-selector-dropdown__list-item-dial-code,.react-international-phone-country-selector-dropdown__list-item--focused .react-international-phone-country-selector-dropdown__list-item-dial-code{color:var(--react-international-phone-selected-dropdown-item-dial-code-color, var(--react-international-phone-dropdown-item-dial-code-color, gray))}.react-international-phone-country-selector-dropdown__list-item--focused{background-color:var(--react-international-phone-selected-dropdown-item-background-color, var(--react-international-phone-selected-dropdown-item-background-color, whitesmoke))}.react-international-phone-dial-code-preview{display:flex;align-items:center;justify-content:center;padding:0 8px;border:1px solid var(--react-international-phone-dial-code-preview-border-color, var(--react-international-phone-border-color, gainsboro));margin-right:-1px;background-color:var(--react-international-phone-dial-code-preview-background-color, var(--react-international-phone-background-color, white));color:var(--react-international-phone-dial-code-preview-text-color, var(--react-international-phone-text-color, #222));font-size:var(--react-international-phone-dial-code-preview-font-size, var(--react-international-phone-font-size, 13px))}.react-international-phone-dial-code-preview--disabled{background-color:var(--react-international-phone-dial-code-preview-disabled-background-color, var(--react-international-phone-disabled-background-color, whitesmoke));color:var(--react-international-phone-dial-code-preview-disabled-text-color, var(--react-international-phone-disabled-text-color, #666))}.react-international-phone-input-container{display:flex}.react-international-phone-input-container .react-international-phone-country-selector-button{border-radius:var(--react-international-phone-border-radius, 4px);margin-right:-1px;border-bottom-right-radius:0;border-top-right-radius:0}.react-international-phone-input-container .react-international-phone-input{overflow:visible;height:var(--react-international-phone-height, 36px);box-sizing:border-box;padding:0 8px;border:1px solid var(--react-international-phone-border-color, gainsboro);border-radius:var(--react-international-phone-border-radius, 4px);margin:0;background-color:var(--react-international-phone-background-color, white);border-bottom-left-radius:0;border-top-left-radius:0;color:var(--react-international-phone-text-color, #222);font-family:inherit;font-size:var(--react-international-phone-font-size, 13px)}.react-international-phone-input-container .react-international-phone-input:focus{outline:none}.react-international-phone-input-container .react-international-phone-input--disabled{background-color:var(--react-international-phone-disabled-background-color, whitesmoke);color:var(--react-international-phone-disabled-text-color, #666)}.legal-container{display:flex;justify-content:center;align-items:flex-start;min-height:100vh;padding:40px 20px;background:var(--bg-primary)}.legal-card{width:100%;max-width:800px;padding:40px;background-color:var(--bg-secondary);border:1px solid var(--border)}.legal-card h1{margin-bottom:8px;font-size:24px;text-align:center;color:var(--text-primary)}.legal-revision{text-align:center;color:var(--text-secondary);margin-bottom:32px;font-size:14px}.legal-content{color:var(--text-primary);line-height:1.6;font-size:16px}.legal-content h3{margin-top:24px;margin-bottom:12px;font-size:18px;color:var(--text-primary)}.legal-content p{margin-bottom:12px}.legal-content li{margin-bottom:8px;margin-left:20px}.legal-actions{margin-top:40px;display:flex;justify-content:center}.back-button{padding:10px 24px;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:16px;transition:opacity .2s}.back-button:hover{opacity:.9}@media (max-width: 600px){.legal-card{padding:24px}}:root{--bg-primary: #0a0a0a;--bg-secondary: #151515;--bg-tertiary: #1f1f1f;--bg-elevated: #252525;--text-primary: #ffffff;--text-secondary: #b0b0b0;--text-tertiary: #808080;--accent: #3b82f6;--accent-hover: #2563eb;--accent-light: rgba(59, 130, 246, .1);--border: #2a2a2a;--border-light: #1f1f1f;--success: #10b981;--success-light: rgba(16, 185, 129, .1);--warning: #f59e0b;--warning-light: rgba(245, 158, 11, .1);--error: #ef4444;--error-light: rgba(239, 68, 68, .1);--info: #3b82f6;--info-light: rgba(59, 130, 246, .1);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono: "SF Mono", "Monaco", "Inconsolata", "Roboto Mono", "Courier New", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem}*{margin:0;padding:0;box-sizing:border-box}html{overflow-x:hidden;width:100%}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;width:100%;max-width:100vw}img{max-width:100%;height:auto}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:var(--leading-tight);color:var(--text-primary)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}h5{font-size:var(--text-base)}h6{font-size:var(--text-sm)}p{margin-bottom:var(--spacing-md);color:var(--text-secondary)}code{font-family:var(--font-mono);font-size:.9em;background-color:var(--bg-tertiary);padding:.125rem .375rem;border-radius:var(--radius-sm)}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}.form-input,.form-select,.select{width:100%;padding:.625rem var(--spacing-md);background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);transition:all var(--transition-base);outline:none;font-family:inherit}.form-input:focus,.form-select:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light);background-color:var(--bg-tertiary)}.form-input:hover:not(:disabled),.form-select:hover:not(:disabled),.select:hover:not(:disabled){border-color:var(--accent)}.form-input::placeholder{color:var(--text-tertiary)}select.form-input,select.form-select,.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23808080'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;padding-right:2.5rem;cursor:pointer}.plate-tag{display:inline-block;background-color:var(--bg-primary);color:var(--text-primary);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border);font-family:var(--font-mono);font-weight:700;font-size:var(--text-sm);text-transform:uppercase}
