.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;max-width:400px}.toast{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#fff;border-radius:.75rem;box-shadow:0 10px 40px #00000026;animation:toast-slide-in .3s ease-out;border-left:4px solid}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{flex-shrink:0;margin-top:.125rem}.toast-message{flex:1;font-size:.875rem;color:var(--gray-700);line-height:1.5}.toast-close{flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--gray-400);padding:.25rem;margin:-.25rem;border-radius:.25rem;transition:all .15s}.toast-close:hover{background:var(--gray-100);color:var(--gray-600)}.toast-success{border-left-color:#10b981}.toast-success .toast-icon{color:#10b981}.toast-error{border-left-color:#ef4444}.toast-error .toast-icon{color:#ef4444}.toast-warning{border-left-color:#f59e0b}.toast-warning .toast-icon{color:#f59e0b}.toast-info{border-left-color:#3b82f6}.toast-info .toast-icon{color:#3b82f6}.language-switcher{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:.375rem;color:#fffc;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s}.language-switcher:hover{background:#ffffff26;color:#fff}.lang-text{min-width:1.25rem;text-align:center}.sidebar{position:relative;width:100%;height:100%;background-color:var(--sidebar-bg);display:flex;flex-direction:column}@media (min-width: 1024px){.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width)}}@media (max-width: 1023px){.sidebar-header{display:none}.sidebar-nav{padding-top:calc(var(--header-height) + 1rem)}}.sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between}.sidebar-logo{display:flex;align-items:center;gap:.75rem}.logo-image{width:2.5rem;height:2.5rem;border-radius:50%;-o-object-fit:cover;object-fit:cover}.logo-text{font-size:1.25rem;font-weight:700;color:#fff}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:#ffffffb3;text-decoration:none;transition:all .15s ease;border-left:3px solid transparent}.nav-item:hover{background-color:var(--sidebar-hover);color:#fff}.nav-item.active{background-color:var(--sidebar-active);color:#fff;border-left-color:#ef4444}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:.75rem}.sidebar-footer .language-switcher{width:100%;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.sidebar-footer .language-switcher:hover{background:#ffffff1a}.user-menu{position:relative}.user-menu-trigger{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff1a;border:none;border-radius:.5rem;cursor:pointer;text-align:left;transition:background .15s}.user-menu-trigger:hover{background:#ffffff26}.user-avatar{width:2.5rem;height:2.5rem;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1rem}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{display:block;color:#fff;font-weight:500;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{display:block;color:#ffffffb3;font-size:.8125rem}.chevron{color:#ffffff80;transition:transform .15s}.chevron.open{transform:rotate(180deg)}.user-dropdown{position:absolute;left:0;right:0;bottom:100%;margin-bottom:.5rem;background:#fff;border-radius:.5rem;box-shadow:0 4px 12px #0003;overflow:hidden}.dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;font-size:.875rem;color:var(--gray-700);transition:background .15s}.dropdown-item:hover{background:var(--gray-100)}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:#fef2f2}@media (max-width: 480px){.sidebar-footer{padding:.75rem}.user-menu-trigger{padding:.5rem;gap:.5rem}.user-avatar{width:2rem;height:2rem;font-size:.875rem}.sidebar-user-name{font-size:.8125rem}.sidebar-user-role{font-size:.75rem}.sidebar-footer .language-switcher{padding:.375rem .5rem;font-size:.6875rem}}.layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:2rem;background-color:var(--gray-100);min-height:100vh}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--sidebar-bg);z-index:101;padding:0 1rem;align-items:center;gap:1rem}.menu-toggle{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:#ffffff1a;border:none;border-radius:.5rem;color:#fff;cursor:pointer;transition:background .15s}.menu-toggle:hover{background:#fff3}.mobile-logo{display:flex;align-items:center;gap:.75rem;color:#fff;font-weight:600;font-size:1.125rem}.mobile-logo-img{width:2rem;height:2rem;border-radius:50%;-o-object-fit:cover;object-fit:cover}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}.sidebar-wrapper{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);z-index:100}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:var(--gray-100);gap:1rem}.page-header{margin-bottom:2rem;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem}.page-title{font-size:1.5rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.page-subtitle{color:var(--gray-500)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.content-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 1024px){.content-grid.two-cols{grid-template-columns:2fr 1fr}}@media (max-width: 1023px){.mobile-header{display:flex}.main-content{margin-left:0;padding-top:calc(var(--header-height) + 1.5rem);padding-left:1.5rem;padding-right:1.5rem;padding-bottom:1.5rem}.sidebar-wrapper{transform:translate(-100%);transition:transform .3s ease}.sidebar-wrapper.open{transform:translate(0)}.sidebar-overlay{display:block;opacity:0;pointer-events:none;transition:opacity .3s ease}.sidebar-wrapper.open+.main-content .sidebar-overlay,.layout:has(.sidebar-wrapper.open) .sidebar-overlay{opacity:1;pointer-events:auto}.layout .sidebar-overlay{display:block}.page-header{flex-direction:column;align-items:stretch}.header-actions{display:flex;gap:.5rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}}@media (max-width: 639px){.main-content{padding:1rem;padding-top:calc(var(--header-height) + 1rem)}.page-title{font-size:1.25rem}.stats-grid{grid-template-columns:1fr}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{min-width:600px}.card{padding:1rem}.btn{padding:.5rem .75rem;font-size:.8125rem}.modal{max-width:calc(100vw - 2rem);max-height:calc(100vh - 2rem);margin:1rem}.modal-body{padding:1rem}.form-row{flex-direction:column}.form-row .form-group{width:100%}}@media (max-width: 399px){.mobile-logo span{display:none}.header-actions{flex-wrap:wrap}}.login-page{min-height:100vh;display:flex;position:relative;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%)}.login-container{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;z-index:1}.login-card{width:100%;max-width:400px;background:#fff;border-radius:1rem;box-shadow:0 20px 50px #0000004d;overflow:hidden}.login-header{text-align:center;padding:2.5rem 2rem 1.5rem;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.login-logo-img{width:5rem;height:5rem;margin:0 auto 1rem;border-radius:50%;-o-object-fit:cover;object-fit:cover;box-shadow:0 4px 12px #0000001a}.login-header h1{font-size:1.5rem;font-weight:700;color:var(--gray-900);margin-bottom:.25rem}.login-header p{color:var(--gray-500);font-size:.875rem}.login-form{padding:2rem}.login-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.875rem;margin-bottom:1.5rem}.login-button{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;background:var(--primary);color:#fff;font-size:1rem;font-weight:600;border:none;border-radius:.5rem;cursor:pointer;transition:background .15s;margin-top:1.5rem}.login-button:hover:not(:disabled){background:var(--primary-dark)}.login-button:disabled{opacity:.7;cursor:not-allowed}.loading-spinner-small{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.login-footer{text-align:center;padding:1.5rem;background:var(--gray-50);border-top:1px solid var(--gray-200)}.login-footer p{color:var(--gray-500);font-size:.75rem}.login-bg{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.1;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='1'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.dashboard-page{max-width:1400px;margin:0 auto}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:.75rem;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px #0000001a;transition:transform .15s,box-shadow .15s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-icon-wrapper{width:3.5rem;height:3.5rem;display:flex;align-items:center;justify-content:center;border-radius:.75rem;color:#fff}.stat-primary .stat-icon-wrapper{background:var(--primary)}.stat-success .stat-icon-wrapper{background:var(--success)}.stat-danger .stat-icon-wrapper{background:var(--danger)}.stat-warning .stat-icon-wrapper{background:var(--warning)}.stat-content{flex:1}.stat-value{font-size:1.75rem;font-weight:700;color:var(--gray-900);line-height:1;margin-bottom:.25rem}.stat-label{font-size:.875rem;color:var(--gray-500)}.dashboard-section{margin-bottom:2rem}.section-title{font-size:1.125rem;font-weight:600;color:var(--gray-900);margin-bottom:1rem}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.quick-action-card{background:#fff;border-radius:.5rem;padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;text-decoration:none;color:var(--gray-700);box-shadow:0 1px 3px #0000001a;transition:all .15s}.quick-action-card:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}.quick-action-card span{font-size:.875rem;font-weight:500}.devices-page{max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.device-stats{display:flex;gap:1rem;margin-bottom:1.5rem}.stat-item{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .15s}.stat-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.stat-item.online{color:var(--success)}.stat-item.offline{color:var(--danger)}.stat-value{font-size:1.5rem;font-weight:700}.stat-label{color:var(--gray-500);font-size:.875rem}.toolbar{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.search-box{flex:1;min-width:250px;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.search-box input{flex:1;border:none;outline:none;font-size:.875rem}.search-box svg{color:var(--gray-400)}.filter-tabs{display:flex;background:#fff;border-radius:.5rem;overflow:hidden;box-shadow:0 1px 3px #0000001a}.filter-tabs button{padding:.75rem 1.25rem;border:none;background:none;cursor:pointer;font-size:.875rem;color:var(--gray-600);transition:all .15s}.filter-tabs button:hover{background:var(--gray-100)}.filter-tabs button.active{background:var(--primary);color:#fff}.device-list{display:flex;flex-direction:column;gap:.75rem}.device-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .15s}.device-card:hover{background:var(--gray-50);transform:translate(4px)}.device-icon{position:relative;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border-radius:.5rem;color:var(--gray-600)}.status-dot{position:absolute;top:-2px;right:-2px;width:12px;height:12px;border-radius:50%;border:2px solid white}.status-dot.online{background:var(--success)}.status-dot.offline{background:var(--gray-400)}.device-info{flex:1}.device-name{font-weight:600;color:var(--gray-900);margin-bottom:.25rem}.device-meta{font-size:.75rem;color:var(--gray-500);display:flex;gap:.5rem}.chevron{color:var(--gray-400)}.loading,.empty{text-align:center;padding:3rem;color:var(--gray-500);background:#fff;border-radius:.5rem}@media (max-width: 768px){.device-stats{flex-wrap:wrap}.stat-item{flex:1;min-width:100px;padding:.75rem 1rem}.stat-value{font-size:1.25rem}.search-box{min-width:100%}.filter-tabs{width:100%}.filter-tabs button{flex:1;padding:.625rem .5rem;font-size:.8125rem}.device-card,.device-meta{flex-wrap:wrap}}@media (max-width: 480px){.stat-item{min-width:calc(50% - .5rem)}.header-actions .btn{white-space:nowrap}.header-actions .btn span{display:none}}.alert-panel{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.alert-panel-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-200)}.alert-panel-header-content{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.alert-panel-title{font-size:1.125rem;font-weight:600;color:var(--gray-900);display:flex;align-items:center;gap:.5rem}.alert-panel-count{font-size:.875rem;color:var(--gray-500);font-weight:400}.alert-filter-buttons{display:flex;gap:.5rem}.alert-filter-btn{padding:.5rem 1rem;font-size:.875rem;border-radius:.375rem;border:none;cursor:pointer;transition:all .15s;background:var(--gray-200);color:var(--gray-700)}.alert-filter-btn:hover{background:var(--gray-300)}.alert-filter-btn.active{background:var(--primary);color:#fff}.alert-list{max-height:400px;overflow-y:auto}.alert-item{padding:1rem 1.5rem;border-bottom:1px solid var(--gray-100);transition:background .1s}.alert-item:hover{background:var(--gray-50)}.alert-item:last-child{border-bottom:none}.alert-item-content{display:flex;gap:.75rem}.alert-severity-icon{padding:.5rem;border-radius:.5rem;flex-shrink:0}.alert-severity-icon.critical{background:#fee2e2;color:#dc2626}.alert-severity-icon.warning{background:#fef3c7;color:#d97706}.alert-severity-icon.info{background:#dbeafe;color:#2563eb}.alert-body{flex:1;min-width:0}.alert-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.alert-type{font-weight:500;color:var(--gray-900);font-size:.9375rem}.alert-time{font-size:.75rem;color:var(--gray-500)}.alert-message{font-size:.875rem;color:var(--gray-600);margin-top:.25rem}.alert-meta{margin-top:.5rem;display:flex;flex-direction:column;gap:.5rem}.alert-meta-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.alert-device-id{font-size:.75rem;color:var(--gray-500)}.alert-badge{display:inline-flex;align-items:center;padding:.25rem .5rem;font-size:.6875rem;font-weight:500;border-radius:.25rem}.alert-badge.line-sent{background:#d1fae5;color:#065f46}.alert-badge.acknowledged{background:var(--gray-200);color:var(--gray-600)}.alert-map-link{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--primary);background:none;border:none;cursor:pointer;padding:0}.alert-map-link:hover{text-decoration:underline}.alert-acknowledge-btn{margin-top:.5rem;font-size:.75rem;font-weight:500;color:var(--primary);background:none;border:none;cursor:pointer;padding:0}.alert-acknowledge-btn:hover{text-decoration:underline}.alert-empty{padding:3rem;text-align:center;color:var(--gray-400)}.alert-loading{padding:3rem;text-align:center}.alert-loading-content{display:flex;flex-direction:column;align-items:center;gap:.75rem}.alert-pagination{padding:1rem 1.5rem;border-top:1px solid var(--gray-100);background:var(--gray-50)}.device-detail-page{max-width:1400px;margin:0 auto}.detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:1px solid var(--gray-200);border-radius:.5rem;cursor:pointer;color:var(--gray-700);font-size:.875rem;transition:all .15s}.back-btn:hover{background:var(--gray-50);border-color:var(--gray-300)}.header-info{flex:1}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:500}.status-badge.online{background:#d1fae5;color:#065f46}.status-badge.offline{background:var(--gray-200);color:var(--gray-600)}.info-row{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:1.5rem}@media (min-width: 1024px){.info-row{grid-template-columns:1fr 1fr}}.card{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--gray-100)}.card-header h3{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--gray-900);margin:0}.btn-icon{padding:.5rem;background:none;border:none;border-radius:.375rem;cursor:pointer;color:var(--gray-500);transition:all .15s}.btn-icon:hover{background:var(--gray-100);color:var(--gray-700)}.device-info-card .info-grid{padding:1.25rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem}.info-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.info-item .label{color:var(--gray-500);min-width:60px}.info-item .value{color:var(--gray-900);font-weight:500}.info-item svg{color:var(--gray-400);flex-shrink:0}.health-card .health-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1.25rem}.health-item{text-align:center;padding:1rem;background:var(--gray-50);border-radius:.5rem}.health-item svg{margin-bottom:.5rem}.health-item svg.text-red{color:#ef4444}.health-item svg.text-purple{color:#8b5cf6}.health-item svg.text-orange{color:#f97316}.health-value{font-size:1.5rem;font-weight:700;color:var(--gray-900)}.health-unit{font-size:.75rem;font-weight:400;color:var(--gray-500);margin-left:.25rem}.health-label{font-size:.75rem;color:var(--gray-500);margin-top:.25rem}.health-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.25rem;gap:1rem}.health-loading p{color:var(--gray-500);font-size:.875rem;margin:0}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tabs{display:flex;gap:.25rem;background:#fff;padding:.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem;overflow-x:auto}.tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;background:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--gray-600);white-space:nowrap;transition:all .15s}.tab:hover{background:var(--gray-100);color:var(--gray-900)}.tab.active{background:var(--primary);color:#fff}.tab-content .card{padding:1.25rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--gray-700);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--gray-100)}.cmd-message{padding:.75rem 1rem;border-radius:.5rem;font-size:.875rem;margin-bottom:1rem}.cmd-message.success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.cmd-message.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.command-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem}@media (min-width: 768px){.command-grid{grid-template-columns:repeat(4,1fr)}}.command-btn{display:flex;align-items:center;gap:.75rem;padding:1rem;border:none;border-radius:.5rem;cursor:pointer;color:#fff;text-align:left;transition:all .15s}.command-btn:disabled{opacity:.5;cursor:not-allowed}.command-btn.blue{background:#3b82f6}.command-btn.blue:hover:not(:disabled){background:#2563eb}.command-btn.purple{background:#8b5cf6}.command-btn.purple:hover:not(:disabled){background:#7c3aed}.command-btn.red{background:#ef4444}.command-btn.red:hover:not(:disabled){background:#dc2626}.command-btn.orange{background:#f97316}.command-btn.orange:hover:not(:disabled){background:#ea580c}.cmd-text{display:flex;flex-direction:column}.cmd-label{font-weight:500;font-size:.875rem}.cmd-desc{font-size:.7rem;opacity:.85}.settings-grid{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--gray-50);border-radius:.5rem;flex-wrap:wrap;gap:1rem}.setting-info{display:flex;align-items:center;gap:.75rem}.setting-info svg{color:var(--gray-500)}.setting-label{font-size:.875rem;font-weight:500;color:var(--gray-900)}.setting-desc{font-size:.75rem;color:var(--gray-500)}.setting-control{display:flex;align-items:center;gap:.5rem}.setting-control input[type=number]{width:80px;padding:.5rem;border:1px solid var(--gray-300);border-radius:.375rem;font-size:.875rem}.setting-control .unit{font-size:.875rem;color:var(--gray-500)}.sos-form{background:var(--gray-50);padding:1rem;border-radius:.5rem}.sos-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.sos-input{display:flex;align-items:center;gap:.5rem;background:#fff;padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:.375rem;flex:1;min-width:150px}.sos-input svg{color:var(--gray-400)}.sos-input input{border:none;outline:none;flex:1;font-size:.875rem}.logs-section{padding:0!important}.logs-toolbar{display:flex;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--gray-100);flex-wrap:wrap}.filter-input{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:.375rem;flex:1;min-width:200px}.filter-input svg{color:var(--gray-400)}.filter-input input{border:none;background:transparent;outline:none;font-size:.875rem;flex:1}.logs-toolbar select{padding:.5rem .75rem;border:1px solid var(--gray-200);border-radius:.375rem;font-size:.875rem;background:#fff}.logs-table-wrapper{overflow-x:auto}.logs-table{width:100%;border-collapse:collapse}.logs-table th,.logs-table td{padding:.75rem 1.25rem;text-align:left;border-bottom:1px solid var(--gray-100)}.logs-table th{background:var(--gray-50);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500)}.logs-table tbody tr:hover{background:var(--gray-50)}.time-cell{font-size:.875rem;color:var(--gray-500);white-space:nowrap}.command-cell .command-info{display:flex;align-items:center;gap:.5rem}.cmd-icon{font-size:1.25rem}.cmd-name{display:block;font-size:.875rem;font-weight:500;color:var(--gray-900)}.cmd-code{display:block;font-size:.75rem;color:var(--gray-500)}.data-cell{font-size:.875rem}.data-item{display:flex;align-items:center;gap:.375rem;margin-bottom:.25rem}.data-item svg{color:var(--info)}.data-item.alert{color:var(--warning)}.map-link{display:inline-flex;align-items:center;gap:.25rem;color:var(--info);background:none;border:none;cursor:pointer;font-size:.875rem}.map-link:hover{text-decoration:underline}.map-link svg{opacity:0;transition:opacity .15s}.map-link:hover svg{opacity:1}.loading-cell,.empty-cell{text-align:center;color:var(--gray-500);padding:2rem!important}.voice-list{display:flex;flex-direction:column;gap:.75rem}.voice-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--gray-50);border-radius:.5rem}.play-btn{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .15s}.play-btn:hover{background:var(--primary-dark);transform:scale(1.05)}.play-btn.playing{background:var(--success)}.voice-info{flex:1}.voice-time{font-size:.875rem;font-weight:500;color:var(--gray-900)}.voice-duration{font-size:.75rem;color:var(--gray-500)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--gray-400)}.empty-state svg{margin-bottom:1rem}.empty-state p{font-size:.875rem;color:var(--gray-500)}.toggle-list{display:flex;flex-direction:column;gap:1rem}.toggle-item{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--gray-50);border-radius:.5rem}.toggle-info{display:flex;align-items:center;gap:.75rem}.toggle-info svg{color:var(--gray-500)}.toggle-label{font-size:.875rem;font-weight:500;color:var(--gray-900)}.toggle-desc{font-size:.75rem;color:var(--gray-500)}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--gray-300);transition:.3s;border-radius:26px}.health-chart-wrapper{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.health-chart-wrapper>div{border-radius:.75rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem;color:var(--gray-500)}.not-found{text-align:center;padding:3rem}.not-found h2{font-size:1.25rem;color:var(--gray-900);margin-bottom:.5rem}.not-found p{color:var(--gray-500);margin-bottom:1.5rem}@media (max-width: 1023px){.detail-header{flex-direction:column;align-items:flex-start}.header-info{width:100%}.status-badge{align-self:flex-start}.health-card .health-grid{grid-template-columns:repeat(3,1fr)}.tabs{padding:.375rem}.tab{padding:.625rem 1rem;font-size:.8125rem}.logs-table th,.logs-table td{padding:.625rem 1rem}}@media (max-width: 767px){.device-info-card .info-grid{grid-template-columns:1fr}.health-card .health-grid{grid-template-columns:1fr;gap:.75rem}.health-item{display:flex;align-items:center;justify-content:space-between;text-align:left;padding:.75rem 1rem}.health-item svg{margin-bottom:0;margin-right:.75rem}.health-value{font-size:1.25rem}.tabs{gap:0}.tab{padding:.5rem .75rem;font-size:.75rem;gap:.25rem}.tab svg{width:16px;height:16px}.command-btn{padding:.75rem}.cmd-label{font-size:.8125rem}.cmd-desc{display:none}.setting-row{flex-direction:column;align-items:flex-start}.setting-control{width:100%;justify-content:flex-end}.sos-row{flex-direction:column}.sos-input{width:100%}.logs-toolbar{flex-direction:column}.filter-input{min-width:100%}.logs-table{min-width:600px}.voice-item,.toggle-item{flex-wrap:wrap}.toggle-info{flex:1;min-width:200px}}@media (max-width: 479px){.back-btn span{display:none}.page-title{font-size:1.125rem}.tab span{display:none}.command-grid{grid-template-columns:1fr}.command-btn{justify-content:center}.cmd-text{text-align:center}}.map-page{display:flex;flex-direction:column;height:calc(100vh - 4rem)}.page-subtitle .refresh-time{margin-left:.5rem;font-size:.75rem;color:var(--gray-400)}.map-stats{display:flex;gap:1.5rem;margin-bottom:1rem;padding:1rem;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.map-stats .stat{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--gray-600)}.map-stats .stat.online{color:var(--success)}.map-stats .stat.offline{color:var(--danger)}.map-container{flex:1;background:#fff;border-radius:.5rem;overflow:hidden;box-shadow:0 1px 3px #0000001a}.map{width:100%;height:100%;min-height:500px}.loading{display:flex;align-items:center;justify-content:center;height:100%;min-height:500px;color:var(--gray-500)}.loading-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.custom-marker{background:transparent;border:none}.map-marker{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid white;box-shadow:0 2px 6px #0000004d}.map-marker.online{background:var(--success)}.map-marker.offline{background:var(--gray-400)}.marker-dot{width:8px;height:8px;background:#fff;border-radius:50%}.marker-popup{font-size:.875rem}.marker-popup .online{color:var(--success)}.marker-popup .offline{color:var(--danger)}.leaflet-popup-content-wrapper{border-radius:.5rem}.leaflet-popup-content{margin:.75rem 1rem}@media (max-width: 1023px){.map-page{height:calc(100vh - var(--header-height) - 2rem)}}@media (max-width: 768px){.map-stats{flex-wrap:wrap;gap:.75rem;padding:.75rem}.map-stats .stat{font-size:.8125rem}.map{min-height:400px}}@media (max-width: 480px){.map-stats{flex-direction:column;gap:.5rem}.map{min-height:300px}}.users-page{max-width:1400px;margin:0 auto}.toolbar{margin-bottom:1.5rem}.search-box{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;max-width:400px;border:1px solid var(--gray-200);transition:all .15s}.limit-select:focus{outline:none;border-color:var(--primary)}.table-user-cell{display:flex;align-items:center;gap:.875rem}.table-avatar{width:2.75rem;height:2.75rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.125rem;flex-shrink:0}.table-user-info{min-width:0}.table-user-name{font-weight:600;color:var(--gray-900);font-size:.9375rem}.table-user-username{font-size:.8125rem;color:var(--gray-500);margin-top:.125rem}.email-cell{color:var(--gray-600);font-size:.875rem}.date-cell{color:var(--gray-500);font-size:.8125rem;white-space:nowrap}.role-badge{display:inline-flex;padding:.375rem .875rem;font-size:.75rem;font-weight:500;border-radius:.375rem;background:var(--gray-100);color:var(--gray-700)}.form-label .hint{font-weight:400;color:var(--gray-400);font-size:.75rem}.form-input:disabled{background:var(--gray-100);color:var(--gray-500);cursor:not-allowed}.toggle-wrapper{display:flex;align-items:center;gap:.75rem;padding-top:.5rem}@media (max-width: 1023px){.toolbar{flex-direction:column}.search-box{max-width:100%}.data-table th,.data-table td{padding:.75rem 1rem}}@media (max-width: 767px){.data-table{min-width:700px}.table-user-cell{min-width:150px}.modal{max-width:calc(100vw - 2rem);margin:1rem}.modal-body{padding:1rem}.form-row{flex-direction:column}.form-row .form-group{width:100%}.modal-footer{padding:1rem;flex-wrap:wrap}.modal-footer .btn{flex:1;min-width:100px}}@media (max-width: 479px){.header-actions{width:100%;justify-content:flex-end}.btn{padding:.5rem .75rem;font-size:.8125rem}.limit-select{width:100%}}.roles-page{max-width:1400px;margin:0 auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.header-actions{display:flex;gap:.75rem}.spin{animation:spin 1s linear infinite}.toolbar{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;flex:1;max-width:400px;border:1px solid var(--gray-200);transition:all .15s}.search-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-100)}.search-box input{flex:1;border:none;outline:none;font-size:.875rem;background:transparent}.search-box svg{color:var(--gray-400);flex-shrink:0}.limit-select{padding:.75rem 1rem;background:#fff;border:1px solid var(--gray-200);border-radius:.5rem;font-size:.875rem;color:var(--gray-700);cursor:pointer}.table-card{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:1rem 1.25rem;text-align:left;border-bottom:1px solid var(--gray-100)}.data-table th{background:var(--gray-50);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);white-space:nowrap}.data-table tbody tr{transition:background .1s}.data-table tbody tr:hover{background:var(--gray-50)}.data-table tbody tr.system-row{background:#8b5cf60d}.data-table tbody tr:last-child td{border-bottom:none}.role-cell{display:flex;align-items:center;gap:.875rem}.role-icon{width:2.5rem;height:2.5rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.role-info{min-width:0}.role-name{font-weight:600;color:var(--gray-900);font-size:.9375rem}.role-code{font-size:.8125rem;color:var(--gray-500);margin-top:.125rem}.desc-cell{color:var(--gray-600);font-size:.875rem;max-width:300px}.text-muted{color:var(--gray-400);font-style:italic}.permission-badge{display:inline-flex;padding:.375rem .75rem;font-size:.75rem;font-weight:500;border-radius:.375rem;background:var(--primary-100);color:var(--primary)}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:500;border-radius:9999px}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:var(--gray-200);color:var(--gray-600)}.system-badge{display:inline-flex;margin-left:.5rem;padding:.25rem .5rem;font-size:.6875rem;font-weight:600;border-radius:.25rem;background:var(--gray-200);color:var(--gray-600)}.actions-col{width:100px}.actions-cell{display:flex;gap:.375rem;justify-content:flex-end}.action-btn{width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:.5rem;cursor:pointer;color:var(--gray-500);transition:all .15s}.action-btn:hover{background:var(--gray-100);color:var(--gray-700)}.action-btn.edit:hover{background:#dbeafe;color:#2563eb}.action-btn.delete:hover{background:#fee2e2;color:#dc2626}.loading-cell,.empty-cell{padding:3rem!important;color:var(--gray-400);text-align:center!important;vertical-align:middle!important}.loading-cell>div,.empty-cell>div{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;width:100%}.loading-spinner{width:32px;height:32px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.empty-cell p{font-size:.875rem;margin:0}.table-footer{padding:1rem 1.25rem;border-top:1px solid var(--gray-100);background:var(--gray-50)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal{background:#fff;border-radius:1rem;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 60px #00000040}.modal.modal-lg{max-width:700px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-100)}.modal-header h2{font-size:1.25rem;font-weight:600;color:var(--gray-900)}.close-btn{background:none;border:none;cursor:pointer;color:var(--gray-400);padding:.375rem;border-radius:.375rem;transition:all .15s}.close-btn:hover{background:var(--gray-100);color:var(--gray-700)}.modal-body{padding:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.form-input{width:100%;padding:.75rem 1rem;font-size:.875rem;border:1px solid var(--gray-300);border-radius:.5rem;background:#fff;transition:all .15s}.form-input:disabled{background:var(--gray-100);color:var(--gray-500)}textarea.form-input{resize:vertical;min-height:60px}.permissions-matrix{border:1px solid var(--gray-200);border-radius:.5rem;overflow:hidden}.permissions-matrix table{width:100%;border-collapse:collapse}.permissions-matrix th,.permissions-matrix td{padding:.75rem;text-align:center;border-bottom:1px solid var(--gray-100)}.permissions-matrix th{background:var(--gray-50);font-size:.75rem;font-weight:600;color:var(--gray-600)}.permissions-matrix th:first-child,.permissions-matrix td:first-child{text-align:left;font-weight:500}.permissions-matrix tr:last-child td{border-bottom:none}.module-label{font-size:.875rem;color:var(--gray-900)}.checkbox-cell{width:60px;text-align:center}.checkbox-cell input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:var(--primary)}.toggle-wrapper{display:flex;align-items:center;gap:.75rem}.toggle-label{font-size:.875rem;color:var(--gray-700)}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background-color:var(--gray-300);transition:.3s;border-radius:26px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.slider{background-color:var(--success)}.toggle-switch input:checked+.slider:before{transform:translate(22px)}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--gray-100);background:var(--gray-50);border-radius:0 0 1rem 1rem}@media (max-width: 1023px){.search-box{max-width:100%}.data-table th,.data-table td{padding:.75rem 1rem}}@media (max-width: 767px){.data-table{min-width:600px}.role-cell{min-width:150px}.modal{max-width:calc(100vw - 2rem);margin:1rem}.modal-lg{max-width:calc(100vw - 2rem)}.modal-body{padding:1rem}.form-row{flex-direction:column}.form-row .form-group{width:100%}.permissions-matrix{overflow-x:auto}.permissions-matrix table{min-width:500px}.permissions-matrix th,.permissions-matrix td{padding:.5rem;font-size:.75rem}.modal-footer{padding:1rem;flex-wrap:wrap}.modal-footer .btn{flex:1;min-width:100px}}@media (max-width: 479px){.header-actions{width:100%;justify-content:flex-end}.btn{padding:.5rem .75rem;font-size:.8125rem}.limit-select{width:100%}.toolbar{flex-direction:column}}:root{--primary: #8a1f1d;--primary-dark: #6b1816;--primary-light: #b33d3a;--primary-50: #fef2f2;--primary-100: #fee2e2;--primary-200: #fecaca;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--sidebar-bg: #1f2937;--sidebar-hover: #374151;--sidebar-active: var(--primary);--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--sidebar-width: 260px;--header-height: 64px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--gray-100);color:var(--gray-900);line-height:1.5}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:.375rem;border:none;cursor:pointer;transition:all .15s ease}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-dark)}.btn-secondary{background-color:var(--gray-200);color:var(--gray-700)}.btn-secondary:hover{background-color:var(--gray-300)}.btn-danger{background-color:var(--danger);color:#fff}.btn-danger:hover{background-color:#dc2626}.card{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.card-title{font-size:1.125rem;font-weight:600;color:var(--gray-900)}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:500;border-radius:9999px}.badge-success{background-color:#d1fae5;color:#065f46}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-info{background-color:#dbeafe;color:#1e40af}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:var(--gray-700)}.form-input{width:100%;padding:.625rem .875rem;font-size:.875rem;border:1px solid var(--gray-300);border-radius:.375rem;background-color:#fff;transition:border-color .15s,box-shadow .15s}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-100)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--gray-200)}.table th{background-color:var(--gray-50);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500)}.table tbody tr:hover{background-color:var(--gray-50)}.stat-card{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.stat-card .stat-icon{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;border-radius:.5rem;font-size:1.5rem}.stat-card .stat-value{font-size:2rem;font-weight:700;color:var(--gray-900)}.stat-card .stat-label{font-size:.875rem;color:var(--gray-500)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.flex{display:flex}.justify-between{justify-content:space-between}.flex-1{flex:1}.hidden{display:none}.relative{position:relative}.z-10{z-index:10}.text-sm{font-size:.875rem}.rounded-md{border-radius:.375rem}.rounded-l-md{border-top-left-radius:.375rem;border-bottom-left-radius:.375rem}.rounded-r-md{border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}.-space-x-px>*+*{margin-left:-1px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.flex.items-center.justify-between{padding:1rem 1.25rem;border-top:1px solid var(--gray-200);background:#fff}@media (min-width: 640px){.sm\:hidden{display:none!important}.sm\:flex{display:flex!important}.sm\:flex-1{flex:1!important}.sm\:items-center{align-items:center!important}.sm\:justify-between{justify-content:space-between!important}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}.text-gray-500{color:var(--gray-500)}.px-2{padding-left:.5rem;padding-right:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.ml-3{margin-left:.75rem}.border{border-width:1px;border-style:solid}.border-t{border-top-width:1px;border-top-style:solid}.border-blue-500{border-color:var(--info)}.bg-gray-50{background-color:var(--gray-50)}.bg-blue-50{background-color:#eff6ff}.text-blue-600{color:var(--info)}.h-5{height:1.25rem}.w-5{width:1.25rem}[class*=inline-flex][class*=items-center][class*=border][class*=bg-white]{display:inline-flex;align-items:center;background-color:#fff;border:1px solid var(--gray-300);font-size:.875rem;font-weight:500;color:var(--gray-700);cursor:pointer;transition:all .15s}[class*=inline-flex][class*=items-center][class*=border][class*=bg-white]:hover:not(:disabled){background-color:var(--gray-50)}[class*=inline-flex][class*=items-center][class*=border][class*=bg-white]:disabled{opacity:.5;cursor:not-allowed}[class*=bg-blue-50][class*=border-blue-500][class*=text-blue-600]{background-color:var(--primary-50)!important;border-color:var(--primary)!important;color:var(--primary)!important}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.space-y-4>*+*{margin-top:1rem}.space-y-1>*+*{margin-top:.25rem}.w-3{width:.75rem}.h-3{height:.75rem}.w-4{width:1rem}.h-4{height:1rem}.w-full{width:100%}.w-3\/4{width:75%}.transition-opacity{transition:opacity .15s}.opacity-0{opacity:0}.group:hover .group-hover\:opacity-100{opacity:1}.focus\:ring-2:focus{box-shadow:0 0 0 2px}.focus\:ring-blue-500:focus{box-shadow:0 0 0 2px var(--info)}.focus\:border-transparent:focus{border-color:transparent}.rounded{border-radius:.25rem}.text-orange-600{color:#ea580c}.text-blue-600,.text-blue-500{color:var(--info)}.text-blue-800{color:#1e40af}.text-green-800{color:#166534}.text-red-800{color:#991b1b}.text-red-600{color:#dc2626}.bg-green-50{background-color:#f0fdf4}.bg-red-50{background-color:#fef2f2}.bg-green-200{background-color:#bbf7d0}.bg-red-200{background-color:#fecaca}.bg-gray-200{background-color:var(--gray-200)}.bg-blue-500{background-color:#3b82f6}.bg-purple-500{background-color:#8b5cf6}.bg-purple-600{background-color:#7c3aed}.bg-red-500{background-color:#ef4444}.bg-red-600{background-color:#dc2626}.bg-orange-500{background-color:#f97316}.bg-orange-600{background-color:#ea580c}.bg-green-500{background-color:#22c55e}.bg-green-600{background-color:#16a34a}.bg-teal-500{background-color:#14b8a6}.bg-teal-600{background-color:#0d9488}.hover\:bg-blue-600:hover{background-color:#2563eb}.hover\:bg-purple-600:hover{background-color:#7c3aed}.hover\:bg-red-600:hover{background-color:#dc2626}.hover\:bg-orange-600:hover{background-color:#ea580c}.hover\:bg-green-600:hover{background-color:#16a34a}.hover\:bg-teal-600:hover{background-color:#0d9488}.flex-shrink-0{flex-shrink:0}.text-xs{font-size:.75rem}.text-base{font-size:1rem}.text-xl{font-size:1.25rem}.overflow-x-auto{overflow-x:auto}.divide-y>*+*{border-top-width:1px;border-top-style:solid}.divide-gray-200>*+*{border-color:var(--gray-200)}.whitespace-nowrap{white-space:nowrap}.tracking-wider{letter-spacing:.05em}.uppercase{text-transform:uppercase}.flex-col{flex-direction:column}.hover\:underline:hover{text-decoration:underline}.text-left{text-align:left}.text-center{text-align:center}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}@media (min-width: 768px){.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.gap-4{gap:1rem}.mb-1{margin-bottom:.25rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.p-6{padding:1.5rem}.pl-10{padding-left:2.5rem}.pr-4{padding-right:1rem}.h-64{height:16rem}.w-1\/2{width:50%}.text-2xl{font-size:1.5rem}.font-bold{font-weight:700}.transition-colors{transition:color .15s,background-color .15s,border-color .15s}.transform{transform:translate(0)}.-translate-y-1\/2{transform:translateY(-50%)}.top-1\/2{top:50%}.left-3{left:.75rem}.absolute{position:absolute}.shadow{box-shadow:0 1px 3px #0000001a}.border-b{border-bottom-width:1px;border-bottom-style:solid}.py-12{padding-top:3rem;padding-bottom:3rem}.bg-gray-100{background-color:var(--gray-100)}.hover\:bg-gray-200:hover{background-color:var(--gray-200)}.fixed{position:fixed}.inset-0{top:0;right:0;bottom:0;left:0}.z-50{z-index:50}.overflow-y-auto{overflow-y:auto}.bg-opacity-50{--tw-bg-opacity: .5}.bg-black{background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))}.min-h-full{min-height:100%}.items-center{align-items:center}.justify-center{justify-content:center}.p-4{padding:1rem}.max-w-4xl{max-width:56rem}.lg\:max-w-5xl{max-width:64rem}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.text-white{color:#fff}.text-gray-400{color:var(--gray-400)}.text-gray-600{color:var(--gray-600)}.text-gray-700{color:var(--gray-700)}.text-gray-900{color:var(--gray-900)}.hover\:text-gray-600:hover{color:var(--gray-600)}.bg-blue-600{background-color:#2563eb}.hover\:bg-blue-700:hover{background-color:#1d4ed8}.hover\:bg-gray-300:hover{background-color:var(--gray-300)}.w-6{width:1.5rem}.h-6{height:1.5rem}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-gray-200{border-color:var(--gray-200)}.text-lg{font-size:1.125rem;line-height:1.75rem}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-sm{font-size:.875rem;line-height:1.25rem}.mt-1{margin-top:.25rem}.ml-2{margin-left:.5rem}.gap-2{gap:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.gap-3{gap:.75rem}.inline-flex{display:inline-flex}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.border-gray-300{border-color:var(--gray-300)}.shadow-sm{box-shadow:0 1px 2px #0000000d}.hover\:shadow:hover{box-shadow:0 1px 3px #0000001a,0 1px 2px -1px #0000001a}.hover\:bg-gray-50:hover{background-color:var(--gray-50)}.focus\:ring-4:focus{box-shadow:0 0 0 4px}.focus\:ring-blue-300:focus{box-shadow:0 0 0 4px #3b82f64d}.focus\:ring-gray-200:focus{box-shadow:0 0 0 4px #e5e7eb80}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-gray-800{color:var(--gray-800)}.bg-white{background-color:#fff}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.loading-spinner{width:2.5rem;height:2.5rem;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
