.dashboard-container{padding:1rem;background-color:#f5f5f5;min-height:100vh}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));gap:1rem;margin-bottom:2rem}.stats-grid .stat-card{background:white;padding:1.5rem;border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,0.06)}.stats-grid .stat-card .stat-title{font-size:0.875rem;color:#6b7280;margin-bottom:0.5rem}.stats-grid .stat-card .stat-value{font-size:2rem;font-weight:700;color:#1f2937}.stats-grid .stat-card .stat-value.text-green{color:#10b981}.stats-grid .stat-card .stat-value.text-red{color:#ef4444}.main-grid{display:grid;grid-template-columns:1fr 400px;gap:1rem;height:calc(100vh - 250px)}.map-container{background:white;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px rgba(0,0,0,0.1);width:100%;height:400px;position:relative}#map{width:100%;height:100%}.custom-marker .marker-pin{width:25px;height:25px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:2px solid white;box-shadow:0 2px 5px rgba(0,0,0,0.3)}.custom-marker .marker-pin.normal{background-color:#10b981}.custom-marker .marker-pin.alert{background-color:#f59e0b}.custom-marker .marker-pin.tamper{background-color:#ef4444}.custom-marker .marker-pin.low_battery{background-color:#eab308}.custom-marker .marker-pin.offline{background-color:#6b7280}.custom-marker .marker-pulse{animation:pulse 2s ease-out}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:0.7}100%{transform:scale(1);opacity:1}}.sidebar{display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.sidebar .panel{background:white;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,0.1)}.sidebar .panel .panel-header{padding:1rem;border-bottom:1px solid #e5e7eb}.sidebar .panel .panel-header h3{margin:0;font-size:1.125rem;font-weight:600}.sidebar .panel .panel-body{max-height:400px;overflow-y:auto}.device-list .device-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #f3f4f6;transition:background-color 0.2s}.device-list .device-item:hover{background-color:#f9fafb}.device-list .device-item .device-name{font-weight:500;margin-bottom:0.25rem}.device-list .device-item .device-location{font-size:0.875rem;color:#6b7280}.status-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0}.status-indicator.normal{background-color:#10b981}.status-indicator.alert{background-color:#f59e0b;animation:blink 1s infinite}.status-indicator.tamper{background-color:#ef4444;animation:blink 0.5s infinite}.status-indicator.low_battery{background-color:#eab308}.status-indicator.offline{background-color:#6b7280}@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}.events-list .event-item{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;padding:1rem;border-bottom:1px solid #f3f4f6}.events-list .event-item.severity-critical,.events-list .event-item.severity-emergency{background-color:#fef2f2}.events-list .event-item .event-time{font-size:0.75rem;color:#6b7280}.events-list .event-item .event-type{font-weight:500;margin-bottom:0.25rem}.events-list .event-item .event-device{font-size:0.875rem;color:#6b7280}@media (max-width: 768px){.main-grid{grid-template-columns:1fr;height:auto}.map-container{height:400px}.sidebar{height:auto}}.badge{display:inline-block;padding:0.25em 0.6em;font-size:0.75rem;font-weight:600;line-height:1;border-radius:0.25rem;color:#fff}.badge-warning{background-color:#f0ad4e}.badge-success{background-color:#5cb85c}.badge-danger{background-color:#d9534f}.badge-secondary{background-color:#6c757d}.badge-dark{background-color:#343a40}.badge-primary{background-color:#007bff}.btn{display:inline-block;padding:0.5em 1em;font-size:1rem;font-weight:500;text-decoration:none;border:none;border-radius:0.25rem;cursor:pointer;color:#fff}.btn-primary{background-color:#007bff}.btn-success{background-color:#28a745}.btn-danger{background-color:#dc3545}.btn-info{background-color:#17a2b8}.btn-warning{background-color:#ffc107;color:#212529}.btn-secondary{background-color:#6c757d}.table{width:100%;border-collapse:collapse;margin-bottom:1rem}.table th,.table td{padding:0.75em;border:1px solid #dee2e6}.table thead{background-color:#e9ecef}.row{display:flex;flex-wrap:wrap;margin:-0.5rem}.col-md-4,.col-md-6,.col-md-8{padding:0.5rem}.col-md-4{width:33.3333%}.col-md-6{width:50%}.col-md-8{width:66.6667%}.form-control{width:100%;padding:0.5em;border:1px solid #ced4da;border-radius:0.25rem}.form-control .btn{width:100%}#flash-container{position:fixed;bottom:1rem;left:1rem;z-index:1050}.flash-message{margin-top:0.5rem;padding:0.75rem 1.25rem;border-radius:4px;color:white;animation:slide-in 0.3s ease-out}.flash-message.flash-notice{background:#28a745}.flash-message.flash-alert{background:#dc3545}@keyframes slide-in{from{transform:translateX(-100%);opacity:0}to{transform:translateX(0);opacity:1}}.devices-page .page-header{margin-bottom:1.5rem}.devices-page .page-header h1{font-size:2rem;font-weight:600;color:#102a43}.devices-page .devices-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:1.5rem}.devices-page .device-card{background:#fff;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,0.05);display:flex;flex-direction:column;transition:transform 0.2s}.devices-page .device-card:hover{transform:translateY(-4px)}.devices-page .device-card .card-header{padding:1rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.devices-page .device-card .card-header .device-name{margin:0;font-size:1.25rem;color:#334e68}.devices-page .device-card .card-body{padding:1rem;flex:1}.devices-page .device-card .card-body p{margin:0.5rem 0;font-size:0.95rem;color:#475569}.devices-page .device-card .card-body p strong{color:#102a43}.devices-page .device-card .card-footer{padding:1rem;border-top:1px solid #e5e7eb;display:flex;gap:0.5rem;justify-content:flex-end}.devices-page .device-card .card-footer .btn{font-size:0.875rem;padding:0.4rem 0.8rem}.container{max-width:960px}#device-map{height:400px}.card.h-100{display:flex;flex-direction:column}.card.h-100 .card-body{flex:1;position:relative;padding:0 !important}.card-header{background-color:#f8f9fa;font-size:1rem}dl.row dt{font-weight:500}dl.row dd{margin-bottom:0.75rem}.devise-container{max-width:400px;margin:4rem auto;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,0.05)}.devise-container h2{margin-bottom:1.5rem;font-size:1.5rem;font-weight:600;color:#102a43;text-align:center}.devise-container .form-group{margin-bottom:1.25rem}.devise-container .form-group label{display:block;margin-bottom:0.5rem;font-weight:500;color:#334e68}.devise-container .form-group input{width:95%;padding:0.5rem;border:1px solid #ced4da;border-radius:0.25rem;font-size:1rem}.devise-container .form-actions{margin-top:1.5rem;display:flex;flex-direction:row;gap:1rem;justify-content:center;align-items:center}.devise-container .form-actions .btn{padding:0.5rem 1rem}.devise-container .links{margin-top:1rem;font-size:0.875rem;text-align:center}.devise-container .links a{color:#3f83f8;text-decoration:none}.devise-container .links a:hover{text-decoration:underline}.devise-container .form-group.remember-me{display:flex;align-items:center;gap:0.5rem}.devise-container .form-group.remember-me label{margin:0;font-weight:400;font-size:0.95rem;color:#334e68}.devise-container .form-group.remember-me input[type="checkbox"]{width:auto;height:auto;accent-color:#007bff}body{font-family:'Inter', system-ui, -apple-system, sans-serif;color:#102a43;background:#f0f4f8}.row{display:flex;flex-wrap:wrap;margin:0 -0.5rem}.col{padding:0 0.5rem;flex:1 1 0%}.col-half{flex:0 0 50%;max-width:50%}.col-third{flex:0 0 33.333%;max-width:33.333%}.col-quarter{flex:0 0 25%;max-width:25%}@media (max-width: 768px){.col-half,.col-third,.col-quarter{flex:0 0 100%;max-width:100%}}.navbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:#102a43;box-shadow:0 4px 16px rgba(0,0,0,0.1)}.navbar__brand{flex:1}.navbar__logo{font-size:1.5rem;font-weight:600;color:#fff;text-decoration:none}.navbar__menu{list-style:none;display:flex;gap:1.5rem;margin:0;padding:0}.navbar__menu .navbar__item{color:#cdd9e5;font-weight:500;text-decoration:none;padding:0.5rem;transition:color 0.2s, border-bottom 0.2s}.navbar__menu .navbar__item.is-active,.navbar__menu .navbar__item:hover{color:#fff;border-bottom:2px solid #3f83f8}.navbar__actions{display:flex;align-items:center;gap:1rem}.navbar__alerts .badge{display:inline-flex;align-items:center;gap:0.25rem;background:#e74c3c;color:#fff;padding:0.25rem 0.5rem;border-radius:0.5rem;font-size:0.875rem}.navbar__alerts .badge i{font-size:1rem}.navbar__profile{position:relative}.navbar__profile .dropdown__toggle{background:none;border:none;color:#cdd9e5;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:0.25rem;padding:0.5rem;transition:color 0.2s}.navbar__profile .dropdown__toggle:hover{color:#fff}.navbar__profile .dropdown__menu{display:none;position:absolute;right:0;top:100%;background:#fff;border-radius:0.5rem;box-shadow:0 4px 12px rgba(0,0,0,0.1);list-style:none;margin:0.5rem 0 0;padding:0.5rem 0;z-index:100}.navbar__profile .dropdown__menu .dropdown__item{display:block;padding:0.5rem 1.5rem;color:#102a43;text-decoration:none;white-space:nowrap;transition:background 0.2s}.navbar__profile .dropdown__menu .dropdown__item:hover{background:#f0f4f8}.navbar__profile.show .dropdown__menu{display:block}.users-container{max-width:80rem;margin-left:auto;margin-right:auto;padding:3rem 1rem;background-color:#f8fafc}.page-header{margin-bottom:2rem}.page-header h1{letter-spacing:-0.5px}.page-header .btn-primary{padding:0.5rem 1rem;font-size:1rem}.users-table{background-color:#ffffff;border-radius:0.5rem;box-shadow:0 4px 12px rgba(0,0,0,0.05);overflow-x:auto}.users-table table{width:100%;border-collapse:separate;border-spacing:0 0.5rem}.users-table th,.users-table td{padding:1rem 1.5rem;text-align:left;vertical-align:middle}.users-table thead th{background-color:#f1f5f9;color:#4a5568;font-weight:600;font-size:0.875rem}.users-table tbody tr{background-color:#ffffff;transition:background-color 0.2s}.users-table tbody tr:hover{background-color:#f7fafc}.users-table tbody td{font-size:0.9375rem;color:#2d3748}.btn-sm{padding:0.35rem 0.75rem;font-size:0.875rem}.badge{font-size:0.75rem;padding:0.3em 0.6em}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}
