/* ==========================================================================
   CÉDRUSKERT SHOP – STABIL VÉGLEGES VERZIÓ
   ========================================================================== */


/* ==========================================================================
   1. LAYOUT
   ========================================================================== */

body .cedruskert-shop-wrap {
    display: flex !important;
    align-items: flex-start !important;
    gap: 40px !important;
    max-width: 1400px !important;
    margin: 40px auto !important;
    padding: 0 20px !important;
    box-sizing: border-box !important;
}


/* ==========================================================================
   SIDEBAR – DESKTOP
   ========================================================================== */

body .cedruskert-shop-filters {
    width: 260px !important;
    min-width: 260px !important;
    flex-shrink: 0 !important;
    background: #fff !important;
    padding: 25px !important;
    border: 1px solid #eee !important;
    border-radius: 10px !important;
    position: relative !important;
}

body .cedruskert-filter-title {
    font-size: 18px !important;
    font-weight: 700 !important;
    margin-bottom: 20px !important;
    border-bottom: 2px solid #7aa95c !important;
    padding-bottom: 8px !important;
}

body .cedruskert-filter-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

body .cedruskert-filter-parent {
    margin-bottom: 18px !important;
}

body .cedruskert-parent-name {
    font-weight: 700 !important;
    font-size: 15px !important;
}

body .cedruskert-filter-checkbox {
    margin-right: 8px !important;
    accent-color: #2f6b3f !important;
}

/* Gyermek kategóriák */

body .cedruskert-filter-children {
    list-style: none !important;
    padding-left: 18px !important;
    border-left: 2px solid #e5e5e5 !important;
    margin-top: 6px !important;
}

body .cedruskert-filter-children li {
    margin-bottom: 6px !important;
}

body .cedruskert-child-name {
    font-size: 13px !important;
}


/* ==========================================================================
   CONTENT
   ========================================================================== */

body .cedruskert-shop-grid-wrap {
    flex: 1 !important;
}


/* ==========================================================================
   2. TOOLBAR
   ========================================================================== */

body .cedruskert-shop-toolbar {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 25px !important;
    padding-bottom: 15px !important;
    border-bottom: 1px solid #eee !important;
    flex-wrap: wrap !important;
}

body .cedruskert-filter-toggle {
    display: none !important;
    background: #2f6b3f !important;
    color: #fff !important;
    border: none !important;
    padding: 10px 18px !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    cursor: pointer !important;
}

body .cedruskert-sort-wrap select {
    padding: 8px 12px !important;
    border: 1px solid #ddd !important;
    border-radius: 6px !important;
}


/* ==========================================================================
   3. VIEW TOGGLE
   ========================================================================== */

body .cedruskert-view-toggle {
    display: flex !important;
    gap: 6px !important;
}

body .cedruskert-view-btn {
    background: none !important;
    border: 1px solid transparent !important;
    padding: 6px !important;
    opacity: 0.4 !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    transition: all .25s ease !important;
}

body .cedruskert-view-btn.is-active {
    opacity: 1 !important;
    border-color: #7aa95c !important;
    background: #f4f9f3 !important;
}

body .cedruskert-view-toggle img {
    width: 22px !important;
}

body .cedruskert-view-btn.mobile-only {
    display: none !important;
}


/* ==========================================================================
   4. GRID
   ========================================================================== */

body .cedruskert-products-grid {
    display: grid !important;
    gap: 30px !important;
    grid-template-columns: repeat(3, 1fr) !important;
}

body .cedruskert-products-grid.cedruskert-view-compact {
    grid-template-columns: repeat(4, 1fr) !important;
}


/* ==========================================================================
   5. PRODUCT CARD
   ========================================================================== */

body .cedruskert-card {
    background: #fff !important;
    border: 1px solid #eee !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    transition: all .3s ease !important;
    position: relative !important;
    padding-bottom: 25px !important;
}

body .cedruskert-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 15px 30px rgba(0,0,0,0.08) !important;
}

body .cedruskert-image img {
    width: 100% !important;
    height: 250px !important;
    object-fit: cover !important;
}

body .cedruskert-content {
    padding: 20px !important;
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
}

body .cedruskert-title {
    font-size: 16px !important;
    font-weight: 700 !important;
    margin-bottom: 10px !important;
}

body .cedruskert-price {
    font-size: 18px !important;
    font-weight: 800 !important;
    margin-top: auto !important;
    margin-bottom: 20px !important;
}

body .cedruskert-button {
    background: #2f6b3f !important;
    color: #fff !important;
    padding: 10px 18px !important;
    border-radius: 6px !important;
    text-align: center !important;
    text-decoration: none !important;
}

body .cedruskert-line {
    height: 6px !important;
    background: #7aa95c !important;
    width: 85% !important;
    position: absolute !important;
    bottom: 20px !important;
    left: 0 !important;
    right: 0 !important;
    margin: auto !important;
}


/* ==========================================================================
   OVERLAY (mobil)
   ========================================================================== */

.cedruskert-filter-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.4);
    z-index: 99998;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s ease;
}

.cedruskert-filter-overlay.is-active {
    opacity: 1;
    pointer-events: auto;
}


/* ==========================================================================
   MOBILE – OFFCANVAS
   ========================================================================== */

