/**
 * CockpitOS Light Theme - Centerplan Directory Board
 * 
 * Verantwortlichkeit: Directory Board Styling
 * 
 * @package CockpitOS_Light_Theme
 * @version 1.0.0
 */

/* ========================================
   Directory Board Container
   ======================================== */

.centerplan-directory-board {
    padding: var(--spacing-md, 1rem);
    background-color: var(--color-white, #ffffff);
    border-radius: var(--radius-lg, 0.75rem);
    box-shadow: var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, 0.1));
    min-height: 400px;
    max-width: 100%;
    width: 100%;
}

/* ========================================
   Vertical Layout (Logo oben, Services links, Kategorien rechts)
   ======================================== */

.centerplan-directory-board--vertical {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg, 1.5rem);
}

/* Logo mittig oben */
.centerplan-directory-board--vertical .centerplan-directory-board__logo {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding-bottom: var(--spacing-md, 1rem);
    border-bottom: 1px solid var(--color-gray-200, #e5e7eb);
}

/* ========================================
   Masonry Container (Vereinheitlicht für alle Layouts)
   ======================================== */

/* Masonry Container: Grid für Spalten */
.centerplan-directory-board__masonry-container {
    display: grid;
    grid-template-columns: repeat(var(--masonry-columns, 3), 1fr);
    gap: var(--spacing-md, 1rem);
    align-items: start;
    width: 100%;
}

/* Masonry-Spalten (werden via JS erstellt) */
.centerplan-directory-board__masonry-column {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg, 1.5rem);
}

/* ========================================
   Elemente in Spalten (Services + Kategorien)
   ======================================== */

/* Services Block */
.centerplan-directory-board__services {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm, 0.5rem);
}

.centerplan-directory-board__services-title {
    font-size: var(--font-size-base, 1rem);
    font-weight: var(--font-weight-bold, 700);
    color: var(--color-gray-900, #0f172a);
    margin: 0 0 var(--spacing-xs, 0.25rem) 0;
}

.centerplan-directory-board__services-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs, 0.25rem);
}

/* Kategorie Block */
.centerplan-directory-board__category {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs, 0.25rem);
}

.centerplan-directory-board__category-header {
    display: block;
    margin-bottom: var(--spacing-xs, 0.25rem);
    font-size: var(--font-size-base, 1rem);
    font-weight: var(--font-weight-semibold, 600);
}

.centerplan-directory-board__category-items {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs, 0.25rem);
}

/* ========================================
   Horizontal Layout (Logo links, Services links unten, Kategorien rechts)
   ======================================== */

.centerplan-directory-board--horizontal {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg, 1.5rem);
}

/* Logo mittig oben */
.centerplan-directory-board--horizontal .centerplan-directory-board__logo {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding-bottom: var(--spacing-md, 1rem);
    border-bottom: 1px solid var(--color-gray-200, #e5e7eb);
}

/* Alte horizontal/vertical Layout-Styles nicht mehr benötigt */
/* Alle Layouts verwenden jetzt das Masonry-System */

/* ========================================
   Logo (Standard-Styles für beide Modi)
   ======================================== */

.centerplan-directory-board__logo {
    display: flex;
    flex-direction: column;
}

.centerplan-directory-board__logo img {
    max-width: 300px;
    max-height: 80px;
    width: auto;
    height: auto;
    object-fit: contain;
}

/* Alte Content-Wrapper-Styles entfernt */
/* Services & Kategorien sind jetzt innerhalb des Masonry-Systems definiert */


.centerplan-directory-board__service-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm, 0.5rem);
    font-size: var(--font-size-sm, 0.875rem);
    color: var(--color-gray-700, #334155);
}

.centerplan-directory-board__service-icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-gray-600, #475569);
}

/* ========================================
   Categories
   ======================================== */

.centerplan-directory-board__categories {
    /* Layout wird durch Modifier-Klassen gesteuert */
}

.centerplan-directory-board__categories-column {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md, 1rem);
}

.centerplan-directory-board__category {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs, 0.25rem);
}

.centerplan-directory-board__category-header {
    padding: var(--spacing-xs, 0.25rem) 0;
    font-size: var(--font-size-sm, 0.875rem);
    font-weight: var(--font-weight-semibold, 600);
    background-color: transparent !important;
    border-radius: 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--spacing-xs, 0.25rem);
}

.centerplan-directory-board__category-items {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs, 0.25rem);
    padding: var(--spacing-xs, 0.25rem) 0;
}

.centerplan-directory-board__shop-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs, 0.25rem);
    padding: var(--spacing-xs, 0.25rem) 0;
    border-radius: 0;
    font-size: var(--font-size-sm, 0.875rem);
    font-weight: var(--font-weight-normal, 400);
    background-color: transparent;
    color: var(--color-gray-900, #0f172a);
    transition: opacity var(--transition-fast, 150ms ease);
    text-decoration: none;
    line-height: 1.4;
    white-space: nowrap;
}

/* Links haben Pointer-Cursor */
a.centerplan-directory-board__shop-item {
    cursor: pointer;
}

