/*
 * Internationale Preisvergleiche - Zentrale Stildatei
 * Version 7.4 (Finale Korrekturen für mobile Listen-Ansicht)
 */

/* ==========================================================
   1. AJAX FILTER & INTERFACE (Shortcode [ipc_price_table])
   ========================================================== */

/* 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; }

/* 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; }
.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; }

/* Live-Suchergebnisse */
.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; }

/* 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; }
#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; }


/* ==========================================================
   2. ERGEBNISLISTEN (GRID & LIST VIEW)
   ========================================================== */

.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 !important; 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: flex; align-items: center; justify-content: center; background: #f9f9f9; padding: 10px; box-sizing: border-box; }
.grid-view .ipc-item-image img { width: 100%; height: 100%; object-fit: contain; }
.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; align-items: flex-start; }
.grid-view .ipc-grid-meta-item {
    display: flex;
    align-items: center;
    gap: 5px;
    width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.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: 140px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; background: #f9f9f9; border-radius: 8px; }
.ipc-item-list-desktop .ipc-item-list-image img { width: 100%; height: 100%; object-fit: contain; }
.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; }

/* ==========================================================
   3. STILE FÜR ARCHIV-SEITEN (SHOP, SUCHE, WOOCOMMERCE)
   ========================================================== */

.ipc-section-separator { text-align: center; margin: 3em 0 2.5em; display: flex; align-items: center; color: #555; }
.ipc-section-separator::before, .ipc-section-separator::after { content: ''; flex: 1; border-bottom: 2px solid #e0e0e0; }
.ipc-separator-icon { font-size: 1.8em; margin: 0 .5em; color: #0073aa; }
.ipc-separator-title { margin: 0 .75em; font-size: 1.5em; white-space: nowrap; color: #333; }
.ipc-price-table-container { margin-top: 1.5em; display: flex; flex-direction: column; gap: 16px; }
.ipc-list-item { display: flex; gap: 14px; background: #fff; border: 1px solid #e0e0e0; border-radius: 12px; padding: 14px 16px; box-shadow: 0 2px 8px rgba(0,0,0,.06); align-items: center; transition: box-shadow .2s ease-in-out; }
.ipc-list-item:hover { box-shadow: 0 4px 12px rgba(0,0,0,.1); }
li.product .ipc-list-item-wrapper { padding: 14px 16px; }
.woocommerce ul.products li.product, .ipc-list-item { display: flex; align-items: center; gap: 14px; }
.woocommerce ul.products li.product .woocommerce-loop-product__link { display: contents; }
.ipc-list-image { flex-shrink: 0; width: 100px; height: 100px; border-radius: 8px; overflow: hidden; display: flex; align-items: center; justify-content: center; background: #f9f9f9; }
.ipc-list-image img { max-width: 100%; max-height: 100%; object-fit: contain; }
.ipc-list-info { flex: 1; display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.ipc-list-name { font-weight: 600; font-size: 1.05em; color: #333; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ipc-list-meta { font-size: .85em; color: #666; display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.ipc-list-meta > div { display: flex; align-items: center; gap: 6px; }
.ipc-list-meta img.flag-icon { width: 16px; height: 12px; border-radius: 2px; object-fit: cover; }
.ipc-list-footer { display: flex; flex-direction: column; align-items: flex-end; gap: 10px; margin-left: auto; text-align: right; }
.ipc-list-price { font-weight: 700; font-size: 1.25em; color: #0073aa; white-space: nowrap; }
.ipc-list-price .woocommerce-Price-amount.amount { font-size: inherit !important; color: inherit !important; }
.ipc-list-link { display: flex; gap: 8px; flex-shrink: 0; }
.ipc-list-link a { color: #fff !important; text-decoration: none; padding: 10px 16px; font-weight: 600; border-radius: 8px; display: inline-block; transition: background-color .3s ease; white-space: nowrap; font-size: .9em; }
.ipc-list-link a.ipc-button-offer, .ipc-list-link a.add_to_cart_button { background-color: #0073aa; }
.ipc-list-link a.ipc-button-offer:hover, .ipc-list-link a.add_to_cart_button:hover { background-color: #005177; }
.ipc-list-link a.ipc-button-compare { background-color: #f5f5f5; color: #333 !important; border: 1px solid #ddd; }
.ipc-list-link a.ipc-button-compare:hover { background-color: #e0e0e0; }

/* ==========================================================
   4. STILE FÜR DYNAMISCHE TEMPLATE-SEITEN (DB & EBAY)
   ========================================================== */
.ipc-full-width-header-container { width: 100%; position: relative; background-color: #34495e; color: #fff; margin-bottom: 2.5em; }
.ipc-header-content { max-width: 1200px; margin: 0 auto; padding: 0 35px; display: flex; justify-content: space-between; align-items: center; gap: 20px; }
.ipc-header-title h1 { font-size: 28px; font-weight: 700; margin: 0; color: #fff; }
.ipc-header-title h1::after { content: ''; display: block; width: 60px; height: 4px; background: #95a5a6; margin-top: 10px; border-radius: 2px; }
.ipc-header-logo-wrapper { padding: 10px; flex-shrink: 0; }
.ipc-header-logo-wrapper img { max-height: 100px; margin-bottom: -20px; margin-top: -10px; width: auto; display: block; }
.ipc-price-table-container .ipc-list-image { width: 120px; height: 120px; }
.ipc-price-table-container .ipc-list-name { font-size: 1.1em; }
.ipc-price-table-container .ipc-list-meta { font-size: .9em; gap: 14px; }
.ipc-price-table-container .ipc-list-link { margin-left: 20px; }
.ipc-price-table-container .ipc-list-link a { font-size: .95em; }
.ipc-price-table-container .ipc-list-item:first-child { background-color: #f0f8ff; border-color: #0073aa; }
.ipc-to-full-table { margin-top: 2em; display: inline-block; background-color: #f0f0f0; color: #333; padding: 12px 24px; border-radius: 8px; font-weight: 600; text-decoration: none; transition: background-color .3s ease; }
.ipc-to-full-table:hover { background-color: #e0e0e0; }

/* ==========================================================
   5. RESPONSIVE ANPASSUNGEN
   ========================================================== */
@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; }
    .ipc-price-filter-wrapper { display: none; }
    .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: 90px; height: 90px; 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; }
    
    /* === START FINALER KORREKTURBLOCK für mobile Listen-Ansicht (Shortcode) === */
    .ipc-mobile-list-meta {
        display: flex;
        flex-direction: column; /* WICHTIG: Stellt die Meta-Daten untereinander */
        align-items: flex-start; /* WICHTIG: Richtet die Daten linksbündig aus */
        gap: 4px; /* Abstand zwischen den Zeilen */
        font-size: 12px;
        color: #666;
        margin-top: 6px;
    }
    .ipc-mobile-list-meta > div {
        display: flex;
        align-items: center;
        gap: 6px; /* Abstand zwischen Icon (Flagge) und Text */
    }
    /* === ENDE FINALER KORREKTURBLOCK === */
    
    .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; }

    /* Responsive für Template-Seiten */
    .ipc-header-content { flex-direction: column; text-align: center; }
    .ipc-header-title h1::after { margin-left: auto; margin-right: auto; }
    .ipc-price-table-container .ipc-list-item {
        flex-wrap: wrap;
    }
    .ipc-price-table-container .ipc-list-info {
        order: 1;
        width: calc(100% - 134px);
    }
    .ipc-price-table-container .ipc-list-image {
        order: 2;
    }
    .ipc-price-table-container .ipc-list-footer {
        order: 3;
        width: 100%;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        margin-top: 12px;
        margin-left: 0;
        gap: 10px;
    }
    .ipc-price-table-container .ipc-list-price {
        order: initial;
        margin: 0;
        text-align: left;
        flex-shrink: 0;
    }
    .ipc-price-table-container .ipc-list-link {
        order: initial;
        width: auto;
        margin: 0;
    }
    .ipc-price-table-container .ipc-list-link a {
        display: inline-block;
        text-align: center;
        padding: 6px 10px;
        font-size: 12px;
    }
}

@media (max-width: 480px) {
    /* Generelle Anpassung für sehr kleine Bildschirme */
    .ipc-list-item, .woocommerce ul.products li.product, .ipc-price-table-container .ipc-list-item { flex-direction: column; align-items: stretch; }
    .ipc-list-info, .ipc-price-table-container .ipc-list-info { order: 2; width: 100%; }
    .ipc-list-image, .ipc-price-table-container .ipc-list-image { order: 1; width: 100%; height: auto; max-height: 180px; }
    .ipc-list-footer, .ipc-price-table-container .ipc-list-footer { order: 3; }
    .ipc-product-detail { padding: 1em; }
}



/* In /assets/css/ipc-styles.css hinzufügen */

/* ==========================================================
   STILE FÜR STATISCHE TEMPLATE-SEITEN (Shop-Landingpages etc.)
   ========================================================== */

.ipc-page-wrapper {
    max-width: 1200px;
    margin: 2em auto;
    padding: 0 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-breadcrumbs span {
    color: #1d2327;
}

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

.ipc-page-description {
    margin-top: 0.5em; 
    font-size: 1.1em; 
    color: #555;
}

@media (max-width: 768px) {
    .ipc-page-title {
        font-size: 1.8em;
    }
    .ipc-breadcrumbs {
        font-size: 13px;
    }
}




/*
 * ===================================================================
 * CSS für die IPC Post Table - Adaptiert von ipc-ajax.css
 * ===================================================================
*/

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

/* === DESKTOP FILTER-BEREICH === */
#ipc-post-table-container #ipc-filter-form-desktop { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 2em; align-items: center; }
#ipc-post-table-container .ipc-filter-pills-container { display: flex; flex-wrap: wrap; gap: 10px; }
#ipc-post-table-container .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-post-table-container .ipc-filter-pill:hover { border-color: #ccc; }
#ipc-post-table-container .ipc-filter-pill select { 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-post-table-container .ipc-filter-pill select:focus { outline: none; }
#ipc-post-table-container .ipc-controls-container { margin-left: auto; display: flex; gap: 6px; }
#ipc-post-table-container .ipc-reset-button { height: 36px; border-radius: 20px; border: 1px solid #ccc; background: #fff; padding: 0 15px; cursor: pointer; font-size: 14px; }
#ipc-post-table-container .ipc-reset-button:hover { background-color: #f0f0f0; }

/* === MOBILER FILTER-SIDEBAR === */
#ipc-post-table-container.ipc-sidebar-is-open #ipc-filter-sidebar { transform: translateX(0); }
#ipc-post-table-container.ipc-sidebar-is-open #ipc-filter-overlay { opacity: 1; visibility: visible; }
#ipc-post-table-container #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-post-table-container #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-post-table-container .ipc-sidebar-header { display: flex; justify-content: space-between; align-items: center; padding: 15px 20px; border-bottom: 1px solid #eee; flex-shrink: 0; }
#ipc-post-table-container .ipc-sidebar-header h3 { margin: 0; font-size: 18px; }
#ipc-post-table-container #ipc-close-filters-btn { font-size: 28px; font-weight: 300; background: none; border: none; cursor: pointer; line-height: 1; padding: 0; color: #555; }
#ipc-post-table-container .ipc-sidebar-content { padding: 20px; overflow-y: auto; flex-grow: 1; }
#ipc-post-table-container #ipc-filter-form-mobile { display: flex; flex-direction: column; gap: 15px; }
#ipc-post-table-container #ipc-filter-form-mobile label { font-weight: 600; font-size: 14px; margin-bottom: -10px; color: #333; }
#ipc-post-table-container #ipc-filter-form-mobile select, #ipc-post-table-container #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; }
#ipc-post-table-container .ipc-sidebar-footer { display: flex; gap: 10px; padding: 15px 20px; border-top: 1px solid #eee; flex-shrink: 0; }
#ipc-post-table-container .ipc-sidebar-footer .ipc-reset-button, #ipc-post-table-container .ipc-sidebar-footer .ipc-submit-button { width: 100%; height: 44px; font-size: 16px; font-weight: 600; border-radius: 8px; }
#ipc-post-table-container .ipc-sidebar-footer .ipc-reset-button { background-color: #6c757d; color: #fff; border-color: #6c757d; }
#ipc-post-table-container .ipc-sidebar-footer .ipc-submit-button { background-color: #0073aa; color: #fff; border-color: #0073aa; }

/* === ALLGEMEINE BUTTON-STILE === */
#ipc-post-table-container .ipc-action-button { font-size: 12px; text-decoration: none; padding: 6px 12px; border-radius: 6px; font-weight: 600; text-align: center; }
#ipc-post-table-container .ipc-button-offer { background-color: #0073aa; color: #fff !important; border: 1px solid #0073aa; }

/* === GRID-ANSICHT für Beiträge === */
#ipc-post-table-results.grid-view { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; }
#ipc-post-table-container .grid-view .ipc-post-card { display: flex; flex-direction: column; background: #fff; border: 1px solid #e0e0e0; border-radius: 12px; overflow: hidden; }
#ipc-post-table-container .grid-view .ipc-post-image { height: auto; aspect-ratio: 16 / 10; display: block; overflow:hidden; }
#ipc-post-table-container .grid-view .ipc-post-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease; }
#ipc-post-table-container .grid-view .ipc-post-card:hover .ipc-post-image img { transform: scale(1.05); }
#ipc-post-table-container .grid-view .ipc-post-info { padding: 16px; flex-grow: 1; display: flex; flex-direction: column; }
#ipc-post-table-container .grid-view .ipc-post-title { font-weight: 600; font-size: 1.1em; line-height: 1.4; margin:0 0 10px 0; }
#ipc-post-table-container .grid-view .ipc-post-title a { color: inherit; text-decoration: none; }
#ipc-post-table-container .grid-view .ipc-post-excerpt { font-size: 0.9em; color: #555; flex-grow: 1; }
#ipc-post-table-container .grid-view .ipc-post-footer { padding: 0 16px 16px; margin-top: 15px; }

/* === LISTEN-ANSICHT für Beiträge === */
#ipc-post-table-results.list-view { display: flex; flex-direction: column; gap: 16px; }
#ipc-post-table-container .ipc-post-list-item { display: flex; gap: 16px; background: #fff; border: 1px solid #ddd; border-radius: 12px; padding: 16px; align-items: center; }
#ipc-post-table-container .ipc-post-list-item .ipc-post-list-image a { width: 150px; height: 100px; display:flex; align-items:center; justify-content:center; flex-shrink: 0; overflow:hidden; border-radius: 8px; }
#ipc-post-table-container .ipc-post-list-item .ipc-post-list-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease; }
#ipc-post-table-container .ipc-post-list-item:hover .ipc-post-list-image img { transform: scale(1.05); }
#ipc-post-table-container .ipc-post-list-item .ipc-post-list-info { flex: 1; min-width: 0; }
#ipc-post-table-container .ipc-post-list-item .ipc-post-list-name { font-weight: 700; font-size: 1.2em; margin-bottom: 8px; }
#ipc-post-table-container .ipc-post-list-item .ipc-post-list-name a { text-decoration: none; color: inherit; }
#ipc-post-table-container .ipc-post-list-item .ipc-post-list-excerpt { font-size: 0.9em; color: #555; }
#ipc-post-table-container .ipc-post-list-item .ipc-post-list-right-col { margin-left: auto; flex-shrink: 0; display: flex; flex-direction: column; align-items: flex-end; gap: 10px; }

/* PAGINIERUNG */
#ipc-post-table-container #ipc-pagination-container { margin-top: 2.5em; text-align: center; }
#ipc-post-table-container #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-post-table-container #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-post-table-container #ipc-filter-form-desktop { display: none; }
    #ipc-post-table-container #ipc-open-filters-btn { display: flex; }
    #ipc-post-table-container .ipc-view-switcher button:first-child { border-radius: 0; border-right: none; }
    #ipc-post-table-container .ipc-view-switcher button:last-child { border-radius: 0 8px 8px 0; }
    
    #ipc-post-table-results.grid-view { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 15px; }
    
    #ipc-post-table-results.list-view { gap: 17px; background-color: #ffffff; border-top: 1px solid #e0e0e0; border-bottom: 1px solid #e0e0e0; }
    #ipc-post-table-container .list-view .ipc-post-list-item { border-radius: 0; flex-wrap: wrap; }
    #ipc-post-table-container .list-view .ipc-post-list-image a { width: 100px; height: 75px; }
    #ipc-post-table-container .list-view .ipc-post-list-info { order: 1; width: calc(100% - 115px); }
    #ipc-post-table-container .list-view .ipc-post-list-name { font-size: 1.05em; margin-bottom: 4px; }
    #ipc-post-table-container .list-view .ipc-post-list-excerpt { display: none; /* Excerpt auf Mobile in Liste ausblenden */ }
    #ipc-post-table-container .list-view .ipc-post-list-right-col { order: 2; width: 100%; margin-top: 10px; align-items: flex-start; }
    #ipc-post-table-container .list-view .ipc-post-list-actions .ipc-action-button { width: 100%; }
}