@media (max-width: 768px) {

    body .cedruskert-shop-wrap {
        display: block !important;
    }

    body .cedruskert-shop-filters {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        height: 100vh !important;
        width: 85% !important;
        max-width: 320px !important;
        transform: translateX(-110%) !important;
        transition: transform .3s ease !important;
        z-index: 99999 !important;
        overflow-y: auto !important;
        box-shadow: 2px 0 20px rgba(0,0,0,0.2) !important;
        padding: 70px 20px 20px 20px !important;
    }

    body .cedruskert-shop-filters.is-open {
        transform: translateX(0) !important;
    }

    body .cedruskert-filter-close {
        position: absolute !important;
        top: 18px !important;
        right: 18px !important;
        font-size: 28px !important;
        background: transparent !important;
        border: none !important;
        cursor: pointer !important;
        z-index: 100000 !important;
        color: #222 !important;
    }

    /* Toolbar mobil layout */

    body .cedruskert-shop-toolbar {
        display: grid !important;
        grid-template-columns: 1fr auto !important;
        grid-template-rows: auto auto !important;
        gap: 10px !important;
        align-items: center !important;
    }

    body .cedruskert-filter-toggle {
        display: inline-block !important;
        grid-column: 1 !important;
        grid-row: 1 !important;
    }

    body .cedruskert-view-toggle {
        grid-column: 2 !important;
        grid-row: 1 !important;
        justify-self: end !important;
    }

    body .cedruskert-sort-wrap {
        grid-column: 1 / span 2 !important;
        grid-row: 2 !important;
        width: 100% !important;
    }

    body .cedruskert-sort-wrap select {
        width: 100% !important;
    }

    /* Grid mobil */

    body .cedruskert-products-grid,
    body .cedruskert-products-grid.cedruskert-view-large,
    body .cedruskert-products-grid.cedruskert-view-mobile-2 {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 15px !important;
    }

    body .cedruskert-products-grid.cedruskert-view-mobile-1 {
        grid-template-columns: 1fr !important;
    }

    body .cedruskert-image img {
        height: 160px !important;
    }
    
    /* Mobil override */

body .cedruskert-view-btn.desktop-only {
    display: none !important;
}

body .cedruskert-view-btn.mobile-only {
    display: inline-flex !important;
}
}


/* ==========================================================================
   DESKTOP – CLOSE GOMB REJTÉS
   ========================================================================== */

@media (min-width: 769px) {
    body .cedruskert-filter-close {
        display: none !important;
    }
}



/* ==========================================================================
   LIVE SEARCH STYLING – JAVÍTOTT (Mobil-fókuszú)
   ========================================================================== */

.cedruskert-search-wrap {
    position: relative;
    width: 100%;
    max-width: 400px;
    margin-bottom: 20px;
    /* Biztosítjuk, hogy a wrap maga is magasabb rétegen legyen */
    z-index: 100001 !important; 
}

/* Keresőmező finomítás */
#cedruskert-search-input {
    width: 100% !important;
    height: 45px !important;
    padding: 10px 15px !important;
    border: 2px solid #eee !important;
    border-radius: 10px !important;
    font-size: 16px !important; /* Fontos: mobilon a 16px megakadályozza az automata zoomot */
    box-sizing: border-box !important;
    transition: border-color 0.3s ease;
    -webkit-appearance: none; /* iOS fix */
}

#cedruskert-search-input:focus {
    border-color: #7aa95c !important;
    outline: none !important;
}

/* Találati lista – A legfontosabb javítás */
.cedruskert-search-results {
    position: absolute !important;
    top: calc(100% + 5px) !important;
    left: 0 !important;
    right: 0 !important;
    background: #ffffff !important;
    border: 1px solid #ddd !important;
    border-radius: 10px !important;
    box-shadow: 0 15px 35px rgba(0,0,0,0.2) !important;
    display: none;
    /* Brutál magas z-index, hogy az offcanvas menü felett legyen (99999 felett) */
    z-index: 100002 !important; 
    max-height: 70vh !important; /* Mobilon ne lógjon ki a képernyőből */
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
}

/* Találati elem */
.cedruskert-search-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px !important;
    text-decoration: none !important;
    color: #222 !important;
    border-bottom: 1px solid #f5f5f5 !important;
    transition: background 0.2s ease;
}

.cedruskert-search-item:last-child {
    border-bottom: none !important;
}

.cedruskert-search-item:hover, 
.cedruskert-search-item:active {
    background: #f4f9f3 !important;
}

.cedruskert-search-item img {
    width: 50px !important;
    height: 50px !important;
    min-width: 50px !important; /* Ne nyomódjon össze */
    object-fit: cover !important;
    border-radius: 8px !important;
    background: #eee;
}

.cedruskert-search-title {
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    display: block !important; /* Stackeljük mobilon a szöveget */
}

.cedruskert-search-price {
    font-size: 13px !important;
    color: #2f6b3f !important;
    font-weight: 600 !important;
    margin-top: 4px !important;
}

/* Készlethiány badge */
.cedruskert-badge-out {
    display: inline-block !important;
    font-size: 10px !important;
    background: #e53935 !important;
    color: #fff !important;
    padding: 1px 6px !important;
    border-radius: 4px !important;
    margin-left: 5px !important;
    vertical-align: middle !important;
}

/* Mobil specifikus igazítás */
@media (max-width: 768px) {
    .cedruskert-search-wrap {
        max-width: 100% !important;
        margin-bottom: 15px !important;
    }
    
    .cedruskert-search-results {
        width: 100% !important;
        position: fixed !important; /* Mobilon stabilabb, ha fixen marad gépeléskor */
        left: 5% !important;
        right: 5% !important;
        width: 90% !important;
        top: 80px !important; /* Állítsd be a fejleced magasságához! */
    }
}


