.elementor-372 .elementor-element.elementor-element-419344d{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:8.5em;--margin-bottom:0em;--margin-left:0em;--margin-right:0em;}.elementor-372 .elementor-element.elementor-element-d4a181c{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:6rem 6rem;--row-gap:6rem;--column-gap:6rem;--margin-top:-1.7rem;--margin-bottom:0rem;--margin-left:0rem;--margin-right:0rem;--padding-top:3rem;--padding-bottom:3.8rem;--padding-left:0rem;--padding-right:0rem;}body.elementor-page-372:not(.elementor-motion-effects-element-type-background), body.elementor-page-372 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}/* Start custom CSS for shortcode, class: .elementor-element-0524d40 *//* =========================================
   NEO-BRUTALIST / INDUSTRIAL MINIMALISM CSS
   ========================================= */

/* 1. Fonts & Variables */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;700&display=swap');

.ep-grid-wrap {
    --ep-neon: #B0FF18;
    --ep-black: #000000;
    --ep-white: #FFFFFF;
    --ep-border: 2px solid #000000;
    --ep-font: 'Oswald', sans-serif;
    
    font-family: var(--ep-font);
    color: var(--ep-black);
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.ep-grid-wrap * {
    box-sizing: border-box;
    border-radius: 0px !important; /* RULE: No Radius anywhere */
}

/* === 2. TOP BAR CONTROLS === */
.ep-mode-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    align-items: center; 
    margin-bottom: 40px;
    padding-bottom: 20px;
    border-bottom: var(--ep-border);
    position: relative;
}

/* Tabs Container */
.ep-switcher-track {
    display: inline-flex;
    gap: 0; 
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    mask-image: none !important; -webkit-mask-image: none !important;
}

.ep-glider { display: none !important; }

/* Tab Buttons */
.ep-switcher-track .ep-mode-btn {
    background: var(--ep-white) !important;
    color: var(--ep-black) !important;
    border: var(--ep-border) !important;
    
    font-family: var(--ep-font) !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px;
    padding: 12px 30px !important;
    margin-right: -2px; /* Pull them together */
    
    cursor: pointer;
    transition: all 0.1s ease !important;
    opacity: 1 !important;
    z-index: 1;
    box-shadow: none !important;
}

.ep-switcher-track .ep-mode-btn:hover,
.ep-switcher-track .ep-mode-btn.is-active {
    background-color: var(--ep-neon) !important;
    color: var(--ep-black) !important;
    z-index: 10; /* Bring active/hover to front */
}

/* === 3. SEARCH BAR (FIXED) === */
.ep-mode-tools {
    margin-left: auto;
    display: flex;
    align-items: center;
}

.ep-search {
    position: relative; 
    width: 300px;
    max-width: 100%;
    display: flex;
    align-items: center;
}

.ep-search-input {
    width: 100% !important;
    height: 50px !important;
    background: var(--ep-white) !important;
    border: var(--ep-border) !important;
    color: var(--ep-black) !important;
    
    font-family: var(--ep-font) !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    font-size: 14px !important;
    padding: 0 40px 0 15px !important;
    margin: 0 !important;
    
    transition: background 0.1s ease !important;
    outline: none !important;
}

.ep-search-input:focus {
    background-color: var(--ep-neon) !important;
}

.ep-search-input::placeholder { color: #555 !important; opacity: 1; }

/* FIX: Absolute Positioning for X button */
.ep-search-clear {
    position: absolute !important;
    right: 2px !important;
    top: 2px !important;
    bottom: 2px !important;
    width: 40px !important;
    height: auto !important;
    
    display: flex !important;
    align-items: center;
    justify-content: center;
    
    background: transparent !important;
    border: none !important;
    border-left: var(--ep-border) !important; /* Separator line */
    
    color: var(--ep-black) !important;
    font-size: 24px !important;
    font-weight: 700 !important;
    cursor: pointer;
    opacity: 1 !important;
    z-index: 5;
}
.ep-search-clear:hover {
    background: var(--ep-black) !important;
    color: var(--ep-white) !important;
}

/* Hide X when empty */
.ep-search:not(.has-value) .ep-search-clear { display: none !important; }
.ep-search-icon { display: none !important; }

/* === 4. FILTER BAR (FIXED VISIBILITY) === */
.ep-filter-bar { 
    margin-bottom: 40px; 
    width: 100%;
}

/* FIX: Force hide inactive mode to prevent overlap */
.ep-filter-clip[data-mode] { display: none !important; }
.ep-filter-clip[data-mode].is-current { display: block !important; }

/* Container for chips */
.ep-filter-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: flex-start;
    width: 100%;
}

/* Chips */
.ep-type-card, .ep-artist-card {
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    
    background: var(--ep-white) !important;
    border: var(--ep-border) !important;
    color: var(--ep-black) !important;
    
    font-family: var(--ep-font) !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    font-size: 14px !important;
    padding: 8px 16px !important;
    line-height: 1.2;
    min-height: 40px;
    
    transition: background 0.1s ease !important;
}

/* Interaction */
.ep-type-card:hover, .ep-artist-card:hover,
.ep-type-card.is-active, .ep-artist-card.is-active {
    background-color: var(--ep-neon) !important;
    border-color: var(--ep-black) !important;
    color: var(--ep-black) !important;
}

.ep-artist-card--all, .ep-type-card--all {
    border-style: dashed !important;
}

