.menu-item {
            background: var(--card-bg);
            border-radius: 12px;
            box-shadow: 0 2px 8px var(--card-shadow);
            transition: all 0.3s ease;
            display: flex;
            flex-direction: column;
            overflow: hidden;
            width: 100%;
            max-width: 100%;
            margin: 0;
        }

        .menu-item-image-container {
            width: 100%;
            aspect-ratio: 16/9;
            overflow: hidden;
            position: relative;
        }

        .menu-item-image {
            width: 100%;
            height: 100%;
            object-fit: cover;
            transition: transform 0.3s ease;
        }

        .menu-item:hover .menu-item-image {
            transform: scale(1.05);
        }

        .menu-item.center-focused .menu-item-image {
            transform: scale(1.15);
        }

        .menu-item-content {
            padding: 16px;
            flex: 1;
            display: flex;
            flex-direction: column;
            gap: 8px;
            width: 100%;
            max-width: 100%;
        }

        .menu-item-header {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            gap: 12px;
            margin-bottom: 8px;
            position: relative;
        }

        .menu-item-title {
            font-size: 16px;
            font-weight: 600;
            color: var(--text-primary);
            margin: 0;
            flex: 1;
        }

        .menu-item-description {
            font-size: 14px;
            color: var(--text-secondary);
            margin: 0;
            line-height: 1.4;
        }

        .menu-item-price {
            padding: 4px 10px;
            border-radius: 100px;
            font-size: 13px;
            font-weight: 600;
            white-space: nowrap;
            background: var(--price-bg);
            color: var(--price-text);
            cursor: pointer;
            transition: all 0.3s ease;
            user-select: none;
            -webkit-user-select: none;
            display: flex;
            align-items: center;
            gap: 4px;
            z-index: 2;
        }

        .menu-item-price.has-variants .material-symbols-rounded {
            font-size: 16px;
            transition: transform 0.3s ease;
            display: inline-flex;
        }

        .menu-item-price.expanded .material-symbols-rounded {
            transform: rotate(180deg);
        }

        .menu-item-price:hover {
            transform: scale(1.02);
            box-shadow: 0 2px 8px var(--card-shadow);
        }

        .menu-item-price:active {
            transform: scale(0.98);
        }

        .variants-container {
            height: 0;
            overflow: hidden;
            transition: height 0.3s ease, opacity 0.3s ease;
            background: var(--variant-bg);
            border-radius: 8px;
            margin-top: 4px;
            margin-bottom: 8px;
            box-shadow: 0 4px 12px var(--card-shadow);
        }

        .variants-container.show {
            height: auto;
        }

        .variants-inner {
            padding: 4px;
            display: flex;
            flex-direction: column;
            gap: 2px;
        }

        .variant-option {
            padding: 4px 10px;
            border-radius: 4px;
            font-size: 13px;
            font-weight: 500;
            white-space: nowrap;
            color: var(--price-text);
            transition: all 0.2s ease;
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 16px;
        }

        .variant-option:hover {
            background: var(--variant-hover-bg);
        }

        .variant-name {
            color: var(--price-text);
            opacity: 0.9;
            font-size: 12px;
        }

        .variant-price {
            font-weight: 600;
            color: var(--price-text);
            font-size: 12px;
        }

        /* Responsive Grid */
        .menu-category {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
            gap: 24px;
            padding: 16px;
            width: 100%;
            max-width: 100%;
            margin: 0;
        }

        @media (min-width: 640px) {
            .menu-category {
                grid-template-columns: repeat(2, 1fr);
                gap: 24px;
                padding: 24px;
            }

            .menu-item-title {
                font-size: 20px;
            }

            .menu-item-description {
                font-size: 15px;
            }
        }

        @media (min-width: 1024px) {
            .menu-category {
                grid-template-columns: repeat(3, 1fr);
                gap: 32px;
                padding: 32px;
            }

            .menu-item-content {
                padding: 20px;
            }

            .menu-item-title {
                font-size: 22px;
            }

            .menu-item-description {
                font-size: 16px;
            }
        }