/* Waggi Device Analytics Dashboard Styles */

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Waggi Color Palette Variables */
:root {
    /* Background colors */
    --waggi-bg-dark: #04343C;
    --waggi-bg-teal: #004E5B;
    --waggi-bg-teal-medium: #00788C;
    --waggi-bg-cyan: #06BAD7;
    --waggi-bg-cyan-light: #70EBFF;
    --waggi-bg-cyan-lightest: #E2FBFF;
    --waggi-bg-purple: #5937CA;
    --waggi-bg-purple-light: #8B6EEC;
    --waggi-bg-purple-lightest: #F3F0FD;
    --waggi-bg-page: #F6F8F9;
    --waggi-bg-card: #FFFFFF;
    --waggi-bg-subtle: #F0F4F5;

    /* Font colors */
    --waggi-text-primary: #021316;
    --waggi-text-secondary: #5B5D6B;
    --waggi-text-tertiary: #8E909F;
    --waggi-text-teal: #104E58;

    /* Outline colors */
    --waggi-border: #D4D5DC;
    --waggi-border-light: #E8E9ED;

    /* Semantic colors */
    --waggi-info: #2C4FAC;
    --waggi-info-icon: #638FFF;
    --waggi-info-bg: #DCE6FF;
    --waggi-success: #105824;
    --waggi-success-icon: #25B90D;
    --waggi-success-bg: #DEFFE7;
    --waggi-alert: #866202;
    --waggi-alert-icon: #DB9F29;
    --waggi-alert-bg: #FFEECD;
    --waggi-error: #790707;
    --waggi-error-icon: #DB2929;
    --waggi-error-bg: #FFE7E7;

    /* Graph colors */
    --waggi-graph-1: #5937CA;
    --waggi-graph-2: #8B6EEC;
    --waggi-graph-3: #00788C;
    --waggi-graph-4: #70EBFF;
    --waggi-graph-5: #B48718;
    --waggi-graph-6: #F5C242;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
    background: var(--waggi-bg-page);
    color: var(--waggi-text-primary);
    line-height: 1.6;
}

/* Header */
.header {
    background: linear-gradient(135deg, var(--waggi-bg-dark) 0%, var(--waggi-bg-teal-medium) 100%);
    color: white;
    padding: 24px 40px;
    box-shadow: 0 4px 20px rgba(4, 52, 60, 0.15);
}

.header h1 {
    font-size: 24px;
    font-weight: 600;
    letter-spacing: -0.5px;
}

.header p {
    opacity: 0.85;
    font-size: 14px;
    color: var(--waggi-bg-cyan-light);
}

/* Compare link (on main page, next to Load Data) */
.compare-link {
    font-size: 13px;
    font-weight: 500;
    color: var(--waggi-bg-teal-medium);
    text-decoration: none;
    padding: 10px 0;
    border-bottom: 1px dashed transparent;
    transition: border-color 0.2s, color 0.2s;
    white-space: nowrap;
}

.compare-link:hover {
    color: var(--waggi-bg-teal);
    border-bottom-color: var(--waggi-bg-teal-medium);
}


/* Compare Page Styles */

/* Editable device label (dot + inline name input) */
.device-label-editable {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 6px;
}

.device-color-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.device-color-dot.dot-a {
    background: var(--waggi-bg-teal-medium);
}

.device-color-dot.dot-b {
    background: var(--waggi-bg-purple);
}

.config-group .device-name-input,
.config-group .device-name-input:focus,
.config-group .device-name-input:hover {
    background: transparent;
    border: none;
    border-radius: 0;
    outline: none;
    box-shadow: none;
    font-size: 13px;
    font-weight: 500;
    color: var(--waggi-text-secondary);
    width: auto;
    flex: 1;
    padding: 0;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s, color 0.2s;
    cursor: text;
    background-image: none;
}

.config-group .device-name-input:hover {
    border-bottom-color: var(--waggi-border);
}

.config-group .device-name-input:focus {
    border-bottom-color: var(--waggi-text-secondary);
    color: var(--waggi-text-primary);
}

/* Compare Stats */
.compare-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}

@media (max-width: 700px) {
    .compare-stats-grid {
        grid-template-columns: 1fr;
    }
}

.compare-stat-card {
    background: var(--waggi-bg-card);
    border-radius: 12px;
    padding: 16px 12px;
    box-shadow: 0 1px 4px rgba(4, 52, 60, 0.06);
    border: 1px solid var(--waggi-border-light);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}

.compare-stat-card h4 {
    font-size: 10px;
    text-transform: uppercase;
    color: var(--waggi-text-tertiary);
    letter-spacing: 0.6px;
    font-weight: 600;
    margin: 0;
    text-align: center;
}

.compare-stat-values {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
}

.compare-stat-device {
    text-align: center;
    flex: 1;
    min-width: 0;
}

.compare-stat-device .device-label {
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    margin-bottom: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
}

.compare-stat-device .device-label::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    flex-shrink: 0;
}

.compare-stat-device.device-a .device-label {
    color: var(--waggi-bg-teal-medium);
}

.compare-stat-device.device-a .device-label::before {
    background: var(--waggi-bg-teal-medium);
}

.compare-stat-device.device-b .device-label {
    color: var(--waggi-bg-purple);
}

.compare-stat-device.device-b .device-label::before {
    background: var(--waggi-bg-purple);
}

.compare-stat-device .stat-val {
    font-size: 18px;
    font-weight: 700;
    color: var(--waggi-text-primary);
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.compare-stat-diff {
    font-size: 11px;
    font-weight: 600;
    padding: 3px 8px;
    border-radius: 20px;
    white-space: nowrap;
    flex-shrink: 0;
    line-height: 1.3;
}

.compare-stat-diff.positive {
    background: var(--waggi-success-bg);
    color: var(--waggi-success);
}

.compare-stat-diff.negative {
    background: var(--waggi-error-bg);
    color: var(--waggi-error);
}

.compare-stat-diff.neutral {
    background: var(--waggi-bg-subtle);
    color: var(--waggi-text-tertiary);
}

/* Compare Charts */
.compare-charts-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 24px;
}

.compare-charts-grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

.compare-chart-card {
    background: var(--waggi-bg-card);
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(4, 52, 60, 0.06);
    border: 1px solid var(--waggi-border-light);
}

.compare-chart-card h3 {
    font-size: 14px;
    font-weight: 600;
    color: var(--waggi-text-primary);
    margin-bottom: 12px;
}

.compare-chart-card .chart-container {
    height: 280px;
    position: relative;
}

.compare-chart-full {
    grid-column: 1 / -1;
}

/* Compare Legend */
.compare-legend {
    display: flex;
    gap: 20px;
    justify-content: center;
    margin-bottom: 20px;
}

.compare-legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--waggi-text-secondary);
}

.compare-legend-swatch {
    width: 12px;
    height: 3px;
    border-radius: 2px;
}

.compare-legend-swatch.device-a {
    background: var(--waggi-bg-teal-medium);
}

.compare-legend-swatch.device-b {
    background: var(--waggi-bg-purple);
}

/* Compare loading */
.compare-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    color: var(--waggi-text-secondary);
    gap: 12px;
}

@media (max-width: 900px) {
    .compare-charts-grid {
        grid-template-columns: 1fr;
    }
    .compare-charts-grid-3 {
        grid-template-columns: 1fr;
    }
}

/* Container */
.container {
    max-width: 100%;
    margin: 0 auto;
    padding: 20px;
}

/* Config Panel */
.config-panel {
    background: var(--waggi-bg-card);
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 24px;
    box-shadow: 0 2px 8px rgba(4, 52, 60, 0.06);
    border: 1px solid var(--waggi-border-light);
    transition: box-shadow 0.3s ease;
}

.config-panel:hover {
    box-shadow: 0 4px 16px rgba(4, 52, 60, 0.1);
}

.config-panel h3 {
    margin-bottom: 16px;
    color: var(--waggi-text-teal);
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    font-weight: 600;
}

.config-row {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
    align-items: flex-end;
}

.config-group {
    flex: 1;
    min-width: 200px;
}

.config-group label {
    display: block;
    margin-bottom: 6px;
    font-size: 13px;
    color: var(--waggi-text-secondary);
    font-weight: 500;
}

.config-group input,
.config-group select {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--waggi-border);
    border-radius: 8px;
    font-size: 14px;
    color: var(--waggi-text-primary);
    background: var(--waggi-bg-card);
    transition: border-color 0.2s, box-shadow 0.2s, background-color 0.2s;
}

.config-group select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding-right: 40px;
    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='%235B5D6B' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    cursor: pointer;
}

.config-group select:hover {
    border-color: var(--waggi-bg-teal-medium);
    background-color: var(--waggi-bg-subtle);
}

.config-group input:focus,
.config-group select:focus {
    outline: none;
    border-color: var(--waggi-bg-cyan);
    box-shadow: 0 0 0 3px rgba(6, 186, 215, 0.15);
    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='%2306BAD7' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
}

.config-group select option {
    padding: 10px;
    background: var(--waggi-bg-card);
    color: var(--waggi-text-primary);
}

.config-group select option:hover,
.config-group select option:checked {
    background: var(--waggi-bg-subtle);
}

.config-group input::placeholder {
    color: var(--waggi-text-tertiary);
}

/* Override browser autofill styling */
.config-group input:-webkit-autofill,
.config-group input:-webkit-autofill:hover,
.config-group input:-webkit-autofill:focus,
.config-group input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 30px var(--waggi-bg-card) inset !important;
    -webkit-text-fill-color: var(--waggi-text-primary) !important;
    background-clip: content-box !important;
}

/* Custom Select Dropdown */
.custom-select {
    position: relative;
    width: 100%;
}

.custom-select-trigger {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 10px 14px;
    padding-right: 40px;
    border: 1px solid var(--waggi-border);
    border-radius: 8px;
    font-size: 14px;
    color: var(--waggi-text-primary);
    background: var(--waggi-bg-card);
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s, background-color 0.2s;
    position: relative;
}

.custom-select-trigger:hover {
    border-color: var(--waggi-bg-teal-medium);
    background-color: var(--waggi-bg-subtle);
}

.custom-select.open .custom-select-trigger,
.custom-select-trigger:focus {
    outline: none;
    border-color: var(--waggi-bg-cyan);
    box-shadow: 0 0 0 3px rgba(6, 186, 215, 0.15);
}

