/* ===== ADMIN HEADER ===== */
.admin-header {
    background: var(--bg-panel, #fff);
    border-bottom: 1px solid var(--border-primary, #D5CFC7);
}

.admin-header-top {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.admin-agency-badge {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-sm, 8px);
    background: var(--accent-bronze, #9B7C58);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
}

/* --- Stats row --- */
.admin-stats {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    border-top: 1px solid var(--border-subtle, rgba(0,0,0,0.05));
    border-bottom: 1px solid var(--border-subtle, rgba(0,0,0,0.05));
}

.admin-stat-item {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0;
    font-size: 0.8rem;
    color: var(--text-secondary, #68707A);
}

.admin-stat-item i {
    font-size: 0.85rem;
    color: var(--text-muted, #9A938A);
}

.admin-stat-value {
    font-weight: 700;
    font-size: 1rem;
    color: var(--text-primary, #2B2F33);
}

.admin-stat-label {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text-muted, #9A938A);
}

/* --- Tab navigation --- */
.admin-nav {
    padding-top: 0.25rem;
}

.admin-tab-nav {
    display: flex;
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.admin-tab {
    display: inline-flex;
    align-items: center;
    padding: 0.6rem 1rem;
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--text-secondary, #68707A);
    text-decoration: none;
    border-bottom: 2px solid transparent;
    white-space: nowrap;
    transition: color var(--transition-fast, 0.15s ease), border-color var(--transition-fast, 0.15s ease);
}

.admin-tab:hover {
    color: var(--text-primary, #2B2F33);
    text-decoration: none;
}

.admin-tab.active {
    color: var(--accent-bronze, #9B7C58);
    border-bottom-color: var(--accent-bronze, #9B7C58);
    font-weight: 600;
}

.admin-tab i {
    font-size: 0.85rem;
}

/* ===== ADMIN SIDEBAR ===== */
.admin-sidebar {
    min-height: calc(100vh - 120px);
}

.admin-sidebar .list-group-item {
    border-radius: 0;
    border-left: 3px solid transparent;
    font-size: 0.9rem;
    padding: 0.6rem 1rem;
}

.admin-sidebar .list-group-item.active {
    background-color: var(--bg-sidebar, #EEE9E2);
    color: var(--accent-bronze, #9B7C58);
    border-left-color: var(--accent-bronze, #9B7C58);
    font-weight: 600;
}

.admin-sidebar .list-group-item:hover:not(.active) {
    background-color: var(--bg-hover, #E6E1DA);
    border-left-color: var(--border-primary, #D5CFC7);
}

.admin-content {
    padding: 1.5rem 2rem;
}

.admin-card {
    transition: transform 0.15s;
}

.admin-card:hover {
    transform: translateY(-2px);
}

#geofenceMap {
    height: 350px;
    border: 1px solid var(--border-primary, #D5CFC7);
    border-radius: var(--radius-sm, 0.375rem);
}

/* ===== Device Form Sections ===== */
.device-form-section {
    background: var(--bg-sidebar, #f8f9fa);
    border: 1px solid var(--border-primary, #e9ecef);
    border-radius: var(--radius-sm, 0.5rem);
    padding: 0.75rem 1rem;
    margin-bottom: 0.75rem;
}

.device-form-section-title {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted, #6c757d);
    margin-bottom: 0.5rem;
    padding-bottom: 0.35rem;
    border-bottom: 1px solid var(--border-primary, #dee2e6);
}

.device-form-section .form-label {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-secondary, #495057);
    margin-bottom: 0.2rem;
}

.device-form-section .form-control,
.device-form-section .form-select {
    font-size: 0.82rem;
    padding: 0.25rem 0.5rem;
}

.device-form-section .row {
    --bs-gutter-y: 0.5rem;
    --bs-gutter-x: 0.75rem;
}

.device-form-actions {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    padding-top: 1rem;
    margin-top: 0.5rem;
    border-top: 1px solid var(--border-primary, #e9ecef);
}

/* ===== Sync Status Chips (Installer device header) ===== */
.sync-chip {
    background: var(--bg-sidebar, #f0f1f3);
    border: 1px solid var(--border-primary, #e1e4e8);
    border-radius: var(--radius-sm, 0.375rem);
    padding: 0.3rem 0.65rem;
    font-size: 0.8rem;
    line-height: 1.3;
    white-space: nowrap;
}

.sync-chip-label {
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--text-muted, #6c757d);
}

/* ===== Collapsible Device List (Department / Project groups) ===== */
.dept-chevron,
.proj-chevron {
    transition: transform 0.2s ease;
}

.collapsed .dept-chevron,
.collapsed .proj-chevron {
    transform: rotate(-90deg);
}

/* ===== Installer Sidebar (Devices / Alarms list panel) ===== */
.installer-sidebar {
    width: 280px;
    min-width: 280px;
    overflow: hidden;
    transition: width 0.2s ease, min-width 0.2s ease;
}

.installer-sidebar.collapsed {
    width: 0;
    min-width: 0;
    overflow: hidden;
}

/* Center the close button vertically in alerts */
.alert-dismissible .btn-close {
    top: 50%;
    transform: translateY(-50%);
    padding: 0.5rem;
}

/* ===== Compact card forms on Installer Alarms ===== */
.installer-alarm-form .card {
    margin-bottom: 0.5rem !important;
}
.installer-alarm-form .card-header {
    padding: 0.35rem 0.75rem;
}
.installer-alarm-form .card-body {
    padding: 0.5rem 0.75rem;
}
.installer-alarm-form .card-footer {
    padding: 0.35rem 0.75rem;
}
.installer-alarm-form .form-label {
    font-size: 0.78rem;
    font-weight: 600;
    margin-bottom: 0.2rem;
}
.installer-alarm-form .form-control,
.installer-alarm-form .form-select {
    font-size: 0.82rem;
    padding: 0.25rem 0.5rem;
}
.installer-alarm-form .row {
    --bs-gutter-y: 0.5rem;
    --bs-gutter-x: 0.75rem;
}
