/**
 * CockpitOS CM-Immo Theme - Shop Grid Widget (CM-Immo Style)
 * 
 * Verantwortlichkeit: Shop Grid Styling für Mall-Shops
 * Cookie-Mood: Cards mit Badges, Tags, Hover-Effekte
 * 
 * @package CockpitOS_Light_Theme
 * @version 1.2.0 (CM-Immo Style Update)
 */

/* Shop Grid Container */
.cockpit-shop-grid {
}

/* Shop Grid */
.cockpit-shop-grid__grid {
    display: grid;
    gap: var(--spacing-8, 3rem);
}

/* Grid Columns (Dynamic) */
.cockpit-shop-grid__grid[data-columns="1"] { grid-template-columns: 1fr; }
.cockpit-shop-grid__grid[data-columns="2"] { grid-template-columns: repeat(2, 1fr); }
.cockpit-shop-grid__grid[data-columns="3"] { grid-template-columns: repeat(3, 1fr); }
.cockpit-shop-grid__grid[data-columns="4"] { grid-template-columns: repeat(4, 1fr); }

/* Shop Card */
.cockpit-shop-grid__card {
    position: relative;
    overflow: hidden;
}

/* Badge Position (Top Left wie Cookie-Theme) */
.cockpit-shop-grid__card .cm-badge {
    position: absolute;
    top: var(--spacing-4, 1.5rem);
    left: var(--spacing-4, 1.5rem);
    z-index: 10;
}

/* Badge Star Icon */
.cm-badge--star {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background-color: #ffffff;
    border-radius: 50px;
    box-shadow: var(--shadow-md);
    font-size: 14px;
    font-weight: 600;
}

.cm-badge--star i {
    color: var(--color-gold, #fbbf24); /* Gelb/Gold für Stern */
    font-size: 14px;
}

/* Shop Image */
.cockpit-shop-grid__image-wrapper {
    margin-bottom: var(--spacing-4, 1.5rem);
    overflow: hidden;
    border-radius: 20px;
}

.cockpit-shop-grid__image-link {
    display: block;
    text-decoration: none;
}

.cockpit-shop-grid__card img.cm-image {
    transition: transform var(--duration-normal) var(--ease-smooth);
}

.cockpit-shop-grid__card:hover img.cm-image {
    transform: scale(1.05);
}

/* Shop Content */
.cockpit-shop-grid__content {
    padding: var(--spacing-4, 1.5rem);
}

/* Category Tag */
.cockpit-shop-grid__content .cm-tag {
    margin-bottom: var(--spacing-3, 1rem);
}

/* Shop Title */
.cockpit-shop-grid__title {
    font-family: var(--font-family-heading, 'Baloo 2', sans-serif);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-primary, var(--color-primary, #da2032));
    margin: 0 0 var(--spacing-3, 1rem) 0;
    line-height: 1.3;
}

.cockpit-shop-grid__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--duration-fast) var(--ease-smooth);
}

.cockpit-shop-grid__title a:hover {
    color: var(--color-secondary, #F25363);
}

/* Shop Description */
.cockpit-shop-grid__description {
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--color-text-secondary, #6b7280);
    margin-bottom: var(--spacing-4, 1.5rem);
}

/* Shop Location */
.cockpit-shop-grid__location {
    display: flex;
    align-items: center;
    gap: var(--spacing-2, 0.75rem);
    font-size: 0.875rem;
    color: var(--color-text-secondary, #6b7280);
    margin-bottom: var(--spacing-4, 1.5rem);
}

.cockpit-shop-grid__location i {
    color: var(--color-secondary, #F25363);
}

/* Link Button */
.cockpit-shop-grid__content .cm-button {
    width: 100%;
    justify-content: center;
}

/* Responsive */
@media (max-width: 1024px) {
    .cockpit-shop-grid__grid[data-columns-tablet="1"] { grid-template-columns: 1fr; }
    .cockpit-shop-grid__grid[data-columns-tablet="2"] { grid-template-columns: repeat(2, 1fr); }
    .cockpit-shop-grid__grid[data-columns-tablet="3"] { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
    .cockpit-shop-grid {
        padding: var(--spacing-8, 3rem) var(--spacing-4, 1.5rem);
    }
    
    .cockpit-shop-grid__grid {
        gap: var(--spacing-6, 2rem);
    }
    
    .cockpit-shop-grid__grid[data-columns-mobile="1"] { grid-template-columns: 1fr; }
    .cockpit-shop-grid__grid[data-columns-mobile="2"] { grid-template-columns: repeat(2, 1fr); }
    
    .cockpit-shop-grid__title {
        font-size: 1.25rem;
    }
}

@media (max-width: 480px) {
    .cockpit-shop-grid {
        padding: var(--spacing-6, 2rem) var(--spacing-3, 1rem);
    }
    
    .cockpit-shop-grid__grid {
        gap: var(--spacing-4, 1.5rem);
    }
}
