/* === GLOBALE CONTAINER & TOP-BAR === */
#ipc-price-table-container { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; }
#ipc-top-bar { display: flex; margin-bottom: 15px; gap: 10px; align-items: center; }
.ipc-search-wrapper { flex-grow: 1; }
.ipc-search-wrapper input[name="search"] { width: 100%; height: 40px; padding: 0 15px; border-radius: 8px; border: 1px solid #ccc; font-size: 15px; }
.ipc-view-switcher { display: flex; flex-shrink: 0; gap: 0; }
.ipc-view-switcher button, #ipc-open-filters-btn { width: 40px; height: 40px; border: 1px solid #ccc; background: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; padding: 0; }
.ipc-view-switcher button img, #ipc-open-filters-btn img { height: 20px; width: 20px; }
.ipc-view-switcher button:first-child { border-radius: 8px 0 0 8px; }
.ipc-view-switcher button:last-child { border-radius: 0 8px 8px 0; border-left: none; }
.ipc-view-switcher button.active { background-color: #0073aa; border-color: #0073aa; }
.ipc-view-switcher button.active img { filter: brightness(0) invert(1); }
#ipc-open-filters-btn { display: none; border-radius: 8px; }

/* === NEU: Preisfilter in der Top-Bar === */
.ipc-price-filter-wrapper { display: flex; }
.ipc-price-filter-inputs { display: flex; gap: 6px; }
.ipc-price-filter-inputs input {
    width: 90px;
    height: 40px;
    padding: 0 10px;
    text-align: center;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 15px;
    -moz-appearance: textfield; /* Firefox */
}
.ipc-price-filter-inputs input::-webkit-outer-spin-button,
.ipc-price-filter-inputs input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}


/* === DESKTOP FILTER-BEREICH === */
#ipc-filter-form-desktop { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 2em; align-items: center; }
.ipc-filter-pills-container { display: flex; flex-wrap: wrap; gap: 10px; }
.ipc-filter-pill { display: flex; align-items: center; background-color: #f5f5f5; border: 1px solid transparent; border-radius: 20px; height: 36px; font-size: 14px; padding: 0; }
.ipc-live-search-wrapper { position: relative; }
.ipc-filter-pill:hover { border-color: #ccc; }
.ipc-filter-pill select, .ipc-filter-pill input.ipc-live-search-input { border: none; background: transparent; -webkit-appearance: none; appearance: none; font-size: 14px; font-weight: 500; cursor: pointer; padding: 0 15px; height: 100%; border-radius: 20px; }
.ipc-filter-pill select:focus, .ipc-filter-pill input.ipc-live-search-input:focus { outline: none; }
.ipc-controls-container { margin-left: auto; display: flex; gap: 6px; }
.ipc-reset-button, .ipc-submit-button { height: 36px; border-radius: 20px; border: 1px solid #ccc; background: #fff; padding: 0 15px; cursor: pointer; font-size: 14px; }
.ipc-reset-button:hover, .ipc-submit-button:hover { background-color: #f0f0f0; }
.ipc-submit-button { background-color: #0073aa; color: #fff; border-color: #0073aa; font-weight: 600; }
.ipc-submit-button:hover { background-color: #005a87; }

/* === MOBILER FILTER-SIDEBAR === */
#ipc-filter-sidebar { position: fixed; top: 0; right: 0; width: 300px; max-width: 85%; height: 100%; background: #fff; z-index: 1002; box-shadow: -5px 0 15px rgba(0,0,0,0.1); transform: translateX(100%); transition: transform 0.3s ease-in-out; display: flex; flex-direction: column; }
#ipc-filter-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); z-index: 1001; opacity: 0; visibility: hidden; transition: opacity 0.3s, visibility 0.3s; }
.ipc-sidebar-is-open #ipc-filter-sidebar { transform: translateX(0); }
.ipc-sidebar-is-open #ipc-filter-overlay { opacity: 1; visibility: visible; }
.ipc-sidebar-header { display: flex; justify-content: space-between; align-items: center; padding: 15px 20px; border-bottom: 1px solid #eee; flex-shrink: 0; }
.ipc-sidebar-header h3 { margin: 0; font-size: 18px; }
#ipc-close-filters-btn { font-size: 28px; font-weight: 300; background: none; border: none; cursor: pointer; line-height: 1; padding: 0; color: #555; }
.ipc-sidebar-content { padding: 20px; overflow-y: auto; flex-grow: 1; }
#ipc-filter-form-mobile { display: flex; flex-direction: column; gap: 15px; }
#ipc-filter-form-mobile label { font-weight: 600; font-size: 14px; margin-bottom: -10px; color: #333; }
#ipc-filter-form-mobile select, #ipc-filter-form-mobile input { width: 100%; height: 44px; padding: 0 10px; border-radius: 8px; border: 1px solid #ccc; font-size: 15px; background-color: #f5f5f5; -webkit-appearance: none; appearance: none; }
/* NEU: Stile für Preisfilter im mobilen Sidebar */
#ipc-filter-form-mobile .ipc-price-filter-inputs { display: flex; gap: 10px; }
#ipc-filter-form-mobile .ipc-price-filter-inputs input { width: 100%; }
#ipc-filter-form-mobile .ipc-live-search-wrapper input { border-radius: 8px !important; }
.ipc-sidebar-footer { display: flex; gap: 10px; padding: 15px 20px; border-top: 1px solid #eee; flex-shrink: 0; }
.ipc-sidebar-footer .ipc-reset-button, .ipc-sidebar-footer .ipc-submit-button { width: 100%; height: 44px; font-size: 16px; font-weight: 600; border-radius: 8px; }
.ipc-sidebar-footer .ipc-reset-button { background-color: #6c757d; color: #fff; border-color: #6c757d; }

/* === ALLGEMEINE STILE & BUTTONS === */
.ipc-live-search-results { position: absolute; top: 100%; left: 0; right: 0; background: #fff; border: 1px solid #ccc; border-radius: 8px; z-index: 1003; max-height: 250px; overflow-y: auto; display: none; box-shadow: 0 5px 15px rgba(0,0,0,0.15); }
.ipc-live-search-results div { padding: 10px 15px; cursor: pointer; white-space: nowrap; }
.ipc-live-search-results div:hover { background: #f0f0f0; }
.ipc-action-button { font-size: 13px; text-decoration: none; padding: 6px 12px; border-radius: 6px; font-weight: 600; text-align: center; }
.ipc-button-compare { background-color: #f5f5f5; color: #333; border: 1px solid #ddd; }
.ipc-button-offer { background-color: #0073aa; color: #fff !important; border: 1px solid #0073aa; }

/* === GRID-ANSICHT === */
#ipc-price-table-results.grid-view { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 20px; }
.grid-view .ipc-item-card { display: flex; flex-direction: column; background: #fff; border: 1px solid #e0e0e0; border-radius: 12px; overflow: hidden; }
.grid-view .ipc-item-image { height: auto; aspect-ratio: 1 / 1; display: block; }
.grid-view .ipc-item-image img { width: 100%; height: 100%; object-fit: cover; }
.grid-view .ipc-item-info { padding: 12px 16px; flex-grow: 1; display: flex; flex-direction: column; }
.grid-view .ipc-item-name { font-weight: 600; font-size: 14px; line-height: 1.4; height: 58px; overflow: hidden; }
.grid-view .ipc-item-name a { color: inherit; text-decoration: none; }
.grid-view .ipc-item-meta-grid { margin-top: auto; padding-top: 10px; border-top: 1px solid #f5f5f5; font-size: 12px; color: #555; display: flex; flex-direction: column; gap: 4px; }
.grid-view .ipc-grid-meta-item { display: flex; align-items: center; gap: 5px; }
.grid-view .ipc-grid-meta-item img { width: 16px; flex-shrink: 0; }
.grid-view .ipc-item-footer { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; padding: 10px 16px 16px; margin-top: auto; }
.grid-view .ipc-item-price { font-size: 18px; font-weight: 700; }
.grid-view .ipc-item-actions { display: flex; gap: 8px; }

/* === DESKTOP LISTEN-ANSICHT === */
#ipc-price-table-results.list-view { display: flex; flex-direction: column; gap: 16px; }
.ipc-item-list-desktop { display: flex; gap: 14px; background: #fff; border: 1px solid #ddd; border-radius: 12px; padding: 14px 16px; align-items: center; }
.ipc-item-list-desktop .ipc-item-list-image a { width: 140px; height: 110px; display:flex; align-items:center; justify-content:center; flex-shrink: 0; }
.ipc-item-list-desktop .ipc-item-list-image img { width: 100%; height: 125%; margin-right: 35px; object-fit: cover; } /* KORREKTUR: Füllt den Container */
.ipc-item-list-desktop .ipc-item-list-info { flex: 1; min-width: 0; }
.ipc-item-list-desktop .ipc-item-list-name { font-weight: 700; font-size: 1.1em; }
.ipc-item-list-desktop .ipc-item-list-name a { text-decoration: none; color: inherit; }
.ipc-item-list-desktop .ipc-item-list-meta { font-size: 0.9em; color: #555; display: flex; flex-wrap: wrap; gap: 6px 12px; margin-top: 5px; }
.ipc-item-list-desktop .ipc-item-list-meta img { width: 18px; border-radius: 2px; }
.ipc-item-list-desktop .ipc-item-list-right-col { margin-left: auto; flex-shrink: 0; display: flex; flex-direction: column; align-items: flex-end; gap: 10px; }
.ipc-item-list-desktop .ipc-item-price { font-weight: 700; font-size: 1.2em; color: #0073aa; text-align: right; }
.ipc-item-list-desktop .ipc-item-actions { display: flex; gap: 8px; }
.ipc-item-list-mobile { display: none; }

/* PAGINIERUNG */
#ipc-pagination-container { margin-top: 2.5em; text-align: center; }
#ipc-pagination-container .page-numbers { display: inline-block; padding: 8px 14px; margin: 0 2px; border: 1px solid #ddd; background: #fff; color: #333; text-decoration: none; border-radius: 4px; }
#ipc-pagination-container .page-numbers.current { background-color: #0073aa; color: #fff; border-color: #0073aa; font-weight: 600; }

/* === RESPONSIVE ANPASSUNGEN & MOBILE UX === */
@media (max-width: 768px) {
    #ipc-filter-form-desktop { display: none; }
    #ipc-open-filters-btn { display: flex; }
    .ipc-view-switcher button:first-child { border-radius: 0; border-right: none; }
    .ipc-view-switcher button:last-child { border-radius: 0 8px 8px 0; }

    /* NEU: Preisfilter in der Top-Bar auf Mobilgeräten ausblenden */
    .ipc-price-filter-wrapper { display: none; }

    /* KORREKTUR: Mobile Grid-Ansicht Footer (Buttons neben Preis) */
    .grid-view .ipc-item-footer { flex-direction: row; justify-content: space-between; align-items: center; }

    #ipc-price-table-results.grid-view { grid-template-columns: 1fr; }
    #ipc-price-table-results.list-view .ipc-item-list-desktop { display: none; }
    
    #ipc-price-table-results.list-view {
        display: flex;
        flex-direction: column;
        gap: 1px;
        border: none;
        border-radius: 0;
        background-color: #e0e0e0;
    }
    .ipc-item-list-mobile {
        display: flex;
        align-items: flex-start;
        gap: 12px;
        padding: 10px;
        background: #fff;
    }
    .ipc-mobile-list-image a { flex-shrink: 0; width: 70px; height: 70px; display:flex; align-items: center; justify-content: center; border: 1px solid #eee; border-radius: 4px; }
    .ipc-mobile-list-image img { width: 100%; height: 100%; object-fit: contain; }
    .ipc-mobile-list-details { flex-grow: 1; display: flex; flex-direction: column; min-width: 0; }
    .ipc-mobile-list-name a { font-size: 14px; font-weight: 600; color: #333; text-decoration: none; line-height: 1.4; }
    .ipc-mobile-list-meta { display: flex; gap: 8px; align-items: center; font-size: 12px; color: #666; margin-top: 4px; }
    .ipc-mobile-list-meta img { width: 16px; }
    .ipc-mobile-list-price { font-size: 13px; font-weight: 700; color: #0073aa; margin-top: 4px; }
    .ipc-mobile-list-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
    .ipc-mobile-button { font-size: 12px; text-decoration: none; padding: 4px 10px; border-radius: 6px; font-weight: 600; text-align: center; }
}



/* === STILE FÜR SEITEN-HEADER (Shop- & Kategorieseiten etc.) === */

.ipc-page-wrapper {
    /* Optional: Ein max-width Container, um den Inhalt zentriert zu halten */
    max-width: 1200px;
    margin: 0 auto;
    padding: 2em 15px;
}

.ipc-page-header {
    margin-bottom: 2.5em;
    border-bottom: 1px solid #eee;
    padding-bottom: 1.5em;
}

.ipc-breadcrumbs {
    font-size: 14px;
    color: #555;
    margin-bottom: 1em;
}

.ipc-breadcrumbs a {
    color: #0073aa;
    text-decoration: none;
}

.ipc-breadcrumbs a:hover {
    text-decoration: underline;
}

.ipc-breadcrumb-separator {
    margin: 0 8px;
    color: #999;
}

.ipc-page-title {
    font-size: 2.5em;
    font-weight: 700;
    margin: 0;
    line-height: 1.2;
}

/* Responsive Anpassungen für den Header */
@media (max-width: 768px) {
    .ipc-page-title {
        font-size: 1.8em;
    }
    .ipc-breadcrumbs {
        font-size: 13px;
    }
}