/* Prolice Immo — public styles. Uses CSS custom properties for easy theming. */
.prolice-immo-archive,
.prolice-immo-single {
    --wpi-radius: 12px;
    --wpi-gap: 24px;
    --wpi-accent: #103d3b;
    --wpi-muted: #6c6c6c;
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 16px;
}

/* Cards grid */
.prolice-immo-grid-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--wpi-gap);
}

.prolice-immo-card {
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: var(--wpi-radius);
    overflow: hidden;
    background: #fff;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.prolice-immo-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.1);
}

.prolice-immo-card__media {
    position: relative;
    display: block;
    aspect-ratio: 4 / 3;
    background: #f1efe9;
}

.prolice-immo-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.prolice-immo-card__status {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 4px 10px;
    border-radius: 999px;
    background: var(--wpi-accent);
    color: #fff;
    font-size: 0.75rem;
    font-weight: 700;
}

.prolice-immo-card__body {
    padding: 16px;
}

.prolice-immo-card__title {
    margin: 0 0 4px;
    font-size: 1.05rem;
}

.prolice-immo-card__title a {
    text-decoration: none;
    color: inherit;
}

.prolice-immo-card__city {
    margin: 0 0 8px;
    color: var(--wpi-muted);
    font-size: 0.9rem;
}

.prolice-immo-card__price {
    margin: 0 0 10px;
    font-weight: 800;
    color: var(--wpi-accent);
}

.prolice-immo-card__specs {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
    font-size: 0.85rem;
    color: var(--wpi-muted);
}

/* Search form */
.prolice-immo-search-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin: 24px 0;
    padding: 18px;
    border-radius: var(--wpi-radius);
    background: #f8f6f1;
}

.prolice-immo-search-form__row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.prolice-immo-search-form input,
.prolice-immo-search-form select {
    flex: 1 1 160px;
    min-height: 42px;
    padding: 0 12px;
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: 8px;
}

.prolice-immo-energy-filter {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    border: 0;
    margin: 0;
    padding: 0;
}

.prolice-immo-search-submit,
.prolice-immo-contact-submit {
    min-height: 44px;
    padding: 0 22px;
    border: 0;
    border-radius: 8px;
    background: var(--wpi-accent);
    color: #fff;
    font-weight: 700;
    cursor: pointer;
}

/* Results state */
.prolice-immo-results.is-loading {
    opacity: 0.5;
    pointer-events: none;
}

.prolice-immo-results__count {
    margin: 0 0 16px;
    color: var(--wpi-muted);
}

.prolice-immo-pagination {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin: 30px 0;
}

.prolice-immo-pagination .page-numbers {
    padding: 6px 12px;
    border-radius: 6px;
    border: 1px solid rgba(0, 0, 0, 0.12);
    text-decoration: none;
}

.prolice-immo-pagination .current {
    background: var(--wpi-accent);
    color: #fff;
}

/* Single */
.prolice-immo-single__price {
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--wpi-accent);
}

.prolice-immo-specs__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 12px;
    list-style: none;
    padding: 0;
}

.prolice-immo-specs__grid .label {
    display: block;
    font-size: 0.8rem;
    color: var(--wpi-muted);
}

.prolice-immo-features__list {
    columns: 2;
    gap: 24px;
}

/* PEB label image (bundled badges A++ → G) */
.prolice-immo-peb-label {
    height: 40px;
    width: auto;
    display: inline-block;
    vertical-align: middle;
}

.prolice-immo-card__peb {
    margin: 8px 0 0;
}

.prolice-immo-card__peb .prolice-immo-peb-label {
    height: 28px;
}

/* PEB text badge (fallback when no image) */
.prolice-immo-peb {
    display: inline-block;
    padding: 6px 16px;
    border-radius: 6px;
    color: #fff;
    font-weight: 800;
}

.prolice-immo-peb--a { background: #1a9641; }
.prolice-immo-peb--b { background: #73c378; }
.prolice-immo-peb--c { background: #c4e687; }
.prolice-immo-peb--d { background: #fee08b; color: #333; }
.prolice-immo-peb--e { background: #fdae61; }
.prolice-immo-peb--f { background: #f46d43; }
.prolice-immo-peb--g { background: #d73027; }

/* Embeds */
.prolice-immo-embed {
    position: relative;
    padding-top: 56.25%;
}

.prolice-immo-embed iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

/* Contact form */
.prolice-immo-contact-form label {
    display: block;
    font-weight: 600;
}

.prolice-immo-contact-form input,
.prolice-immo-contact-form textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: 8px;
}

.prolice-immo-contact-feedback.is-success { color: #1a9641; }
.prolice-immo-contact-feedback.is-error { color: #d73027; }

@media (max-width: 768px) {
    .prolice-immo-features__list { columns: 1; }
}