.custom-select-trigger .select-icon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    color: var(--waggi-text-secondary);
}

.custom-select-trigger .select-value {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.custom-select-trigger .select-value.placeholder {
    color: var(--waggi-text-tertiary);
}

.custom-select-trigger .select-arrow {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 6px solid var(--waggi-text-secondary);
    transition: transform 0.2s ease;
}

.custom-select.open .custom-select-trigger .select-arrow {
    transform: translateY(-50%) rotate(180deg);
}

.custom-select-options {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: var(--waggi-bg-card);
    border: 1px solid var(--waggi-border);
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    max-height: 280px;
    overflow-y: auto;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
}

.custom-select.open .custom-select-options {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.custom-option {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    cursor: pointer;
    transition: background-color 0.15s;
}

.custom-option:hover {
    background-color: var(--waggi-bg-subtle);
}

.custom-option.selected {
    background-color: var(--waggi-bg-cyan-lightest);
}

.custom-option .option-icon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    color: var(--waggi-text-secondary);
}

.custom-option.selected .option-icon {
    color: var(--waggi-bg-teal-medium);
}

.custom-option .option-content {
    flex: 1;
    min-width: 0;
}

.custom-option .option-label {
    font-size: 14px;
    color: var(--waggi-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.custom-option .option-sublabel {
    font-size: 12px;
    color: var(--waggi-text-tertiary);
    margin-top: 2px;
}

.custom-option .option-check {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    color: var(--waggi-bg-cyan);
    opacity: 0;
    transition: opacity 0.15s;
}

.custom-option.selected .option-check {
    opacity: 1;
}

.custom-select-options .options-divider {
    height: 1px;
    background: var(--waggi-border-light);
    margin: 4px 0;
}

.custom-select-options .options-group-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--waggi-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 8px 14px 4px;
}

/* Loading state for device dropdown */
.custom-select-trigger .mini-spinner {
    width: 14px;
    height: 14px;
    border: 2px solid var(--waggi-border);
    border-top-color: var(--waggi-bg-cyan);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.custom-select.disabled .custom-select-trigger {
    opacity: 0.6;
    cursor: not-allowed;
    background-color: var(--waggi-bg-subtle);
}

/* Device status dot */
.device-status-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}

.device-status-dot.status-online {
    background-color: var(--waggi-success-icon);
    box-shadow: 0 0 6px var(--waggi-success-icon);
}

.device-status-dot.status-recent {
    background-color: var(--waggi-alert-icon);
}

.device-status-dot.status-offline {
    background-color: var(--waggi-border);
}

/* Custom Range Container */
.custom-range-container {
    display: none;
    flex-wrap: wrap;
    gap: 16px;
    padding: 16px 20px;
    background: linear-gradient(135deg, var(--waggi-bg-subtle) 0%, #f0f7f8 100%);
    border-radius: 10px;
    margin-top: 16px;
    border: 1px solid var(--waggi-border-light);
    align-items: flex-end;
    position: relative;
}

.custom-range-container.active {
    display: flex;
}

.clear-custom-range-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 22px;
    height: 22px;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--waggi-text-tertiary, #94a3b8);
    border-radius: 50%;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    opacity: 0.6;
    transition: opacity 0.15s, background 0.15s, color 0.15s;
}

.clear-custom-range-btn:hover {
    opacity: 1;
    background: rgba(0, 0, 0, 0.06);
    color: var(--waggi-text-secondary, #64748b);
}

.clear-custom-range-btn:focus {
    outline: 2px solid rgba(89, 55, 202, 0.4);
    outline-offset: 1px;
    opacity: 1;
}

.custom-range-container .config-group {
    flex: 1;
    min-width: 200px;
}

.custom-range-container .range-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--waggi-text-teal);
    margin-bottom: 0;
    padding: 10px 0;
    white-space: nowrap;
}

.custom-range-container .range-label svg {
    width: 16px;
    height: 16px;
    opacity: 0.7;
}

.custom-range-container .range-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--waggi-text-tertiary);
    padding: 10px 4px;
}

.custom-range-container .range-arrow svg {
    width: 20px;
    height: 20px;
}

.custom-range-container .input-mode-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-left: auto;
    padding: 8px 0;
}

.custom-range-container .input-mode-toggle label {
    font-size: 12px;
    color: var(--waggi-text-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
}

.custom-range-container .input-mode-toggle input[type="checkbox"] {
    width: 36px;
    height: 20px;
    appearance: none;
    -webkit-appearance: none;
    background: var(--waggi-border);
    border-radius: 10px;
    position: relative;
    cursor: pointer;
    transition: background 0.2s;
}

.custom-range-container .input-mode-toggle input[type="checkbox"]:checked {
    background: var(--waggi-bg-teal-medium);
}

.custom-range-container .input-mode-toggle input[type="checkbox"]::before {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: white;
    top: 2px;
    left: 2px;
    transition: transform 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.custom-range-container .input-mode-toggle input[type="checkbox"]:checked::before {
    transform: translateX(16px);
}

.unix-inputs {
    display: contents;
}

.unix-inputs.hidden {
    display: none;
}

.date-inputs {
    display: none;
}

.date-inputs.active {
    display: contents;
}

.unix-hint {
    font-size: 11px;
    color: var(--waggi-text-tertiary);
    margin-top: 4px;
}

.flatpickr-input,
.custom-range-container input[type="text"] {
    cursor: pointer;
    background-image: none !important;
    background-repeat: no-repeat !important;
}

/* Buttons */
.btn {
    padding: 11px 28px;
    background: linear-gradient(135deg, var(--waggi-bg-teal) 0%, var(--waggi-bg-teal-medium) 100%);
    color: white;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.3px;
    transition: transform 0.2s, box-shadow 0.2s;
}

.btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(0, 78, 91, 0.35);
}

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.btn-secondary {
    background: var(--waggi-bg-purple);
}

.btn-secondary:hover {
    box-shadow: 0 6px 20px rgba(89, 55, 202, 0.35);
}

/* Stats Grid */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
    margin-bottom: 20px;
}

.stat-card {
    background: var(--waggi-bg-card);
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(4, 52, 60, 0.06);
    border: 1px solid var(--waggi-border-light);
    transition: transform 0.2s, box-shadow 0.2s;
    text-align: center;
}

.stat-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(4, 52, 60, 0.1);
}

.stat-card h4 {
    font-size: 11px;
    text-transform: uppercase;
    color: var(--waggi-text-tertiary);
    margin-bottom: 8px;
    letter-spacing: 0.5px;
    font-weight: 600;
}

.stat-card .value {
    font-size: 28px;
    font-weight: 700;
    color: var(--waggi-bg-teal);
}

.stat-card .subtext {
    font-size: 12px;
    color: var(--waggi-text-tertiary);
    margin-top: 4px;
}

/* Chart Layout */
.primary-chart {
    margin-bottom: 20px;
}

.primary-chart .chart-card {
    width: 100%;
}

.primary-chart .chart-container {
    height: 250px;
}

/* Battery Panel: stacked battery+temp / charging rug / power-state lane */
.battery-panel-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
}

.battery-panel-header h3 {
    margin: 0;
}

.battery-panel {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.battery-panel-pane {
    position: relative;
    width: 100%;
}

.battery-panel-pane > canvas {
    display: block;
    width: 100% !important;
}

.battery-panel-main {
    height: 280px;
}

.battery-panel-charging {
    height: 28px;
}

.battery-panel-power {
    height: 56px;
}

.battery-panel-pane-label {
    position: absolute;
    top: 4px;
    left: 8px;
    z-index: 2;
    font-size: 10px;
    font-weight: 600;
    color: var(--waggi-text-secondary, #64748b);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    pointer-events: none;
    background: rgba(255, 255, 255, 0.85);
    padding: 1px 6px;
    border-radius: 3px;
}

/* Drag-to-zoom selection rectangle on the battery panel */
.battery-panel-selection {
    position: absolute;
    top: 0;
    bottom: 0;
    background: rgba(89, 55, 202, 0.12);
    border-left: 1px solid #5937CA;
    border-right: 1px solid #5937CA;
    pointer-events: none;
    display: none;
    z-index: 5;
}

/* Flash highlight when a metrics row is scrolled to via a click on the battery panel */
@keyframes metricsRowFlash {
    0%   { background-color: rgba(89, 55, 202, 0.32); }
    60%  { background-color: rgba(89, 55, 202, 0.18); }
    100% { background-color: transparent; }
}
#metricsTable tbody tr.metrics-row-flash {
    animation: metricsRowFlash 1.6s ease-out;
}

.location-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    margin-bottom: 20px;
}

.location-row .map-container {
    height: 280px;
    border-radius: 8px;
    overflow: hidden;
}

/* Expand map button */
.expand-map-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    background: #f8fafc;
    color: #64748b;
    cursor: pointer;
    transition: all 0.15s ease;
}

.expand-map-btn:hover {
    background: #e2e8f0;
    color: #334155;
    border-color: #cbd5e1;
}

/* Expanded map modal */
.expanded-map-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    background: #ffffff;
    display: flex;
    flex-direction: column;
}

.expanded-map-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 20px;
    border-bottom: 1px solid #e2e8f0;
    background: #ffffff;
    flex-shrink: 0;
}

.expanded-map-header h3 {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: #1e293b;
}

.close-map-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #f8fafc;
    color: #64748b;
    cursor: pointer;
    transition: all 0.15s ease;
}

.close-map-btn:hover {
    background: #fee2e2;
    color: #dc2626;
    border-color: #fecaca;
}

.expanded-map-container {
    flex: 1 1 0;
    width: 100%;
    min-height: 0;
}

/* Map playback controls (play/pause + chronological slider) */
.map-playback-controls {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 12px;
    margin-top: 8px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    font-size: 12px;
}

.map-playback-controls-expanded {
    margin: 0;
    border-radius: 0;
    border-left: none;
    border-right: none;
    border-bottom: none;
    padding: 10px 20px;
    flex-shrink: 0;
}

.map-playback-btn {
    flex: 0 0 auto;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #e2e8f0;
    background: #ffffff;
    border-radius: 6px;
    color: #5937CA;
    cursor: pointer;
    transition: all 0.15s ease;
    padding: 0;
}

.map-playback-btn:hover {
    background: #5937CA;
    color: #ffffff;
    border-color: #5937CA;
}

.map-playback-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.map-playback-btn:disabled:hover {
    background: #ffffff;
    color: #5937CA;
    border-color: #e2e8f0;
}