/* === 5. TOGGLE BUTTON (BLACK BAR) === */
/* -------------------------------------
   ΠΡΟΣΘΗΚΗ: Κρύβει ό,τι περισσεύει πάνω από τις 3 γραμμές
---------------------------------------- */
.ep-filter-clip {
    overflow: hidden !important; /* Απαραίτητο για να μην φαίνονται τα από κάτω */
    max-height: var(--clip-max, 1000px);
    transition: max-height 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    width: 100%;
    position: relative;
    display: none; /* Αρχικά κρυμμένο, το JS θα το κάνει block */
}

.ep-filter-clip.is-current {
    display: block !important;
}

/* Προαιρετικό: Ένα "fader" εφέ για να μην κόβεται απότομα η τελευταία σειρά */
.ep-filter-clip:not(.is-open).has-overflow::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 40px;
    background: linear-gradient(to bottom, transparent, var(--ep-white));
    pointer-events: none;
    z-index: 2;
}

/* === 5. TOGGLE BUTTON (BLACK BAR) === */
.ep-filter-toggle {
    width: 100% !important;
    height: 40px !important;
    margin-top: 15px !important;
    background: var(--ep-black) !important;
    border: var(--ep-border) !important;
    color: var(--ep-white) !important;
    cursor: pointer;
    display: flex !important;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.ep-filter-toggle:hover {
    background: var(--ep-neon) !important;
    color: var(--ep-black) !important;
    border-color: var(--ep-black) !important;
}

/* FIX: Το Plus γίνεται Minus (-) αντί για X */
.plus { position: relative; width: 14px; height: 14px; display: block; }
.plus::before, .plus::after { 
    content: ""; position: absolute; 
    background-color: currentColor !important; 
    transition: transform 0.3s ease, opacity 0.3s ease;
}
.plus::before { top: 6px; left: 0; width: 100%; height: 2px; } /* Οριζόντια γραμμή */
.plus::after { top: 0; left: 6px; width: 2px; height: 100%; } /* Κάθετη γραμμή */

.ep-filter-toggle.is-open .plus::before { 
    transform: rotate(0deg); 
} /* Η οριζόντια μένει ως έχει (μείον) */

.ep-filter-toggle.is-open .plus::after { 
    transform: rotate(90deg) scale(0); 
    opacity: 0; 
} /* Η κάθετη μικραίνει, περιστρέφεται και εξαφανίζεται */

.ep-filter-toggle.is-hidden { display: none !important; }

/* === 6. GRID LAYOUT (FIXED COLUMNS) === */
.ep-products-grid {
    display: grid !important;
    /* Default Desktop: 4 Columns */
    grid-template-columns: repeat(4, 1fr) !important; 
    gap: 0 !important; /* Industrial Look: Merged borders */
    
    border-top: var(--ep-border) !important;
    border-left: var(--ep-border) !important;
    margin-top: 20px;
    
    opacity: 1; 
    transform: translateY(0);
    transition: opacity 0.2s ease;
    width: 100%;
}

.is-transitioning .ep-products-grid { opacity: 0; }

/* Product Items inside Grid */
.ep-products-grid > * {
    border-right: var(--ep-border) !important;
    border-bottom: var(--ep-border) !important;
    padding: 20px !important;
    background: var(--ep-white);
    transition: background 0.1s ease;
    
    /* Ensure content doesn't break layout */
    min-width: 0; 
    width: 100% !important;
    margin: 0 !important;
}

/* Hover on Grid Item */
.ep-products-grid > *:hover {
    background-color: var(--ep-neon) !important;
}

/* === 7. PAGINATION === */
.ep-pagination {
    display: flex;
    justify-content: flex-start;
    gap: -2px; /* Connected */
    margin-top: 40px;
    padding-top: 20px;
}

.ep-page {
    width: 50px !important;
    height: 50px !important;
    display: flex; align-items: center; justify-content: center;
    
    background: var(--ep-white) !important;
    border: var(--ep-border) !important;
    color: var(--ep-black) !important;
    
    font-family: var(--ep-font) !important;
    font-weight: 700 !important;
    font-size: 18px !important;
    text-decoration: none !important;
    margin-right: -2px;
}

.ep-page:hover, .ep-page.is-current {
    background-color: var(--ep-neon) !important;
    color: var(--ep-black) !important;
    z-index: 2;
}

/* === 8. RESPONSIVE BREAKPOINTS === */

/* Large Laptop */
@media (max-width: 1300px) {
    .ep-products-grid { grid-template-columns: repeat(3, 1fr) !important; }
}

/* Tablet */
@media (max-width: 900px) {
    .ep-products-grid { grid-template-columns: repeat(2, 1fr) !important; }
    
    .ep-mode-bar { gap: 15px; }
    .ep-search { width: 100%; max-width: none; margin-top: 10px; }
    .ep-mode-tools { width: 100%; }
}

/* Mobile */
@media (max-width: 600px) {
    .ep-products-grid { grid-template-columns: repeat(1, 1fr) !important; }
    
    .ep-mode-bar { flex-direction: column; align-items: stretch; gap: 20px; border-bottom: none; }
    .ep-switcher-track { width: 100%; display: flex; }
    .ep-switcher-track .ep-mode-btn { flex: 1; text-align: center; justify-content: center; }
    
    /* Adjust Search on Mobile */
    .ep-search { margin-top: 0; }
}/* End custom CSS */
/* Start custom CSS */.foot {
    background: #1D1D1D !important;
}/* End custom CSS */