/*
 * QuickMonster Image Fallback Styles
 * Graceful handling when images fail to load
 */

/* Image error state */
.img-fallback {
    position: relative;
    background: linear-gradient(135deg, var(--qm-charcoal) 0%, var(--qm-midnight-blue) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100px;
}

.img-fallback::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(45deg, var(--qm-granite) 25%, transparent 25%),
        linear-gradient(-45deg, var(--qm-granite) 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, var(--qm-granite) 75%),
        linear-gradient(-45deg, transparent 75%, var(--qm-granite) 75%);
    background-size: 20px 20px;
    background-position: 0 0, 0 10px, 10px -10px, -10px 0px;
    opacity: 0.3;
}

.img-fallback::after {
    content: 'Image unavailable';
    position: relative;
    z-index: 1;
    color: var(--qm-text-muted);
    font-size: var(--qm-text-sm);
    text-align: center;
    padding: var(--qm-space-md);
}

/* Larger fallback for main images */
.img-fallback-lg::after {
    content: 'Image temporarily unavailable';
    font-size: var(--qm-text-base);
}

.img-fallback-lg {
    min-height: 200px;
}

/* Icon version for gallery thumbnails */
.img-fallback-icon::after {
    content: '🖼';
    font-size: 1.5rem;
}

/* Hide broken image icon */
img.img-error {
    opacity: 0;
    position: absolute;
}

/* Storage status banner */
.storage-status-banner {
    background: linear-gradient(135deg, var(--qm-warning-dark) 0%, var(--qm-obsidian) 100%);
    border: 1px solid var(--qm-warning);
    border-radius: var(--qm-radius-md);
    padding: var(--qm-space-sm) var(--qm-space-md);
    margin-bottom: var(--qm-space-md);
    display: flex;
    align-items: center;
    gap: var(--qm-space-sm);
    font-size: var(--qm-text-sm);
    color: var(--qm-warning-light);
}

.storage-status-banner-icon {
    font-size: 1.2rem;
}

.storage-status-banner-text {
    flex: 1;
}

.storage-status-banner-dismiss {
    background: none;
    border: none;
    color: var(--qm-text-muted);
    cursor: pointer;
    padding: var(--qm-space-xs);
    font-size: 1.2rem;
    line-height: 1;
}

.storage-status-banner-dismiss:hover {
    color: var(--qm-text-light);
}