.map-playback-slider {
    flex: 1 1 auto;
    accent-color: #5937CA;
    cursor: pointer;
    height: 4px;
    min-width: 0;
}

.map-playback-time {
    flex: 0 0 auto;
    font-variant-numeric: tabular-nums;
    color: #64748b;
    min-width: 150px;
    text-align: right;
    font-size: 11px;
}

.map-playback-cursor {
    pointer-events: none;
}

.map-playback-follow {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 6px;
    color: #64748b;
    font-size: 11px;
    cursor: pointer;
    user-select: none;
}

.map-playback-follow input {
    accent-color: #5937CA;
    cursor: pointer;
    margin: 0;
}

.metrics-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-bottom: 20px;
}

/* WiFi Section */
.wifi-section {
    margin-bottom: 20px;
}

.wifi-signal-bar {
    display: inline-block;
    height: 8px;
    border-radius: 4px;
    min-width: 20px;
    max-width: 100px;
}

.wifi-signal-excellent {
    background: linear-gradient(90deg, var(--waggi-success-icon) 0%, var(--waggi-success) 100%);
}

.wifi-signal-good {
    background: linear-gradient(90deg, #7cb342 0%, #558b2f 100%);
}

.wifi-signal-fair {
    background: linear-gradient(90deg, var(--waggi-alert-icon) 0%, var(--waggi-alert) 100%);
}

.wifi-signal-weak {
    background: linear-gradient(90deg, var(--waggi-error-icon) 0%, var(--waggi-error) 100%);
}

/* Map Popup */
.map-popup-content {
    font-size: 12px;
    line-height: 1.5;
    color: var(--waggi-text-primary);
}

.map-popup-content strong {
    color: var(--waggi-bg-teal);
}

.map-popup-jump {
    margin-top: 10px;
    padding: 6px 10px;
    border-radius: 4px;
    background: rgba(89, 55, 202, 0.08);
    color: #5937CA;
    font-size: 11px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    transition: background 0.15s, color 0.15s;
    user-select: none;
}

.map-popup-jump:hover {
    background: #5937CA;
    color: #fff;
}

.map-popup-jump-arrow {
    font-size: 13px;
    line-height: 1;
}

/* Charts Grid */
.charts-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.chart-card {
    background: var(--waggi-bg-card);
    border-radius: 12px;
    padding: 24px;
    box-shadow: 0 2px 8px rgba(4, 52, 60, 0.06);
    border: 1px solid var(--waggi-border-light);
    transition: transform 0.2s, box-shadow 0.2s;
}

.chart-card:hover {
    box-shadow: 0 8px 24px rgba(4, 52, 60, 0.1);
}

.chart-card h3 {
    margin-bottom: 16px;
    font-size: 15px;
    color: var(--waggi-text-primary);
    font-weight: 600;
}

.chart-container {
    position: relative;
    height: 300px;
}

/* Loading States */
.loading {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 200px;
    color: var(--waggi-text-tertiary);
}

.spinner {
    width: 40px;
    height: 40px;
    border: 3px solid var(--waggi-border-light);
    border-top: 3px solid var(--waggi-bg-cyan);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin-right: 15px;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.error {
    background: var(--waggi-error-bg);
    border: 1px solid var(--waggi-error-icon);
    color: var(--waggi-error);
    padding: 16px;
    border-radius: 8px;
    margin: 20px 0;
    animation: fadeIn 0.3s ease;
}

/* Skeleton Loading Styles */
@keyframes shimmer {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

.skeleton {
    background: linear-gradient(90deg, #E8E9ED 25%, #D4D5DC 50%, #E8E9ED 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
    border-radius: 4px;
}

.skeleton-text {
    height: 14px;
    margin-bottom: 8px;
}

.skeleton-text-sm {
    height: 10px;
    width: 60%;
}

.skeleton-value {
    height: 32px;
    width: 80px;
    margin-bottom: 8px;
}

.skeleton-chart {
    height: 280px;
    border-radius: 8px;
}

.skeleton-row {
    display: flex;
    gap: 10px;
    padding: 12px 10px;
    border-bottom: 1px solid #f0f0f0;
}

.skeleton-cell {
    height: 16px;
    flex: 1;
}

.skeleton-badge {
    height: 20px;
    width: 70px;
    border-radius: 10px;
}

/* Welcome State */
.welcome-state {
    text-align: center;
    padding: 40px 20px;
}

.welcome-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 24px;
    background: linear-gradient(135deg, var(--waggi-bg-teal) 0%, var(--waggi-bg-teal-medium) 100%);
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 30px rgba(0, 78, 91, 0.25);
}

.welcome-icon svg {
    width: 40px;
    height: 40px;
    color: white;
}

.welcome-state h2 {
    font-size: 24px;
    color: var(--waggi-text-primary);
    margin-bottom: 8px;
    font-weight: 600;
}

.welcome-state p {
    color: var(--waggi-text-secondary);
    font-size: 15px;
    margin-bottom: 24px;
}

.welcome-steps {
    display: flex;
    justify-content: center;
    gap: 32px;
    margin-top: 32px;
    flex-wrap: wrap;
}

.welcome-step {
    display: flex;
    align-items: center;
    gap: 12px;
    color: var(--waggi-text-secondary);
    font-size: 14px;
}

.step-number {
    width: 28px;
    height: 28px;
    background: var(--waggi-bg-cyan-lightest);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    color: var(--waggi-bg-teal);
    font-size: 13px;
}

.welcome-step.active .step-number {
    background: linear-gradient(135deg, var(--waggi-bg-teal) 0%, var(--waggi-bg-teal-medium) 100%);
    color: white;
}

/* Device Status Indicator */
.device-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: var(--waggi-text-tertiary);
}

.device-status .mini-spinner {
    width: 12px;
    height: 12px;
    border: 2px solid var(--waggi-border-light);
    border-top-color: var(--waggi-bg-cyan);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.device-status.loaded {
    color: var(--waggi-success-icon);
}

.device-status.loaded .mini-spinner {
    display: none;
}

.device-status .check-icon {
    display: none;
    color: var(--waggi-success-icon);
}

.device-status.loaded .check-icon {
    display: inline;
}

.device-status.error {
    color: var(--waggi-error);
}

.device-status.error .check-icon {
    display: none;
}

/* Device UID Display */
.device-uid {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 6px;
    padding: 4px 8px;
    background: var(--waggi-bg-subtle);
    border-radius: 4px;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', 'Roboto Mono', monospace;
    position: relative;
}

.device-uid .uid-label {
    font-size: 10px;
    color: var(--waggi-text-tertiary);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.device-uid .uid-trigger {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 1;
    min-width: 0;
    border-radius: 3px;
    padding: 1px 2px;
    transition: background 0.15s;
}

.device-uid .uid-value {
    font-size: 11px;
    color: var(--waggi-text-secondary);
    user-select: all;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Multi-UID mode: trigger becomes clickable with a count pill and chevron */
.device-uid.has-multiple .uid-trigger {
    cursor: pointer;
}

.device-uid.has-multiple .uid-trigger:hover {
    background: var(--waggi-bg-cyan-lightest);
}

.device-uid .uid-count-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 16px;
    padding: 0 5px;
    font-size: 10px;
    font-weight: 600;
    color: var(--waggi-bg-teal);
    background: var(--waggi-bg-cyan-lightest);
    border-radius: 8px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    letter-spacing: 0;
}

.device-uid .uid-arrow {
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid var(--waggi-text-tertiary);
    flex-shrink: 0;
    transition: transform 0.2s ease;
}

.device-uid.open .uid-arrow {
    transform: rotate(180deg);
}

/* UID picker dropdown — reuses the look of the device dropdown options panel */
.device-uid .uid-options {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    min-width: 100%;
    max-width: 380px;
    background: var(--waggi-bg-card);
    border: 1px solid var(--waggi-border);
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    max-height: 280px;
    overflow-y: auto;
    z-index: 1001;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
    padding: 4px 0;
}

.device-uid.open .uid-options {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.device-uid .uid-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    cursor: pointer;
    font-size: 11px;
    color: var(--waggi-text-secondary);
    transition: background 0.15s;
}

.device-uid .uid-option:hover {
    background: var(--waggi-bg-subtle);
}

.device-uid .uid-option.selected {
    background: var(--waggi-bg-cyan-lightest);
    color: var(--waggi-text-primary);
}

.device-uid .uid-option-check {
    width: 12px;
    color: var(--waggi-bg-cyan);
    opacity: 0;
    font-size: 11px;
    flex-shrink: 0;
    text-align: center;
}

.device-uid .uid-option.selected .uid-option-check {
    opacity: 1;
}

.device-uid .uid-option-value {
    flex: 1;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', 'Roboto Mono', monospace;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.device-uid .uid-option-date {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 10px;
    color: var(--waggi-text-tertiary);
    white-space: nowrap;
    flex-shrink: 0;
}

.device-uid .uid-copy {
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    padding: 2px;
    cursor: pointer;
    color: var(--waggi-text-tertiary);
    border-radius: 3px;
    transition: color 0.2s, background 0.2s;
    flex-shrink: 0;
}

.device-uid .uid-copy:hover {
    color: var(--waggi-bg-teal);
    background: var(--waggi-bg-cyan-lightest);
}

.device-uid .uid-copy.copied {
    color: var(--waggi-success);
}

/* Fade Animations */
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.fade-in {
    animation: fadeIn 0.4s ease forwards;
}

.fade-in-up {
    animation: fadeInUp 0.5s ease forwards;
}

/* Staggered Animation Delays */
.stagger-1 { animation-delay: 0.1s; opacity: 0; }
.stagger-2 { animation-delay: 0.2s; opacity: 0; }
.stagger-3 { animation-delay: 0.3s; opacity: 0; }
.stagger-4 { animation-delay: 0.4s; opacity: 0; }

/* Loading Overlay */
.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(246, 248, 249, 0.95);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    backdrop-filter: blur(4px);
}

.loading-overlay .spinner-large {
    width: 50px;
    height: 50px;
    border: 4px solid var(--waggi-border-light);
    border-top-color: var(--waggi-bg-cyan);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin-bottom: 20px;
}

.loading-overlay p {
    color: var(--waggi-text-primary);
    font-size: 16px;
    font-weight: 500;
}

.loading-overlay .loading-subtext {
    color: var(--waggi-text-tertiary);
    font-size: 13px;
    margin-top: 8px;
}

/* Progress Dots */
.loading-dots {
    display: flex;
    gap: 6px;
    margin-top: 16px;
}

.loading-dots span {
    width: 8px;
    height: 8px;
    background: var(--waggi-bg-cyan);
    border-radius: 50%;
    animation: dotPulse 1.4s infinite ease-in-out;
}

.loading-dots span:nth-child(1) { animation-delay: 0s; }
.loading-dots span:nth-child(2) { animation-delay: 0.2s; }
.loading-dots span:nth-child(3) { animation-delay: 0.4s; }

@keyframes dotPulse {
    0%, 80%, 100% { transform: scale(0.6); opacity: 0.5; }
    40% { transform: scale(1); opacity: 1; }
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: 60px 20px;
    color: var(--waggi-text-tertiary);
}

.empty-state h3 {
    margin-bottom: 10px;
    color: var(--waggi-text-secondary);
}

.location-map {
    height: 300px;
    background: var(--waggi-bg-page);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--waggi-text-tertiary);
}

/* Data Tables */
.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    table-layout: fixed;
}

.data-table th,
.data-table td {
    padding: 12px;
    text-align: left;
    border-bottom: 1px solid var(--waggi-border-light);
    word-wrap: break-word;
    overflow-wrap: break-word;
    word-break: break-word;
}

/* Column widths for metrics table */
#metricsTable th:nth-child(1),
#metricsTable td:nth-child(1) { width: 12%; min-width: 140px; }
#metricsTable th:nth-child(2),
#metricsTable td:nth-child(2) { width: 10%; min-width: 80px; }
#metricsTable th:nth-child(3),
#metricsTable td:nth-child(3) { width: 15%; min-width: 100px; }
#metricsTable th:nth-child(4),
#metricsTable td:nth-child(4) { width: 18%; min-width: 120px; }
#metricsTable th:nth-child(5),
#metricsTable td:nth-child(5) { width: 45%; }

/* Column widths for location table */
#locationTable th:nth-child(1),
#locationTable td:nth-child(1) { width: 13%; min-width: 140px; }
#locationTable th:nth-child(2),
#locationTable td:nth-child(2) { width: 8%; min-width: 80px; }
#locationTable th:nth-child(3),
#locationTable td:nth-child(3) { width: 9%; min-width: 85px; }
#locationTable th:nth-child(4),
#locationTable td:nth-child(4) { width: 10%; min-width: 95px; }
#locationTable th:nth-child(5),
#locationTable td:nth-child(5) { width: 10%; min-width: 95px; }
#locationTable th:nth-child(6),
#locationTable td:nth-child(6) { width: 8%; min-width: 75px; }
#locationTable th:nth-child(7),
#locationTable td:nth-child(7) { width: 8%; min-width: 75px; }
#locationTable th:nth-child(8),
#locationTable td:nth-child(8) { width: 8%; min-width: 75px; }
#locationTable th:nth-child(9),
#locationTable td:nth-child(9) { width: 26%; }

.data-table th {
    background: var(--waggi-bg-page);
    font-weight: 600;
    color: var(--waggi-text-secondary);
}

.data-table th.time-toggle-header {
    cursor: pointer;
    user-select: none;
    transition: color 0.15s ease;
}

.data-table th.time-toggle-header:hover {
    color: #3b82f6;
}

.data-table th.time-toggle-header .time-source-hint {
    font-weight: 500;
    color: var(--waggi-text-tertiary, #94a3b8);
    font-size: 11px;
}

/* Device time that fell back to ingest time (no device-sent timestamp): subtly muted */
.data-table td .time-fallback {
    color: var(--waggi-text-tertiary, #94a3b8);
}

/* Minimal device-vs-received clock-gap indicator under the Time cell */
.data-table td .time-delta {
    margin-top: 2px;
    font-size: 11px;
    line-height: 1.2;
    color: var(--waggi-text-tertiary, #94a3b8);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.data-table tr:hover {
    background: var(--waggi-bg-page);
}

.tables-section {
    margin-top: 20px;
}

.table-container {
    max-height: 400px;
    overflow-y: auto;
    overflow-x: hidden;
    border: 1px solid var(--waggi-border-light);
    border-radius: 8px;
    position: relative;
}

/* Mobile scroll hint indicator */
.table-scroll-hint {
    display: none;
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 40px;
    background: linear-gradient(to right, transparent, rgba(255,255,255,0.9));
    pointer-events: none;
    z-index: 1;
}

.table-scroll-hint::after {
    content: '→';
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--waggi-text-tertiary);
    font-size: 16px;
    animation: scrollHintPulse 1.5s ease-in-out infinite;
}

@keyframes scrollHintPulse {
    0%, 100% { opacity: 0.4; transform: translateY(-50%) translateX(0); }
    50% { opacity: 1; transform: translateY(-50%) translateX(3px); }
}

.data-table thead {
    position: sticky;
    top: 0;
    background: var(--waggi-bg-page);
    z-index: 1;
}

/* Type Badge */
.type-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
}

/* Connection Events - Waggi Semantic Colors */
.type-CONNECT, .type-Connect { background: var(--waggi-success-bg); color: var(--waggi-success); }
.type-DISCONNECT, .type-Disconnect { background: var(--waggi-error-bg); color: var(--waggi-error); }
.type-wake-up { background: #FEF9E7; color: #C79A07; }

/* Health Metrics - Maximally Distinguishable Colors */
.type-battery { background: var(--waggi-success-bg); color: #0D7C3E; }
.type-steprate { background: var(--waggi-bg-purple-lightest); color: var(--waggi-graph-1); }
.type-calorie { background: #FFF0E6; color: #D35400; }
.type-sleeprate { background: var(--waggi-info-bg); color: var(--waggi-info); }

/* Location - Waggi Cyan/Teal */
.type-location { background: var(--waggi-bg-cyan-lightest); color: var(--waggi-bg-teal-medium); }
.type-live-location { background: #FFE8EC; color: #C0392B; }

/* Location Type Filter Toggles (Chart/Map) */
.location-type-filters {
    display: flex;
    gap: 8px;
    align-items: center;
}

.location-type-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border: 1px solid var(--waggi-border);
    border-radius: 20px;
    background: var(--waggi-bg-card);
    font-size: 12px;
    font-weight: 500;
    color: var(--waggi-text-secondary);
    cursor: pointer;
    transition: all 0.2s ease;
}

.location-type-toggle:hover {
    border-color: var(--waggi-bg-teal-medium);
    background: var(--waggi-bg-subtle);
}

.location-type-toggle.active {
    border-color: transparent;
}

.location-type-toggle.active[data-type="location"] {
    background: var(--waggi-bg-cyan-lightest);
    color: var(--waggi-bg-teal-medium);
}

.location-type-toggle.active[data-type="live-location"] {
    background: #FFE8EC;
    color: #C0392B;
}

.location-type-toggle:not(.active) {
    opacity: 0.5;
    background: var(--waggi-bg-subtle);
}

.location-type-toggle .type-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.location-type-toggle .location-dot {
    background: linear-gradient(135deg, #9ca3af, #06BAD7);
}

.location-type-toggle .live-location-dot {
    background: linear-gradient(135deg, #ffcc99, #DC3545);
}

/* Location Source Toggle Buttons */
.location-source-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border: 1px solid var(--waggi-border);
    border-radius: 20px;
    background: var(--waggi-bg-card);
    font-size: 12px;
    font-weight: 500;
    color: var(--waggi-text-secondary);
    cursor: pointer;
    transition: all 0.2s ease;
}

.location-source-toggle:hover {
    border-color: var(--waggi-bg-teal-medium);
    background: var(--waggi-bg-subtle);
}

.location-source-toggle.active {
    border-color: transparent;
}

.location-source-toggle.active[data-source="gps"] {
    background: var(--waggi-bg-cyan-lightest);
    color: var(--waggi-bg-teal-medium);
}

.location-source-toggle.active[data-source="geolocate-wifi"] {
    background: #F3E8FF;
    color: #8E44AD;
}

.location-source-toggle.active[data-source="geolocate-cellTower"] {
    background: #E8F8F0;
    color: #27AE60;
}

.location-source-toggle:not(.active) {
    opacity: 0.5;
    background: var(--waggi-bg-subtle);
}

.location-source-toggle .type-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.location-source-toggle .gps-dot {
    background: linear-gradient(135deg, #9ca3af, #06BAD7);
}

.location-source-toggle .geolocate-wifi-dot {
    background: linear-gradient(135deg, #ba9cdb, #8E44AD);
}

.location-source-toggle .geolocate-cell-dot {
    background: linear-gradient(135deg, #a3d6a3, #27AE60);
}

/* Streaming States - Distinct Colors */
.type-livestream-app-state { background: #F5E6FF; color: #8E44AD; }
.type-livestream-device-state { background: #E8F6F3; color: #16A085; }

/* System/Debug - Neutral */
.type-debug-info { background: #F0F1F3; color: var(--waggi-text-secondary); }
.type-unknown { background: #F6F7F9; color: var(--waggi-text-tertiary); }

/* Type Filter Dropdown */
.type-filter-wrapper {
    position: relative;
    display: inline-block;
}

.type-filter-header {
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    user-select: none;
    padding: 2px 0;
    transition: color 0.15s ease;
}

.type-filter-header:hover {
    color: #3b82f6;
}

.type-filter-count {
    background: #3b82f6;
    color: white;
    font-size: 9px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 10px;
    line-height: 1;
}

.type-filter-dropdown {
    position: absolute;
    top: 0;
    left: calc(100% + 8px);
    background: white;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.08);
    z-index: 100;
    width: 240px;
    max-height: 320px;
    overflow: hidden;
    display: none;
}

.type-filter-dropdown.open {
    display: block;
    animation: dropdownFade 0.15s ease-out;
}

@keyframes dropdownFade {
    from { opacity: 0; transform: translateX(-4px); }
    to { opacity: 1; transform: translateX(0); }
}

.type-filter-actions {
    display: flex;
    gap: 6px;
    padding: 10px 12px;
    background: #f8fafc;
    border-bottom: 1px solid #e5e7eb;
}

.type-filter-actions button {
    flex: 1;
    font-size: 11px;
    font-weight: 500;
    padding: 5px 10px;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    cursor: pointer;
    color: #475569;
    transition: all 0.15s ease;
}

.type-filter-actions button:hover {
    background: #f1f5f9;
    border-color: #cbd5e1;
}

.type-filter-items-container {
    max-height: 250px;
    overflow-y: auto;
    padding: 6px 0;
}

.type-filter-item {
    display: flex;
    align-items: center;
    padding: 8px 14px;
    cursor: pointer;
    gap: 10px;
    transition: background 0.1s ease;
}

.type-filter-item:hover {
    background: #f1f5f9;
}

.type-filter-checkbox {
    width: 16px;
    height: 16px;
    border: 1.5px solid #cbd5e1;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all 0.15s ease;
    background: white;
}

.type-filter-checkbox.checked {
    background: #3b82f6;
    border-color: #3b82f6;
}

.type-filter-checkbox.checked::after {
    content: '';
    width: 4px;
    height: 7px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg) translateY(-1px);
}

.type-filter-item .type-badge {
    font-size: 11px;
    padding: 3px 10px;
}

/* Numeric Range Filter (Altitude / Accuracy / Speed) */
.range-filter-dropdown {
    width: 240px;
}

.range-histogram {
    display: flex;
    align-items: flex-end;
    gap: 1px;
    height: 52px;
    padding: 10px 12px 6px;
    background: #f8fafc;
    border-bottom: 1px solid #e5e7eb;
}

.range-bar {
    flex: 1;
    min-height: 2px;
    border-radius: 2px 2px 0 0;
    background: #cbd5e1;
    transition: background 0.15s ease;
}

.range-bar.in-range {
    background: #3b82f6;
}

.range-histogram-empty {
    flex: 1;
    text-align: center;
    align-self: center;
    color: #94a3b8;
    font-size: 11px;
    font-weight: 500;
}

.range-filter-body {
    padding: 10px 12px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.range-filter-body label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    font-size: 11px;
    font-weight: 500;
    color: #475569;
    text-transform: none;
}

.range-filter-body input[type="number"] {
    width: 110px;
    padding: 5px 8px;
    font-size: 12px;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    color: #1e293b;
    background: white;
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.range-filter-body input[type="number"]:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.15);
}

.type-filter-count.range-active {
    background: #3b82f6;
    min-width: 12px;
    text-align: center;
    padding: 2px 5px;
}

.table-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
}

.table-header h3 {
    margin: 0;
}

.table-header select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding: 8px 32px 8px 12px;
    border: 1px solid var(--waggi-border);
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--waggi-text-primary);
    background: var(--waggi-bg-card);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%235B5D6B' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s, background-color 0.2s;
}

.table-header select:hover {
    border-color: var(--waggi-bg-teal-medium);
    background-color: var(--waggi-bg-subtle);
}

.table-header select:focus {
    outline: none;
    border-color: var(--waggi-bg-cyan);
    box-shadow: 0 0 0 2px rgba(6, 186, 215, 0.15);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%2306BAD7' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
}

.empty-table {
    text-align: center;
    padding: 40px 20px;
    color: #888;
    background: #f8f9fa;
    border-radius: 8px;
}

/* Live Toggle Button */
.live-btn {
    padding: 6px 14px;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 6px;
    background: #e2e8f0;
    color: #475569;
}

.live-btn:hover {
    background: #cbd5e1;
    box-shadow: none;
    transform: none;
}

.live-btn.active {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
    color: white;
}

.live-btn.active:hover {
    background: linear-gradient(135deg, #dc2626 0%, #b91c1c 100%);
}

.live-indicator {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #94a3b8;
}

.live-btn.active .live-indicator {
    background: white;
    animation: pulse 1s infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

/* Export Button - Subtle/Muted */
.export-btn {
    padding: 5px 10px;
    font-size: 12px;
    background: transparent;
    color: #64748b;
    border: 1px solid #e2e8f0;
    font-weight: 400;
}

.export-btn:hover {
    background: #f1f5f9;
    color: #475569;
    box-shadow: none;
    transform: none;
}

/* Time Format Toggle */
.time-toggle {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    color: #94a3b8;
    cursor: pointer;
    padding: 3px 6px;
    border-radius: 4px;
    user-select: none;
}

.time-toggle:hover {
    background: #f1f5f9;
    color: #64748b;
}

.time-toggle.active {
    color: #667eea;
}

.time-toggle svg {
    width: 12px;
    height: 12px;
}

/* Responsive - Tablet */
@media (max-width: 768px) {
    .charts-grid {
        grid-template-columns: 1fr;
    }
    .location-row {
        grid-template-columns: 1fr;
    }
    .location-type-filters {
        flex-wrap: wrap;
        gap: 6px;
    }
    .location-type-toggle,
    .location-source-toggle {
        padding: 5px 10px;
        font-size: 11px;
    }
    .metrics-row {
        grid-template-columns: 1fr;
    }
    .primary-chart .chart-container {
        height: 200px;
    }
    .battery-panel-main {
        height: 220px;
    }
    .battery-panel-charging {
        height: 24px;
    }
    .battery-panel-power {
        height: 48px;
    }
    .config-row {
        flex-direction: column;
    }
    .welcome-steps {
        flex-direction: column;
        align-items: center;
        gap: 16px;
    }

    .welcome-step {
        width: 160px;
        justify-content: flex-start;
    }

    /* Filters Section Mobile Optimizations */
    .config-panel {
        padding: 16px;
        border-radius: 10px;
        margin-bottom: 16px;
    }

    .config-panel h3 {
        font-size: 12px;
        margin-bottom: 14px;
    }

    .config-row {
        gap: 12px;
    }

    .config-group {
        min-width: 100%;
        flex: none;
    }

    .config-group label {
        font-size: 12px;
        margin-bottom: 5px;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 4px;
    }

    .config-group input,
    .config-group select {
        padding: 12px 14px;
        font-size: 16px;
        border-radius: 8px;
    }

    .config-group select {
        padding-right: 36px;
    }

    /* Load Data button full width on mobile */
    .config-row > .btn {
        width: 100%;
        padding: 14px 20px;
        font-size: 15px;
        margin-top: 4px;
    }

    /* Device status indicator compact */
    .device-status {
        font-size: 10px;
    }

    .device-status .mini-spinner {
        width: 10px;
        height: 10px;
    }

    /* Device UID display mobile */
    .device-uid {
        margin-top: 8px;
        padding: 6px 10px;
    }

    .device-uid .uid-value {
        font-size: 10px;
        word-break: break-all;
    }

    .device-uid .uid-copy {
        padding: 4px;
        min-width: 24px;
        min-height: 24px;
    }

    /* Custom Range Container Mobile */
    .custom-range-container {
        padding: 14px;
        margin-top: 14px;
        gap: 12px;
    }

    .custom-range-container .range-label {
        font-size: 12px;
        padding: 8px 0;
        width: 100%;
    }

    .custom-range-container .range-label svg {
        width: 14px;
        height: 14px;
    }

    .custom-range-container .config-group {
        min-width: 100%;
    }

    /* Date inputs stack vertically - override display: contents */
    .date-inputs.active,
    .unix-inputs:not(.hidden) {
        display: flex;
        flex-direction: column;
        gap: 12px;
        width: 100%;
    }

    .date-inputs .config-group,
    .unix-inputs .config-group {
        width: 100%;
        min-width: unset;
    }

    /* Hide the arrow between date fields on mobile, show text instead */
    .range-arrow {
        display: none;
    }

    /* Input mode toggle touch-friendly */
    .input-mode-toggle {
        width: 100%;
        justify-content: center;
        padding: 10px 0;
    }

    .input-mode-toggle label {
        font-size: 13px;
        padding: 8px 12px;
    }

    .input-mode-toggle input[type="checkbox"] {
        width: 44px;
        height: 24px;
    }

    .input-mode-toggle input[type="checkbox"]::before {
        width: 20px;
        height: 20px;
    }

    /* Metrics Data Mobile Optimizations */
    .tables-section .chart-card {
        padding: 16px;
    }

    /* Stack table header controls vertically on mobile */
    .table-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .table-header h3 {
        font-size: 16px;
        margin-bottom: 0;
    }

    /* Controls row - wrap and space efficiently */
    .table-header > div {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        width: 100%;
    }

    /* Make buttons more touch-friendly */
    .table-header .live-btn,
    .table-header .export-btn {
        padding: 8px 12px;
        font-size: 12px;
    }

    .table-header .time-toggle {
        padding: 6px 10px;
        font-size: 12px;
    }

    /* Live status text */
    #liveStatus,
    #liveLocationStatus {
        font-size: 11px !important;
        flex-basis: 100%;
        order: -1;
    }

    /* Enable horizontal scroll for table on mobile */
    .table-container {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Show scroll hint on mobile */
    .table-scroll-hint {
        display: block;
    }

    .table-container.scrolled .table-scroll-hint {
        display: none;
    }

    /* Adjust table for mobile */
    .data-table {
        font-size: 11px;
        min-width: 600px;
    }

    .data-table th,
    .data-table td {
        padding: 8px 6px;
    }

    /* Metrics table mobile column widths */
    #metricsTable th:nth-child(1),
    #metricsTable td:nth-child(1) { min-width: 100px; }
    #metricsTable th:nth-child(2),
    #metricsTable td:nth-child(2) { min-width: 60px; }
    #metricsTable th:nth-child(3),
    #metricsTable td:nth-child(3) { min-width: 70px; }
    #metricsTable th:nth-child(4),
    #metricsTable td:nth-child(4) { min-width: 80px; }
    #metricsTable th:nth-child(5),
    #metricsTable td:nth-child(5) { min-width: 200px; }

    /* Location table mobile column widths */
    #locationTable th:nth-child(1),
    #locationTable td:nth-child(1) { min-width: 100px; }
    #locationTable th:nth-child(2),
    #locationTable td:nth-child(2) { min-width: 65px; }
    #locationTable th:nth-child(3),
    #locationTable td:nth-child(3) { min-width: 70px; }
    #locationTable th:nth-child(4),
    #locationTable td:nth-child(4) { min-width: 75px; }
    #locationTable th:nth-child(5),
    #locationTable td:nth-child(5) { min-width: 75px; }
    #locationTable th:nth-child(6),
    #locationTable td:nth-child(6) { min-width: 60px; }
    #locationTable th:nth-child(7),
    #locationTable td:nth-child(7) { min-width: 60px; }
    #locationTable th:nth-child(8),
    #locationTable td:nth-child(8) { min-width: 60px; }
    #locationTable th:nth-child(9),
    #locationTable td:nth-child(9) { min-width: 150px; }

    /* Type badge compact on mobile */
    .type-badge {
        font-size: 10px;
        padding: 2px 6px;
    }

    /* Type filter dropdown mobile */
    .type-filter-dropdown {
        right: auto;
        left: 0;
        min-width: 150px;
    }
}

/* Extra small screens (phones in portrait) */
@media (max-width: 480px) {
    /* Filters Section - Extra Small */
    .config-panel {
        padding: 12px;
        border-radius: 8px;
        margin-bottom: 12px;
    }

    .config-panel h3 {
        font-size: 11px;
        margin-bottom: 12px;
        letter-spacing: 0.6px;
    }

    .config-row {
        gap: 10px;
    }

    .config-group label {
        font-size: 11px;
    }

    .config-group input,
    .config-group select {
        padding: 10px 12px;
        font-size: 16px;
    }

    /* Load Data button compact */
    .config-row > .btn {
        padding: 12px 16px;
        font-size: 14px;
    }

    /* Device refresh button smaller */
    .config-group label button {
        font-size: 11px;
        padding: 2px 4px;
    }

    /* Custom Range even more compact */
    .custom-range-container {
        padding: 10px;
        margin-top: 10px;
        gap: 10px;
        border-radius: 8px;
    }

    .custom-range-container .range-label {
        font-size: 11px;
        padding: 6px 0;
    }

    .unix-hint {
        font-size: 10px;
    }

    .input-mode-toggle label {
        font-size: 12px;
        padding: 6px 10px;
    }

    .input-mode-toggle input[type="checkbox"] {
        width: 40px;
        height: 22px;
    }

    .input-mode-toggle input[type="checkbox"]::before {
        width: 18px;
        height: 18px;
    }

    /* Metrics Data - Extra Small */
    .tables-section .chart-card {
        padding: 12px;
        border-radius: 8px;
    }

    .table-header h3 {
        font-size: 14px;
    }

    .table-header > div {
        gap: 6px;
    }

    .table-header .live-btn,
    .table-header .export-btn {
        padding: 6px 10px;
        font-size: 11px;
    }

    .table-header .time-toggle {
        padding: 4px 8px;
        font-size: 11px;
    }

    .data-table {
        font-size: 10px;
        min-width: 500px;
    }

    .data-table th,
    .data-table td {
        padding: 6px 4px;
    }

    /* Even more compact widths for very small screens */
    #metricsTable th:nth-child(1),
    #metricsTable td:nth-child(1) { min-width: 85px; }
    #metricsTable th:nth-child(2),
    #metricsTable td:nth-child(2) { min-width: 50px; }
    #metricsTable th:nth-child(3),
    #metricsTable td:nth-child(3) { min-width: 60px; }
    #metricsTable th:nth-child(4),
    #metricsTable td:nth-child(4) { min-width: 70px; }
    #metricsTable th:nth-child(5),
    #metricsTable td:nth-child(5) { min-width: 150px; }

    .type-badge {
        font-size: 9px;
        padding: 2px 4px;
    }

    .table-container {
        max-height: 350px;
    }
}

@media (max-width: 1024px) and (min-width: 769px) {
    .metrics-row {
        grid-template-columns: repeat(2, 1fr);
    }
    .metrics-row .chart-card:last-child {
        grid-column: span 2;
    }
}

/* ============================================
   DEBUG-INFO VISUALIZATION STYLES
   ============================================ */

.debug-info-section {
    margin-bottom: 20px;
}

.debug-info-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    margin-bottom: 16px;
    user-select: none;
}

.debug-info-header:hover .debug-info-collapse {
    background: var(--waggi-bg-subtle);
}

.debug-info-title {
    display: flex;
    align-items: center;
    gap: 12px;
}

.debug-info-title h3 {
    margin: 0 !important;
}

.debug-info-meta {
    display: flex;
    gap: 8px;
    align-items: center;
}

.debug-info-badge {
    font-size: 11px;
    padding: 3px 10px;
    border-radius: 12px;
    background: var(--waggi-bg-subtle);
    color: var(--waggi-text-secondary);
    font-weight: 500;
}

.debug-info-operator {
    background: #EBF5FB;
    color: #2980B9;
}

.debug-info-operator strong {
    font-weight: 600;
}

.debug-info-collapse {
    background: none;
    border: none;
    padding: 6px;
    border-radius: 6px;
    cursor: pointer;
    color: var(--waggi-text-secondary);
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
}

.debug-info-collapse svg {
    transition: transform 0.2s ease;
}

.debug-info-collapse.collapsed svg {
    transform: rotate(-90deg);
}

.debug-group-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--waggi-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 20px 0 10px 0;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--waggi-border);
}

.debug-group-label:first-child {
    margin-top: 0;
}

.debug-chart-row {
    display: grid;
    gap: 16px;
    margin-bottom: 16px;
}

.debug-chart-row-2 {
    grid-template-columns: repeat(2, 1fr);
}

.debug-chart-row-1 {
    grid-template-columns: 1fr;
}

.debug-chart-card {
    background: var(--waggi-bg-subtle);
    border-radius: 10px;
    padding: 16px;
    border: 1px solid var(--waggi-border);
}

.debug-chart-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.debug-chart-card h4 {
    margin: 0;
    font-size: 13px;
    font-weight: 500;
    color: var(--waggi-text-primary);
}

/* Info tip (i) button */
.debug-info-tip {
    position: relative;
    flex-shrink: 0;
    cursor: pointer;
    outline: none;
}

.debug-info-tip-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 1.5px solid var(--waggi-border);
    font-size: 11px;
    font-weight: 600;
    font-style: italic;
    font-family: Georgia, 'Times New Roman', serif;
    color: var(--waggi-text-tertiary);
    background: var(--waggi-bg-card);
    transition: border-color 0.15s, color 0.15s;
    line-height: 1;
}

.debug-info-tip:hover .debug-info-tip-icon,
.debug-info-tip:focus .debug-info-tip-icon {
    border-color: var(--waggi-bg-teal-medium);
    color: var(--waggi-bg-teal-medium);
}

.debug-info-tip-content {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    z-index: 50;
    width: 280px;
    padding: 10px 12px;
    border-radius: 8px;
    background: var(--waggi-bg-card);
    border: 1px solid var(--waggi-border-light);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.10);
    font-size: 12px;
    line-height: 1.5;
    color: var(--waggi-text-secondary);
    font-weight: 400;
}

.debug-info-tip-content strong {
    color: var(--waggi-text-primary);
    font-weight: 600;
}

.debug-info-tip:hover .debug-info-tip-content,
.debug-info-tip:focus .debug-info-tip-content {
    display: block;
}

.debug-chart-container {
    position: relative;
    height: 240px;
}

@media (max-width: 768px) {
    .debug-chart-row-2 {
        grid-template-columns: 1fr;
    }
    .debug-chart-container {
        height: 200px;
    }
    .debug-info-meta {
        display: none;
    }
}

@media (max-width: 1024px) and (min-width: 769px) {
    .debug-chart-container {
        height: 220px;
    }
}

/* ============================================
   SWIM LANE VISUALIZATION STYLES
   ============================================ */

/* File Upload Section */
.log-upload-section {
    margin-bottom: 24px;
}

.upload-zone {
    border: 2px dashed var(--waggi-border);
    border-radius: 12px;
    padding: 40px 20px;
    text-align: center;
    transition: all 0.3s ease;
    cursor: pointer;
    background: var(--waggi-bg-subtle);
}

.upload-zone:hover,
.upload-zone.dragover {
    border-color: var(--waggi-bg-cyan);
    background: var(--waggi-bg-cyan-lightest);
}

.upload-zone.dragover {
    transform: scale(1.01);
}

.upload-icon {
    width: 48px;
    height: 48px;
    margin: 0 auto 16px;
    color: var(--waggi-bg-teal-medium);
}

.upload-zone h4 {
    color: var(--waggi-text-primary);
    font-size: 16px;
    margin-bottom: 8px;
}

.upload-zone p {
    color: var(--waggi-text-secondary);
    font-size: 13px;
    margin-bottom: 16px;
}

.upload-zone .file-input {
    display: none;
}

.upload-btn {
    display: inline-block;
    padding: 10px 24px;
    background: var(--waggi-bg-teal-medium);
    color: white;
    border-radius: 8px;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.2s;
}

.upload-btn:hover {
    background: var(--waggi-bg-teal);
}

.uploaded-file-info {
    display: none;
    flex-direction: column;
    gap: 8px;
    padding: 12px 16px;
    background: var(--waggi-success-bg);
    border-radius: 8px;
    margin-top: 16px;
}

.uploaded-file-info.active {
    display: flex;
}

.uploaded-files-header {
    display: flex;
    align-items: center;
    gap: 12px;
}

.uploaded-file-info .file-icon {
    color: var(--waggi-success-icon);
}

.uploaded-file-info .file-details {
    flex: 1;
}

.uploaded-file-info .file-name {
    font-weight: 500;
    color: var(--waggi-text-primary);
}

.uploaded-file-info .file-meta {
    font-size: 12px;
    color: var(--waggi-text-secondary);
}

.uploaded-file-info .remove-file {
    background: none;
    border: none;
    color: var(--waggi-text-tertiary);
    cursor: pointer;
    padding: 4px;
}

.uploaded-file-info .remove-file:hover {
    color: var(--waggi-error);
}

.uploaded-files-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding-left: 36px;
}

.uploaded-files-list:empty {
    display: none;
}

.file-chip {
    display: inline-flex;
    align-items: center;
    padding: 2px 10px;
    background: var(--waggi-bg-secondary);
    border: 1px solid var(--waggi-border);
    border-radius: 12px;
    font-size: 11px;
    color: var(--waggi-text-secondary);
    font-family: 'SF Mono', 'Fira Code', monospace;
}

/* Swim Lane Container */
.swimlane-container {
    display: none;
    margin-top: 24px;
}

.swimlane-container.active {
    display: block;
}

/* Swimlane Toolbar */
.swimlane-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 12px;
    background: var(--waggi-bg-card);
    border: 1px solid var(--waggi-border-light);
    border-radius: 10px;
    margin-bottom: 8px;
    gap: 16px;
}

.toolbar-left,
.toolbar-right {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.log-search-input {
    width: 160px;
    height: 26px;
    padding: 0 8px;
    border: 1px solid var(--waggi-border-light);
    border-radius: 6px;
    background: var(--waggi-bg-subtle);
    color: var(--waggi-text-primary);
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    font-size: 11px;
    outline: none;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.log-search-input:focus {
    border-color: var(--waggi-accent, #42A5F5);
    box-shadow: 0 0 0 2px rgba(66, 165, 245, 0.15);
}

.log-search-input::placeholder {
    color: var(--waggi-text-secondary, #999);
    opacity: 0.6;
}

.search-highlight {
    background: rgba(255, 213, 79, 0.4);
    color: inherit;
    border-radius: 2px;
    padding: 0 1px;
}

.toolbar-center {
    flex: 1;
    display: flex;
    justify-content: center;
}

/* Compact Time Range */
.time-range-compact {
    display: flex;
    align-items: center;
    gap: 10px;
    max-width: 400px;
    width: 100%;
}

.time-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--waggi-text-primary);
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    background: var(--waggi-bg-subtle);
    padding: 4px 8px;
    border-radius: 4px;
    white-space: nowrap;
}

.time-range-slider-inline {
    flex: 1;
    min-width: 120px;
}

.time-range-track {
    position: relative;
    height: 6px;
    background: var(--waggi-border);
    border-radius: 3px;
    cursor: pointer;
}

.time-range-selected {
    position: absolute;
    height: 100%;
    background: linear-gradient(90deg, var(--waggi-bg-teal-medium), var(--waggi-bg-cyan));
    border-radius: 3px;
    left: 0%;
    right: 0%;
}

.time-range-handle {
    position: absolute;
    top: 50%;
    width: 14px;
    height: 14px;
    background: var(--waggi-bg-card);
    border: 2px solid var(--waggi-bg-teal-medium);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    cursor: grab;
    z-index: 2;
    transition: box-shadow 0.2s;
    touch-action: none;
}

/* Invisible expanded hit target so handles are easy to grab on small widths */
.time-range-handle::before {
    content: '';
    position: absolute;
    inset: -10px;
    border-radius: 50%;
}

.time-range-handle:hover {
    box-shadow: 0 2px 8px rgba(0, 128, 128, 0.3);
}

.time-range-handle:active {
    cursor: grabbing;
}

.time-range-handle.start { left: 0%; }
.time-range-handle.end { left: 100%; }

/* Detected event clusters — subtle span highlights on the track, clickable to zoom */
.time-range-cluster {
    position: absolute;
    top: -3px;
    bottom: -3px;
    background: rgba(0, 128, 128, 0.18);
    border-radius: 2px;
    cursor: pointer;
    z-index: 0;
    transition: background 0.15s;
}

.time-range-cluster:hover {
    background: rgba(0, 128, 128, 0.38);
}

/* Cluster-boundary tick marks — snap targets */
.time-range-snap-tick {
    position: absolute;
    top: -5px;
    width: 1px;
    height: 16px;
    background: rgba(0, 128, 128, 0.55);
    pointer-events: none;
    z-index: 1;
    transform: translateX(-50%);
}

.reset-range-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    padding: 0;
    color: var(--waggi-text-tertiary);
    background: transparent;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s;
}

.reset-range-btn:hover {
    background: var(--waggi-bg-subtle);
    color: var(--waggi-bg-teal-medium);
}

/* View Toggle - Clean Pills */
.view-toggle {
    display: flex;
    background: var(--waggi-bg-subtle);
    border-radius: 6px;
    padding: 3px;
}

.view-toggle button {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    border: none;
    background: transparent;
    color: var(--waggi-text-tertiary);
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    border-radius: 4px;
    transition: all 0.2s;
}

.view-toggle button svg {
    opacity: 0.7;
}

.view-toggle button.active {
    background: var(--waggi-bg-card);
    color: var(--waggi-text-primary);
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}

.view-toggle button.active svg {
    opacity: 1;
}

/* Level Filters - Compact Dots */
.level-filters {
    display: flex;
    align-items: center;
    gap: 4px;
}

.level-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    padding: 0;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.15s;
    background: transparent;
}

.level-toggle .level-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    transition: transform 0.15s;
}

.level-toggle.level-error .level-dot { background: #EF5350; }
.level-toggle.level-warning .level-dot { background: #FFA726; }
.level-toggle.level-info .level-dot { background: #42A5F5; }
.level-toggle.level-debug .level-dot { background: #BDBDBD; }

.level-toggle:hover {
    background: var(--waggi-bg-subtle);
}

.level-toggle:hover .level-dot {
    transform: scale(1.2);
}

.level-toggle:not(.active) .level-dot {
    opacity: 0.25;
}

/* Lane Filters Bar */
.lane-filters-bar {
    padding: 8px 0;
    margin-bottom: 8px;
}

.lane-toggles {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.lane-toggle {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    border-radius: 100px;
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s;
    border: none;
    user-select: none;
}

.lane-toggle:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}

.lane-toggle.active {
    opacity: 1;
}

.lane-toggle:not(.active) {
    opacity: 0.4;
    background: var(--waggi-bg-subtle) !important;
    color: var(--waggi-text-tertiary) !important;
    transform: none;
    box-shadow: none;
}

.lane-toggle .toggle-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: currentColor;
}

/* Lane Colors */
.lane-ble { background: #E8F4FD; color: #1976D2; }
.lane-gnss { background: #E8F5E9; color: #388E3C; }
.lane-gsm { background: #FFF3E0; color: #F57C00; }
.lane-battery { background: #FCE4EC; color: #C2185B; }
.lane-wifi { background: #E1F5FE; color: #0288D1; }
.lane-led { background: #FFF8E1; color: #FFA000; }
.lane-analytics { background: #F3E5F5; color: #7B1FA2; }
.lane-state { background: #ECEFF1; color: #546E7A; }
.lane-modem { background: #FFEBEE; color: #D32F2F; }
.lane-debug { background: #EFEBE9; color: #795548; }
.lane-other { background: #F5F5F5; color: #757575; }

/* Swim Lane Viewer */
.swimlane-viewer {
    background: var(--waggi-bg-card);
    border: 1px solid var(--waggi-border-light);
    border-radius: 10px;
    overflow: hidden;
}

.swimlane-header {
    display: flex;
    background: var(--waggi-bg-subtle);
    border-bottom: 1px solid var(--waggi-border-light);
    position: sticky;
    top: 0;
    z-index: 10;
}

.lane-label-header {
    width: 90px;
    min-width: 90px;
    padding: 8px 12px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--waggi-text-tertiary);
    border-right: 1px solid var(--waggi-border-light);
    position: sticky;
    left: 0;
    background: var(--waggi-bg-subtle);
    z-index: 5;
}

.swimlane-header .timeline-header {
    flex: 1;
    overflow: hidden;
}

.time-marker {
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    font-size: 10px;
    color: var(--waggi-text-tertiary);
    padding: 8px 0;
    text-align: center;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    white-space: nowrap;
}


.time-gridline-overlay {
    position: relative;
    height: 0;
    overflow: visible;
    pointer-events: none;
    z-index: 0;
}

.time-gridline {
    position: absolute;
    bottom: 0;
    width: 1px;
    background: var(--waggi-border-light);
    opacity: 0.4;
}

.swimlane-header .time-marker {
    /* inherits from .time-marker */
}

.swimlane-body {
    max-height: 450px;
    overflow: auto;
    position: relative;
}

/* Battery Percentage Bottom Axis */
.battery-axis-footer {
    display: flex;
    background: var(--waggi-bg-subtle);
    border-top: 1px solid var(--waggi-border-light);
    overflow: hidden;
}

.battery-axis-label {
    padding: 6px 10px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #C2185B;
    border-right: 1px solid var(--waggi-border-light);
    display: flex;
    align-items: center;
    gap: 5px;
    position: sticky;
    left: 0;
    background: var(--waggi-bg-subtle);
    z-index: 5;
    flex-shrink: 0;
}

.battery-axis-label svg {
    stroke: #C2185B;
    flex-shrink: 0;
}

.battery-axis-markers {
    flex: 1;
    position: relative;
    overflow: hidden;
    height: 28px;
}

.battery-axis-marker {
    font-size: 10px;
    color: #C2185B;
    padding: 6px 0;
    text-align: center;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    font-weight: 600;
    white-space: nowrap;
    position: absolute;
    top: 0;
}

/* Network Strength Bottom Axis */
.network-strength-axis-footer {
    display: flex;
    background: var(--waggi-bg-subtle);
    border-top: 1px solid var(--waggi-border-light);
    overflow: hidden;
}

.network-strength-axis-label {
    padding: 6px 10px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #1976D2;
    border-right: 1px solid var(--waggi-border-light);
    display: flex;
    align-items: center;
    gap: 5px;
    position: sticky;
    left: 0;
    background: var(--waggi-bg-subtle);
    z-index: 5;
    flex-shrink: 0;
}

.network-strength-axis-label svg {
    stroke: #1976D2;
    flex-shrink: 0;
}

.network-strength-axis-markers {
    flex: 1;
    position: relative;
    overflow: hidden;
    height: 28px;
}

.network-strength-axis-marker {
    font-size: 10px;
    color: #1976D2;
    padding: 6px 0;
    text-align: center;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    font-weight: 600;
    white-space: nowrap;
    position: absolute;
    top: 0;
}

.swimlane-row {
    display: flex;
    border-bottom: 1px solid var(--waggi-border-light);
    min-height: 36px;
}

.swimlane-row:last-child {
    border-bottom: none;
}

.swimlane-row:nth-child(even) {
    background: rgba(0,0,0,0.01);
}

.swimlane-row .lane-label {
    width: 90px;
    min-width: 90px;
    padding: 6px 10px;
    font-size: 11px;
    font-weight: 500;
    border-right: 1px solid var(--waggi-border-light);
    display: flex;
    align-items: center;
    gap: 6px;
    position: sticky;
    left: 0;
    background: var(--waggi-bg-card);
    z-index: 5;
}

.swimlane-row .lane-label .lane-icon {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    flex-shrink: 0;
}

.swimlane-row .lane-track {
    flex: none;
    position: relative;
    min-height: 36px;
}

/* Event Markers */
.event-marker {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    transition: all 0.15s ease;
    z-index: 1;
}

.event-marker:hover {
    z-index: 10;
    transform: translateY(-50%) scale(1.4);
}

.event-marker.instant {
    width: 7px;
    height: 7px;
    padding: 0;
    border-radius: 50%;
    box-shadow: 0 1px 2px rgba(0,0,0,0.15);
}

/* Level indicators on markers */
.event-marker.level-error {
    box-shadow: 0 0 0 2px #EF5350, 0 0 4px rgba(239, 83, 80, 0.5);
}

.event-marker.level-warning {
    box-shadow: 0 0 0 2px #FFA726, 0 0 4px rgba(255, 167, 38, 0.4);
}

/* Event Tooltip */
.event-tooltip {
    position: fixed;
    background: rgba(2, 19, 22, 0.95);
    color: white;
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 12px;
    max-width: 400px;
    z-index: 1000;
    pointer-events: none;
    box-shadow: 0 8px 24px rgba(0,0,0,0.2);
    display: none;
}

.event-tooltip.visible {
    display: block;
}

.event-tooltip .tooltip-time {
    color: var(--waggi-bg-cyan-light);
    font-size: 11px;
    margin-bottom: 2px;
    font-weight: 500;
}

.event-tooltip .tooltip-time-extra {
    display: flex;
    gap: 12px;
    font-size: 10px;
    color: #9eafb4;
    margin-bottom: 6px;
}

.event-tooltip .tooltip-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 6px;
}

.event-tooltip .tooltip-type {
    font-weight: 600;
}

.event-tooltip .tooltip-level {
    font-size: 10px;
    font-weight: 700;
    padding: 2px 6px;
    background: rgba(255,255,255,0.15);
    border-radius: 3px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.event-tooltip .tooltip-message {
    color: #E2FBFF;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    font-size: 11px;
    word-break: break-word;
    max-height: 150px;
    overflow-y: auto;
}

/* Hide upload zone when file is loaded */
.log-upload-section.file-loaded .upload-zone {
    display: none;
}

.log-upload-section.file-loaded .uploaded-file-info {
    margin-top: 0;
    border-radius: 8px 8px 0 0;
}

/* Timeline Footer */
.swimlane-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 16px;
    background: var(--waggi-bg-card);
    border-top: 1px solid var(--waggi-border-light);
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 8px;
    border-radius: 10px;
    border: 1px solid var(--waggi-border-light);
}

/* Timeline Stats */
.swimlane-stats {
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
}

.swimlane-stat {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.swimlane-stat .stat-label {
    font-size: 9px;
    color: var(--waggi-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.swimlane-stat .stat-value {
    font-size: 14px;
    font-weight: 600;
    color: var(--waggi-text-primary);
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
}

/* Choose Another File Button */
.choose-another-btn {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 6px 12px;
    background: transparent;
    border: 1px solid var(--waggi-border);
    border-radius: 6px;
    color: var(--waggi-text-tertiary);
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.choose-another-btn:hover {
    background: var(--waggi-bg-subtle);
    border-color: var(--waggi-bg-teal-medium);
    color: var(--waggi-bg-teal-medium);
}

.choose-another-btn svg {
    width: 14px;
    height: 14px;
}

/* State Chart View */
.state-chart-viewer {
    background: var(--waggi-bg-card);
    border: 1px solid var(--waggi-border-light);
    border-radius: 10px;
    overflow: hidden;
}

.state-chart-header {
    display: flex;
    background: var(--waggi-bg-subtle);
    border-bottom: 1px solid var(--waggi-border-light);
    position: sticky;
    top: 0;
    z-index: 10;
}

.state-chart-label-header {
    width: 110px;
    min-width: 110px;
    padding: 8px 12px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--waggi-text-tertiary);
    border-right: 1px solid var(--waggi-border-light);
    position: sticky;
    left: 0;
    background: var(--waggi-bg-subtle);
    z-index: 5;
}

.state-chart-header .state-chart-timeline-header {
    flex: 1;
    overflow: hidden;
}

.state-chart-header .time-marker {
    /* inherits from .time-marker base class */
}

.state-chart-body {
    max-height: 350px;
    overflow: auto;
    position: relative;
}

.state-chart-row {
    display: flex;
    border-bottom: 1px solid var(--waggi-border-light);
    min-height: 32px;
}

.state-chart-row:last-child {
    border-bottom: none;
}

.state-chart-row:nth-child(even) {
    background: rgba(0,0,0,0.01);
}

.state-chart-row .state-chart-label {
    width: 110px;
    min-width: 110px;
    padding: 6px 10px;
    font-size: 11px;
    font-weight: 500;
    border-right: 1px solid var(--waggi-border-light);
    display: flex;
    align-items: center;
    gap: 6px;
    position: sticky;
    left: 0;
    background: var(--waggi-bg-card);
    z-index: 5;
}

.state-chart-row .state-chart-label .lane-icon {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    flex-shrink: 0;
}

.state-chart-row .state-chart-track {
    flex: none;
    position: relative;
    min-height: 32px;
}

.state-bar {
    position: absolute;
    top: 4px;
    bottom: 4px;
    border-radius: 3px;
    cursor: pointer;
    transition: box-shadow 0.15s ease, filter 0.15s ease;
    z-index: 1;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.state-bar:hover {
    z-index: 10;
    box-shadow: 0 2px 8px rgba(0,0,0,0.25);
    filter: brightness(1.1);
}

.state-bar-label {
    font-size: 9px;
    color: #fff;
    padding: 0 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-shadow: 0 1px 2px rgba(0,0,0,0.4);
    font-weight: 500;
    line-height: 1;
}

.state-chart-empty {
    padding: 24px;
    text-align: center;
    color: var(--waggi-text-tertiary);
    font-size: 13px;
}

/* Event List (alternative view) */
.event-list-view {
    display: none;
    max-height: 450px;
    overflow-y: auto;
    background: var(--waggi-bg-card);
    border: 1px solid var(--waggi-border-light);
    border-radius: 10px;
}

.event-list-view.active {
    display: block;
}

/* Virtual scroll support */
.event-list-view {
    position: relative;
}
.virtual-scroll-spacer {
    width: 100%;
    pointer-events: none;
}
.virtual-scroll-viewport {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    will-change: transform;
}

/* Upload progress indicator */
.upload-progress {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    color: var(--waggi-text-secondary);
    font-size: 13px;
}

.event-list-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-bottom: 1px solid var(--waggi-border-light);
    font-size: 11px;
    transition: background 0.15s;
    box-sizing: border-box;
    overflow: hidden;
    height: 36px;
    flex-shrink: 0;
}

.event-list-item:last-child {
    border-bottom: none;
}

.event-list-item:hover {
    background: var(--waggi-bg-subtle);
}

.event-list-item .event-time {
    color: var(--waggi-text-tertiary);
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    font-size: 10px;
    min-width: 160px;
}

.event-list-item .event-device-time {
    color: var(--waggi-text-tertiary);
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    font-size: 10px;
    min-width: 80px;
    opacity: 0.6;
}

.event-list-item .event-battery {
    color: #C2185B;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    font-size: 10px;
    min-width: 36px;
    font-weight: 600;
    opacity: 0.85;
}

.event-list-item .event-lane {
    min-width: 65px;
}

.event-list-item .event-message {
    flex: 1;
    color: var(--waggi-text-primary);
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    font-size: 11px;
    line-height: 1.4;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Level badge in event list */
.event-level-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 8px;
    padding: 2px 6px;
    border-radius: 3px;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.3px;
    min-width: 50px;
}

.event-level-badge .level-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
}

.event-level-badge.level-error {
    background: rgba(239, 83, 80, 0.15);
    color: #EF5350;
}

.event-level-badge.level-error .level-dot {
    background: #EF5350;
}

.event-level-badge.level-warning {
    background: rgba(255, 167, 38, 0.15);
    color: #F57C00;
}

.event-level-badge.level-warning .level-dot {
    background: #FFA726;
}

.event-level-badge.level-info {
    background: rgba(66, 165, 245, 0.15);
    color: #42A5F5;
}

.event-level-badge.level-info .level-dot {
    background: #42A5F5;
}

.event-level-badge.level-debug {
    background: rgba(189, 189, 189, 0.15);
    color: #9E9E9E;
}

.event-level-badge.level-debug .level-dot {
    background: #BDBDBD;
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .swimlane-toolbar {
        flex-direction: column;
        gap: 10px;
        padding: 10px;
    }

    .toolbar-left,
    .toolbar-center,
    .toolbar-right {
        width: 100%;
        justify-content: center;
    }

    .time-range-compact {
        max-width: none;
    }

    .lane-filters-bar {
        padding: 6px 0;
    }

    .lane-toggles {
        justify-content: center;
    }

    .lane-label-header,
    .swimlane-row .lane-label {
        width: 70px;
        min-width: 70px;
        font-size: 9px;
    }

    .swimlane-footer {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
    }

    .swimlane-stats {
        justify-content: space-between;
    }

    .choose-another-btn {
        justify-content: center;
    }
}

/* ============================================================
   WIDE-DISPLAY RESPONSIVE (QHD, ultrawide, 4K, 5K)
   Container runs edge-to-edge at all sizes. Below breakpoints
   scale paddings, font sizes, chart/map heights together so
   the layout stays proportionally balanced — things get taller
   as they get wider, not just wider.
   ============================================================ */

@media (min-width: 2000px) {
    .container { padding: 24px; }

    .config-panel { padding: 28px; }

    .stat-card { padding: 28px; }
    .stat-card h4 { font-size: 12px; }
    .stat-card .value { font-size: 34px; }
    .stat-card .subtext { font-size: 13px; }

    .chart-card { padding: 28px; }
    .chart-card h3 { font-size: 16px; margin-bottom: 18px; }

    .primary-chart .chart-container { height: 380px; }
    .chart-container { height: 380px; }
    .location-row .map-container { height: 400px; }
    .debug-chart-container { height: 300px; }
}

@media (min-width: 3200px) {
    .container { padding: 36px; }

    .config-panel { padding: 40px; }

    .stat-card { padding: 44px 32px; }
    .stat-card h4 { font-size: 14px; }
    .stat-card .value { font-size: 48px; }
    .stat-card .subtext { font-size: 14px; }

    .chart-card { padding: 36px; }
    .chart-card h3 { font-size: 20px; margin-bottom: 24px; }

    .primary-chart .chart-container { height: 560px; }
    .chart-container { height: 500px; }
    .location-row .map-container { height: 600px; }
    .debug-chart-container { height: 420px; }
}