a.centerplan-directory-board__shop-item:hover {
    opacity: 0.7;
    text-decoration: none;
    color: var(--color-gray-900, #0f172a);
}

/* Div-Elemente (ohne Link) haben Default-Cursor */
div.centerplan-directory-board__shop-item {
    cursor: default;
}

div.centerplan-directory-board__shop-item:hover {
    opacity: 1;
}

.centerplan-directory-board__shop-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: var(--font-weight-bold, 700);
    flex-shrink: 0;
    min-width: 32px;
    height: 24px;
    padding: 0 var(--spacing-xs, 0.25rem);
    border-radius: var(--radius-xs, 0.125rem);
    text-align: center;
    font-size: var(--font-size-sm, 0.875rem);
    color: var(--color-white, #ffffff);
}

.centerplan-directory-board__shop-name {
    flex-shrink: 0;
    white-space: nowrap;
}

/* ========================================
   Responsive
   ======================================== */

/* Laptop (13" MacBook, etc.) */
@media (max-width: 1440px) {
    /* Masonry: Max 2 Spalten auf Laptop */
    .centerplan-directory-board__masonry-container {
        grid-template-columns: repeat(min(var(--masonry-columns, 3), 2), 1fr) !important;
    }
    
    .centerplan-directory-board {
        padding: var(--spacing-md, 1rem);
    }
    
    .centerplan-directory-board__masonry-column {
        gap: var(--spacing-lg, 1.5rem);
    }
}

/* Tablet: Kompakter */
@media (max-width: 1024px) {
    .centerplan-directory-board--horizontal,
    .centerplan-directory-board--vertical {
        gap: var(--spacing-md, 1rem);
    }
    
    /* Masonry-Spalten: Reduzierter Gap auf Tablet */
    .centerplan-directory-board__masonry-column {
        gap: var(--spacing-md, 1rem);
    }
    
    .centerplan-directory-board {
        padding: var(--spacing-md, 1rem);
    }
    
    .centerplan-directory-board__logo img {
        max-width: 200px;
        max-height: 60px;
    }
    
    .centerplan-directory-board__category-header {
        font-size: var(--font-size-sm, 0.875rem);
    }
    
    .centerplan-directory-board__shop-item {
        font-size: var(--font-size-sm, 0.875rem);
    }
    
    .centerplan-directory-board__shop-number {
        min-width: 28px;
        height: 20px;
        font-size: var(--font-size-xs, 0.75rem);
    }
}

/* Mobile: Alles untereinander */
@media (max-width: 768px) {
    .centerplan-directory-board--horizontal,
    .centerplan-directory-board--vertical {
        gap: var(--spacing-md, 1rem);
    }
    
    .centerplan-directory-board {
        padding: var(--spacing-md, 1rem);
    }
    
    /* Logo zentriert */
    .centerplan-directory-board__logo {
        justify-content: center;
    }
    
    .centerplan-directory-board__logo img {
        max-width: 200px;
        max-height: 70px;
    }
    
    /* Content: Untereinander statt nebeneinander */
    .centerplan-directory-board--horizontal .centerplan-directory-board__content,
    .centerplan-directory-board--vertical .centerplan-directory-board__content {
        grid-template-columns: 1fr;
        gap: var(--spacing-md, 1rem);
    }
    
    /* Services: Volle Breite */
    .centerplan-directory-board__services {
        grid-column: 1;
    }
    
    /* Mobile: Kategorien = 2 Spalten (wenn genug Platz) */
    .centerplan-directory-board--horizontal .centerplan-directory-board__categories,
    .centerplan-directory-board--vertical .centerplan-directory-board__categories {
        grid-column: 1;
        grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
        gap: var(--spacing-md, 1rem);
    }
    
    
    .centerplan-directory-board__category-header {
        font-size: var(--font-size-sm, 0.875rem);
    }
    
    .centerplan-directory-board__shop-item {
        font-size: var(--font-size-sm, 0.875rem);
        padding: var(--spacing-xs, 0.25rem) 0;
    }
    
    .centerplan-directory-board__shop-number {
        min-width: 32px;
        height: 24px;
        font-size: var(--font-size-sm, 0.875rem);
    }
    
    /* Masonry: Max 2 Spalten auf Tablet */
    .centerplan-directory-board__masonry-container {
        grid-template-columns: repeat(min(var(--masonry-columns, 3), 2), 1fr) !important;
    }
}

/* Kleine Mobile: 1 Spalte */
@media (max-width: 480px) {
    .centerplan-directory-board {
        padding: var(--spacing-sm, 0.5rem);
    }
    
    .centerplan-directory-board--horizontal,
    .centerplan-directory-board--vertical {
        gap: var(--spacing-sm, 0.5rem);
    }
    
    /* Masonry: 1 Spalte auf Mobile */
    .centerplan-directory-board__masonry-container {
        grid-template-columns: 1fr !important;
        gap: var(--spacing-sm, 0.5rem);
    }
    
    .centerplan-directory-board__masonry-column {
        gap: var(--spacing-md, 1rem);
    }
    
    .centerplan-directory-board__masonry-column {
        gap: var(--spacing-xs, 0.25rem);
    }
    
    .centerplan-directory-board__logo img {
        max-width: 150px;
        max-height: 50px;
    }
    
    .centerplan-directory-board__services-title {
        font-size: var(--font-size-sm, 0.875rem);
    }
    
    .centerplan-directory-board__service-item {
        font-size: var(--font-size-xs, 0.75rem);
    }
    
    .centerplan-directory-board__category-header {
        font-size: var(--font-size-xs, 0.75rem);
    }
    
    .centerplan-directory-board__shop-item {
        font-size: var(--font-size-xs, 0.75rem);
    }
    
    .centerplan-directory-board__shop-number {
        min-width: 28px;
        height: 20px;
        font-size: var(--font-size-xs, 0.75rem);
    }
}

