/* Catering Banner System - Uses presence detector structure with accent theme */

/* Main catering indicator using presence structure */
.catering-banner {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-bottom: 8px !important;
    padding: 8px 10px !important;
    /* Use theme's accent colors with transparency */
    background: rgba(var(--accent-primary-rgb, 167, 139, 250), 0.1) !important;
    border-radius: 8px !important;
    border: 1px solid rgba(var(--accent-primary-rgb, 167, 139, 250), 0.3) !important;
    position: relative !important;
    z-index: 2 !important;
    justify-content: space-between !important;
}

/* Use presence-content for proper flex layout */
.catering-banner .presence-content {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    flex: 1 !important;
    min-width: 0 !important;
}

/* Progress bar uses presence classes with accent override */
.catering-banner .presence-bar-compact {
    flex: 1 !important;
    height: 16px !important;
    background: rgba(0, 0, 0, 0.3) !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    position: relative !important;
}

.catering-banner .presence-fill-compact {
    height: 100% !important;
    /* Use theme's accent gradient */
    background: linear-gradient(90deg, var(--accent-primary), var(--accent-secondary)) !important;
    transition: width 0.3s !important;
    box-shadow: 0 0 10px rgba(var(--accent-primary-rgb, 167, 139, 250), 0.5) !important;
}

/* Catering text styling */
.catering-text {
    color: var(--accent-primary) !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    white-space: nowrap !important;
}

.catering-timer {
    color: var(--accent-primary) !important;
    font-weight: 600 !important;
    font-size: 12px !important;
    margin-left: 8px !important;
}

/* State: Locked */
.catering-banner.locked {
    background: rgba(128, 128, 128, 0.1) !important;
    border-color: rgba(128, 128, 128, 0.3) !important;
}

.catering-banner.locked .catering-text {
    color: var(--text-secondary) !important;
}

/* State: Ready */
.catering-banner.ready {
    animation: 2s ease-in-out infinite catering-glow !important;
}

@keyframes catering-glow {
    0%, 100% {
        box-shadow: 0 0 5px rgba(var(--accent-primary-rgb, 167, 139, 250), 0.3);
    }
    50% {
        box-shadow: 0 0 20px rgba(var(--accent-primary-rgb, 167, 139, 250), 0.6);
    }
}

/* Cooking state gradient */
.catering-banner.cooking .presence-fill-compact {
    /* Use a warmer gradient for cooking state */
    background: linear-gradient(90deg, var(--warning), var(--success)) !important;
}

/* Unlock / action button */
.catering-unlock-btn {
    background: rgba(var(--accent-primary-rgb, 167, 139, 250), 0.2) !important;
    border: 1px solid rgba(var(--accent-primary-rgb, 167, 139, 250), 0.4) !important;
    color: var(--accent-primary) !important;
    padding: 4px 12px !important;
    border-radius: 4px !important;
    cursor: pointer !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    transition: all 0.3s !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    position: relative !important;
}

.catering-unlock-btn:hover:not(:disabled) {
    background: rgba(var(--accent-primary-rgb, 167, 139, 250), 0.3) !important;
    box-shadow: 0 2px 8px rgba(var(--accent-primary-rgb, 167, 139, 250), 0.4) !important;
}

.catering-unlock-btn:disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
}

/* Container cleanup */
#cateringSection {
    background: none !important;
    border: none !important;
    padding: 0 !important;
    margin-top: 5px !important;
    width: 100% !important;
    display: block !important;
}

#cateringDisplay {
    background: none !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
}

/* Responsive adjustments */
@media (max-width: 1750px) {
    .catering-banner {
        padding: 4px 8px !important;
        gap: 6px !important;
    }

    .catering-banner .presence-bar-compact {
        height: 14px !important;
    }

    .catering-text {
        font-size: 11px !important;
    }
}

@media (max-width: 768px) {
    .catering-banner {
        padding: 3px 6px !important;
        gap: 4px !important;
    }

    .catering-banner .presence-bar-compact {
        height: 12px !important;
    }

    .catering-text {
        font-size: 10px !important;
    }

    .catering-unlock-btn {
        font-size: 9px !important;
        padding: 2px 6px !important;
    }
}

