/* Performance optimizations for SkaiShield */

/* Reduce initial layout shifts */
.status-indicator {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: #6c757d;
    transition: background-color 0.3s ease;
}

.status-indicator.connected {
    background-color: #198754;
}

.status-indicator.reconnecting {
    background-color: #fd7e14;
    animation: pulse 1s infinite;
}

.status-indicator.disconnected {
    background-color: #dc3545;
}

.status-indicator.failed {
    background-color: #dc3545;
    animation: flash 0.5s infinite;
}

/* Optimized animations */
@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

@keyframes flash {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
}

/* Loading states */
.loading-skeleton {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: loading 1.5s infinite;
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Efficient card layout */
.token-card {
    contain: layout style;
    will-change: transform;
    transition: transform 0.2s ease;
}

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

/* Optimize heavy elements */
.chart-container {
    contain: strict;
    height: 300px;
}

/* Mobile optimizations */
@media (max-width: 768px) {
    .container-fluid {
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }
    
    .card {
        margin-bottom: 0.5rem;
    }
    
    .btn {
        padding: 0.25rem 0.5rem;
        font-size: 0.875rem;
    }
    
    /* Hide non-essential elements on mobile */
    .d-mobile-none {
        display: none !important;
    }
}

/* Performance-focused visibility */
.tab-content .tab-pane:not(.active) {
    display: none !important;
}

/* Efficient table styling */
.table {
    table-layout: fixed;
}

.table td, .table th {
    word-wrap: break-word;
}

/* Reduce repaints */
.badge {
    contain: layout style;
}

/* Optimize scrolling */
.scrollable-content {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    will-change: scroll-position;
}

/* Memory efficient animations */
.fade-in {
    animation: fadeIn 0.3s ease-in;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}