    :root {
        --eco-darkest: #0B0F19;
        --eco-dark-surface: #1A202C;
        --eco-lime-green: #78EB4A; /* <-- НОВИЙ ЗЕЛЕНИЙ КОЛІР */
        --eco-electric-blue: #3B82F6;
        --eco-neon-cyan: #22D3EE;
        --eco-text-primary: #E2E8F0;
        --eco-text-secondary: #CBD5E0;
        --eco-radius-xl: 1.5rem; /* 24px */
        --eco-radius-full: 9999px; /* Для круглих елементів */
        --eco-border-color: rgba(255, 255, 255, 0.08); /* Define a common border color */
    }

    body {
        background-color: var(--eco-darkest);
        font-family: 'Inter', sans-serif;
        padding: 0rem;
        /*transition: padding 0.3s ease;*/


	}

	.eco-slider .carousel-item {
        height: 468px; /* Зменшено на 15% з 550px */
        background: linear-gradient(135deg, var(--eco-dark-surface) 0%, var(--eco-darkest) 100%);
        border-radius: var(--eco-radius-xl);
        padding: 2rem 4rem;
        overflow: hidden;
        transition: height 0.3s ease, padding 0.3s ease;
    }

    .eco-slider .carousel-item-wrapper {
        display: flex;
        align-items: center;
        justify-content: space-between;
        height: 100%;
        gap: 2rem;
        margin-left: 2%;
    }

    .eco-slider .banner-content {
        max-width: 50%;
    }

    .eco-slider .banner-content h1 {
        font-size: clamp(2.5rem, 5vw, 3.8rem);
        font-weight: 800;
        color: white;
        line-height: 1.2;
        margin-bottom: 1.5rem;
    }

    .eco-slider .banner-content p {
        font-size: 1.2rem;
        color: var(--eco-text-secondary);
        margin-bottom: 2rem;
        max-width: 500px;
    }

    .eco-slider .banner-image {
        max-width: 45%;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .eco-slider .banner-image img {
        max-width: 100%;
        max-height: 100%;
        object-fit: contain;
        filter: drop-shadow(0px 15px 30px rgba(0, 0, 0, 0.6));
    }

    .btn-banner {
        border-radius: var(--eco-radius-full);
        padding: 0.85rem 2rem;
        font-weight: 700;
        font-size: 1.1rem;
        transition: all 0.3s ease;
        border: none;
        text-decoration: none;
        display: inline-block;
    }
    .btn-eco-lime {
        background: linear-gradient(135deg, var(--eco-lime-green), #56bb2a);
        color: var(--eco-darkest);
        box-shadow: 0 4px 20px rgba(120, 235, 74, 0.4);
    }
    .btn-eco-lime:hover {
        transform: translateY(-3px) scale(1.05);
        box-shadow: 0 6px 25px rgba(120, 235, 74, 0.6);
        color: var(--eco-darkest);
    }
    .btn-eco-blue {
        background: linear-gradient(135deg, var(--eco-electric-blue), #2563EB);
        color: white;
        box-shadow: 0 4px 20px rgba(59, 130, 246, 0.4);
    }
    .btn-eco-blue:hover {
        transform: translateY(-3px) scale(1.05);
        box-shadow: 0 6px 25px rgba(59, 130, 246, 0.6);
        color: white;
    }

    /* Анімації */
    .carousel-item .animated-element {
        opacity: 0;
        transition: opacity 0.8s ease-out, transform 0.8s ease-out;
    }
    .carousel-item.active .animated-element {
        opacity: 1;
    }

    .carousel-item .animate-text {
        transform: translateX(-30px);
    }
    .carousel-item.active .animate-text {
        transform: translateX(0);
    }

    .carousel-item .animate-image {
        transform: scale(0.8) translateX(30px);
    }
    .carousel-item.active .animate-image {
        transform: scale(1) translateX(0);
    }

    .carousel-item.active .animated-element.delay-1 { transition-delay: 0.2s; }
    .carousel-item.active .animated-element.delay-2 { transition-delay: 0.4s; }
    .carousel-item.active .animated-element.delay-3 { transition-delay: 0.6s; }

    /* Стилізація контролів слайдера */
    .eco-slider .carousel-control-prev,
    .eco-slider .carousel-control-next {
        width: 5%;
        background: rgba(0,0,0,0.1);
    }
    .eco-slider .carousel-control-prev:hover,
    .eco-slider .carousel-control-next:hover {
        background: rgba(0,0,0,0.3);
    }
    .eco-slider .carousel-indicators button {
        background-color: var(--eco-text-muted);
    }
    .eco-slider .carousel-indicators button.active {
        background-color: var(--eco-lime-green);
    }

    @keyframes animated-border {
        0% { transform: translate(-50%, -50%) rotate(0deg); }
        100% { transform: translate(-50%, -50%) rotate(360deg); }
    }

    .category-card-wrapper {
        position: relative;
        border-radius: var(--eco-radius-xl);
        overflow: hidden;
        transition: transform 0.3s ease, box-shadow 0.3s ease;
        z-index: 1;
        background-color: var(--eco-dark-surface);
        border: 1px solid var(--eco-border-color);
		animation: pulse-neon-border 8s infinite linear;
    }

    .category-card-wrapper:hover {
        transform: translateY(-8px);
        box-shadow: 0 10px 30px rgba(0,0,0,0.4), 0 0 0 2px var(--eco-neon-cyan);
    }

    .category-card-wrapper::before {
		content: '';
        position: absolute;
        top: 50%;
        left: 50%;
        width: 250%;
        height: 250%;
        z-index: 1;
        background: conic-gradient(
                from 180deg at 50% 50%,
                var(--eco-neon-cyan), var(--eco-electric-blue), #a855f7,
                #ec4899, var(--eco-lime-green), var(--eco-neon-cyan)
        );
        animation: animated-border 6s linear infinite;
        opacity: 0;
        transition: opacity 0.4s ease;
    }

    .category-card-wrapper:hover::before {
        opacity: 1;
    }

    .category-card {
        position: relative;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        height: 200px;
        background-color: var(--eco-dark-surface);
        border-radius: calc(var(--eco-radius-xl) - 2px);
        overflow: hidden;
        text-decoration: none;
        z-index: 2;
        margin: 2px;
        padding: 1rem;
        padding-bottom: 3.5rem; /* Место для заголовка */
    }

    .category-card::before,
    .category-card::after {
        content: '';
        position: absolute;
        border-radius: 50%;
        filter: blur(60px);
        z-index: 1;
        transition: all 0.4s ease;
    }

    .category-card::before {
        width: 150px; height: 150px;
        background-color: rgba(120, 235, 74, 0.15);
        top: -40px; left: -50px;
    }

    .category-card::after {
        width: 180px; height: 180px;
        background-color: rgba(59, 130, 246, 0.15);
        bottom: -60px; right: -70px;
    }

    .category-icon {
        width: 80px;
        height: 80px;
        z-index: 2;
        transition: transform 0.3s ease;
    }

    .category-icon path {
        fill: var(--eco-text-secondary);
        transition: fill 0.3s ease;
    }

    .category-card-wrapper:hover .category-icon {
        transform: scale(1.1);
    }

    .category-card-wrapper:hover .category-icon path {
        fill: var(--eco-lime-green);
    }

    .category-title {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        z-index: 3;
        color: var(--eco-text-primary);
        font-weight: 600;
        font-size: 1.2rem;
        text-align: center;
        transition: color 0.3s ease, text-shadow 0.3s ease;
        padding: 1rem;
        background: linear-gradient(to top, rgba(26, 32, 44, 0.8) 20%, transparent 100%);
    }

    .category-card-wrapper:hover .category-title {
        color: white;
        text-shadow: 0 0 10px var(--eco-lime-green);
    }
    .modal-content-custom {
        background-color: var(--eco-dark-surface) !important;
        border: 1px solid var(--eco-border-color) !important;
        border-radius: var(--eco-radius-xl) !important;
    }
    .modal-header-custom {
        border-bottom: 1px solid var(--eco-border-color) !important;
    }
    .modal-header-custom .modal-title {
        color: var(--eco-neon-cyan) !important;
    }
    .modal-footer-custom {
        border-top: 1px solid var(--eco-border-color) !important;
    }
    .promo-banner {
        background: linear-gradient(135deg, var(--eco-dark-surface) 0%, var(--eco-darkest) 100%);
        border-radius: var(--eco-radius-xl);
        padding: 4rem;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 2rem;
        border: 1px solid var(--eco-border-color);
        overflow: hidden;
        position: relative;
    }
    .promo-banner::before {
        content: '';
        position: absolute;
        top: -50%;
        left: -20%;
        width: 400px;
        height: 400px;
        background: radial-gradient(circle, rgba(34, 211, 238, 0.1), transparent 70%);
        animation: subtle-blob 15s infinite linear;
    }
    .promo-banner-content {
        max-width: 50%;
        z-index: 1;
    }
    .promo-banner-content h2 {
        font-size: clamp(1.8rem, 4vw, 2.8rem);
        font-weight: 700;
        color: var(--eco-text-primary);
        margin-bottom: 1.5rem;
    }
    .promo-banner-content p {
        font-size: 1.1rem;
        color: var(--eco-text-secondary);
        margin-bottom: 2rem;
    }
    .promo-banner-image {
        max-width: 45%;
        z-index: 1;
    }
    .promo-banner-image img {
        width: 100%;
        filter: drop-shadow(0px 10px 30px rgba(0, 0, 0, 0.5));
        transform: rotate(-5deg) scale(1.1);
    }

    /* Стилі для оголошень */
    /* Додаємо flex-контейнер до колонок, щоб їх діти могли розтягуватись */
	.row.row-cols-2.row-cols-sm-3.row-cols-lg-4.row-cols-xl-5.g-4.justify-content-center {
        flex-grow: 1 !important;
        align-content: flex-start; /* Залишає рядки у верхній частині сітки */
    }

	.card-listing {
        display: flex;
        flex-direction: column;
        height: 100%; /* Забезпечує, що картка заповнює всю висоту колонки */
        border-radius: var(--eco-radius-xl);
        background-color: var(--eco-dark-surface);
        overflow: hidden;
        transition: transform 0.3s ease, box-shadow 0.3s ease;
        border: 1px solid var(--eco-border-color); /* Added subtle border */
		margin: 0.5rem 0;
		padding: 0;
        width: auto;
        max-width: none;
		min-width: 0;
		/*flex: 1;*/
		/*box-shadow: 0 0 15px rgba(34, 211, 238, 0.7);*/
    }

    .card-listing:hover {
        transform: translateY(-5px);
        box-shadow: 0 12px 25px rgba(0, 0, 0, 0.4), 0 0 0 2px var(--eco-lime-green); /* Enhanced shadow with accent border */
		border-color: var(--eco-neon-cyan);
    }

    .card-listing-img-container {
        /*
		width: 100%;
        padding-top: 60%;
        overflow: hidden;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
		*/
        position: relative;
        transition: transform 0.3s ease;
    }

    .card-listing:hover .card-listing-img-container {
        transform: scale(1.05);
    }
	.card-listing .img-fluid {
        border-top-left-radius: var(--eco-radius-lg);
        border-top-right-radius: var(--eco-radius-lg);
        border: none;
        padding: 0;
        aspect-ratio: 1/1;
        object-fit: cover;
	}

    .badge-overlay {
        position: absolute;
        top: 1rem;
        left: 1rem;
        padding: 0.3rem 0.8rem;
        border-radius: var(--eco-radius-full);
        font-size: 0.8rem;
        font-weight: 700;
        z-index: 10;
    }

    .badge-new {
        background-color: var(--eco-lime-green);
        color: var(--eco-darkest);
    }

    .badge-used {
        background-color: var(--eco-electric-blue);
        color: white;
    }

    .card-body {
        display: flex;
        flex-direction: column;
        flex-grow: 1;
        padding: 1.2rem;
    }

    .card-title {
        color: var(--eco-text-primary);
        font-size: 1.2rem;
        font-weight: 700;
		height: 2.7rem;
        /*line-height: 2;*/
        /*flex-grow: 1;*/
        margin-bottom: 0.75rem;
		overflow: hidden;
    }

    .card-title a {
        color: inherit;
        text-decoration: none;
    }

    .card-title a:hover {
        color: var(--eco-lime-green);
    }

    .price-line {
        display: flex;
        align-items: baseline;
        margin-bottom: rem;
		justify-content: space-between;
    }

    .price {
        color: var(--eco-lime-green);
        font-weight: 800;
        font-size: 1.3rem;
    }

    .price-old {
        color: var(--eco-neon-cyan);
        text-decoration: line-through;
        font-size: 0.9rem;
    }

    .card-details {
        display: block;
        font-size: 0.85rem;
        color: var(--eco-text-muted);
        /*margin-top: 0.5rem;*/
		margin-bottom: 0rem !important;
    }
/*
    .card-body .btn-eco-blue {
        display: block;
        font-size: 0.85rem;
        color: var(--eco-text-muted);
        margin-top: 0.5rem;
    }
*/
    /* Animations for new cards */
    .ticker-item.hidden {
        opacity: 0;
        transform: translateY(20px);
        transition: opacity 0.6s ease-out, transform 0.6s ease-out; /* Add transition for hiding */
    }

    .ticker-item.fade-in {
        animation: fadeInSlideUp 0.6s ease-out forwards;
    }



    /* DJANGO-SELECT2*/

    .select2-selection__rendered{
        color: var(--eco-text-primary) !important; /* Колір тексту в інпутах */
    }
    .select2-container--default .select2-selection--single {
        background-color: rgba(0, 0, 0, 0.2) !important; /* Фон інпутів в offcanvas */
        color: var(--eco-text-primary) !important; /* Колір тексту в інпутах */
        border: 1px solid var(--eco-border-color) !important;
        border-radius: var(--eco-radius-md) !important;
        padding: 0.6rem 1rem;
        height: auto;
        min-height: calc(1.5em + 1.2rem + 2px); /* Забезпечує мінімальну висоту */
        transition: all 0.3s ease;
        box-shadow: inset 0 1px 3px rgba(0,0,0,0.3);
    }
    .select2-container--default .select2-selection--single:focus-within {
        background-color: var(--eco-dark-surface) !important;
        border-color: var(--eco-electric-blue) !important;
        box-shadow: 0 0 0 0.25rem rgba(59, 130, 246, 0.25), inset 0 1px 3px rgba(0,0,0,0.5);
        outline: none;
    }

    /* Результати випадаючого списку Select2 (для offcanvas та global_order) */
    .select2-container--default .select2-results__option {
        background-color: var(--eco-dark-surface);
        color: var(--eco-text-primary);
        padding: 0.75rem 1rem;
        transition: background-color 0.2s ease, color 0.2s ease;
    }
    .select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
        background-color: var(--eco-medium-surface) !important;
        color: var(--eco-neon-cyan) !important;
    }
    .select2-container--default .select2-results__option--selected {
        background-color: var(--eco-light-surface) !important;
        color: var(--eco-lime-green) !important;
        font-weight: 600;
    }
    .select2-container--default .select2-dropdown {
        background-color: var(--eco-darkest);
        border: 1px solid var(--eco-border-color);
        border-radius: var(--eco-radius-md);
        box-shadow: var(--eco-shadow-lg);
        overflow: hidden;
    }

    .select2-search--dropdown .select2-search__field {
        background-color: var(--eco-medium-surface) !important;
        color: var(--eco-text-primary) !important;
        border: 1px solid var(--eco-border-color) !important;
        border-radius: var(--eco-radius-sm) !important;
        padding: 0.5rem 0.75rem !important;
    }
    @keyframes fadeInSlideUp {
        from {
            opacity: 0;
            transform: translateY(20px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }
	.spinner-border {
		height: 20px;
		width: 20px;		
	}
	
    /* --- MOBILE OPTIMIZATIONS --- */
    @media (max-width: 991px) {
        .eco-slider .carousel-item {
            padding: 2rem; /* Reduce padding on tablets */
        }
        .eco-slider .carousel-item-wrapper {
            flex-direction: column;
            justify-content: center;
            text-align: center;
        }
        .eco-slider .banner-content, .eco-slider .banner-image {
            max-width: 100%;
        }
        .eco-slider .banner-content {
            order: 2;
        }
        .eco-slider .banner-image {
            order: 1;
            max-height: 40%;
        }
        .eco-slider .banner-content p {
            max-width: 100%;
        }
        .promo-banner {
            flex-direction: column;
            text-align: center;
            padding: 2rem;
        }
        .promo-banner-content, .promo-banner-image {
            max-width: 100%;
        }
        .promo-banner-image img {
            transform: rotate(0) scale(1);
        }
        .category-title {
            font-size: 1rem;
        }
    }

    @media (max-width: 767px) {
        /*Уменьшение ширині*/
		.eco-slider {
			width: 98%;
		}
		.eco-slider .carousel-item {
            height: auto; /* Make height dynamic */
            min-height: 500px; /* Set a min-height */
            padding: 2rem 1.5rem; /* Adjust padding for mobile */
        }

        .eco-slider .banner-content h1 {
            font-size: 2.2rem; /* Adjust font size for mobile */
        }

        .eco-slider .banner-content p {
            font-size: 1rem; /* Adjust font size for mobile */
            margin-bottom: 1.5rem;
        }

        .eco-slider .banner-image {
            max-height: 35%; /* Adjust image height */
        }

        .promo-banner {
            padding: 2rem 1.5rem;
        }

        .promo-banner-content h2 {
            font-size: 1.8rem;
        }

        .promo-banner-content p {
            font-size: 1rem;
        }

        .category-grid {
            --bs-gutter-x: 1rem; /* Reduce gap between category cards */
            --bs-gutter-y: 1rem;
        }
        .category-title {
            font-size: 1rem;
        }
        .category-grid.row {
            display: flex;
            /*flex-wrap: nowrap;*/
            /*overflow-x: auto;*/
            -webkit-overflow-scrolling: touch; /* Плавная прокрутка на iOS */
            -ms-overflow-style: none;  /* Скрыть скроллбар в IE и Edge */
            scrollbar-width: none;  /* Скрыть скроллбар в Firefox */
            scroll-snap-type: x mandatory; /* Включаем привязку */
            padding-bottom: 1rem; /* Отступ снизу, если появится скроллбар */
			
        }

        .category-grid.row::-webkit-scrollbar {
            display: none; /* Скрыть скроллбар в Chrome, Safari, Opera */
        }

        .category-grid.row > .col {
            flex: 0 0 25%; /* Ширина одной карточки, чтобы было видно следующую */
            max-width: 25%; /* Максимальная ширина для консистентности */
            scroll-snap-align: start; /* Привязка к началу элемента */
            scroll-snap-stop: always; /* Убедимся, что привязка всегда срабатывает */
			padding-right: 0.2rem;
			padding-left: 0.2rem;
        }
		.category-grid.row h5 {
			display: none;
		}
		.category-grid.row .category-card {
			height: 100px;
			padding: 0;
		}

