/* KE Preisliste - Frontend-Styles
 * Design: moderne, dezente Liste mit Leistung links, Preis rechts.
 * Responsive: auf Mobile stackt die Zeile in zwei Zeilen.
 * Farbgebung lehnt an Hello Elementor / eigenes Theme an (Variablen von Elementor werden übernommen).
 */

.ke-preisliste {
    --kepl-color-text: var(--e-global-color-text, #2e2e2e);
    --kepl-color-price: var(--e-global-color-accent, #8a9a5b);
    --kepl-color-muted: #6a6a6a;
    --kepl-color-divider: rgba(0, 0, 0, 0.08);
    --kepl-gap: 14px;
    --kepl-font-size-leistung: 1rem;
    --kepl-font-size-preis: 1rem;
    --kepl-font-size-anmerkung: 0.85rem;
    font-family: inherit;
    color: var(--kepl-color-text);
    max-width: 100%;
}

.ke-preisliste__kat-title {
    font-size: 1.4rem;
    font-weight: 600;
    margin: 1.8em 0 0.6em;
    color: var(--kepl-color-text);
    letter-spacing: 0.01em;
}

.ke-preisliste__kat-title:first-child {
    margin-top: 0;
}

.ke-preisliste__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ke-preisliste__item {
    padding: var(--kepl-gap) 0;
    border-bottom: 1px solid var(--kepl-color-divider);
}

.ke-preisliste__item:last-child {
    border-bottom: none;
}

.ke-preisliste__head {
    display: flex;
    align-items: baseline;
    gap: 1em;
    width: 100%;
}

.ke-preisliste__leistung {
    flex: 1 1 auto;
    font-size: var(--kepl-font-size-leistung);
    font-weight: 500;
    line-height: 1.35;
}

.ke-preisliste__preis {
    flex: 0 0 auto;
    font-size: var(--kepl-font-size-preis);
    font-weight: 600;
    color: var(--kepl-color-price);
    white-space: nowrap;
    text-align: right;
}

.ke-preisliste__einheit {
    display: inline-block;
    margin-left: 4px;
    font-weight: 400;
    font-size: 0.85em;
    color: var(--kepl-color-muted);
}

.ke-preisliste__anmerkung {
    margin-top: 4px;
    font-size: var(--kepl-font-size-anmerkung);
    color: var(--kepl-color-muted);
    line-height: 1.4;
    font-style: italic;
}

.ke-preisliste--align-center {
    text-align: center;
}

.ke-preisliste--align-center .ke-preisliste__head {
    justify-content: center;
    gap: 0.5em;
}

/* Mobile: zwei Zeilen pro Eintrag */
@media (max-width: 600px) {
    .ke-preisliste__head {
        flex-direction: column;
        align-items: flex-start;
        gap: 2px;
    }
    .ke-preisliste__preis {
        text-align: left;
    }
    .ke-preisliste--align-center .ke-preisliste__head {
        align-items: center;
    }
}
